CFD Online Logo CFD Online URL
www.cfd-online.com
[Sponsors]
Home > Forums > Software User Forums > OpenFOAM > OpenFOAM Programming & Development

chtIcoMultiRegionFoam - Incompressible version of chtMultiRegionFoam.

Register Blogs Community New Posts Updated Threads Search

Like Tree12Likes

Reply
 
LinkBack Thread Tools Search this Thread Display Modes
Old   July 11, 2011, 11:11
Default
  #41
Senior Member
 
maddalena's Avatar
 
maddalena
Join Date: Mar 2009
Posts: 436
Rep Power: 23
maddalena will become famous soon enough
Hi Nicolas,

Quote:
Originally Posted by NicolasB View Post
Hi,
I've set up a case with both a solid and a fluid.
...
I join an archive with these cases (just use the "Allrun" scripts).
can you attach the solver as well? Otherwise I cannot run your cases...

Quote:
Originally Posted by NicolasB View Post
What I don't understand is why we have to run this solver on transient mode for fluids while it works on steady for solids...
What have you done to make the solver steady? I guess you should reproduces the same changes there are between chtMultiRegionFoam and chtMultiRegionSimpleFoam. You cannot declare the case as steadyState on fvSchemes only, something weird may appear. Please correct me if I am wrong...


mad
maddalena is offline   Reply With Quote

Old   July 12, 2011, 06:34
Default
  #42
Member
 
Nicolas
Join Date: Apr 2011
Location: Biarritz / France
Posts: 33
Rep Power: 15
NicolasB is on a distinguished road
Hi Maddalena,

I've just use the chtIcoMultiRegionFoam solver from the first post in this thread, with no modification.
As it was run steady for solids, I thought I only had to change the fvSchemes and the controlDict. Seems that was too easy
I hope you can enlighten me since I'm pretty new on CFD and OF.

Nicolas
NicolasB is offline   Reply With Quote

Old   July 12, 2011, 06:52
Default
  #43
Senior Member
 
maddalena's Avatar
 
maddalena
Join Date: Mar 2009
Posts: 436
Rep Power: 23
maddalena will become famous soon enough
Quote:
Originally Posted by NicolasB View Post
Seems that was too easy
I hope you can enlighten me since I'm pretty new on CFD and OF.
Well, I do not know if you can make steady state the solver changing fvSchemes and controlDict simply... I guess you have problem with simple and piso loop, see here, so on fvSolution as well.
As the name says, chtIcoMultiRegionFoam is based on icoFoam. It means that the fluid part is solved in the same way of icoFoam. Thus one thing you can try is to take a icoFoam tutorial (cavity should be ok) and compare the unsteady and steady solution, the latter obtained changing fvSchemes, fvSolution and controlDict only, and adjusting BC if necessary. I guess the solver will complain...
In that case, you have to modify chtIcoMultiRegionFoam throwing away all the ddt terms and changing the loops accordingly. A good point where to start is to reproduce the same changes there are between chtMultiRegionFoam and chtMultiRegionSimpleFoam, as I said before.

mad



PS: of course, I am not saying you have to do it for me: I need a steadyState version of this solver as well. I hope we can work together on it!
maddalena is offline   Reply With Quote

Old   July 13, 2011, 07:10
Default
  #44
Member
 
Nicolas
Join Date: Apr 2011
Location: Biarritz / France
Posts: 33
Rep Power: 15
NicolasB is on a distinguished road
+1 for your PS
Can you check the solver in the attachment?
I made a copy of chtIcoMultiRegionFoam;
changed the names;
commented the "ddt" terms in the equations;
commented the "#include" with time, Pimple and piso;
added the "readSIMPLEcontrols" from chtMultiRegionSimpleFoam;
changed the PISO loop to a SIMPLE one.

I hope I've forgotten nothing.
Waiting for your feedback
Regards
Attached Files
File Type: gz chtIcoMultiRegionSimpleFoam.tar.gz (11.9 KB, 115 views)
brucechen1115 likes this.
NicolasB is offline   Reply With Quote

Old   July 13, 2011, 08:16
Default
  #45
Senior Member
 
maddalena's Avatar
 
maddalena
Join Date: Mar 2009
Posts: 436
Rep Power: 23
maddalena will become famous soon enough
Just give a fast look at it. I think you commented too much, especially on the fluid part. But give me some more time to go deeper.

mad
maddalena is offline   Reply With Quote

Old   July 20, 2011, 12:09
Default
  #46
Senior Member
 
Mirko Vukovic
Join Date: Mar 2009
Posts: 159
Rep Power: 17
mirko is on a distinguished road
Quote:
Originally Posted by maddalena View Post
Hello,
nicolasB, Mirco, have you succeeded in creating a steady state version of chtIcoMultiRegionFoam?

mad
Sorry, Maddalena, no progress here.

Mirko
mirko is offline   Reply With Quote

Old   July 20, 2011, 12:52
Default
  #47
Member
 
Fábio César Canesin
Join Date: Mar 2010
Location: Florianópolis
Posts: 67
Rep Power: 16
Canesin is on a distinguished road
Hi all,

You will not have success in creating a steady version in it definition.

The energy exchange at the interface is done in an boundary update methodology.. segregated.

The only thing could be done in an segregated approach is to use an fake transient with large time step (like the pimpleFoam solver).

To create an trully steady state version of the solver one needs to make it fully coupled, like in an block coupling for velocity-pressure.
Canesin is offline   Reply With Quote

Old   July 21, 2011, 11:13
Default
  #48
Senior Member
 
Mirko Vukovic
Join Date: Mar 2009
Posts: 159
Rep Power: 17
mirko is on a distinguished road
Quote:
Originally Posted by Canesin View Post
Hi all,

You will not have success in creating a steady version in it definition.

The energy exchange at the interface is done in an boundary update methodology.. segregated.

The only thing could be done in an segregated approach is to use an fake transient with large time step (like the pimpleFoam solver).

To create an trully steady state version of the solver one needs to make it fully coupled, like in an block coupling for velocity-pressure.
Nice thinking :-)
mirko is offline   Reply With Quote

Old   August 8, 2011, 11:38
Default
  #49
Member
 
Nicolas
Join Date: Apr 2011
Location: Biarritz / France
Posts: 33
Rep Power: 15
NicolasB is on a distinguished road
Hi Fábio,

As I'm preparing the oral following my training period, I'd like some pieces of information not to be trapped by easy questions...
Just to be sure, can you confirm the next equations are solved in your chtIcoMultiRegionFoam?

Solid:
d(rho*Cp*T)/dt - grad.(K*grad(T)) = 0

Fluid:
dU/dt + grad.(phi*U) - grad.(nu*grad(U)) + (source) = - grad(p)
dT/dt + grad.(phi*T) - grad.(Kappaeff*grad(T)) = 0
grad.(rUA*grad(p)) = grad.(phi)

I'm not very skilled in C++, nor in Of: I've got difficulties in converting the code in mathematical language.

Moreover, I haven't understood what is the central coefficient rUA. Could you enlighten me?

Thanks in advance,

Nicolas
NicolasB is offline   Reply With Quote

Old   August 8, 2011, 15:53
Default
  #50
Member
 
Fábio César Canesin
Join Date: Mar 2010
Location: Florianópolis
Posts: 67
Rep Power: 16
Canesin is on a distinguished road
Nicolas,

You are almost right .. .just the last equation:

grad(rAU*grad(p))= grad(phi)


rAU = 1.0/UEqn().A()

Look at doxygen what the .A() is:

//- Return the central coefficient
00403 tmp<volScalarField> A() const;

It is related with the PISO algorithm in OpenFOAM:
refer to: http://openfoamwiki.net/index.php/Th...hm_in_OpenFOAM
Canesin is offline   Reply With Quote

Old   August 9, 2011, 09:08
Default
  #51
Member
 
Nicolas
Join Date: Apr 2011
Location: Biarritz / France
Posts: 33
Rep Power: 15
NicolasB is on a distinguished road
There's something I don't understand.
Are they really gradients and not divergences, in the p-equation? Because in the file pEqn.H we have:
Code:
fvScalarMatrix pEqn
        (
            fvm::laplacian(rUA, p) == fvc::div(phi)
        );
I thought that for gradients we'd had
Code:
fvScalarMatrix pEqn
        (
            volVectorField temp = rUA*fvc::grad(p);
            fvm::grad(temp) == fvc::grad(phi)
        );
or something like that...

I'd seen the definition of rUA, but I've no idea of what the 'central coefficient' returned by the A() function is. I'm going to dig deeper in the PISO algorithm.

Many thanks for your help,

Nicolas
NicolasB is offline   Reply With Quote

Old   July 17, 2013, 17:45
Default
  #52
Senior Member
 
Mojtaba.a's Avatar
 
Mojtaba Amiraslanpour
Join Date: Jun 2011
Location: Tampa, US
Posts: 308
Rep Power: 16
Mojtaba.a is on a distinguished road
Send a message via Skype™ to Mojtaba.a
Hello,
Dear Fabio, Thank you for your contribution.

Fabio and mad I wonder if you have been able to develop a code for incompressible steady turbulent flows, as it is the base characteristics for most of the heat transfer cases.

Is this new solver (chtIcoMultiRegionFoam) appropriate for using turbulence models?

All these aside, I can not understand one thing.
Is it OK to use the compressible chtMultiRegionSimpleFoam solver for an incompressible case? as it has been used in here: planeWall2D ?

Best wishes,
Mojtaba
__________________
Learn OpenFOAM in Persian
SFO (StarCCM+ FLUENT OpenFOAM) Project Team Member
Complex Heat & Flow Simulation Research Group
If you can't explain it simply, you don't understand it well enough. "Richard Feynman"
Mojtaba.a is offline   Reply With Quote

Old   August 22, 2013, 07:17
Default
  #53
Member
 
X Meng
Join Date: Jun 2012
Location: Scotland
Posts: 89
Rep Power: 14
mxylondon is on a distinguished road
I am thinking about this as well...
mxylondon is offline   Reply With Quote

Old   August 26, 2013, 10:00
Default
  #54
Member
 
X Meng
Join Date: Jun 2012
Location: Scotland
Posts: 89
Rep Power: 14
mxylondon is on a distinguished road
Hi, I am trying to compile the application in Version 2.2.0, a fatal error occured as:
'directMappedPatchBase.H: No such file or directory'.
Actually, I can't find this in this version.
mxylondon is offline   Reply With Quote

Old   August 26, 2013, 10:10
Default
  #55
Member
 
Leonardo Honfi Camilo
Join Date: Mar 2009
Location: Delft, Zuid Holland, The Netherlands
Posts: 60
Rep Power: 17
lhcamilo is on a distinguished road
Quote:
Originally Posted by mxylondon View Post
Hi, I am trying to compile the application in Version 2.2.0, a fatal error occured as:
'directMappedPatchBase.H: No such file or directory'.
Actually, I can't find this in this version.

This is due to the fact that the directMapped patch was renamed in OF>=2.1 to just mapped.

This patch is used by the conjugate boundary conditions so you should go to the following folder inside your solver:

derivedFvPatchFields/solidWallMixedTemperatureCoupled


search for every instance of directMapped* and change it to mapped* , you should do that for both the .C and .H file.

PS: The * is just there to indicate that the patch name above may be part of a longer word.
elham usefi likes this.

Last edited by lhcamilo; August 26, 2013 at 10:15. Reason: PS
lhcamilo is offline   Reply With Quote

Old   August 27, 2013, 07:14
Default
  #56
Member
 
X Meng
Join Date: Jun 2012
Location: Scotland
Posts: 89
Rep Power: 14
mxylondon is on a distinguished road
Hi, Camilo, thank you very much for your reply.
Now, my solver is compiled well.
However, an error "hanging pointer, cannot dereference" occurs when 'adding to turbulence' for a very simple case.
Still struggling for that....
mxylondon is offline   Reply With Quote

Old   August 27, 2013, 07:40
Default
  #57
Member
 
Leonardo Honfi Camilo
Join Date: Mar 2009
Location: Delft, Zuid Holland, The Netherlands
Posts: 60
Rep Power: 17
lhcamilo is on a distinguished road
I have had those problems... they are more fun than a barrel full of monkeys.

In any case,my guess is that your problem is probably somewhere inside the fluid/createFluidFields.H folder or solid/createSolidFields.H , some variable is probably not properly declared , usually the type of field or information is wrong.

These may be tricky to find and I had to spend more time than I care to admit understanding the purpose of each of these lines and variables in these folders (and the entire solver) to the point that I could re-write them from scratch (which I eventually did) for the particular set of cases I have been working on).

I wish I could be more help but this is a very hands on type of problem, you can also add the following bit of code to check where exactly the breaking happens

Code:
Info << "\n Check 1... \n"<<endl;
Make several of those lines inside one of those files with different numbers, so you can see how far the code goes before it breaks, that way you can narrow down where the problem may be.

GL
elham usefi likes this.
lhcamilo is offline   Reply With Quote

Old   August 27, 2013, 10:54
Default
  #58
Member
 
X Meng
Join Date: Jun 2012
Location: Scotland
Posts: 89
Rep Power: 14
mxylondon is on a distinguished road
Thank you!
I got it, the problem is my definition of transportModel.
Thanks again!!!
mxylondon is offline   Reply With Quote

Old   June 9, 2014, 05:14
Default double viscous term
  #59
New Member
 
Join Date: Apr 2013
Posts: 2
Rep Power: 0
Haryo is on a distinguished road
tmp<fvVectorMatrix> UEqn
(
fvm::ddt(U)
+ fvm::div(phi, U)
- fvm::laplacian(nu, U)
+ turb.divDevReff(U)
);

If you look the UEqn in the chtIcoMultiRegionFoam posted by Mr. Canesin (shown above), the viscous term appears twice.
So the - fvm::laplacian(nu, U) or + turb.divDevReff(U) should be deleted ( I deleted the - fvm::laplacian(nu, U)).
I compared the calculation results with the reference results shown below.
http://www.sciencedirect.com/science...17931086900177
Both of them show good agreement
Haryo is offline   Reply With Quote

Old   July 2, 2014, 08:29
Unhappy Dimension of phi are not correct
  #60
New Member
 
Cyril
Join Date: Mar 2014
Posts: 5
Rep Power: 12
cyril.trp is on a distinguished road
Hello everyone!

I installed chtIcoMultiRegionFoam on the 2.3 version of OpenFoam. Because of the new version, I replaced ddtPhiCorr with ddtCorr in pEqn.H compile and ran the previous case but I got this error:

Solving for fluid region fluid
DILUPBiCG: Solving for Ux, Initial residual = 1, Final residual = 0.02009576, No Iterations 1
DILUPBiCG: Solving for Uy, Initial residual = 0.98533956, Final residual = 0.011378115, No Iterations 1
DILUPBiCG: Solving for T, Initial residual = 1, Final residual = 4.4231395e-09, No Iterations 5
max(T) [0 0 0 1 0 0 0] 400


--> FOAM FATAL ERROR:
dimensions of phi are not correct

From function EulerDdtScheme<Type>::fvcDdtPhiCorr
in file finiteVolume/ddtSchemes/EulerDdtScheme/EulerDdtScheme.C at line 602.

It seems that something goes wrong with phi . What can I do to fix this error?

Thank you

Regards Cyril
cyril.trp is offline   Reply With Quote

Reply


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are Off
Pingbacks are On
Refbacks are On


Similar Threads
Thread Thread Starter Forum Replies Last Post
OpenFOAM on cluster: version GLIBCXX_3.4.9 and GLIBCXX_3.4.11 not found ovie OpenFOAM 10 April 19, 2021 19:06
paraview installation woes vex OpenFOAM Installation 15 January 30, 2011 08:11
bubbleFoam validation case balkrishna OpenFOAM Running, Solving & CFD 24 August 30, 2010 05:37
[OpenFOAM] Problem with paraFoam on a linux-64 bit bunni ParaView 4 April 14, 2010 21:55
paraFoam reader for OpenFOAM 1.6 smart OpenFOAM Installation 13 November 16, 2009 22:41


All times are GMT -4. The time now is 17:28.