SpECTRE  v2024.12.16
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Modules Pages
gr::Solutions::KerrSchild Class Reference

Kerr black hole in Kerr-Schild coordinates. More...

#include <KerrSchild.hpp>

Classes

struct  Center
 
class  IntermediateComputer
 
class  IntermediateVars
 
struct  internal_tags
 
struct  Mass
 
struct  Spin
 
struct  Velocity
 

Public Types

using options = implementation defined
 
template<typename DataType , typename Frame = Frame::Inertial>
using tags = implementation defined
 
template<typename DataType , typename Frame = ::Frame::Inertial>
using CachedBuffer = CachedTempBuffer< internal_tags::x_minus_center_unboosted< DataType, Frame >, internal_tags::x_minus_center< DataType, Frame >, internal_tags::a_dot_x< DataType >, internal_tags::a_dot_x_squared< DataType >, internal_tags::half_xsq_minus_asq< DataType >, internal_tags::r_squared< DataType >, internal_tags::r< DataType >, internal_tags::a_dot_x_over_rsquared< DataType >, internal_tags::deriv_log_r_denom< DataType >, internal_tags::deriv_log_r< DataType, Frame >, internal_tags::H_denom< DataType >, internal_tags::H< DataType >, internal_tags::deriv_H_temp1< DataType >, internal_tags::deriv_H_temp2< DataType >, internal_tags::deriv_H_unboosted< DataType, Frame >, internal_tags::deriv_H< DataType, Frame >, internal_tags::denom< DataType >, internal_tags::a_dot_x_over_r< DataType >, internal_tags::null_form_unboosted< DataType, Frame >, internal_tags::null_form< DataType, Frame >, internal_tags::deriv_null_form_unboosted< DataType, Frame >, internal_tags::deriv_null_form< DataType, Frame >, internal_tags::null_form_dot_deriv_H< DataType >, internal_tags::null_form_dot_deriv_null_form< DataType, Frame >, internal_tags::lapse_squared< DataType >, gr::Tags::Lapse< DataType >, internal_tags::deriv_lapse_multiplier< DataType >, internal_tags::shift_multiplier< DataType >, gr::Tags::Shift< DataType, 3, Frame >, DerivShift< DataType, Frame >, gr::Tags::SpatialMetric< DataType, 3, Frame >, gr::Tags::InverseSpatialMetric< DataType, 3, Frame >, DerivSpatialMetric< DataType, Frame >, ::Tags::dt< gr::Tags::SpatialMetric< DataType, 3, Frame > >, gr::Tags::ExtrinsicCurvature< DataType, 3, Frame >, gr::Tags::SpatialChristoffelFirstKind< DataType, 3, Frame >, gr::Tags::SpatialChristoffelSecondKind< DataType, 3, Frame > >
 
- Public Types inherited from gr::AnalyticSolution< 3_st >
using DerivLapse = ::Tags::deriv< gr::Tags::Lapse< DataType >, tmpl::size_t< volume_dim >, Frame >
 
using DerivShift = ::Tags::deriv< gr::Tags::Shift< DataType, volume_dim, Frame >, tmpl::size_t< volume_dim >, Frame >
 
using DerivSpatialMetric = ::Tags::deriv< gr::Tags::SpatialMetric< DataType, volume_dim, Frame >, tmpl::size_t< volume_dim >, Frame >
 
using tags = implementation defined
 

Public Member Functions

 KerrSchild (double mass, const std::array< double, 3 > &dimensionless_spin, const std::array< double, 3 > &center, const std::array< double, 3 > &boost_velocity={{0., 0., 0.}}, const Options::Context &context={})
 
 KerrSchild (CkMigrateMessage *)
 
 KerrSchild (const KerrSchild &)=default
 
KerrSchildoperator= (const KerrSchild &)=default
 
 KerrSchild (KerrSchild &&)=default
 
KerrSchildoperator= (KerrSchild &&)=default
 
template<typename DataType , typename Frame , typename... Tags>
tuples::TaggedTuple< Tags... > variables (const tnsr::I< DataType, volume_dim, Frame > &x, double, tmpl::list< Tags... >) const
 
void pup (PUP::er &p)
 
double mass () const
 
const std::array< double, volume_dim > & center () const
 
const std::array< double, volume_dim > & dimensionless_spin () const
 
const std::array< double, volume_dim > & boost_velocity () const
 
bool zero_spin () const
 
bool zero_velocity () const
 

Static Public Attributes

static constexpr Options::String help
 
- Static Public Attributes inherited from gr::AnalyticSolution< 3_st >
static constexpr size_t volume_dim
 

Detailed Description

Kerr black hole in Kerr-Schild coordinates.

Details

The metric is gμν=ημν+2Hlμlν, where ημν is the Minkowski metric, H is a scalar function, and lμ is the outgoing null vector. H and lμ are known functions of the coordinates and of the mass and spin vector.

The following are input file options that can be specified:

  • Mass (default: 1.)
  • Center (default: {0,0,0})
  • Spin (default: {0,0,0})

Kerr-Schild Coordinates

A Kerr-Schild coordinate system is defined by

(1)gμνημν+2Hlμlν,

where H is a scalar function of the coordinates, ημν is the Minkowski metric, and lμ is a null vector. Note that the form of the metric along with the nullness of lμ allows one to raise and lower indices of lμ using ημν, and that ltlt=ltlt=lili. Note also that

(2)gμνημν2Hlμlν,

and that g=1. Also, lμ is a geodesic with respect to both the physical metric and the Minkowski metric:

(3)lμμlν=lμμlν=0.

The corresponding 3+1 quantities are

(4)γij=δij+2Hlilj,(5)γij=δij2Hlilj1+2Hltlt,(6)detγij=1+2Hltlt,(7)k(detγij)=2ltltkH,(8)βi=2Hltli1+2Hltlt,(9)N=(1+2Hltlt)1/2,(lapse)(10)α=(1+2Hltlt)1,(densitized lapse)Kij=(1+2Hltlt)1/2[liljtH+2Hl(itlj)](11)2(1+2Hltlt)1/2[Hlt(ilj)+Hl(ij)lt+ltl(ij)H+2H2ltl(ilkklj)+HltliljlkkH],(12)kγij=2liljkH+4Hl(iklj),(13)kN=(1+2Hltlt)3/2(ltltkH+2Hltklt),(14)kβi=2(1+2Hltlt)1(ltlikH+Hltkli+Hliklt)+4Hltli(1+2Hltlt)2(ltltkH+2Hltklt),Γkij=δkm(liljmH+2l(imlj))+2Hl(ij)lk(15)+(1+2Hltlt)1[2lkl(ij)H+2HliljlklmmH+2Hlk(ilj)+4H2lkl(i(lmmlj)j)lt)].

Note that li is not equal to γijlj; it is equal to giμlμ.

Kerr Spacetime

Spin in the z direction

Assume Cartesian coordinates (t,x,y,z). Then for stationary Kerr spacetime with mass M and angular momentum aM in the z direction,

(16)H=Mr3r4+a2z2,(17)lμ=(1,rx+ayr2+a2,ryaxr2+a2,zr),

where r is defined by

(18)x2+y2a2+r2+z2r2=1,

or equivalently,

(19)r2=12(x2+y2+z2a2)+(14(x2+y2+z2a2)2+a2z2)1/2.

Possibly useful formula:

(20)ir=xi+zδiza2r22r(1x2+y2+z2a22r2).

Spin in an arbitrary direction

For arbitrary spin direction, let x(x,y,z) and a be a flat-space three-vector with magnitude-squared ( δij norm) equal to a2. Then the Kerr-Schild quantities for Kerr spacetime are:

(21)H=Mr3r4+(ax)2,(22)l=rxa×x+(ax)a/rr2+a2,(23)lt=1,(24)r2=12(xxa2)+(14(xxa2)2+(ax)2)1/2,

where l(lx,ly,lz), and all dot and cross products are evaluated as flat-space 3-vector operations.

Possibly useful formulae:

(25)ir=xi+(ax)ai/r22r(1xxa22r2),

(26)iHH=3irr4r3ir+2(ax)ar4+(ax)2,

(27)(r2+a2)jli=(xi2rli(ax)ai/r2)jr+rδij+aiaj/r+ϵijkak.

Cartesian and Spherical Coordinates for Kerr

The Kerr-Schild coordinates are defined in terms of the Cartesian coordinates (x,y,z). If one wishes to express Kerr-Schild coordinates in terms of the spherical polar coordinates (r~,θ,ϕ) then one can make the obvious and usual transformation

(28)x=r~sinθcosϕ,y=r~sinθsinϕ,z=r~cosθ.

This is simple, and has the advantage that in this coordinate system for M0, Kerr spacetime becomes Minkowski space in spherical coordinates (r~,θ,ϕ). However, the disadvantage is that the horizon of a Kerr hole is not located at constant r~, but is located instead at constant r, where r is the radial Boyer-Lindquist coordinate defined in ( 24).

For spin in the z direction, one could use the transformation

(29)x=r2+a2sinθcosϕ,y=r2+a2sinθsinϕ,z=rcosθ.

In this case, for M0, Kerr spacetime becomes Minkowski space in spheroidal coordinates, but now the horizon is on a constant-coordinate surface.

Right now we use ( 28), but we may wish to use the other transformation in the future.

Boost of the Kerr-Schild solution

We add initial momentum to the solution by applying a Lorentz boost to the metric. Since the Kerr-Schild metric can be expressed covariantly in terms of the Minkowski metric, a scalar function and a one form, we construct the metric in the rest frame of the black hole and then apply an inverse boost to each of the covariant objects individually. Notice that we also need to appropriately boost the coordinates to the to the rest frame before computing the metric.

Warning
While technically the boosted Kerr-Schild metric is dependent on both the time and space coordinates, we have implemented it only at t=0 as in SpEC. Therefore it is technically not an analytic solution and should not be used to compute errors with respect to it.

Moreover, since the boosted solution is intended for use as initial data, we do not compute the time derivatives of the lapse and shift in the boosted frame but set them to zero.

Consequently, the gr::Tags::SpacetimeChristoffelSecondKind computed here, corresponds to the boosted Kerr-Schild for the gauge where lapse and shift have vanishing derivatives.

Member Data Documentation

◆ help

constexpr Options::String gr::Solutions::KerrSchild::help
staticconstexpr
Initial value:
{
"Black hole in Kerr-Schild coordinates"}

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