|
[Sponsors] |
May 23, 2019, 12:49 |
Pointers to Objects
|
#1 |
New Member
Amir Bagheri
Join Date: Feb 2019
Location: Southampton, UK
Posts: 11
Rep Power: 7 |
Hi all,
I had a question about how objects are passed as function parameters inside SU2. In some cases, objects are created as pointers to their respective classes. An example is the following: Code:
void CDiscAdjSolver::SetSurface_Sensitivity(CGeometry *geometry, CConfig *config) { } In some function calls however, we get something similar to the following: Code:
void CDiscAdjFluidIteration::InitializeAdjoint(CSolver *****solver_container, CGeometry ****geometry_container, CConfig **config_container, unsigned short iZone, unsigned short iInst){} Code:
solver_container[iZone][iInst][MESH_0][ADJFLOW_SOL]->SetAdj_ObjFunc(geometry_container[iZone][iInst][MESH_0], config_container[iZone]); I'm relatively new to C++ so it might be something fundamental that I'm missing here, but I've done a fair bit of digging online and can't seem to find anything similar. If anyone has any clue what the above means I'd be grateful if they could help. Thanks, Amir |
|
May 23, 2019, 16:49 |
|
#2 |
Senior Member
Pedro Gomes
Join Date: Dec 2017
Posts: 466
Rep Power: 13 |
Hi Amir,
One of the dereference operators (*) is for polymorphism (it should be easy to read about this online). The others are to create an nd-array of which: 1st dimension is for zones defined in the mesh file. 2nd is for instances but I don't think that is in use now. 3rd is for grids (of the same zone) this is used for multigrid acceleration. 4th is for different solvers, numerics, etc. that a zone needs, for example a NS solver and a turbulent solver for RANS simulations, they are stored in fixed (static) locations to make it clear which solver is being accessed, even if the container is never completely full. The numerics container only has numerics pointers to CNumerics objects, the solver container pointer to CSolver objects, etc. Cheers, Pedro |
|
May 24, 2019, 11:59 |
|
#3 |
New Member
Amir Bagheri
Join Date: Feb 2019
Location: Southampton, UK
Posts: 11
Rep Power: 7 |
Hi Pedro,
Once again, thanks for your help. Is there anywhere in the code where the structure of the container arrays are defined? For example, a geometry_container is defined in various functions within the code, sometimes with one asterisk, sometimes two, three or four. How does one determine what the size of the nd-array for the container has to be? Are these defined/allocated anywhere? I guess my question stems from the fact that I don't understand what the use of these arrays are? Can't we just always create the objects with only one deference operator? Cheers, Amir |
|
May 25, 2019, 06:26 |
|
#4 |
Senior Member
Pedro Gomes
Join Date: Dec 2017
Posts: 466
Rep Power: 13 |
At the highest level of the hierarchy you have CDriver, all the containers "belong" to the driver, and the driver allocates and populates these containers in corresponding "XX_Preprocessing" methods.
I use belong in "" because these containers are just pointers (addresses in memory), the actual objects live somewhere in memory, but as with most things in programming it is a matter of abstraction, so lets say the containers are... contained (cough)... in the driver. Now, the driver passes the addresses (pointers) of these objects down to the methods of the classes that make use of them. The important thing is that the objects are only created by the driver, when you see "CSolver *solver" as a function argument this is not a new solver, simply the address of something that exists in memory. Some methods have as arguments only one pointer to solver because the client for the method will decide for it what solver it should work on. Others get the entire nd-array of pointers because they need to operate on multiple solvers, for example methods related to multigrid need to loop trough all the grids of a given zone and there is a solver associated to each grid (not because they are different solvers, but because they contain different data). You could argue that this architecture is too flexible, for example if CIteration uses CSolver then maybe it should own the solver, or if CSolver uses CNumerics maybe it should own them instead of driver... And if the code had been written like that I would now probably say the architecture is inflexible... Anyway, what helped me the most understanding the design intent of each class and how they should interact with each other was to start at the top (CDriver.Run()) and go down the rabbit hole, or in programming terms, follow the call stack. |
|
Tags |
objects, pointers |
Thread Tools | Search this Thread |
Display Modes | |
|
|
Similar Threads | ||||
Thread | Thread Starter | Forum | Replies | Last Post |
Multiple Floating Objects with 6DoF in OF 2.3.0 | tyoung | OpenFOAM Running, Solving & CFD | 23 | June 11, 2024 01:13 |
Multiple floating objects using InterDyMFoam and sixDoFRigidBodyMotion solver | FloatingSolar | OpenFOAM Running, Solving & CFD | 4 | December 29, 2020 11:09 |
Update FOAM objects after new solver run | peterTr | OpenFOAM Programming & Development | 1 | May 11, 2017 16:26 |
[Other] mesh generation for sloping objects | yuyingyuni | ANSYS Meshing & Geometry | 0 | March 15, 2013 02:46 |
Warning when I add my objects | Xu | Phoenics | 0 | November 21, 2008 12:30 |