From cbd8acf745bd5bc3eb2579a22a4af4918ec44132 Mon Sep 17 00:00:00 2001 From: Julien Lamy Date: Mon, 27 Nov 2023 14:36:20 +0100 Subject: [PATCH] Fix crash when creating two pools model --- src/sycomore/epg/Model.cpp | 41 +++++++++++++++++++++++++------------- src/sycomore/epg/Model.h | 3 ++- 2 files changed, 29 insertions(+), 15 deletions(-) diff --git a/src/sycomore/epg/Model.cpp b/src/sycomore/epg/Model.cpp index 3a333b8..da730d0 100644 --- a/src/sycomore/epg/Model.cpp +++ b/src/sycomore/epg/Model.cpp @@ -24,7 +24,7 @@ ::Model( species({species}), M0(pools), k(0), delta_b(0*units::Hz), F(pools), F_star(pools), Z(pools) { - this->_initialize({M0}, initial_size); + this->_initialize(M0, initial_size); } Model @@ -37,7 +37,7 @@ ::Model( species({species_a, species_b}), M0(pools), k(pools), delta_b(delta_b), F(pools), F_star(pools), Z(pools) { - this->_initialize({M0_a, M0_b}, initial_size); + this->_initialize(M0_a, M0_b, initial_size); this->k = { k_a, this->M0[1]!=0. ? k_a*this->M0[0]/this->M0[1] : 0.*units::Hz}; } @@ -53,7 +53,7 @@ ::Model( M0(pools), k(pools), delta_b(0*units::Hz), F(pools), F_star(pools), Z(pools) { - this->_initialize({M0_a, M0_b}, initial_size); + this->_initialize(M0_a, M0_b, initial_size); this->k = { k_a, this->M0[1]!=0. ? k_a*this->M0[0]/this->M0[1] : 0.*units::Hz}; } @@ -100,7 +100,7 @@ ::operator=(Model && other) void Model -::_initialize(std::vector const & M0, std::size_t initial_size) +::_initialize(Vector3R const & M0, std::size_t initial_size) { for(auto & item: this->F) { @@ -115,16 +115,29 @@ ::_initialize(std::vector const & M0, std::size_t initial_size) item.resize(initial_size); } - for(std::size_t i=0; ipools; ++i) - { - auto const M_plus = Complex(M0[i][0], M0[i][1]); - auto const M_minus = Complex(M0[i][0], -M0[i][1]); - - this->F[i][0] = M_plus; - this->F_star[i][0] = M_minus; - this->Z[i][0] = M0[i][2]; - this->M0[i] = M0[i][2]; - } + auto const M_plus = Complex(M0[0], M0[1]); + auto const M_minus = Complex(M0[0], -M0[1]); + + this->F[0][0] = M_plus; + this->F_star[0][0] = M_minus; + this->Z[0][0] = M0[2]; + this->M0[0] = M0[2]; +} + +void +Model +::_initialize( + Vector3R const & M0_a, Vector3R const & M0_b, std::size_t initial_size) +{ + this->_initialize(M0_a, initial_size); + + auto const M_plus = Complex(M0_b[0], M0_b[1]); + auto const M_minus = Complex(M0_b[0], -M0_b[1]); + + this->F[1][0] = M_plus; + this->F_star[1][0] = M_minus; + this->Z[1][0] = M0_b[2]; + this->M0[1] = M0_b[2]; } } diff --git a/src/sycomore/epg/Model.h b/src/sycomore/epg/Model.h index 4ca21ea..17050bb 100644 --- a/src/sycomore/epg/Model.h +++ b/src/sycomore/epg/Model.h @@ -81,8 +81,9 @@ class Model Model & operator=(Model && other); private: + void _initialize(Vector3R const & M0, std::size_t initial_size); void _initialize( - std::vector const & M0, std::size_t initial_size); + Vector3R const & M0_a, Vector3R const & M0_b, std::size_t initial_size); }; }