From 6f5c62f90758d6872b9e12ca9f9aa2c047e3bf7a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?JulienD=C3=B6rner?= Date: Wed, 28 Aug 2024 08:06:32 +0200 Subject: [PATCH 1/6] add setThinning in constructor --- src/module/SynchrotronRadiation.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/module/SynchrotronRadiation.cpp b/src/module/SynchrotronRadiation.cpp index 3e002f67d..b096ed955 100644 --- a/src/module/SynchrotronRadiation.cpp +++ b/src/module/SynchrotronRadiation.cpp @@ -16,6 +16,7 @@ SynchrotronRadiation::SynchrotronRadiation(ref_ptr field, bool ha setLimit(limit); setSecondaryThreshold(1e6 * eV); setMaximumSamples(nSamples); + setThinning(thinning); } SynchrotronRadiation::SynchrotronRadiation(double Brms, bool havePhotons, double thinning, int nSamples, double limit) { @@ -25,6 +26,7 @@ SynchrotronRadiation::SynchrotronRadiation(double Brms, bool havePhotons, double setLimit(limit); setSecondaryThreshold(1e6 * eV); setMaximumSamples(nSamples); + setThinning(thinning); } void SynchrotronRadiation::setField(ref_ptr f) { From bf4fb6f52661ad97c79db901d896ac8d29c712a5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?JulienD=C3=B6rner?= Date: Wed, 28 Aug 2024 08:28:52 +0200 Subject: [PATCH 2/6] add simple test for SynchrotronRadiation --- test/testInteraction.cpp | 94 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 94 insertions(+) diff --git a/test/testInteraction.cpp b/test/testInteraction.cpp index f2fe49dbf..3c6f9777d 100644 --- a/test/testInteraction.cpp +++ b/test/testInteraction.cpp @@ -1144,6 +1144,100 @@ TEST(SynchrotronRadiation, interactionTag) { EXPECT_TRUE(s.getInteractionTag() == "myTag"); } +TEST(SynchrotronRadiation, simpleTestRMS) { + // test initialisation with B_rms + + // check default values + SynchrotronRadiation sync; + + EXPECT_EQ(sync.getBrms(), 0); + EXPECT_FALSE(sync.getHavePhotons()); + EXPECT_EQ(sync.getThinning(), 0); + EXPECT_EQ(sync.getLimit(), 0.1); + EXPECT_EQ(sync.getMaximumSamples(), 0); + EXPECT_EQ(sync.getSecondaryThreshold(), 1 * MeV); + + // init with custom values + double b = 1 * muG; + double thinning = 0.23; + int samples = 4; + double limit = 0.123; + SynchrotronRadiation sync2(b, true, thinning, samples, limit); + + EXPECT_EQ(sync.getBrms(), b); + EXPECT_TRUE(sync.getHavePhotons()); + EXPECT_EQ(sync.getThinning(), thinning); + EXPECT_EQ(sync.getLimit(), limit); + EXPECT_EQ(sync.getMaximumSamples(), samples); + EXPECT_EQ(sync.getSecondaryThreshold(), 1 * MeV); +} + +TEST(SynchrotronRadiation, simpleTestField) { + // test initialisation with field + + // check default values + Vector3d b(0, 0, 1 * muG); + ref_ptr field = new UniformMagneticField(b); + SynchrotronRadiation sync(field); + + EXPECT_EQ(sync.getBrms(), 0); + EXPECT_FALSE(sync.getHavePhotons()); + EXPECT_EQ(sync.getThinning(), 0); + EXPECT_EQ(sync.getLimit(), 0.1); + EXPECT_EQ(sync.getMaximumSamples(), 0); + EXPECT_EQ(sync.getSecondaryThreshold(), 1 * MeV); + Vector3d fieldAtPosition = sync.getField() -> getField(Vector3d(1, 2 , 3)); + EXPECT_EQ(fieldAtPosition.getR(), b.getR()); + + // init with custom values + double thinning = 0.23; + int samples = 4; + double limit = 0.123; + SynchrotronRadiation sync2(field, true, thinning, samples, limit); + + EXPECT_EQ(sync.getBrms(), 0); + EXPECT_TRUE(sync.getHavePhotons()); + EXPECT_EQ(sync.getThinning(), thinning); + EXPECT_EQ(sync.getLimit(), limit); + EXPECT_EQ(sync.getMaximumSamples(), samples); + EXPECT_EQ(sync.getSecondaryThreshold(), 1 * MeV); + Vector3d fieldAtPosition = sync.getField() -> getField(Vector3d(1, 2 , 3)); + EXPECT_EQ(fieldAtPosition.getR(), b.getR()); +} + +TEST(SynchrotronRadiation, getSetFunctions) { + SynchrotronRadiation sync; + + // have photons + sync.setHavePhotons(true); + EXPECT_TRUE(sync.getHavePhotons()); + + // Brms + sync.setBrms(5 * muG); + EXPECT_EQ(sync.getBrms(), 5 * muG); + + // thinning + sync.setThinning(0.345); + EXPECT_EQ(sync.getThinning(), 0.345); + + // limit + sync.setLimit(0.234); + EXPECT_EQ(sync.getLimit(), 0.234); + + // max samples + sync.setMaximumSamples(12345); + EXPECT_EQ(sync.getMaximumSamples(), 12345); + + // field + Vector3d b(1,2,3); + ref_ptr field = new UniformMagneticField(b); + sync.setField(field); + EXPECT_TRUE(field == sync.getField()); // same pointer + + // secondary threshold + sync.setSecondaryThreshold(1 * eV); + EXPECT_EQ(sync.getSecondaryThreshold(), 1 * eV); +} int main(int argc, char **argv) { ::testing::InitGoogleTest(&argc, argv); From 826dc2425b88205a5f49e6cbdf8c0933f039167d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?JulienD=C3=B6rner?= Date: Wed, 28 Aug 2024 09:09:42 +0200 Subject: [PATCH 3/6] add test for energy loss --- test/testInteraction.cpp | 75 +++++++++++++++++++++++++++++++++------- 1 file changed, 62 insertions(+), 13 deletions(-) diff --git a/test/testInteraction.cpp b/test/testInteraction.cpp index 3c6f9777d..7d937ad05 100644 --- a/test/testInteraction.cpp +++ b/test/testInteraction.cpp @@ -1164,12 +1164,12 @@ TEST(SynchrotronRadiation, simpleTestRMS) { double limit = 0.123; SynchrotronRadiation sync2(b, true, thinning, samples, limit); - EXPECT_EQ(sync.getBrms(), b); - EXPECT_TRUE(sync.getHavePhotons()); - EXPECT_EQ(sync.getThinning(), thinning); - EXPECT_EQ(sync.getLimit(), limit); - EXPECT_EQ(sync.getMaximumSamples(), samples); - EXPECT_EQ(sync.getSecondaryThreshold(), 1 * MeV); + EXPECT_EQ(sync2.getBrms(), b); + EXPECT_TRUE(sync2.getHavePhotons()); + EXPECT_EQ(sync2.getThinning(), thinning); + EXPECT_EQ(sync2.getLimit(), limit); + EXPECT_EQ(sync2.getMaximumSamples(), samples); + EXPECT_EQ(sync2.getSecondaryThreshold(), 1 * MeV); } TEST(SynchrotronRadiation, simpleTestField) { @@ -1195,13 +1195,13 @@ TEST(SynchrotronRadiation, simpleTestField) { double limit = 0.123; SynchrotronRadiation sync2(field, true, thinning, samples, limit); - EXPECT_EQ(sync.getBrms(), 0); - EXPECT_TRUE(sync.getHavePhotons()); - EXPECT_EQ(sync.getThinning(), thinning); - EXPECT_EQ(sync.getLimit(), limit); - EXPECT_EQ(sync.getMaximumSamples(), samples); - EXPECT_EQ(sync.getSecondaryThreshold(), 1 * MeV); - Vector3d fieldAtPosition = sync.getField() -> getField(Vector3d(1, 2 , 3)); + EXPECT_EQ(sync2.getBrms(), 0); + EXPECT_TRUE(sync2.getHavePhotons()); + EXPECT_EQ(sync2.getThinning(), thinning); + EXPECT_EQ(sync2.getLimit(), limit); + EXPECT_EQ(sync2.getMaximumSamples(), samples); + EXPECT_EQ(sync2.getSecondaryThreshold(), 1 * MeV); + fieldAtPosition = sync2.getField() -> getField(Vector3d(1, 2 , 3)); EXPECT_EQ(fieldAtPosition.getR(), b.getR()); } @@ -1239,6 +1239,55 @@ TEST(SynchrotronRadiation, getSetFunctions) { EXPECT_EQ(sync.getSecondaryThreshold(), 1 * eV); } +TEST(SynchrotronRadiation, energyLoss) { + double brms = 1 * muG; + double step = 1 * kpc; + SynchrotronRadiation sync(brms, false); + + double dE, lf, Rg, dEdx; + Candidate c(11); + c.setCurrentStep(step); + c.setNextStep(step); + double charge = eplus; + + // 1 GeV + c.current.setEnergy(1 * GeV); + lf = c.current.getLorentzFactor(); + Rg = 1 * GeV / charge / c_light / (brms * sqrt(2. / 3) ); // factor 2/3 for avg magnetic field direction. + dEdx = 1. / 6 / M_PI / epsilon0 * pow(lf * lf - 1, 2) * pow(charge / Rg, 2); // Jackson p. 770 (14.31) + dE = dEdx * step; + sync.process(&c); + EXPECT_NEAR(1 * GeV - c.current.getEnergy(), dE, 0.01 * dE); + + // 100 GeV + c.current.setEnergy(100 * GeV); + lf = c.current.getLorentzFactor(); + Rg = 100 * GeV / charge / c_light / (brms * sqrt(2. / 3) ); // factor 2/3 for avg magnetic field direction. + dEdx = 1. / 6 / M_PI / epsilon0 * pow(lf * lf - 1, 2) * pow(charge / Rg, 2); // Jackson p. 770 (14.31) + dE = dEdx * step; + sync.process(&c); + EXPECT_NEAR(100 * GeV - c.current.getEnergy(), dE, 0.01 * dE); + + // 10 TeV + c.current.setEnergy(10 * TeV); + lf = c.current.getLorentzFactor(); + Rg = 10 * TeV / charge / c_light / (brms * sqrt(2. / 3) ); // factor 2/3 for avg magnetic field direction. + dEdx = 1. / 6 / M_PI / epsilon0 * pow(lf * lf - 1, 2) * pow(charge / Rg, 2); // Jackson p. 770 (14.31) + dE = dEdx * step; + sync.process(&c); + EXPECT_NEAR(10 * TeV - c.current.getEnergy(), dE, 0.01 * dE); + + // 1 PeV + c.current.setEnergy(1 * PeV); + lf = c.current.getLorentzFactor(); + Rg = 1 * PeV / charge / c_light / (brms * sqrt(2. / 3) ); // factor 2/3 for avg magnetic field direction. + dEdx = 1. / 6 / M_PI / epsilon0 * pow(lf * lf - 1, 2) * pow(charge / Rg, 2); // Jackson p. 770 (14.31) + dE = dEdx * step; + sync.process(&c); + EXPECT_NEAR(1 * PeV - c.current.getEnergy(), dE, 0.01 * dE); +} + + int main(int argc, char **argv) { ::testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS(); From 5246f37ec6e3acf4a307e2cdef66376875e790d5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?JulienD=C3=B6rner?= Date: Wed, 28 Aug 2024 09:49:23 +0200 Subject: [PATCH 4/6] add test for avg photon energy --- test/testInteraction.cpp | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/test/testInteraction.cpp b/test/testInteraction.cpp index 7d937ad05..0da78c795 100644 --- a/test/testInteraction.cpp +++ b/test/testInteraction.cpp @@ -1287,6 +1287,32 @@ TEST(SynchrotronRadiation, energyLoss) { EXPECT_NEAR(1 * PeV - c.current.getEnergy(), dE, 0.01 * dE); } +TEST(SynchrotronRadiation, PhotonEnergy) { + double brms = 1 * muG; + SynchrotronRadiation sync(brms, true); + sync.setSecondaryThreshold(0.); // allow all secondaries for testing + + double E = 1 * TeV; + Candidate c(11, E); + c.setCurrentStep(10 * pc); + c.setNextStep(10 * pc); + + double lf = c.current.getLorentzFactor(); + double Rg = E / eplus / c_light / (brms * sqrt(2. / 3) ); // factor 2/3 for avg magnetic field direction. + double Ecrit = 3. / 4 * h_planck / M_PI * c_light * pow(lf, 3) / Rg; + + sync.process(&c); + EXPECT_TRUE(c.secondaries.size() > 0); // must have secondaries + + // check avg energy of the secondary photons + double Esec = 0; + for (size_t i = 0; i < c.secondaries.size(); i++) { + Esec += c.secondaries[i] -> current.getEnergy(); + } + Esec /= c.secondaries.size(); + + EXPECT_NEAR(Esec, Ecrit, Ecrit); +} int main(int argc, char **argv) { ::testing::InitGoogleTest(&argc, argv); From 976d5a5204d28201669e520885b531eab4d5abc6 Mon Sep 17 00:00:00 2001 From: JulienDoerner <32195256+JulienDoerner@users.noreply.github.com> Date: Wed, 28 Aug 2024 10:16:44 +0200 Subject: [PATCH 5/6] Update testing_OSX.yml Move to gfortran-14. (see supported versions https://github.com/actions/runner-images/blob/main/images/macos/macos-14-Readme.md) --- .github/workflows/testing_OSX.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/testing_OSX.yml b/.github/workflows/testing_OSX.yml index ffc39046f..cd0eef5af 100644 --- a/.github/workflows/testing_OSX.yml +++ b/.github/workflows/testing_OSX.yml @@ -11,7 +11,7 @@ jobs: os: macos-14 cxx: "clang++" cc: "clang" - fc: "gfortran-11" + fc: "gfortran-14" swig_builtin: "On" #uses swig 4.0.2 py: "/usr/bin/python3" steps: From 69a7e09c156bfded9a595753aa38aba88eeaf206 Mon Sep 17 00:00:00 2001 From: JulienDoerner <32195256+JulienDoerner@users.noreply.github.com> Date: Wed, 28 Aug 2024 10:21:58 +0200 Subject: [PATCH 6/6] fix numpy version to 1.26 --- .github/workflows/testing_OSX.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/testing_OSX.yml b/.github/workflows/testing_OSX.yml index cd0eef5af..925b85c03 100644 --- a/.github/workflows/testing_OSX.yml +++ b/.github/workflows/testing_OSX.yml @@ -19,7 +19,8 @@ jobs: uses: actions/checkout@v4 - name: Preinstall run: | - brew install hdf5 fftw cfitsio muparser libomp numpy swig + brew install hdf5 fftw cfitsio muparser libomp swig + pip install numpy==1.26 - name: Set up the build env: CXX: ${{ matrix.config.cxx }}