Skip to content

Commit

Permalink
Merge branch 'dev' of github:afd-illinois/kharma into dev
Browse files Browse the repository at this point in the history
  • Loading branch information
Ben Prather committed Dec 8, 2023
2 parents b7cde8f + 4c53502 commit fc4689f
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 0 deletions.
32 changes: 32 additions & 0 deletions kharma/emhd/emhd.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -181,6 +181,38 @@ std::shared_ptr<KHARMAPackage> Initialize(ParameterInput *pin, std::shared_ptr<P
return pkg;
}

void MeshUtoP(MeshData<Real> *md, IndexDomain domain, bool coarse)
{
auto pmb = md->GetBlockData(0)->GetBlockPointer();

// Get only relevant cons, but all prims as we need the Lorentz factor
PackIndexMap prims_map, cons_map;
auto U_E = md->PackVariables(std::vector<MetadataFlag>{Metadata::GetUserFlag("EMHDVar"), Metadata::Conserved}, cons_map);
auto P = md->PackVariables(std::vector<MetadataFlag>{Metadata::GetUserFlag("Primitive")}, prims_map);
const VarMap m_p(prims_map, false), m_u(cons_map, true);

const auto& G = pmb->coords;

auto bounds = coarse ? pmb->c_cellbounds : pmb->cellbounds;
IndexRange ib = bounds.GetBoundsI(domain);
IndexRange jb = bounds.GetBoundsJ(domain);
IndexRange kb = bounds.GetBoundsK(domain);
IndexRange block = IndexRange{0, U_E.GetDim(5)-1};

pmb->par_for("UtoP_EMHD", block.s, block.e, kb.s, kb.e, jb.s, jb.e, ib.s, ib.e,
KOKKOS_LAMBDA (const int& b, const int &k, const int &j, const int &i) {
const Real gamma = GRMHD::lorentz_calc(G, P(b), m_p, k, j, i, Loci::center);
const Real inv_alpha = m::sqrt(-G.gcon(Loci::center, j, i, 0, 0));
const Real ucon0 = gamma * inv_alpha;

// Update the primitive EMHD fields
if (m_p.Q >= 0)
P(b, m_p.Q, k, j, i) = U_E(b, m_u.Q, k, j, i) / (ucon0 * G.gdet(Loci::center, j, i));
if (m_p.DP >= 0)
P(b, m_p.DP, k, j, i) = U_E(b, m_u.DP, k, j, i) / (ucon0 * G.gdet(Loci::center, j, i));
}
);
}
void BlockUtoP(MeshBlockData<Real> *rc, IndexDomain domain, bool coarse)
{
auto pmb = rc->GetBlockPointer();
Expand Down
1 change: 1 addition & 0 deletions kharma/emhd/emhd.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@ void InitEMHDVariables(std::shared_ptr<MeshBlockData<Real>>& rc, ParameterInput
* only on boundaries in order to sync the primitive/conserved variables specifically.
*/
void BlockUtoP(MeshBlockData<Real> *rc, IndexDomain domain, bool coarse);
void MeshUtoP(MeshData<Real> *md, IndexDomain domain, bool coarse=false);
void BlockPtoU(MeshBlockData<Real> *rc, IndexDomain domain, bool coarse);

/**
Expand Down
4 changes: 4 additions & 0 deletions kharma/prob/post_initialize.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@
#include "b_flux_ct.hpp"
#include "blob.hpp"
#include "boundaries.hpp"
#include "emhd.hpp"
#include "floors.hpp"
#include "flux.hpp"
#include "gr_coordinates.hpp"
Expand Down Expand Up @@ -116,6 +117,9 @@ void KHARMA::PostInitialize(ParameterInput *pin, Mesh *pmesh, bool is_restart)
} else if (pkgs.count("B_CT")) {
B_CT::MeshUtoP(md.get(), IndexDomain::entire);
}
if (pkgs.count("EMHD")) {
EMHD::MeshUtoP(md.get(), IndexDomain::entire);
}
} else {
if (pkgs.count("B_FluxCT")) {
B_FluxCT::MeshPtoU(md.get(), IndexDomain::entire);
Expand Down

0 comments on commit fc4689f

Please sign in to comment.