<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class="">Hi Erik,<div class="">Thanks for the quick response!</div><div class=""><br class=""></div><div class="">I’m not using mesh refinement, and yes I ignore the ghost zones in my calculations. I use periodicity within the original (no ghosts) grid for derivatives. </div><div class=""><br class=""></div><div class="">And yes I’m using the ADMBase metric and extrinsic curvature. I get the same result whether I do the calculation in the postpostinitial stage or using the 3D dumps in post-processing. Would there be a loss of precision in ADMBase gij and kij when translating back and forth to BSSN metric/kij, which could then be propagated to the output files? </div><div class=""><br class=""></div><div class="">Best,</div><div class="">Hayley</div><div class=""><div class=""><div dir="auto" style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0); letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none; word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div dir="auto" style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0); letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none; word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div dir="auto" style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0); letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none; word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div dir="auto" style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0); letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none; word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div dir="auto" style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0); letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none; word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div dir="auto" style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0); letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none; word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div><br class=""></div></div></div></div></div></div></div></div><div><blockquote type="cite" class=""><div class="">On 23 Aug 2023, at 11:31, Erik Schnetter <<a href="mailto:schnetter@gmail.com" class="">schnetter@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div class="">Hayley<br class=""><br class="">Are you using mesh refinement in your calculations? If so, the ET<br class="">would fill the ghost and the buffer zones with interpolated data.<br class="">These are generally less accurate than properly calculated data. If<br class="">so, are you ignoring ghost and buffer zones? These should not be used<br class="">for visualization and post-processing.<br class=""><br class="">Which metric variables are you accessing? I assume you are looking at<br class="">ADMBase for the metric and extrinsic curvature? These should change,<br class="">unless you look at them too early: During initialization, we set up<br class="">the ADMBase variables, then define the BSSN variables from these, and<br class="">then recalculate the ADMBase variables. This would change them<br class="">slightly. Analysis tools should only look at the ADMBase variables<br class="">after they have been reset.<br class=""><br class="">-erik<br class=""><br class=""><br class="">On Wed, Aug 23, 2023 at 11:56 AM Hayley Macpherson<br class=""><<a href="mailto:hayleyjmacpherson@gmail.com" class="">hayleyjmacpherson@gmail.com</a>> wrote:<br class=""><blockquote type="cite" class=""><br class="">Hi all,<br class=""><br class="">I’m the author of a cosmological initial data thorn in the ET; FLRWSolver. I’m currently working on improving the initial data to solve the constraint equations exactly (instead of previously using an approximation), for a given metric and Kij. The way this works is to calculate the metric terms on the LHS of both the constraints and solve for the relevant rest mass density and peculiar 3-velocities from the matter terms.<br class=""><br class="">I have my own routines from a post-processing analysis code to calculate the metric terms, and I’ve incorporated these into the ET for both generating the initial data but also then double checking the constraint violation after the initial data is set up.<br class=""><br class="">I noticed something strange: my checks immediately after FLRWSolver is called in the ET show the constraints are satisfied essentially to roundoff error (i.e. the momentum constraint violation has magnitude ~ 1.e-15), but when I take the 3D dump of the initial time slice and run this through my analysis code (which uses the same routines as I use to set up initial data), I see the momentum constraint is violated at the ~ 1e-7 level.<br class=""><br class="">I thought this might be my post processing code, so I added a second call to check the constraints using my routines after the full initial process is finished. The first call which immediately follows my FLRWSolver routine is placed in group HydroBase_Initial, and I added another call in CCTK_POSTINITIAL which gives the same result, however, if I instead schedule this call in POSTPOSTINITIAL I see the momentum constraint violation is identical to what I see when post processing the initial dump, at ~ 1.e-7. I can see the specific terms which are causing this difference are the terms which use finite-difference derivatives (the curvature terms in the momentum constraint), while all others are identical.<br class=""><br class="">So my question is the following: is there any way that the metric and curvature variables could suffer a loss of precision between the POSTINITIAL and POSTPOSTINITIAL phases of the run? Especially, a loss in precision which is then translated to the 3D dumps.<br class=""><br class="">The momentum constraint violation I have is satisfactory, but I am trying to pinpoint why this jump happens to make sure it’s not a bug in my separate code somewhere (also to explain why the constraints aren’t satisfied to roundoff level when they should be, by construction of my initial data :) ).<br class=""><br class="">Any help is much appreciated!<br class="">Best wishes,<br class="">Hayley<br class=""><br class="">----<br class=""><br class="">Hayley Macpherson | NASA Einstein Fellow<br class=""><br class=""><a href="mailto:hjmacpherson@uchicago.edu" class="">Email: hjmacpherson@uchicago.edu</a><br class="">Pronouns: she/her/hers<br class=""><br class="">Office: ERC 479<br class="">Kavli Institute for Cosmological Physics<br class="">Eckhardt Research Center<br class="">5640 South Ellis Avenue<br class="">Chicago, IL, 60637<br class=""><br class="">_______________________________________________<br class="">Users mailing list<br class="">Users@einsteintoolkit.org<br class="">http://lists.einsteintoolkit.org/mailman/listinfo/users<br class=""></blockquote><br class=""><br class=""><br class="">-- <br class="">Erik Schnetter <<a href="mailto:schnetter@gmail.com" class="">schnetter@gmail.com</a>><br class=""><a href="http://www.perimeterinstitute.ca/personal/eschnetter/" class="">http://www.perimeterinstitute.ca/personal/eschnetter/</a><br class=""></div></div></blockquote></div><br class=""></div></body></html>