Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Correction of symmetry plane implementation #2194

Merged
merged 221 commits into from
Aug 4, 2024
Merged
Show file tree
Hide file tree
Changes from 213 commits
Commits
Show all changes
221 commits
Select commit Hold shift + click to select a range
21644d9
initial test
bigfooted Jan 2, 2024
a07dd6a
symmetry -do not reflect normal components
bigfooted Jan 2, 2024
0fa9438
remove unused GG code
bigfooted Jan 2, 2024
4322907
GG wall
bigfooted Jan 3, 2024
0ee6dbd
viscous sym_plane
bigfooted Jan 3, 2024
5de7c24
edge normal correction
bigfooted Jan 3, 2024
9ba8f8e
copy normal correction from nemo
bigfooted Jan 3, 2024
8bb7c2e
Merge branch 'develop' into feature_symmetry
bigfooted Jan 3, 2024
fd2fbb7
remove unused variables
bigfooted Jan 3, 2024
576919d
GG test
bigfooted Jan 4, 2024
7166b66
GG correct velocity mirroring
bigfooted Jan 4, 2024
101c10f
temp saving
bigfooted Jan 6, 2024
06f94ac
add symmetry correction for inlet, outlet, and wall
bigfooted Jan 7, 2024
2840592
code alignment
bigfooted Jan 7, 2024
7387f8c
corrected GG gradient computation on shared nodes
bigfooted Jan 8, 2024
aa4dd00
GG shared nodes mirror
bigfooted Jan 9, 2024
a3e7221
GG corner gradients
bigfooted Jan 10, 2024
48f6d3d
fixes to face normal correction on symmetry
bigfooted Jan 10, 2024
5513218
clean up
bigfooted Jan 10, 2024
77e3efd
clean up
bigfooted Jan 10, 2024
8e346b0
fig GG share nodes for 3D
bigfooted Jan 14, 2024
e9cb623
fig GG share nodes interpolation
bigfooted Jan 15, 2024
dbdbe1d
fig GG share nodes interpolation for outlet
bigfooted Jan 15, 2024
95fb743
activate edge array
bigfooted Jan 17, 2024
e8434e3
edge fluxes test
bigfooted Jan 31, 2024
44637ab
residual correction symmetry plane
bigfooted Jan 31, 2024
1071418
remove unused variable
bigfooted Jan 31, 2024
41b45d8
finalize symmetry plane correction
bigfooted Feb 2, 2024
d81fc0e
deletevalsrowi only for radial velocity
bigfooted Feb 4, 2024
4997a98
symmetry should be called before strong boundaries
bigfooted Feb 4, 2024
9a9b02b
activate edge correction
bigfooted Feb 4, 2024
95a5122
new jacobian
bigfooted Feb 6, 2024
d515946
Merge branch 'develop' into feature_symmetry
bigfooted Feb 8, 2024
b0d7a60
fix diagonal dominance of the Jacobian
pcarruscag Feb 10, 2024
f7ecaeb
clean up
bigfooted Feb 12, 2024
8316f2c
replace GG gradients with Tobi-Edwin method
bigfooted Feb 17, 2024
0c21b48
small cleanup
bigfooted Feb 17, 2024
5e3b208
symmetry instead of full reflection in GG
bigfooted Feb 17, 2024
a920524
Merge branch 'develop' into feature_symmetry
bigfooted Feb 27, 2024
39335cb
test shared symmetry
bigfooted Mar 4, 2024
eb7f217
test GG gradients for shared symmetry
bigfooted Mar 4, 2024
ed7a4a5
Merge branch 'feature_symmetry' of /~https://github.com/su2code/su2 int…
bigfooted Mar 4, 2024
6e01c2c
Merge branch 'develop' into feature_symmetry
bigfooted Mar 5, 2024
7601112
Merge branch 'develop' into feature_symmetry
bigfooted Mar 25, 2024
382e896
test GG gradients with tensor implementation, not working
bigfooted Mar 26, 2024
541d7c0
Merge branch 'feature_symmetry' of /~https://github.com/su2code/su2 int…
bigfooted Mar 26, 2024
b0f7a21
fix gradient conditions for symmetry plane in green-gauss
bigfooted Mar 29, 2024
85ceb0c
remove cout statements
bigfooted Mar 29, 2024
946e7e8
add comment
bigfooted Mar 29, 2024
80a7b5f
cleanup
bigfooted Mar 29, 2024
2a7f5da
move symplane bc to end of bc
bigfooted Mar 30, 2024
2407b19
fix order of BC
bigfooted Mar 31, 2024
05520c3
include EULER_WALL in consideration of symmetry planes
bigfooted Apr 1, 2024
cf36935
no modified timestep at EULER_WALL
bigfooted Apr 1, 2024
2090c7f
fix getsolution to getsolution_old
bigfooted Apr 1, 2024
e2108e7
fix getsolution to getsolution_old
bigfooted Apr 1, 2024
5b90bd0
Merge branch 'develop' into feature_symmetry
bigfooted Apr 3, 2024
4c260aa
move computation of base to geometry_toolbox
bigfooted Apr 3, 2024
26cd83e
Merge branch 'feature_symmetry' of /~https://github.com/su2code/su2 int…
bigfooted Apr 3, 2024
228823d
make green-gauss gradient computations for symmetry planes more compact
bigfooted Apr 4, 2024
1013191
make green-gauss gradient computations for symmetry planes more compact
bigfooted Apr 4, 2024
960dc1f
modify restruncerror
bigfooted Apr 9, 2024
8d45f6c
modify normals in multigrid
bigfooted Apr 9, 2024
3666bcf
modify normals in multigrid - commented
bigfooted Apr 9, 2024
5bdd5fb
Merge branch 'develop' into feature_symmetry
bigfooted Apr 15, 2024
805ba34
small fix
bigfooted Apr 17, 2024
64fd52a
uncomment again
bigfooted Apr 20, 2024
48e77c5
fix GG, fix multigrid
bigfooted Apr 21, 2024
9ab4c69
Merge branch 'develop' into feature_symmetry
bigfooted Apr 21, 2024
aec5c94
Merge branch 'develop' into feature_symmetry
bigfooted Apr 21, 2024
a3c03bb
formatting...
bigfooted Apr 21, 2024
c24fd6e
boilerplate - create only one copy of normal edge correction
bigfooted Apr 21, 2024
1bcf772
rerun conv_numerics->ComputeResiduals, also modify multigrid, and do …
bigfooted Apr 22, 2024
c517767
minus sign
bigfooted Apr 23, 2024
3ef46eb
small fix
bigfooted Apr 24, 2024
61e8ce4
check nodes shared by markers
bigfooted Apr 24, 2024
625d273
fix error for compressible
bigfooted Apr 24, 2024
833100c
fix error for compressible
bigfooted Apr 24, 2024
ef214f1
fix error for compressible
bigfooted Apr 24, 2024
0bdbd22
formatting
bigfooted Apr 24, 2024
c294bfc
switch to solution_old
bigfooted Apr 25, 2024
2bc215f
cleanup
bigfooted Apr 26, 2024
752adfd
precommit alignment
bigfooted Apr 26, 2024
bb1df12
cleanup
bigfooted Apr 26, 2024
9bccbdd
cleanup
bigfooted Apr 26, 2024
8324dc7
cleanup
bigfooted Apr 26, 2024
2db7de2
fix mg for 2d meshes with mpi
bigfooted Apr 26, 2024
bde93f3
remove dependency of config in functions
bigfooted Apr 28, 2024
d3be71c
move gradient update for symmetry to toolbox template
bigfooted Apr 28, 2024
2f59364
move around stuff
bigfooted Apr 28, 2024
ce4d0f3
move gradient correction to geometry_toolbox
bigfooted Apr 28, 2024
91b8816
Merge branch 'develop' into feature_symmetry
bigfooted Apr 28, 2024
5c05ad2
remove commented code
bigfooted Apr 28, 2024
8666f0c
Euler walls can never be agglomerated
bigfooted Apr 28, 2024
707e80d
point to fix_symmetry workflow
bigfooted May 3, 2024
99e60e2
fix regressions for vandv
bigfooted May 4, 2024
f7ea1c4
fix partial regressions for tutorials
bigfooted May 4, 2024
7d3b289
fix partial regressions
bigfooted May 4, 2024
13a79b5
fix tutorial regression
bigfooted May 4, 2024
6163c81
add symmetry routine to WLS
bigfooted May 5, 2024
e5174ae
add grid movement back into symplane
bigfooted May 6, 2024
ff79f70
fix braces
bigfooted May 6, 2024
15761ea
cleanup geometry_toolbox
bigfooted May 7, 2024
a2f5c42
fix tutorials
bigfooted May 7, 2024
d5bc57a
fix regressions
bigfooted May 7, 2024
ca624c1
fix regressions
bigfooted May 8, 2024
98dfead
fix regressions
bigfooted May 8, 2024
264978d
Merge branch 'develop' into feature_symmetry
bigfooted May 8, 2024
59985b8
fix regressions parallel
bigfooted May 8, 2024
b2176ae
Merge branch 'feature_symmetry' of /~https://github.com/su2code/su2 int…
bigfooted May 8, 2024
d9b9dec
fix another bunch of tests
bigfooted May 10, 2024
ba32916
make enum class of mpi_quantities
bigfooted May 11, 2024
848cacb
remove unused variables
bigfooted May 11, 2024
a429470
add idx_vel as argument to gradient functions
bigfooted May 11, 2024
33ea2dc
fix some regressions parallel
bigfooted May 12, 2024
327725d
fix some regressions parallel
bigfooted May 12, 2024
a1e4810
fix some regressions parallel
bigfooted May 12, 2024
dda969a
fix some regressions parallel
bigfooted May 12, 2024
645c824
regressions
bigfooted May 14, 2024
7e06217
merge develop
bigfooted May 14, 2024
3841862
merge develop
bigfooted May 14, 2024
a04bfbb
Merge branch 'develop' into feature_symmetry
bigfooted May 17, 2024
d61ba49
update regression
bigfooted May 17, 2024
1330821
Merge branch 'feature_symmetry' of /~https://github.com/su2code/su2 int…
bigfooted May 17, 2024
233ef03
Merge branch 'develop' into feature_symmetry
bigfooted May 20, 2024
9d32bc6
update regression
bigfooted May 25, 2024
16b583b
update regression
bigfooted May 25, 2024
a554ef4
update regression
bigfooted May 25, 2024
de90bc8
update regression
bigfooted May 26, 2024
93307d3
update regression
bigfooted May 26, 2024
8a3a125
update regression
bigfooted May 26, 2024
cc7a53d
update regression
bigfooted May 26, 2024
5dcf80a
update regression
bigfooted May 26, 2024
19de368
update regression
bigfooted May 26, 2024
c2579d4
update grid velocity
bigfooted May 31, 2024
fec6872
update grid velocity
bigfooted May 31, 2024
102f9eb
update grid velocity
bigfooted May 31, 2024
67d0172
update grid velocity
bigfooted Jun 1, 2024
b71ccca
update grid velocity
bigfooted Jun 1, 2024
b927dd8
update vandv
bigfooted Jun 10, 2024
609fd2c
update tutorials
bigfooted Jun 10, 2024
7fe3866
update hybrid_regression_AD
bigfooted Jun 10, 2024
b5edc4f
Merge branch 'develop' into feature_symmetry
bigfooted Jun 10, 2024
fc8f677
Merge branch 'feature_symmetry' of /~https://github.com/su2code/su2 int…
bigfooted Jun 10, 2024
080c87b
use proper index for temperature
bigfooted Jun 10, 2024
4453aea
use proper index for temperature
bigfooted Jun 10, 2024
dea340e
fix convergence of edge_PPR
bigfooted Jun 11, 2024
51c804b
not just energy
bigfooted Jun 12, 2024
1b0924f
small update
bigfooted Jun 16, 2024
fa25b76
small update
bigfooted Jun 17, 2024
d7818a1
small update
bigfooted Jun 17, 2024
50e97c8
small update
bigfooted Jun 17, 2024
4b605ca
small update
bigfooted Jun 17, 2024
737e653
small update
bigfooted Jun 17, 2024
fd61fca
small update
bigfooted Jun 17, 2024
3e060e8
small update
bigfooted Jun 17, 2024
cf0d1e9
small update
bigfooted Jun 18, 2024
ccdae54
small update
bigfooted Jun 19, 2024
e53dd26
small update
bigfooted Jun 19, 2024
dba4dba
small update
bigfooted Jun 21, 2024
3d136bc
disable OMP line for git regression testing
bigfooted Jun 21, 2024
f7f455c
enable OMP line for git regression testing
bigfooted Jun 21, 2024
48e5de1
small update
bigfooted Jun 22, 2024
4eb41cd
Update SU2_CFD/include/gradients/computeGradientsGreenGauss.hpp
bigfooted Jun 22, 2024
e568e04
Update SU2_CFD/include/gradients/computeGradientsGreenGauss.hpp
bigfooted Jun 22, 2024
5796476
Update SU2_CFD/include/gradients/computeGradientsLeastSquares.hpp
bigfooted Jun 22, 2024
d5405dd
Update SU2_CFD/include/gradients/computeGradientsSymmetry.hpp
bigfooted Jun 22, 2024
b038b3a
change idx_vel to idxVel
bigfooted Jun 22, 2024
7b9d53b
change idxVel to short
bigfooted Jun 22, 2024
7cb3cae
change streamwise regression residual
bigfooted Jun 23, 2024
531d237
pywrapper cases
bigfooted Jun 23, 2024
eadcfcc
fix edge_VW
bigfooted Jun 24, 2024
f91aeb3
fix edge_VW
bigfooted Jun 24, 2024
2d26e6b
fix edge_VW
bigfooted Jun 25, 2024
9955a4a
move normal correction for shared symmetry-nodes
bigfooted Jun 26, 2024
a3c268b
move normal correction for shared symmetry-nodes
bigfooted Jun 27, 2024
ea12523
move normal correction for shared symmetry-nodes
bigfooted Jun 27, 2024
9c4bc6d
Merge branch 'develop' into feature_symmetry
bigfooted Jul 1, 2024
d232ab8
move normal correction for shared symmetry-nodes
bigfooted Jul 1, 2024
0854bb2
clang-format
bigfooted Jul 1, 2024
81ef867
remove unused variables
bigfooted Jul 2, 2024
70154d5
do not use find when vector size zero, remove comment blocks
bigfooted Jul 3, 2024
1615bdd
clang-format
bigfooted Jul 4, 2024
e008c3a
clang-format
bigfooted Jul 4, 2024
980c2e5
correct normals for multigrid
bigfooted Jul 7, 2024
8e06ba3
add some omp statements
bigfooted Jul 7, 2024
67b3d0a
clang-format
bigfooted Jul 7, 2024
37feae6
change resize
bigfooted Jul 7, 2024
a7ecc76
change resize
bigfooted Jul 8, 2024
0045c9c
change idim
bigfooted Jul 8, 2024
47ce8e6
fix regressions again
bigfooted Jul 8, 2024
a9a088b
Merge branch 'develop' into feature_symmetry
bigfooted Jul 11, 2024
5aa4ae8
simplify gradphi
bigfooted Jul 11, 2024
b6d2bdd
simplify gradvel
bigfooted Jul 20, 2024
1120fc5
fix segfault
bigfooted Jul 21, 2024
56e865c
Merge branch 'develop' into feature_symmetry
bigfooted Jul 22, 2024
2cf8ee0
cleanup simplification
bigfooted Jul 22, 2024
d63e182
fix final regression
bigfooted Jul 22, 2024
80cd746
omp for multigrid
bigfooted Jul 23, 2024
f0d8f6a
clang-format
bigfooted Jul 23, 2024
7b4174a
clang-format
bigfooted Jul 23, 2024
2040805
fix omp line
bigfooted Jul 23, 2024
fc98ba9
update laminar sphere regression
bigfooted Jul 24, 2024
f25221b
update laminar sphere regression
bigfooted Jul 25, 2024
500b96f
avoid heap allocations
pcarruscag Jul 27, 2024
1ad2568
Update SU2_CFD/include/gradients/computeGradientsGreenGauss.hpp
pcarruscag Jul 28, 2024
6707c7f
fix order of arguments and use template nDim
pcarruscag Jul 28, 2024
505ed23
Apply suggestions from code review
pcarruscag Jul 28, 2024
6a8b03a
simplify symmetry normals
pcarruscag Jul 29, 2024
76dcbb1
Merge branch 'feature_symmetry' of /~https://github.com/su2code/SU2 int…
pcarruscag Jul 29, 2024
e8ba7c0
fix index
pcarruscag Jul 29, 2024
368444d
checking if surfaces are planes is no longer required
pcarruscag Jul 29, 2024
71fc627
update bunch of regressions
bigfooted Jul 29, 2024
38dd1ee
fix regression
bigfooted Jul 29, 2024
df34b2f
change to getDensity
bigfooted Jul 30, 2024
f552f2f
fix regression
bigfooted Jul 31, 2024
8215322
fix regression
bigfooted Jul 31, 2024
7321fd4
update streamwise file
bigfooted Aug 1, 2024
ddcf40b
fix regression tolerance
bigfooted Aug 2, 2024
09201c6
Merge branch 'feature_symmetry' of /~https://github.com/su2code/su2 int…
bigfooted Aug 2, 2024
f48d2ff
change workflow to develop
bigfooted Aug 4, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/regression.yml
Original file line number Diff line number Diff line change
Expand Up @@ -213,7 +213,7 @@ jobs:
uses: docker://ghcr.io/su2code/su2/test-su2:240320-1536
with:
# -t <Tutorials-branch> -c <Testcases-branch>
args: -b ${{github.ref}} -t develop -c develop -s ${{matrix.testscript}}
args: -b ${{github.ref}} -t fix_symmetry -c fix_symmetry -s ${{matrix.testscript}}
- name: Cleanup
uses: docker://ghcr.io/su2code/su2/test-su2:240320-1536
with:
Expand Down
24 changes: 12 additions & 12 deletions Common/include/geometry/CGeometry.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -240,8 +240,10 @@ class CGeometry {
unsigned long* nVertex{nullptr}; /*!< \brief Number of vertex for each marker. */
unsigned long* nElem_Bound{nullptr}; /*!< \brief Number of elements of the boundary. */
string* Tag_to_Marker{nullptr}; /*!< \brief Names of boundary markers. */
vector<bool>
bound_is_straight; /*!< \brief Bool if boundary-marker is straight(2D)/plane(3D) for each local marker. */

/*!< \brief Corrected normals on nodes with shared symmetry markers. */
vector<std::unordered_map<unsigned long, std::array<su2double, MAXNDIM>>> symmetryNormals;

vector<su2double> SurfaceAreaCfgFile; /*!< \brief Total Surface area for all markers. */

/*--- Partitioning-specific variables ---*/
Expand Down Expand Up @@ -819,6 +821,12 @@ class CGeometry {
*/
inline virtual void SetBoundControlVolume(const CConfig* config, unsigned short action) {}

/*!
* \brief Computes modified normals at intersecting symmetry planes.
* \param[in] config - Definition of the particular problem.
*/
void ComputeModifiedSymmetryNormals(const CConfig* config);

/*!
* \brief A virtual member.
* \param[in] config_filename - Name of the file where the tecplot information is going to be stored.
Expand Down Expand Up @@ -936,9 +944,10 @@ class CGeometry {
/*!
* \brief A virtual member.
* \param[in] fine_grid - Geometrical definition of the problem.
* \param[in] config - Definition of the particular problem.
* \param[in] action - Allocate or not the new elements.
*/
inline virtual void SetBoundControlVolume(const CGeometry* fine_grid, unsigned short action) {}
inline virtual void SetBoundControlVolume(const CGeometry* fine_grid, const CConfig* config, unsigned short action) {}

/*!
* \brief A virtual member.
Expand Down Expand Up @@ -1005,15 +1014,6 @@ class CGeometry {
*/
su2double GetSurfaceArea(const CConfig* config, unsigned short val_marker) const;

/*!
* \brief Check if a boundary is straight(2D) / plane(3D) for EULER_WALL and SYMMETRY_PLANE
* only and store the information in bound_is_straight. For all other boundary types
* this will return false and could therfore be wrong. Used ultimately for BC_Slip_Wall.
* \param[in] config - Definition of the particular problem.
* \param[in] print_on_screen - Boolean whether to print result on screen.
*/
void ComputeSurf_Straightness(CConfig* config, bool print_on_screen);

/*!
* \brief Find and store all vertices on a sharp corner in the geometry.
* \param[in] config - Definition of the particular problem.
Expand Down
3 changes: 2 additions & 1 deletion Common/include/geometry/CMultiGridGeometry.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -104,9 +104,10 @@ class CMultiGridGeometry final : public CGeometry {
/*!
* \brief Set boundary vertex structure of the agglomerated control volume.
* \param[in] fine_grid - Geometrical definition of the problem.
* \param[in] config - Definition of the particular problem.
* \param[in] action - Allocate or not the new elements.
*/
void SetBoundControlVolume(const CGeometry* fine_grid, unsigned short action) override;
void SetBoundControlVolume(const CGeometry* fine_grid, const CConfig* config, unsigned short action) override;

/*!
* \brief Set a representative coordinates of the agglomerated control volume.
Expand Down
9 changes: 6 additions & 3 deletions Common/include/geometry/CPhysicalGeometry.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -208,10 +208,13 @@ class CPhysicalGeometry final : public CGeometry {
* \brief Routine to launch non-blocking sends and recvs amongst all processors.
* \param[in] bufSend - Buffer of data to be sent.
* \param[in] nElemSend - Array containing the number of elements to send to other processors in cumulative storage
* format. \param[in] sendReq - Array of MPI send requests. \param[in] bufRecv - Buffer of data to be received.
* format.
* \param[in] sendReq - Array of MPI send requests.
* \param[in] bufRecv - Buffer of data to be received.
* \param[in] nElemSend - Array containing the number of elements to receive from other processors in cumulative
* storage format. \param[in] sendReq - Array of MPI recv requests. \param[in] countPerElem - Pieces of data per
* element communicated.
* storage format.
* \param[in] sendReq - Array of MPI recv requests.
* \param[in] countPerElem - Pieces of data per element communicated.
*/
void InitiateCommsAll(void* bufSend, const int* nElemSend, SU2_MPI::Request* sendReq, void* bufRecv,
const int* nElemRecv, SU2_MPI::Request* recvReq, unsigned short countPerElem,
Expand Down
8 changes: 3 additions & 5 deletions Common/include/geometry/dual_grid/CPoint.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -314,10 +314,8 @@ class CPoint {
* \return Index of the vertex.
*/
inline long GetVertex(unsigned long iPoint, unsigned long iMarker) const {
if (Boundary(iPoint))
return Vertex[iPoint][iMarker];
else
return -1;
if (Boundary(iPoint)) return Vertex[iPoint][iMarker];
return -1;
}

/*!
Expand Down Expand Up @@ -369,7 +367,7 @@ class CPoint {
inline bool GetPhysicalBoundary(unsigned long iPoint) const { return PhysicalBoundary(iPoint); }

/*!
* \brief Set if a point belong to the boundary.
* \brief Set if a point belong to the solid wall boundary.
* \param[in] iPoint - Index of the point.
* \param[in] boundary - <code>TRUE</code> if the point belong to the physical boundary; otherwise <code>FALSE</code>.
*/
Expand Down
9 changes: 6 additions & 3 deletions Common/include/geometry/meshreader/CCGNSMeshReaderFVM.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -121,10 +121,13 @@ class CCGNSMeshReaderFVM : public CMeshReaderFVM {
* \brief Routine to launch non-blocking sends and recvs amongst all processors.
* \param[in] bufSend - Buffer of data to be sent.
* \param[in] nElemSend - Array containing the number of elements to send to other processors in cumulative storage
* format. \param[in] sendReq - Array of MPI send requests. \param[in] bufRecv - Buffer of data to be received.
* format.
* \param[in] sendReq - Array of MPI send requests.
* \param[in] bufRecv - Buffer of data to be received.
* \param[in] nElemSend - Array containing the number of elements to receive from other processors in cumulative
* storage format. \param[in] sendReq - Array of MPI recv requests. \param[in] countPerElem - Pieces of data per
* element communicated.
* storage format.
* \param[in] sendReq - Array of MPI recv requests.
* \param[in] countPerElem - Pieces of data per element communicated.
*/
void InitiateCommsAll(void* bufSend, const int* nElemSend, SU2_MPI::Request* sendReq, void* bufRecv,
const int* nElemRecv, SU2_MPI::Request* recvReq, unsigned short countPerElem,
Expand Down
182 changes: 65 additions & 117 deletions Common/src/geometry/CGeometry.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2338,7 +2338,7 @@ void CGeometry::UpdateGeometry(CGeometry** geometry_container, CConfig* config)
/*--- Update the control volume structures ---*/

geometry_container[iMesh]->SetControlVolume(geometry_container[iMesh - 1], UPDATE);
geometry_container[iMesh]->SetBoundControlVolume(geometry_container[iMesh - 1], UPDATE);
geometry_container[iMesh]->SetBoundControlVolume(geometry_container[iMesh - 1], config, UPDATE);
geometry_container[iMesh]->SetCoord(geometry_container[iMesh - 1]);
}

Expand Down Expand Up @@ -2453,123 +2453,71 @@ su2double CGeometry::GetSurfaceArea(const CConfig* config, unsigned short val_ma
return 0.0;
}

void CGeometry::ComputeSurf_Straightness(CConfig* config, bool print_on_screen) {
bool RefUnitNormal_defined;
unsigned short iDim, iMarker, iMarker_Global, nMarker_Global = config->GetnMarker_CfgFile();
unsigned long iVertex;
constexpr passivedouble epsilon = 1.0e-6;
su2double Area;
string Local_TagBound, Global_TagBound;

vector<su2double> Normal(nDim), UnitNormal(nDim), RefUnitNormal(nDim);

/*--- Assume now that this boundary marker is straight. As soon as one
AreaElement is found that is not aligend with a Reference then it is
certain that the boundary marker is not straight and one can stop
searching. Another possibility is that this process doesn't own
any nodes of that boundary, in that case we also have to assume the
boundary is straight.
Any boundary type other than SYMMETRY_PLANE or EULER_WALL gets
the value false (or see cases specified in the conditional below)
which could be wrong. ---*/
bound_is_straight.resize(nMarker);
fill(bound_is_straight.begin(), bound_is_straight.end(), true);

/*--- Loop over all local markers ---*/
for (iMarker = 0; iMarker < nMarker; iMarker++) {
Local_TagBound = config->GetMarker_All_TagBound(iMarker);

/*--- Marker has to be Symmetry or Euler. Additionally marker can't be a
moving surface and Grid Movement Elasticity is forbidden as well. All
other GridMovements are rigid. ---*/
if ((config->GetMarker_All_KindBC(iMarker) == SYMMETRY_PLANE ||
config->GetMarker_All_KindBC(iMarker) == EULER_WALL) &&
!config->GetMarker_Moving_Bool(Local_TagBound) && !config->GetMarker_Deform_Mesh_Bool(Local_TagBound)) {
/*--- Loop over all global markers, and find the local-global pair via
matching unique string tags. ---*/
for (iMarker_Global = 0; iMarker_Global < nMarker_Global; iMarker_Global++) {
Global_TagBound = config->GetMarker_CfgFile_TagBound(iMarker_Global);
if (Local_TagBound == Global_TagBound) {
RefUnitNormal_defined = false;
iVertex = 0;

while (bound_is_straight[iMarker] && iVertex < nVertex[iMarker]) {
vertex[iMarker][iVertex]->GetNormal(Normal.data());
UnitNormal = Normal;

/*--- Compute unit normal. ---*/
Area = 0.0;
for (iDim = 0; iDim < nDim; iDim++) Area += Normal[iDim] * Normal[iDim];
Area = sqrt(Area);

/*--- Negate for outward convention. ---*/
for (iDim = 0; iDim < nDim; iDim++) UnitNormal[iDim] /= -Area;

/*--- Check if unit normal is within tolerance of the Reference unit normal.
Reference unit normal = first unit normal found. ---*/
if (RefUnitNormal_defined) {
for (iDim = 0; iDim < nDim; iDim++) {
if (abs(RefUnitNormal[iDim] - UnitNormal[iDim]) > epsilon) {
bound_is_straight[iMarker] = false;
break;
}
}
} else {
RefUnitNormal = UnitNormal; // deep copy of values
RefUnitNormal_defined = true;
}
void CGeometry::ComputeModifiedSymmetryNormals(const CConfig* config) {
/* Check how many symmetry planes there are and use the first (lowest ID) as the basis to orthogonalize against.
* All nodes that are shared by multiple symmetries have to get a corrected normal. */
symmetryNormals.resize(nMarker);
std::vector<unsigned short> symMarkers;

iVertex++;
} // while iVertex
} // if Local == Global
} // for iMarker_Global
} else {
/*--- Enforce default value: false ---*/
bound_is_straight[iMarker] = false;
} // if sym or euler ...
} // for iMarker

/*--- Communicate results and print on screen. ---*/
if (print_on_screen) {
/*--- Additional vector which can later be MPI::Allreduce(d) to pring the results
on screen as nMarker (local) can vary across ranks. Default 'true' as it can
happen that a local rank does not contain an element of each surface marker. ---*/
vector<bool> bound_is_straight_Global(nMarker_Global, true);
/*--- Match local with global tag bound and fill a Global Marker vector. ---*/
for (iMarker = 0; iMarker < nMarker; iMarker++) {
Local_TagBound = config->GetMarker_All_TagBound(iMarker);
for (iMarker_Global = 0; iMarker_Global < nMarker_Global; iMarker_Global++) {
Global_TagBound = config->GetMarker_CfgFile_TagBound(iMarker_Global);

if (Local_TagBound == Global_TagBound) bound_is_straight_Global[iMarker_Global] = bound_is_straight[iMarker];

} // for iMarker_Global
} // for iMarker

vector<int> Buff_Send_isStraight(nMarker_Global), Buff_Recv_isStraight(nMarker_Global);

/*--- Cast to int as std::vector<boolean> can be a special construct. MPI handling using <int>
is more straight-forward. ---*/
for (iMarker_Global = 0; iMarker_Global < nMarker_Global; iMarker_Global++)
Buff_Send_isStraight[iMarker_Global] = static_cast<int>(bound_is_straight_Global[iMarker_Global]);

/*--- Product of type <int>(bool) is equivalnt to a 'logical and' ---*/
SU2_MPI::Allreduce(Buff_Send_isStraight.data(), Buff_Recv_isStraight.data(), nMarker_Global, MPI_INT, MPI_PROD,
SU2_MPI::GetComm());

/*--- Print results on screen. ---*/
if (rank == MASTER_NODE) {
for (iMarker_Global = 0; iMarker_Global < nMarker_Global; iMarker_Global++) {
if (config->GetMarker_CfgFile_KindBC(config->GetMarker_CfgFile_TagBound(iMarker_Global)) == SYMMETRY_PLANE ||
config->GetMarker_CfgFile_KindBC(config->GetMarker_CfgFile_TagBound(iMarker_Global)) == EULER_WALL) {
cout << "Boundary marker " << config->GetMarker_CfgFile_TagBound(iMarker_Global) << " is";
if (!static_cast<bool>(Buff_Recv_isStraight[iMarker_Global])) cout << " NOT";
if (nDim == 2) cout << " a single straight." << endl;
if (nDim == 3) cout << " a single plane." << endl;
} // if sym or euler
} // for iMarker_Global
} // if rank==MASTER
} // if print_on_scren
for (auto iMarker = 0u; iMarker < nMarker; ++iMarker) {
if ((config->GetMarker_All_KindBC(iMarker) == SYMMETRY_PLANE) ||
(config->GetMarker_All_KindBC(iMarker) == EULER_WALL)) {
symMarkers.push_back(iMarker);
}
}

/*--- Loop over all markers and find nodes on symmetry planes that are shared with other symmetries. ---*/
/*--- The first symmetry does not need a corrected normal vector, hence start at 1. ---*/
for (size_t i = 1; i < symMarkers.size(); ++i) {
const auto iMarker = symMarkers[i];

for (auto iVertex = 0ul; iVertex < nVertex[iMarker]; iVertex++) {
const auto iPoint = vertex[iMarker][iVertex]->GetNode();

/*--- Halo points do not need to be considered. ---*/
if (!nodes->GetDomain(iPoint)) continue;

/*--- Get the vertex normal on the current symmetry. ---*/
std::array<su2double, MAXNDIM> iNormal = {};
vertex[iMarker][iVertex]->GetNormal(iNormal.data());

/*--- Loop over previous symmetries and if this point shares them, make this normal orthogonal to them. ---*/
bool isShared = false;

for (size_t j = 0; j < i; ++j) {
const auto jMarker = symMarkers[j];
const auto jVertex = nodes->GetVertex(iPoint, jMarker);
if (jVertex < 0) continue;

isShared = true;

std::array<su2double, MAXNDIM> jNormal = {};
const auto it = symmetryNormals[jMarker].find(jVertex);

if (it != symmetryNormals[jMarker].end()) {
jNormal = it->second;
} else {
vertex[jMarker][jVertex]->GetNormal(jNormal.data());
const su2double area = GeometryToolbox::Norm(nDim, jNormal.data());
for (auto iDim = 0u; iDim < nDim; iDim++) jNormal[iDim] /= area;
}

const auto proj = GeometryToolbox::DotProduct(nDim, jNormal.data(), iNormal.data());
for (auto iDim = 0u; iDim < nDim; iDim++) iNormal[iDim] -= proj * jNormal[iDim];
}

if (!isShared) continue;

/*--- Normalize. If the norm is close to zero it means the normal is a linear combination of previous
* normals, in this case we don't need to store the corrected normal, using the original in the gradient
* correction will have no effect since previous corrections will remove components in this direction). ---*/
const su2double area = GeometryToolbox::Norm(nDim, iNormal.data());
if (area > EPS) {
for (auto iDim = 0u; iDim < nDim; iDim++) iNormal[iDim] /= area;
symmetryNormals[iMarker][iVertex] = iNormal;
}
}
}
}

void CGeometry::ComputeSurf_Curvature(CConfig* config) {
Expand Down
Loading