SpECTRE  v2024.03.19
ah::ComputeHorizonVolumeQuantities Struct Reference

Given the generalized harmonic variables in the volume, computes the quantities that will be interpolated onto an apparent horizon. More...

#include <ComputeHorizonVolumeQuantities.hpp>

Public Types

using allowed_src_tags = tmpl::list< gr::Tags::SpacetimeMetric< DataVector, 3 >, gh::Tags::Pi< DataVector, 3 >, gh::Tags::Phi< DataVector, 3 >, ::Tags::deriv< gh::Tags::Phi< DataVector, 3 >, tmpl::size_t< 3 >, Frame::Inertial > >
 
using required_src_tags = tmpl::list< gr::Tags::SpacetimeMetric< DataVector, 3 >, gh::Tags::Pi< DataVector, 3 >, gh::Tags::Phi< DataVector, 3 > >
 
template<typename TargetFrame >
using allowed_dest_tags_target_frame = tmpl::list< gr::Tags::SpatialMetric< DataVector, 3, TargetFrame >, gr::Tags::InverseSpatialMetric< DataVector, 3, TargetFrame >, gr::Tags::ExtrinsicCurvature< DataVector, 3, TargetFrame >, gr::Tags::SpatialChristoffelSecondKind< DataVector, 3, TargetFrame >, gr::Tags::SpatialRicci< DataVector, 3, TargetFrame > >
 
template<typename TargetFrame >
using allowed_dest_tags = tmpl::remove_duplicates< tmpl::append< allowed_dest_tags_target_frame< TargetFrame >, allowed_dest_tags_target_frame< Frame::Inertial > > >
 
template<typename TargetFrame >
using required_dest_tags = tmpl::list< gr::Tags::ExtrinsicCurvature< DataVector, 3, TargetFrame >, gr::Tags::SpatialChristoffelSecondKind< DataVector, 3, TargetFrame > >
 

Static Public Member Functions

template<typename SrcTagList , typename DestTagList >
static void apply (const gsl::not_null< Variables< DestTagList > * > target_vars, const Variables< SrcTagList > &src_vars, const Mesh< 3 > &mesh)
 Single-frame case.
 
template<typename SrcTagList , typename DestTagList , typename TargetFrame >
static void apply (const gsl::not_null< Variables< DestTagList > * > target_vars, const Variables< SrcTagList > &src_vars, const Mesh< 3 > &mesh, const Jacobian< DataVector, 3, TargetFrame, Frame::Inertial > &jac_target_to_inertial, const InverseJacobian< DataVector, 3, TargetFrame, Frame::Inertial > &invjac_target_to_inertial, const Jacobian< DataVector, 3, Frame::ElementLogical, TargetFrame > &jac_logical_to_target, const InverseJacobian< DataVector, 3, Frame::ElementLogical, TargetFrame > &invjac_logical_to_target, const tnsr::I< DataVector, 3, Frame::Inertial > &inertial_mesh_velocity, const tnsr::I< DataVector, 3, TargetFrame > &grid_to_target_frame_mesh_velocity)
 Dual-frame case.
 

Detailed Description

Given the generalized harmonic variables in the volume, computes the quantities that will be interpolated onto an apparent horizon.

This is meant to be the primary compute_vars_to_interpolate for the horizon finder. Conforms to the intrp::protocols::ComputeVarsToInterpolate protocol

SrcTagList and DestTagList have limited flexibility, and their restrictions are static_asserted inside the apply functions. The lack of complete flexibility is intentional, because most computations (e.g. for observers) should be done only on the horizon surface (i.e. after interpolation) as opposed to in the volume; only those computations that require data in the volume (e.g. volume numerical derivatives) should be done here.

For the dual-frame case, numerical derivatives of Jacobians are taken in order to avoid Hessians.

SrcTagList is usually interpolator_source_vars in the Metavariables, and the allowed and required tags in SrcTagList are given by the type aliases allowed_src_tags and required_src_tags below.

DestTagList is usually vars_to_interpolate_to_target in the InterpolationTarget that uses ComputeHorizonVolumeQuantities. The allowed and required tags in DestTagList are given by the type aliases allowed_dest_tags and required_dest_tags below.


The documentation for this struct was generated from the following file: