From 7daa74ecb024f9db81031234423e0775c8a71be5 Mon Sep 17 00:00:00 2001 From: Sophie Aerdker Date: Wed, 4 Oct 2023 10:54:15 +0200 Subject: [PATCH 1/3] added 1D and 2D oblique shock profiles --- .../crpropa/advectionField/AdvectionField.h | 98 +++++++- src/advectionField/AdvectionField.cpp | 211 ++++++++++++++++++ 2 files changed, 303 insertions(+), 6 deletions(-) diff --git a/include/crpropa/advectionField/AdvectionField.h b/include/crpropa/advectionField/AdvectionField.h index 9d6a71bc5..ee450a954 100644 --- a/include/crpropa/advectionField/AdvectionField.h +++ b/include/crpropa/advectionField/AdvectionField.h @@ -128,6 +128,96 @@ class SphericalAdvectionField: public AdvectionField { std::string getDescription() const; }; +/** + @class 1DAdvectionShock + @brief Advection field in x-direction with shock at x = 0 and width x_sh approximated by tanh() + with variable compression ratio r_comp = v_up/v_down + */ +class OneDimensionalAdvectionShock: public AdvectionField { + double r_comp; //compression ratio of shock + double v_up; //upstream velocity + double x_sh; //shock width +public:/** Constructor + @param r_comp //compression ratio of shock + @param v_up //upstream velocity + @param x_sh //shock width +*/ + OneDimensionalAdvectionShock(double r_comp, double v_up, double x_sh); + Vector3d getField(const Vector3d &position) const; + double getDivergence(const Vector3d &position) const; + + void setComp(double r_comp); + void setVup(double v_up); + void setShockwidth(double x_sh); + + + std::string getDescription() const; +}; + +/** + @class 1DSphericalShock + @brief Advection field in r-direction with shock at r_sh and width l_sh approximated by tanh() + with variable compression ratio r_comp = v_up/v_down + */ +class OneDimensionalSphericalShock: public AdvectionField { + double r_comp; //compression ratio of shock + double v_up; //upstream velocity + double l_sh; //shock width + double r_sh; //shock radius + bool cool_ups; //flag for upstream cooling +public:/** Constructor + @param r_comp //compression ratio of shock + @param v_up //upstream velocity + @param l_sh //shock width + @param r_sh //shock radius + @param cool_ups //flag for upstream cooling +*/ + OneDimensionalSphericalShock(double r_sh, double v_up, double q, double l_sh, bool cool_ups); + Vector3d getField(const Vector3d &position) const; + double getDivergence(const Vector3d &position) const; + + void setComp(double q); + void setVup(double v_up); + void setShockwidth(double l_sh); + void setShockRadius(double r_sh); + void setCooling(bool cool_ups); + + std::string getDescription() const; +}; + +/** + @class ObliqueAdvectionShock + @brief Advection field in x-y-direction with shock at x = 0 and width x_sh approximated by tanh() + with variable compression ratio r_comp = vx_up/vx_down. The y component vy is not shocked + and remains constant. + */ +class ObliqueAdvectionShock: public AdvectionField { + double r_comp; //compression ratio of shock + double vx_up; //upstream velocity x-component + double vy; //constant velocity y-component + double x_sh; //shock width + +public:/** Constructor + @param r_comp //compression ratio of shock + @param vx_up //upstream velocity x-component + @param vy //constant velocity y-component + @param x_sh //shock width + +*/ + ObliqueAdvectionShock(double r_comp, double vx_up, double vy, double x_sh); + Vector3d getField(const Vector3d &position) const; + double getDivergence(const Vector3d &position) const; + + void setComp(double r_comp); + void setVup(double vx_up); + void setVy(double vy); + void setShockwidth(double x_sh); + + + std::string getDescription() const; +}; + +/** /** @class SphericalAdvectionShock @@ -150,6 +240,8 @@ class SphericalAdvectionShock: public AdvectionField { @param r_0 Position of the shock @param v_0 Constant velocity (r< Date: Fri, 6 Oct 2023 14:32:21 +0200 Subject: [PATCH 2/3] fix intendation, whitespaces and variable names, according to JD comments --- .../crpropa/advectionField/AdvectionField.h | 123 ++++++---- src/advectionField/AdvectionField.cpp | 218 ++++++++++-------- 2 files changed, 200 insertions(+), 141 deletions(-) diff --git a/include/crpropa/advectionField/AdvectionField.h b/include/crpropa/advectionField/AdvectionField.h index ee450a954..6002ced97 100644 --- a/include/crpropa/advectionField/AdvectionField.h +++ b/include/crpropa/advectionField/AdvectionField.h @@ -129,58 +129,69 @@ class SphericalAdvectionField: public AdvectionField { }; /** - @class 1DAdvectionShock - @brief Advection field in x-direction with shock at x = 0 and width x_sh approximated by tanh() - with variable compression ratio r_comp = v_up/v_down + @class OneDimensionalCartesianShock + @brief Advection field in x-direction with shock at x = 0 and width lShock approximated by tanh() + with variable compression ratio vUp/vDown */ -class OneDimensionalAdvectionShock: public AdvectionField { - double r_comp; //compression ratio of shock - double v_up; //upstream velocity - double x_sh; //shock width -public:/** Constructor - @param r_comp //compression ratio of shock - @param v_up //upstream velocity - @param x_sh //shock width +class OneDimensionalCartesianShock: public AdvectionField { + double compressionRatio; //compression ratio of shock + double vUp; //upstream velocity + double lShock; //shock width +public: +/** Constructor + @param compressionRatio //compression ratio of shock + @param vUpstream //upstream velocity + @param lShock //shock width */ - OneDimensionalAdvectionShock(double r_comp, double v_up, double x_sh); + OneDimensionalCartesianShock(double compressionRatio, double vUp, double lShock); Vector3d getField(const Vector3d &position) const; double getDivergence(const Vector3d &position) const; - void setComp(double r_comp); - void setVup(double v_up); - void setShockwidth(double x_sh); + void setComp(double compressionRatio); + void setVup(double vUp); + void setShockwidth(double lShock); + double getComp() const; + double getVup() const; + double getShockwidth() const; std::string getDescription() const; }; /** - @class 1DSphericalShock - @brief Advection field in r-direction with shock at r_sh and width l_sh approximated by tanh() - with variable compression ratio r_comp = v_up/v_down + @class OneDimensionalSphericalShock + @brief Advection field in x-direction with shock at rShock and width lShock approximated by tanh() + with variable compression ratio ratio vUp/vDown */ class OneDimensionalSphericalShock: public AdvectionField { - double r_comp; //compression ratio of shock - double v_up; //upstream velocity - double l_sh; //shock width - double r_sh; //shock radius - bool cool_ups; //flag for upstream cooling -public:/** Constructor - @param r_comp //compression ratio of shock - @param v_up //upstream velocity - @param l_sh //shock width - @param r_sh //shock radius - @param cool_ups //flag for upstream cooling + double compressionRatio; //compression ratio of shock + double vUp; //upstream velocity + double lShock; //shock width + double rShock; //shock radius + bool coolUpstream; //flag for upstream cooling +public: +/** Constructor + @param compressionRatio //compression ratio of shock + @param vUp //upstream velocity + @param lShock //shock width + @param rShock //shock radius + @param coolUpstream //flag for upstream cooling */ - OneDimensionalSphericalShock(double r_sh, double v_up, double q, double l_sh, bool cool_ups); + OneDimensionalSphericalShock(double rShock, double vUp, double compressionRatio, double lShock, bool coolUpstream); Vector3d getField(const Vector3d &position) const; double getDivergence(const Vector3d &position) const; - void setComp(double q); - void setVup(double v_up); - void setShockwidth(double l_sh); - void setShockRadius(double r_sh); - void setCooling(bool cool_ups); + void setComp(double compressionRatio); + void setVup(double vUp); + void setShockwidth(double lShock); + void setShockRadius(double rShock); + void setCooling(bool coolUpstream); + + double getComp() const; + double getVup() const; + double getShockwidth() const; + double getShockRadius() const; + double getCooling() const; std::string getDescription() const; }; @@ -192,28 +203,33 @@ class OneDimensionalSphericalShock: public AdvectionField { and remains constant. */ class ObliqueAdvectionShock: public AdvectionField { - double r_comp; //compression ratio of shock - double vx_up; //upstream velocity x-component - double vy; //constant velocity y-component - double x_sh; //shock width + double compressionRatio; //compression ratio of shock + double vXUp; //upstream velocity x-component + double vY; //constant velocity y-component + double lShock; //shock width -public:/** Constructor - @param r_comp //compression ratio of shock - @param vx_up //upstream velocity x-component - @param vy //constant velocity y-component - @param x_sh //shock width +public: +/** Constructor + @param compressionRatio //compression ratio of shock + @param vXUp //upstream velocity x-component + @param vY //constant velocity y-component + @param lShock //shock width */ - ObliqueAdvectionShock(double r_comp, double vx_up, double vy, double x_sh); + ObliqueAdvectionShock(double compressionRatio, double vXUp, double vY, double lShock); Vector3d getField(const Vector3d &position) const; double getDivergence(const Vector3d &position) const; - void setComp(double r_comp); - void setVup(double vx_up); - void setVy(double vy); - void setShockwidth(double x_sh); - + void setComp(double compressionRatio); + void setVup(double vXUp); + void setVy(double vY); + void setShockwidth(double lShock); + double getComp() const; + double getVup() const; + double getVy() const; + double getShockwidth() const; + std::string getDescription() const; }; @@ -240,7 +256,6 @@ class SphericalAdvectionShock: public AdvectionField { @param r_0 Position of the shock @param v_0 Constant velocity (r< Date: Mon, 9 Oct 2023 10:06:18 +0200 Subject: [PATCH 3/3] corrected typo in get-function and comments --- include/crpropa/advectionField/AdvectionField.h | 7 ++----- src/advectionField/AdvectionField.cpp | 2 +- 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/include/crpropa/advectionField/AdvectionField.h b/include/crpropa/advectionField/AdvectionField.h index 6002ced97..2c9a2494a 100644 --- a/include/crpropa/advectionField/AdvectionField.h +++ b/include/crpropa/advectionField/AdvectionField.h @@ -140,7 +140,7 @@ class OneDimensionalCartesianShock: public AdvectionField { public: /** Constructor @param compressionRatio //compression ratio of shock - @param vUpstream //upstream velocity + @param vUp //upstream velocity @param lShock //shock width */ OneDimensionalCartesianShock(double compressionRatio, double vUp, double lShock); @@ -191,7 +191,7 @@ class OneDimensionalSphericalShock: public AdvectionField { double getVup() const; double getShockwidth() const; double getShockRadius() const; - double getCooling() const; + bool getCooling() const; std::string getDescription() const; }; @@ -233,8 +233,6 @@ class ObliqueAdvectionShock: public AdvectionField { std::string getDescription() const; }; -/** - /** @class SphericalAdvectionShock @brief Spherical advection with a constant velocity for r