From ca1fda7da831e82cf84c725794163c74de87e747 Mon Sep 17 00:00:00 2001 From: Eya Dammak Date: Thu, 19 Dec 2024 16:28:06 +0100 Subject: [PATCH] adding the circular polarization case --- src/laser/MultiLaser.H | 3 +++ src/particles/plasma/PlasmaParticleContainer.cpp | 8 +++++++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/src/laser/MultiLaser.H b/src/laser/MultiLaser.H index 29f8616be8..781ca128da 100644 --- a/src/laser/MultiLaser.H +++ b/src/laser/MultiLaser.H @@ -171,6 +171,9 @@ public: /** Get the geometry of the Laser Box */ const amrex::Geometry& GetLaserGeom () const { return m_laser_geom_3D; } + /** If the polarization is linear or circular */ + bool LinearPolarization () const { return m_linear_polarization; } + /** If the laser geometry includes this slice * \param[in] islice slice index */ diff --git a/src/particles/plasma/PlasmaParticleContainer.cpp b/src/particles/plasma/PlasmaParticleContainer.cpp index 187b47d91f..0cd912f2ec 100644 --- a/src/particles/plasma/PlasmaParticleContainer.cpp +++ b/src/particles/plasma/PlasmaParticleContainer.cpp @@ -503,6 +503,7 @@ LaserIonization (const int islice, wp * PhysConstSI::m_e * PhysConstSI::c / PhysConstSI::q_e : 1; const amrex::Real lambda0 = laser.GetLambda0(); const amrex::Real omega0 = 2.0 * MathConst::pi * phys_const.c / lambda0; + const bool linear_polarization = laser.LinearPolarization(); int * const ion_lev = soa_ion.GetIntData(PlasmaIdx::ion_lev).data(); const amrex::Real * const x_prev = soa_ion.GetRealData(PlasmaIdx::x_prev).data(); @@ -570,7 +571,12 @@ LaserIonization (const int islice, std::pow(Ep, adk_power[ion_lev_loc]) * std::exp( adk_exp_prefactor[ion_lev_loc]/Ep ); - amrex::Real w_dtau_ac = w_dtau_dc * std::sqrt(Ep * laser_adk_prefactor[ion_lev_loc]); + amrex::Real w_dtau_ac; + if (linear_polarization) { + w_dtau_ac = w_dtau_dc * std::sqrt(Ep * laser_adk_prefactor[ion_lev_loc]); + } else { + w_dtau_ac = w_dtau_dc; + } amrex::Real p = 1._rt - std::exp( - w_dtau_ac );