Hi Erik, Thanks for your quick response!
I use the none bc type for now, rather than the more complicated radiative bc. I use a stencil that leans over as you approach the boundary. Currently this is a 4th order interior 3rd order sbp fd operator of Strand. By looking at the output on the boundary in both codes, there are round off level numbers appearing after the first Euler step in multiple variables. There is no use comparing these exactly as they're so small but note that the same variables have these in both codes. These come from taking spatial derivatives. Sorry, the lapse is initially one. I have compared output by saving the data in both codes. It seems like, since the first few time steps everything is round off errors, it is hard to see exactly where things start to go wrong. I will try your small grid and see if that yields anything more obvious. Thanks, Chris ________________________________ From: Erik Schnetter <schnet...@gmail.com> Sent: Saturday, May 14, 2022 3:09:17 PM To: Chris Stevens <chris.stev...@canterbury.ac.nz> Cc: Einstein Toolkit Users <users@einsteintoolkit.org> Subject: Re: [Users] Implementing a simple 1+1 BSSN in Python Chris What do you mean by "Boundary conditions are not applied"? What do you do at the boundaries? Are you using one-sided differencing there? Given your description, I assume that all derivatives would be identically zero, that there would not even be a floating-point round-off error. Is that so? If not, why not? Are you really setting the lapse to zero initially? It should be one for Minkowski, same as e.g. g_xx. What happens if you choose a very small grid size (e.g. just 10 points) and compare the initial conditions between the Einstein Toolkit and the Python code? Are they identical? You would need to compare ASCII output and compare all the digits. What happens if you take a single Euler time step? Are the values still all identical? Try to find out and which iteration the first grid point differs between the two codes. -erik On Fri, May 13, 2022 at 9:59 PM Chris Stevens <chris.stev...@canterbury.ac.nz<mailto:chris.stev...@canterbury.ac.nz>> wrote: Hi all, I've been having trouble implementing the BSSN equations, as given by CTGamma, in Python using the package COFFEE, which I am very familiar with: https://gitlab.com/thebarista/coffee https://doi.org/10.1016/j.softx.2019.100283 The main comments are: -- For simplicity, I am starting with a 1+1 code (set 2/3 spatial derivatives to be exactly zero). -- The 1+log slicing for the lapse and a zero shift. -- The "phi" conformal factor type -- The evolution equations are written to Python by a very slight modification of the .m file in CTGEvolution. I've confirmed this .m file outputs the same file that is in the src directory. -- The vanishing of the trace of A is enforced after each full timestep in the same way as CTGamma. -- Boundary conditions are not applied. -- Fourth order SBP operators that lean over toward the boundaries are used. -- Minkowski initial data with all fields zero except \gamma11/22/33. -- Euler step is used for time integration to easier compare between Python and the Einstein toolkit. This leads to a stable evolution in the Einstein toolkit with the attached .par file using a simple one patch Cartesian grid. However, in Python, I get that fields diverge, starting at the boundaries and then propagating inward (including with RK4). This behaviour does not go away with higher resolution or reduced CFL. It is however, fixed completely by setting the second spatial derivative of \alpha to be exactly zero. Trying many different SBP FD operators that have proved successful for other projects has not changed the behaviour. The COFFEE code has been used and tested in a variety of projects and so there should not be a problem here. Thus, the only thing I can think of, is that the Einstein toolkit is doing something that I am not realizing, that is helping it remain stable. Hopefully, somebody on this mailing list might have an idea? Thanks in advance, Chris [cid:180c08545639cddf49f1] [cid:180c085456481d7e37e2] Dr Chris Stevens Lecturer in Applied Mathematics Rm 602, Jack Erskine building School of Mathematics and Statistics T: +64 3 369 0396 (Internal 90396) University of Canterbury | Te Whare Wānanga o Waitaha Private Bag 4800, Christchurch 8140, New Zealand http://www.chrisdoesmaths.com<http://www.chrisdoesmaths.com/> Director SCRI Ltd http://www.scri.co.nz<http://www.scri.co.nz/> _______________________________________________ Users mailing list Users@einsteintoolkit.org<mailto:Users@einsteintoolkit.org> http://lists.einsteintoolkit.org/mailman/listinfo/users -- Erik Schnetter <schnet...@gmail.com<mailto:schnet...@gmail.com>> http://www.perimeterinstitute.ca/personal/eschnetter/
_______________________________________________ Users mailing list Users@einsteintoolkit.org http://lists.einsteintoolkit.org/mailman/listinfo/users