-
Notifications
You must be signed in to change notification settings - Fork 8
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
Virial stress #137
base: main
Are you sure you want to change the base?
Virial stress #137
Conversation
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.
First review - let's get it working without fracture first
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.
Zeros are because the only implemented stress is for Elastic (no fracture) with PMB, which requires modifying the elastic wave problem to use PMB. Looks good on my end making that change. Let me know if you have questions about adding this for fracture
I've made the suggested changes and it is now working with non-fracture problems using the PMB method. (I may have pushed an altered version of elastic wave problem that I used to test it...please disregard this). Will move on to implementing virial stress with fracture. |
Sounds good. One thing that will help quite a bit is using One other note - we'll need to remove the comments tracking incremental changes before we merge (the fact that the force slice was moved outside the kernel is tracked in the git history and would likely be more confusing than not in the future, for example) |
1-s2.0-S0020768322000427-main.pdf Added virial stress to pmb with fracture. Could you please doublecheck the volume summation. it should be normalised by the total volume of the horizon regardless of the number of points within the horizon. I'm thinking we might need to adjust the non-fracture volume too as it does not include vol(i) in the division. |
@pabloseleson can you take a look? |
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.
Should we add this for LPS as well? Or wait for now?
Which equation is being implemented exactly? |
Eq. 29. |
@kinanbezem7 : I looked at Eq. (29) in the reference here. There is something awkward in that equation. The RHS of the equation is for the stress tensor at X. However, the LHS of the equation doesn't depend on X. Instead, I looked at an alternative reference here and implemented Eq. (24) of that reference. In this reference, there is a dependence on R on both the RHS and LHS, so it makes more sense to me. BTW: this stress tensor is in general nonsymmetric (like the classical Piola stress tensor, see here). So, it seems we would need to compute the full tensor, not only the 6 entries. I only included the 6 entries for now. |
@streeve : Please take a look at the current implementation. |
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.
Couple small things to clean up, but this is close to ready. @kinanbezem7 let me know if it makes sense how to fix the failing test or remaining comments or we can look at it in person
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.
Missing LPS stresses
@pabloseleson can you take a look at the new example - the crack isn't centered. @kinanbezem7 there are a number of new files that look unintentional |
Apologies, I got CabanaPD working on WSL on windows and then tried to work from there for this last part, so probably a bunch of files got thrown in. Still getting used to Github |
No worries, but avoiding |
@streeve Is there anything else that you need me to do with this? |
I had hoped @pabloseleson would have time to take a look. Instead, you could remove the unintended files, remove the new example, and run the crack branching case with stress output posted here |
I noticed there was a mistake with the LinearLPS stress which I corrected and removed the extra files. I tested this for both LPS and PMB and looks like we are getting reasonable output, but I haven't looked into a proper validation of the magnitude of the stresses |
Co-authored-by: Sam Reeve <[email protected]> Co-authored-by: pabloseleson <[email protected]>
@kinanbezem7 I updated this branch on main and combined all commits. Can you test with the crack branching and post a result? Should be ready to merge if it looks good |
Sure thing I'll try and get it done ASAP. Apologies things have been really hectic in the lab. |
Hey no worries, other things getting merged simplified this a lot anyway |
@streeve Just leaving a note here, I tried to run the crackbranching example with the elastic solver which failed due to the prenotch only being available with the fracture solver. |
Sounds good. Yeah, that's because currently in order to use a prenotch you need to store the full bond array and check it at each step. We could implement a non-fracture version with sparse bonds, but I'm not sure if anyone truly needs it at the moment |
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.
@pabloseleson I think this is ready. Add any further review you think is needed
@streeve Great to see progress on this! I am very sorry for the delay in reviewing. I plan to get to this soon. |
Added virial stress to particles.hpp and the HDF5 output for the pmb model.
Added logic for calculating virial stress in compute full energy in force_pmb.hpp.
Compiles and runs kalthoff winkler, however the virial stress in the output is zero.
I think the forces may not be being calculated properly in the energy logic. I'm also unsure of how to handle bond breakage here, but my entire approach may be wrong so this might be totally unnecessary