-
Notifications
You must be signed in to change notification settings - Fork 248
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
[GeoMechanicsApplication] Implement well constitutive behaviour for line pressure element #12997
base: master
Are you sure you want to change the base?
Conversation
… takes into account the projected gravity.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for implementing this functionality! I have a few suggestions for clean-up but all in all it's clear (of course I may be a bit biased here 😄 )!
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.cpp
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/transient_Pw_line_element.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/transient_Pw_line_element.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_retention/retention_law_factory.h
Outdated
Show resolved
Hide resolved
const double equivalent_radius_square = Prop[CROSS_AREA] / Globals::Pi; | ||
rPermeabilityMatrix(0, 0) = equivalent_radius_square * 0.125; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would not expect the 'FillPermeabilityMatrix' function to perform a calculation here (
applications/GeoMechanicsApplication/tests/test_pressure_line_element/README.md
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi Mohammed,
Thank you for the work done. I'm not understanding an important point, the nature of the law itself. Please teach me.
Wijtze Pieter
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.cpp
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_retention/retention_law_factory.h
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.h
Outdated
Show resolved
Hide resolved
...tion/tests/test_pressure_line_element/test_oblique_filter_element2D3N/ProjectParameters.json
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This seems a nice extension to me, with documentation and tests. Well done! I have several minor suggestions and a few questions, but nothing major.
applications/GeoMechanicsApplication/custom_elements/filter_compressibility_calculator.cpp
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/transient_Pw_line_element.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/transient_Pw_line_element.h
Show resolved
Hide resolved
applications/GeoMechanicsApplication/custom_elements/transient_Pw_line_element.h
Outdated
Show resolved
Hide resolved
applications/GeoMechanicsApplication/tests/test_pressure_line_element/README.md
Outdated
Show resolved
Hide resolved
...ion/tests/test_pressure_line_element/test_oblique_filter_element2D3N/MaterialParameters.json
Outdated
Show resolved
Hide resolved
...ion/tests/test_pressure_line_element/test_oblique_filter_element2D3N/MaterialParameters.json
Outdated
Show resolved
Hide resolved
...tion/tests/test_pressure_line_element/test_oblique_filter_element2D3N/ProjectParameters.json
Outdated
Show resolved
Hide resolved
...ion/tests/test_pressure_line_element/test_oblique_filter_element3D3N/MaterialParameters.json
Outdated
Show resolved
Hide resolved
...tion/tests/test_pressure_line_element/test_oblique_filter_element3D3N/ProjectParameters.json
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Dear Mohamed,
Thank you for all the work.
I have still some remarks of which some may even be done at an other time.
I would appreciate if the specific resulting formulas from you PDF document could be includes in GeoMechanicsApplication/custom_constitutive/README.md
Regards, Wijtze Pieter
const double result = | ||
1.0 / (r_properties[DENSITY_WATER] * ProjectedGravity * r_properties[FILTER_LENGTH]) + | ||
1.0 / r_properties[BULK_MODULUS_FLUID]; | ||
return result; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not:
return 1.0 / (r_properties[DENSITY_WATER] * ProjectedGravity * r_properties[FILTER_LENGTH]) +
1.0 / r_properties[BULK_MODULUS_FLUID];
There is no need for the intermediate variable result.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
for (std::size_t i = 0; i < number_integration_points; ++i) { | ||
J_container[i].resize(GetGeometry().WorkingSpaceDimension(), | ||
GetGeometry().LocalSpaceDimension(), false); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Probably Sonar Cloud will give a remark about this that can be avoided as follows:
for ( auto& j: J_container ) {
j.resize(GetGeometry().WorkingSpaceDimension(), GetGeometry().LocalSpaceDimension(), false);
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
"IGNORE_UNDRAINED" : false, | ||
"DENSITY_SOLID" : 2.650000e+03, | ||
"DENSITY_WATER" : 1.000000e+03, | ||
"POROSITY" : 1.000000e-01, | ||
"BULK_MODULUS_SOLID" : 9.000000e+19, | ||
"BULK_MODULUS_FLUID" : 1.000000e+20, | ||
"PERMEABILITY_XX" : 9.084000e-06, | ||
"DYNAMIC_VISCOSITY" : 1.000000e-03, | ||
"RETENTION_LAW" : "PressureFilterLaw", | ||
"CROSS_AREA" : 1.0, | ||
"FILTER_LENGTH" : 3.0 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You have gotten rid of quite some redundant material parameters already. I'm guessing that also IGNORE_UNDRAINED is not used and that POROSITY is only there because the transient_Pw_line_element CheckProperties is looking at it. This CheckProperties is doing what the check of the constitutive law check should do. The specific filter law does not seem to contain POROSITY. This repeats in the material properties for the other test.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have one more comment about the C++ code.
for (std::size_t i = 0; i < number_integration_points; ++i) { | ||
J_container[i].resize(GetGeometry().WorkingSpaceDimension(), | ||
GetGeometry().LocalSpaceDimension(), false); | ||
for (auto& container : J_container) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If I'm correct in other parts of the code this is called j
:
for (auto& container : J_container) { | |
for (auto& j : J_container) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
@mnabideltares Is there anything still needed to merge this PR (except approval)? |
Description:
To enhance our computational model for simulating high capacity heat storage systems, we need to implement a pressure "wel/filter" element on top of the existing pressure line element. The pressure filter element will enable us to model the behavior of heat storage under the ground, accounting for their heat exchange processes. This addition is crucial for achieving realistic simulations of heat storage systems and optimizing their performance.
🆕 Changelog