|
[Sponsors] |
![]() |
![]() |
#1 |
New Member
Thomas N.
Join Date: Nov 2018
Posts: 11
Rep Power: 8 ![]() |
Dear OpenFoamers,Foamers and HopeFoamers,
I am struggling lately with the problem of how to solve a non linear 4rth order diffusion equation(see below). Of course, it can be solved full explicitly but on this way someone has to use small time-steps. One idea is to split this equation into two 2nd order equations by defining the brackets as the chemical potential. When someone does this, it will come up with the problem of OpenFOAM and general most of the softwares/toolkits can't solve equations for two variables simultaneously. With OpenFOAM words: FATAL ERROR incompatible fields. Nevertheless, I have attached a picture that I was thinking on this way maybe I could solve my problem but it doesn't work. The idea was to calculate first explicit the chemical potential in order to find the correct values of C and then, to calculate implicity the chemical potential with the new correct values of C that have been calculated in the previous step. After this, you solve the diffusion equation. This idea doesn't work. Therefore, I would like to ask if someone has any idea of how to deal with this problem. Last, of course the ideal case would be to define an implicity laplacian^2 with an implicit scheme but I guess this over my programming skills. Thanks in advance! Thomas |
|
![]() |
![]() |
![]() |
![]() |
#2 | |
Senior Member
Andrew Somorjai
Join Date: May 2013
Posts: 175
Rep Power: 13 ![]() |
Quote:
Incompatible fields for operation Is there some way to end up with just one variable and one matrix? What are the variables by the way in your equation? |
||
![]() |
![]() |
![]() |
![]() |
#3 | |
New Member
Thomas N.
Join Date: Nov 2018
Posts: 11
Rep Power: 8 ![]() |
Quote:
Dear Andrew, first of all, thanks for your answer and you are right this one kind of thesis range problem. Regarding to the link that you have attached: I have seen it and in this case, it used chain rule and you treat the half of the term explicitly. In my case, when someone introduces different methods to solve the Cahn-Hilliard in order to increase the time-step, it turns out that someone has to treat the laplacian^2 term implicitly. Therefore, the idea of splitting the 4rth order equation into two 2nd order equations holds and you can define implicitly the laplacians. By the way, this is a common approach in all of the phase field softwares (FiPy, Moose, PRISMS PF, ... ). However, OpenFOAM can't solve for two variables in the same time. Regarding to your second question, the two variables are the order parameter C and the chemical potential chemPot in the code respectively. So, there boundary conditions for each field separately. Thomas |
||
![]() |
![]() |
![]() |
![]() |
#4 | |
Senior Member
Andrew Somorjai
Join Date: May 2013
Posts: 175
Rep Power: 13 ![]() |
Quote:
volScalarField rUA = 1.0/UEqn().A(); in order to use it for the pressure equation e.g. Code:
fvScalarMatrix pEqn ( fvm::laplacian(rUA, p) == fvc::div(phi) ); pEqn.setReference(pRefCell, pRefValue); pEqn.solve(); |
||
![]() |
![]() |
![]() |
![]() |
#5 |
New Member
Thomas N.
Join Date: Nov 2018
Posts: 11
Rep Power: 8 ![]() |
Dear Andrew,
Unfortunately, it can't. For more details regarding to the PISO loop I am encouraging you to check the wonderful summary of interFoam solver. Download the pdf file from the section 1.2 Useful links. https://openfoamwiki.net/index.php/InterFoam Thomas |
|
![]() |
![]() |
![]() |
![]() |
#6 | |
Senior Member
Arjun
Join Date: Mar 2009
Location: Nurenberg, Germany
Posts: 1,299
Rep Power: 36 ![]() ![]() |
Quote:
I think if you are open to using other solvers then you can (possibly) do with Wildkatze solver using user coding where you supply the descretization and solver solves the linear system for you (also does other tasks like creating variables, and providing them for post processing etc). |
||
![]() |
![]() |
![]() |
![]() |
#7 |
New Member
Thomas N.
Join Date: Nov 2018
Posts: 11
Rep Power: 8 ![]() |
![]() Thomas |
|
![]() |
![]() |
![]() |
![]() |
#8 |
New Member
Azad
Join Date: Nov 2019
Posts: 8
Rep Power: 7 ![]() |
Hello Foamers,
Have you been able to solve the 4th order Diffusion equation using OpenFOAM. Please help me with the same. Thanks |
|
![]() |
![]() |
![]() |
Tags |
c++, cahn hilliard, diffusion, non linear, openfoam |
Thread Tools | Search this Thread |
Display Modes | |
|
|
![]() |
||||
Thread | Thread Starter | Forum | Replies | Last Post |
First Order to Higher Order Blending Factor | NormalVector | FLUENT | 4 | November 13, 2023 08:06 |
Oscillating behaviour when mesh gets too small | james91 | OpenFOAM Running, Solving & CFD | 0 | January 9, 2014 06:04 |
Problems solving T Equation in separated flow using a second Order Closure Model | pascool | OpenFOAM Programming & Development | 1 | November 19, 2012 11:29 |
2nd order boundary conditions for 2nd order discretization? | quarkz | Main CFD Forum | 30 | December 26, 2011 08:12 |
Numerical diffusion error | Z.Zeng | Main CFD Forum | 8 | October 22, 1999 10:06 |