Next Article in Journal
Improved Galaxy Morphology Classification with Convolutional Neural Networks
Next Article in Special Issue
Theoretical Perspectives on Viscous Nature of Strongly Interacting Systems
Previous Article in Journal
Detectors and Shieldings: Past and Future at LUNA
Previous Article in Special Issue
Transport Coefficients of Relativistic Matter: A Detailed Formalism with a Gross Knowledge of Their Magnitude
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

The Parallel Compact Object CALculator: An Efficient General Relativistic Initial Data Solver for Compact Objects

1
LAB Scientific Computing Inc., Miami, FL 33176, USA
2
Department of Physics, University of Illinois at Urbana-Champaign, Urbana, IL 61801, USA
3
National Center for Supercomputing Applications, University of Illinois at Urbana-Champaign, Urbana, IL 61801, USA
4
Research Center for Astronomy and Applied Mathematics, Academy of Athens, 11527 Athens, Greece
5
Department of Physics, University of the Ryukyus, Senbaru, Nishihara 903-0213, Okinawa, Japan
*
Author to whom correspondence should be addressed.
Universe 2024, 10(5), 229; https://doi.org/10.3390/universe10050229
Submission received: 22 March 2024 / Revised: 27 April 2024 / Accepted: 7 May 2024 / Published: 20 May 2024

Abstract

:
Every numerical general relativistic investigation starts from the solution of the initial value equations at a given time. Astrophysically relevant initial values for different systems lead to distinct sets of equations that obey specific assumptions tied to the particular problem. Therefore, a robust and efficient solver for a variety of strongly gravitating sources is needed. In this work, we present the OpenMP version of the Compact Object CALculator (COCAL) on shared memory processors. We performed extensive profiling of the core COCAL modules in order to identify bottlenecks in efficiency, which we addressed. Using modest resources, the new parallel code achieves speedups of approximately one order of magnitude relative to the original serial COCAL code, which is crucial for parameter studies of computationally expensive systems such as magnetized neutron stars, as well as its further development towards more realistic scenarios. As a novel example of our new code, we compute a binary quark system where each companion has a dimensionless spin of 0.43 aligned with the orbital angular momentum.

1. Introduction

Gravitational wave astronomy was launched in 2015 with the first-ever gravitational wave detection of the inspiral and merger from a binary black hole system, as reported by the LIGO scientific collaboration—event GW150914 [1]. Two years later, the simultaneous detection of gravitational waves from an inspiraling binary neutron star system, event GW170817, and its postmerger emission of electromagnetic radiation spurred the era of multimessenger astronomy [2,3,4,5,6]. Merging binary neutron stars and black hole–neutron stars are not only important sources of gravitational radiation, but also promising candidates for coincident electromagnetic counterparts, which could give new insight into their sources. To understand these observations and, in particular, to understand the physics of matter under extreme conditions, it is crucial to compare them with predictions from theoretical modeling which, due to the complexity of the underlying physical phenomena, are largely numerical in nature.
Numerical modeling of strongly gravitating systems typically involves two steps: first, the ab initio calculation of the initial values that describe the astrophysical system at a given time; and second, the evolution of these initial data in order to describe it at later times. These two general relativistic calculations involve two distinct codes: one that solves the elliptic problem to find out the initial data and another that solves the hyperbolic one that simulates their evolution. For these reasons, we have developed the Compact Object CALculator (COCAL) code, which is a serial code that solves for any compact object in equilibrium or quasiequilibrim in a variety of settings and/or mathematical formulations. In particular, COCAL has been used to calculate: (i) rotating neutron stars and quark stars (axisymmetric or triaxial, uniformly or differentially rotating) [7,8,9,10,11,12]; (ii) binary black holes in quasicircular orbits [13,14,15]; (iii) binary neutron stars and quark stars (irrotational or spinning) in quasicircular orbits [16,17]; (iv) magnetized rotating neutron stars with generic mixed poloidal and toroidal magnetic fields and a magnetosphere [18,19,20]; and (v) self-gravitating, tilted black hole-disks (where the angular momentum of the disk is tilted with respect to the angular momentum of the black hole) [21]. The main characteristics of the COCAL code is the use of finite differences and a Green’s function approach, as first developed in [22] for neutron stars and in [23] for black holes, to achieve a convergent solution through a Picard type of iteration, known as the Komatsu–Eriguchi–Hachisu (KEH) method [24,25]. The field equations are solved in spherical coordinates in multiple patches, and a smooth solution is obtained everywhere through boundary surface integrals. For the fluid equations, surface-fitted coordinates are being implemented that allow for an accurate representation of the neutron star surface, which is important in order to impose boundary conditions.
Similar to COCAL, there are a number of other codes whose purposes are to solve for initial data in general relativity. For binary as well as single compact object codes, these include the TwoPunctures [26], LORENE [27], KADATH/FUKA [28,29,30], SGRID [31], Spells [32], Elliptica [33], and NRPyElliptic [34] codes. Each code uses its own numerical methods, and depending on the problem, it may use different mathematical formulations too.
Compact systems (i)–(v) employ different mathematical formulations that nevertheless share common characteristics. For example, one well-known method for the calculation of initial data [35] is the Isenberg–Wilson–Mathews (IWM) [36,37,38,39] formulation, where the spatial three-dimensional metric is assumed to be conformally flat and the trace of the extrinsic curvature is zero. This method is applied from rotating neutron/quark stars [7,11] to binary black holes [13,14,15] and binary neutron stars [16,17] and results in five elliptic equations, i.e., a truncated system of the Einstein field equations. Notwithstanding the approximate nature of the method, its robustness and accuracy (especially for neutron stars) make the IWM method a workhorse in initial data construction. On the other hand, more intricate methods have been developed that can treat the full Einstein system, both for neutron stars and black holes. In [8], rotating axisymmetric or triaxial neutron stars were computed using the waveless method [40,41], while in [18,19,20], this method was employed to calculate generic magnetized equilibria with mixed poloidal and toroidal magnetic fields as well as a force-free magnetosphere. In [42,43], the same method was used to compute binary neutron stars in quasicircular orbits. This method is referred to as the “waveless” formulation. For spacetimes that contain a black hole, a new method has been developed in [21] that solves the complete initial data equations. Contrary to the IWM method, the formulations that try to address the whole Einstein system [21,40] result to a significantly larger number of elliptic equations. For neutron star spacetimes [40], we have fourteen nonlinear Poisson-like equations, with four of them resulting from imposing gauge conditions. For black hole spacetimes, we have a total of seventeen equations, with four of them resulting from imposing gauge conditions and another three being used for an additional decomposition of the extrinsic curvature [21]. The inclusion of magnetohydrodynamics will increase the total number of elliptic equations to be solved even more. Therefore, it is evident that in order to be able to study these astrophysically realistic systems in a systematic manner, an efficient parallelization scheme for the COCAL code needs to be developed.
In this paper, we present the OpenMP version of the COCAL code, which we call the Parallel Compact Object CALculator or PCOCAL for short. For the first time, we have systematically analyzed the whole serial COCAL code and identified the bottlenecks both for single objects (e.g., rotating neutron stars) as well as for binaries (e.g., binary neutron stars) using either the IWM or the waveless formulation. In order to implement the OpenMP directives for parallelization, we had to revise and sometimes completely rewrite many of the original subroutines. Using modest resources of 30–40 cores, both the single rotating neutron star module as well as the binary neutron star one achieve a speedup of an order of magnitude. In the binary case, we observed a smaller speedup than in the single star case, mainly due to the communication between different coordinate systems, which is absent in the latter calculation. As an application of our new code, we computed for the first time a spinning binary quark star system where each companion has a dimensionless spin of 0.43 aligned with the orbital angular momentum.
In the equations presented, Greek indices are taken to run from 0 to 3 while Latin indices run from 1 to 3. We use a signature ( , + , + , + ) for the spacetime line element and a system of units in which c = G = M = 1 (unless explicitly shown).

2. The Initial Value Equations

In this section, we summarize the 3 + 1 decomposition of Einstein’s equations for two representative problems that will be discussed below: (i) single rotating neutron stars in the waveless formalism [8,40] and (ii) spinning binary neutron stars in the IWM formalism [16,17]. While details on these methods can be found in the aforementioned papers, here we provide a broad overview of the equations that need to be solved in order to discuss the time footprint of each one in the iteration procedure, the possible bottlenecks with the parallelization, and the optimizations we perform.
We assume that a spacetime M is foliated by a family of space-like hypersurfaces Σ t , parametrized by a time coordinate t R as M = R × Σ t . The future-pointing unit normal one form to Σ t , n α = α α t , is related to the generator of time translations t α as
t α : = α n α + β α ,
where t α α t = 1 . Here, α and β α are, respectively, the lapse function and the shift vector, which is spatial, β α α t = 0 . The projection tensor γ β α to Σ t is introduced as γ β α : = g β α + n α n β . The induced spatial metric g i j on Σ t is the projection tensor restricted to it. By introducing a conformal spatial geometry with spatial metric γ ˜ i j = ψ 4 γ i j , where ψ is the conformal factor, we can write the line element on a chart { t , x i } of Σ t as
d s 2 = α 2 d t 2 + ψ 4 γ ˜ i j ( d x i + β i d t ) ( d x j + β j d t ) .
The conformal rescaling is determined from a condition γ ˜ = f , where γ ˜ and f are determinants of the rescaled spatial metric γ ˜ i j and the flat metric f i j , respectively. We denote by h i j and h i j the differences between the conformal and flat metric
γ ˜ i j : = f i j + h i j , γ ˜ i j : = f i j + h i j .
The extrinsic curvature of each slice Σ t is defined by
K i j = 1 2 L n γ i j
where L n is the Lie derivative along the normal vector on Σ t . Hereafter, we denote the trace of K i j by K and the trace-free part of K i j by A i j : = K i j 1 3 γ i j K . We define the conformal extrinsic curvature A ˜ i j = ψ 4 A i j , similar to the conformal spatial metric.
In this paper, we consider perfect fluid spacetimes, whose stress–energy tensor is written as
T α β = ( ϵ + p ) u α u β + p g α β ,
where ϵ is the energy density and p is the pressure as measured by the co-moving observer, i.e., an observer with 4-velocity u α . As discussed in [18,19], in the case where we have magnetized neutron stars and total stress–energy tensor in addition to the perfect fluid contribution, Equation (5) will include the contribution of the magnetic field. We decompose the Einstein’s equations E α β : = G α β 8 π T α β = 0 along the hypersurface as well as along its normal n α as follows,
E α β n α n β = 0 ,
E α β γ i α n β = 0 ,
E α β γ α β + 1 2 n α n β = 0 ,
E α β γ i α γ j β 1 3 γ i j γ α β = 0 ,
which correspond, respectively, to the Hamiltonian constraint, momentum constraint, spatial trace part (combined with the Hamiltonian constraint), and spatial trace-free part.
As shown in [40], the above set of field Equations (6)–(9) are reduced to elliptic (Poisson) equations for { ψ , β ˜ i , α ψ , h i j } , respectively, as follows,
Δ ˚ ψ = S H ,
Δ ˚ β ˜ i = S i ,
Δ ˚ ( α ψ ) = S tr ,
Δ ˚ h i j = S i j ,
where Δ ˚ is the flat metric (in arbitrary coordinates) Laplacian, defined by Δ ˚ = f i j D ˚ i D ˚ j . The sources S H , S i , S tr , and S i j [21] depend nonlinearly on the unknown potentials { ψ , β ˜ i , α ψ , h i j } and are written in Appendix A. In the COCAL code, we use the Cartesian components of the elliptic Equations (10)–(13), on spherical grids (see Section 3). Equations (10)–(13) must be supplied with conditions on the boundary of our computational region. Because we will only consider isolated single or binary stars, the boundary conditions for the gravitational equations will only be at spatial infinity, where we impose asymptotic flatness, i.e.,
lim r α = lim r ψ = 1 , lim r β i = lim r h i j = 0 .
In case a black hole is present, COCAL uses excision, and boundary conditions are applied on the excised surface (typically a sphere). Depending on the method, we have employed Robin–Dirichlet, apparent horizon [13,14,23], or simply Kerr–Schild [21] boundary conditions.

2.1. Rotating Neutron Star in the Waveless Formalism

Coordinate gauge conditions such as the maximal slicing and generalized Dirac gauge
K = 0
H i = 0
are assumed for rotating neutron stars. As described in Appendix A, H i = D ˚ j γ ˜ i j . These conditions simplify Equations (A1)–(A4) significantly. In particular, R ˜ i j LI = 0 . The asymptotic behavior of the metric potentials becomes a Coulomb-type fall-off,
ψ 1 = O ( r 1 ) , α 1 = O ( r 1 ) ,
β i = O ( r 2 ) , h i j = O ( r 1 ) .
Our choice of β a is the shift in an (asymptotically) inertial frame.
The Bianchi identity implies α T α β = 0 . Under the assumption of rest mass conservation α ( ρ u α ) = 0 and an isentropic law α s = 0 , it leads to the relativistic Euler equation
u β ω β α = 0 , where ω α β : = α ( h u β ) β ( h u α )
is the relativistic vorticity and h : = ( ϵ + p ) / ρ the relativistic specific enthalpy. We consider two cases of single rotating stars, both of which are described by a 4-velocity
u α = u t k α .
Here, k α = t α + Ω ϕ α is the helical symmetry vector, Ω is the constant angular velocity of the star, and ϕ α is the generator of rotational symmetry. For uniformly rotating stars, it is u β ω β α = u t α ( h u β k β ) .

2.1.1. Axisymmetric Rotating Neutron Stars

For stationary and axisymmetric systems, we impose time symmetry on both the three dimensional metric as well as the extrinsic curvature
L t γ i j = L t K i j = 0 .
Note that we do not explicitly impose the axisymmetry on our formulation. Under these asumptions, u ˜ i j = 0 in Equation (A2) and L α n ( ) = L β ( ) for Equation (A4). Note that the last terms involve second order derivatives of the shift vector β ˜ i .
The stationarity condition for the fluid variables
L t ( h u α ) = L t ρ = 0 ,
reduce the Euler Equation (19) to the simple algebraic equation
h u t = C ,
where C is a constant to be determined. Note that u t is computed by the normalization condition u α u α = 1 . In this work, we also assume that neutron stars are “cold”, i.e., they can be described by a zero-temperature equation of state (EOS),
ϵ = ϵ ( ρ ) , p = p ( ρ ) ,
or, equivalently, p = p ( ϵ ) . This kind of one-parameter EOS is called barotropic. Equations (10)–(13) under gauge conditions (15) and (16) and Equation (23) determine all gravitational and fluid variables.

2.1.2. Triaxial Rotating Neutron Stars

For nonaxisymmetric rotating neutron stars, we impose time symmetry on the three metric but helical symmetry (stationarity in the rotating frame) on the extrinsic curvature
L t γ i j = 0 , and L k K i j = 0 .
Under the conditions of (25), we have u ˜ i j = 0 in Equation (A2) and L α n ( ) = L ω ( ) , where ω α = β α + Ω ϕ α is the so-called corotating shift vector ω α .
The helical symmetry condition for the fluid variables
L k ( h u α ) = L k ρ = 0 ,
reduce Euler Equations (19)–(23) similarly to the stationary and axisymmetric case.

2.2. Binary Neutron Stars in the IWM Formalism

Binary neutron stars are computed within the IWM formalism, where
h i j = 0 , and K = 0 ,
which means that Equation (13) is absent, while in Equations (10)–(12), the magenta terms in the sources (A1)–(A3) are zero. The spacetime helical symmetry
L k γ i j = L k K i j = 0
implies that Equation (A10) can be written as
A ˜ i j = 1 2 α ( L ˜ ω ˜ ) i j
where ω i the corotating shift.
The 4-velocity of the fluid here can be written as
u α : = u t ( k α + V α ) ,
where V i is the fluid velocity in the corotating frame and the helical Killing vector k α refers to a binary system having orbital angular velocity Ω . For irrotational binaries [44,45,46,47], we have ω α β = 0 , so the specific enthalpy current h u α can be derived from a potential h u α = α Φ . In order to allow for arbitrary spinning binary configurations, a 3-vector s i is introduced according to [48]
u ^ i : = γ i α h u α = D i Φ + s i ,
where the D i Φ part corresponds to the “irrotational part” of the flow and s i the “spinning part” of the flow. Equations (30) and (31) yield
V i = D i Φ + s i h u t ω i .
For arbitrary spinning binaries under the assumptions of helical symmetry
L k ( h u α ) = 0
and the additional assumption for the spin of the neutron star
L V ( s α ) = 0 ,
yields
h u t + V j D j Φ = C ,
where C is a constant to be determined.
The conservation of rest mass and Equation (32) for the fluid velocity will produce an extra elliptic equation for the fluid potential Φ
2 Φ = 2 ψ i ψ i Φ + ψ 4 ω i i ( h u t ) + [ ψ 4 h u t ω i i Φ ] i ln α ρ h = ψ 4 i s i + s i i ln α ρ ψ 6 h : = S Φ .
Note that because h i j = 0 , the conformal geometry is flat γ ˜ i j = f i j and therefore i Φ = D ˜ i Φ . The boundary for the fluid is represented by the surface of the star; hence, the boundary condition for Equation (36) will be of the von Neumann type, that is, in terms of derivatives of the rest mass density and of Φ
ψ 4 h u t ω i i Φ ψ 4 s i i ρ surf . = 0 .
Equations (10)–(12) under a maximal slicing gauge condition and Equations (35) and (36) determine all gravitational and fluid variables. As in the rotating star case, u t is determined from the normalization of the 4-velocity. A barotropic EOS is assumed.

3. Numerical Methods

All elliptic equations are solved using the representation theorem of partial differential equations through a Picard type of iteration. Starting from
2 f = S
where S is a nonlinear function of f (here, f can be any of { ψ , α , β ˜ i , h i j , Φ } and S any combination of them), and by using an appropriate Green’s function
2 G ( x , x ) = 4 π δ ( x x ) ,
that satisfies certain boundary conditions, a solution for f can be written as
f ( x ) = 1 4 π V G ( x , x ) S ( x ) d 3 x + 1 4 π V G ( x , x ) a f ( x ) f ( x ) a G ( x , x ) d S a .
where V is the domain of integration, x , x V Σ t , the initial space-like hypersurface. The volume V and its boundary V depend on the coordinate system used and are different for isolated rotating neutron stars and binary neutron stars. We will explain this difference in the next sections. This method is widely known as the KEH method [24,25].
For the evaluation of the integrals in Equation (40), a multipole expansion of G ( x , x ) in associated Legendre functions, P m , on spherical coordinates is used;
G ( x , x ) : = = 0 g ( r , r ) m = 0 ϵ m ( m ) ! ( + m ) ! × P m ( cos θ ) P m ( cos θ ) cos [ m ( ϕ ϕ ) ] ,
where the radial Green’s function g ( r , r ) depends on boundary conditions and the coefficients ϵ m are ϵ 0 = 1 and ϵ m = 2 for m 1 . In practice, the sum over is truncated at = L . The standard value used for single rotating stars as well as binaries is L = 12 . On the other hand, highly rotating black holes and magnetized neutron stars require a larger L 60 .

3.1. Single Rotating Neutron Star

For a single rotating neutron star, the only elliptic equations to be solved are the gravitational Equations (10)–(13). We employ a single spherical coordinate system that covers the region [ r a , r b ] × [ 0 , π ] × [ 0 , 2 π ] , where r a = 0 and r b O ( 10 6 M ) , with M being the total mass of the system. The boundary conditions (14) are applied at r = r b . Coordinate grids ( r i , θ j , ϕ k ) with i = 0 , , N r , j = 0 , , N θ , and k = 0 , , N ϕ , are freely specifiable except for the points at the boundary of the computational domain. The grid setup is the same as in [8]: the radial grid intervals Δ r i : = r i r i 1 are constant when r i [ r a , r c ] ( i = 1 , , N r m ) , which typically extends up to ∼ 1.25 R e , where R e is the equatorial radius of the star, and increase thereafter in a geometric progression with Δ r i = k Δ r i 1 . Here, k is a constant, and r i [ r c , r b ] ( i = N r m + 1 , , N r ) . For the angular coordinate grids ( θ j , ϕ k ) , we choose equally spaced grids. Definitions of the parameters for the grid setups are listed in Table 1.
When applying Equation (40), we use the Green’s function G ( x , x ) = 1 / | x x | . For the quadratures, a 2nd order midpoint rule is used in r and ϕ integrations, and a 4th order midpoint rule is used for θ integration. We also use a 2nd order finite difference formula for the r, θ , and ϕ derivatives evaluated at the midpoints ( r i + 1 2 , θ j + 1 2 , ϕ k + 1 2 ) = ( ( r i + r i + 1 ) / 2 , ( θ i + θ i + 1 ) / 2 , ( ϕ i + ϕ i + 1 ) / 2 ) , except for a 3rd order finite difference formula used in the first radial derivative evaluated at the midpoints. For derivatives at the grid points ( r i , θ j , ϕ k ) , a 4th order finite difference formula is used. We found [13,15] that these choices are necessary in order to maintain an overall second-order accuracy for the COCAL code and a small error near the possible black hole excised surface [15]. Note that we use the midpoint rule for numerical quadrature formula and hence compute the source terms, Equation (A1)–(A4), at the midpoints of the grids.
A relaxation parameter λ is used when updating a newly computed variable f { ψ , α , β ˜ i , h i j , Φ , ρ } . If f ( n ) ( x ) is the value at the n-th iteration, and f ^ ( x ) the current result of the Poisson solver, Equation (40), then the ( n + 1 ) -th iteration value will be
f ( n + 1 ) ( x ) : = λ f ^ ( x ) + ( 1 λ ) f ( n ) ( x ) ,
where 0.1 λ 0.4 . Usually, λ = 0.4 for all variables except for Φ , where λ = 0.1 . The criterion used by the cocal to stop the iteration for a variable f is based on the relative error between two successive iterations and is given by
E f ( x ) = 2 | f ( n ) ( x ) f ( n 1 ) ( x ) | | f ( n ) ( x ) | + | f ( n 1 ) ( x ) | < 10 6 ,
for all points of the grids and all variables. The coupled elliptic Equations (10)–(13) are solved sequentially (starting from ψ , followed by α , β i , and finally the h i j ) at every iteration, and Equation (42) is applied separately to each potential before moving to the next elliptic equation.

3.2. Binary Systems

For binary configurations, the hypersurface Σ t is covered by at least three coordinate systems, as explained in detail in [13,14,15,16]. As an example of a general binary system, we show in Figure 1 a black hole–neutron star ( x y cross-section) that consists of the following: (i) Coordinate system COCP-BH (top-left coordinate system) centered around the black hole extending from an inner sphere S a (small black circle at its center) of radius r a to a sphere S b of radius r b (red outer circle). The surface S a denotes the black hole region and is excised from the grid. If M is the mass of the system, we have r a O ( M ) while r b O ( 100 M ) ; (ii) Coordinate system COCP-NS (top-right coordinate system) centered around the neutron star, which extends from r a = 0 to a sphere S b of radius r b (blue outer circle). Both COCP-BH and COCP-NS contain an excised sphere S e (although we use the common symbol S e , these spheres are different in the two coordinate systems), which is introduced to improve the angular resolution and reduce the number of multipoles for resolving the companion object in a given coordinate system; and (iii) Coordinate system ARCP, which is positioned at the center of mass of the system and extends from an inner sphere S a of radius r a O ( 10 M ) (green inner circle) to an outer sphere S b of radius r b ( 10 6 M ) (outer black circle). Definitions of the parameters for the grid setups are listed in Table 2.
In binary systems, elliptic Equations (10)–(12) are solved separately in all three coordinate systems (in Figure 1), and a smooth solution emerges in an iterative process. On the other hand, Equation (36) is only solved in coordinate systems where a neutron star exists. Therefore, the computational cost of a binary system is significantly larger than that of a single rotating star. Convergence to a smooth solution is achieved because in any given coordinate system, in the calculation of the surface integrals in Equation (40), we use the values of the potential functions f from another coordinate system as indicated by the red, green, and blue arrows in Figure 1. For example, when we calculate the contribution of the surface integral on the red sphere S e inside the COCP-NS coordinate system (top-right), we use the values of the potentials on the corresponding red sphere from the COCP-BH coordinate system (top-left) as indicated by the red curved arrow. In this way, a given potential ( α , ψ , β i ) from one coordinate system is communicated to all others, and at the end of the iterative process, a smooth solution is obtained in the whole computational domain. For a detailed explanation of how the KEH method works in multiple coordinate systems, see [13,14,23].

4. Speedup and Efficiency Results

The original serial COCAL consists of more than 400,000 lines of Fortran 90 code, and in order to use OpenMP parallelization, many of its loops had to be rewritten in a way that would efficiently utilize OpenMP’s capabilities. In particular, in multiple loops, the code inside the innermost one had to be written in a way that is independent between threads. For example, in a typical triple loop over the r (loop 1), θ (loop 2), and ϕ (loop 3) coordinates, any code between loop 1 and loop 2 and/or between loop 2 and loop 3 is written only inside the innermost loop 3. The reason is to utilize the collapse clause, which collapses the multiple loops into a single one, which is then divided among the multiple threads. Most of our loops were three-dimensional, but there were many that were four or even five-dimensional, which result in large speedups through OpenMP parallelization. For example, in a binary system, Figure 1, the calculation of the surface integral on the excised sphere S e uses the Legendre functions with respect to the coordinate system at the center of S e . Assuming θ e is the spherical angle with respect to the z-axis at the center of S e , the term cos ( θ e ) will depend on all coordinates r , θ , ϕ of that particular patch; therefore, these functions become five-dimensional, as they depend on the Legendre indices , m too.
Another commonly used command is the reduction clause, which is used to perform summations, for example in the calculation of the volume and surface integrals. In this case, the code is written in a way that the summation appears only inside the innermost loop so that a combination of the collapse and reduction clauses can execute this operation in multiple threads. The reduction clause is also used in finding the maximum error in Equation (43) for every variable in each coordinate system. The private clause is used extensively for local nested-loop variables so that multiple threads executing a parallel region are independently calculated. Listing a variable as private causes each thread that executes that construct to receive a new temporary variable of the same type, and the multiple loop can be performed independently in parallel.
Below, we will describe the two main modules of the PCOCAL code: (a) the parallelized single rotating star module (Section 2.1); and (b) the parallelized binary neutron star module (Section 2.2). For the single star solver (a), the computational infrastructure is straightforward (one spherical grid), but the mathematical formalism used requires the solution of 14 elliptic equations. On the other hand, for the binary solver (b), a simpler mathematical formalism requires the solution of six elliptic equations in a more intricate computational domain, which involves at least three coordinate systems (see Figure 1).
In order to quantify the speedup and efficiency of PCOCAL, we define the following measures:
  • T p ( n ) : CPU wall-clock time of parallelized part of the code using n threads.
  • T s : CPU wall-clock time of serial (nonparallelized) part of the code. Input/Output (IO) and copying between arrays are excluded.
  • T IO : CPU wall-clock time of serial IO.
  • T m : CPU wall-clock time of memory copy between arrays.
The reason for timing T m is because in COCAL/PCOCAL, every main variable (e.g., the 3D conformal factor ψ ) exists in all coordinate systems (which are at least three) and is stored in a higher dimensional array (for the case of ψ , in a 4D array) where the extra index determines the patch (COCP-1, COCP-2, or ARCP). When calculating quantities in one patch where we want to access a quantity in another patch, an array copy is necessary. The time for these copies is measured by T m .
The total time for a calculation is T = T p + T s + T IO + T m . We define the speedup of the code using n threads as
S p ( n ) = T p ( 1 ) T p ( n ) , S ( n ) = T ( 1 ) T ( n )
while the efficiency is defined as
E p ( n ) = S p ( n ) n , E ( n ) = S ( n ) n .
The speedup S p ( n ) and efficiency E p ( n ) refer to the parallelized part of code (which constitutes the large majority of the solver), while S ( n ) and E ( n ) refer to the total speedup and efficiency, which include the serial parts of the code, the input/output, and memory handling. Note that for the tests performed in this paper, the input/output routines were neither optimized nor minimized (for diagnostic purposes), and thus, the total speedup shown underestimates the real one.
To make sure that the parallelized PCOCAL code produces the same results as COCAL itself, we perform a pointwise check for every parallelized subroutine against the serial code and confirm that the differences between the two codes are ≲ 10 12 in all variables.
Most of the runs have been performed in server A, which has 36 cores with 2 threads per core (72 threads total) and an Intel(R) Xeon(R) Gold 6254 CPU 3.10 GHz (Intel, Santa Clara, CA, USA). We have also used server B, which has 40 cores with 2 threads per core (80 threads total) and an Intel(R) Xeon(R) Gold 6242R CPU 3.10 GHz. Both servers are dual-socket. An Intel compiler (2021.3.0 20210609) is being used.

4.1. Single Rotating Neutron Star

Following the methods of Section 2.1 and Section 3.1, we test our new code in three grid resolutions, as can be seen in Table 3. Resolution H2 has N r × N θ × N ϕ = 442,368 intervals (number of points in the r , θ , ϕ directions are N r + 1 , N θ + 1 , and N ϕ + 1 , respectively), while resolutions H3, H4 have twice and four times as many intervals in every dimension, i.e., 8 and 64 times more intervals in total, respectively. The default value of terms in the Legendre expansions is L = 12 . Below, we also investigate the performance of the code with respect to L.
In Algorithm 1, we sketch the most salient steps taken for a solution. In parentheses with green fonts, we show the percentage of time needed for a given calculation per iteration using a single core using the H3 resolution. Lines that do not have a number indicate that the time it took for completion was less than 1 % . The rest of the time is spent in the calculation of diagnostics as well as further output. Steps 2–12 are repeated iteratively until condition 13 is fulfilled, and hence, convergence to a solution is achieved. As we can see, the most time-consuming routines are the computation of the momentum constraint sources S i (15%), the calculation of the sources S i j (13%), followed by the calculation of the conformal Ricci tensor R ˜ i j (11%) and the Poisson solvers themselves (11%). The reason that the three source arrays S i of the momentum constraint took more time to be computed than the six source arrays S i j was mainly due to the modular way that COCAL implements various mathematical formulations. In particular, for the waveless formulation, the sources (right-hand side of the Poisson equations) are split into two parts: (i) the part that comes from the conformal flat part of the metric and (ii) the ones that come from the nonconformal one. In this way, one has the flexibility of choosing a specific method (conformal flat vs. nonconformal flat) without repeating the writing of a code. The disadvantage is that triple loops all over the gridpoints may be repeated; therefore, speed is sacrificed in view of modularity. In the computation of the momentum constraint sources S i for the waveless formulation (which is not conformally flat), both the fluid part and the gravitational part of the source computation are performed twice, which leads to a larger time footprint than the six source arrays S i j . Overall the bottleneck for the rotating neutron star module in the waveless formulation is the computation of the sources (lines 2–8) rather than the Poisson solvers (line 9). As we will see, this is in contrast with the binary neutron star module in the conformal flat approximation, where the latter dominates over the former.
Algorithm 1 Rotating star in the waveless formalism
1:procedure RNS
2: Interpolate variables to SFC ( 8 % )
3: Compute K i j ( 8 % ) , C k j i ( 8 % ) , R ˜ i j ( 11 % ) ( 27 % )
4: Compute volume sources S H , Equation (A1) ( 5 % )
5: Compute volume sources S tr , Equation (A3) ( 6 % )
6: Compute volume sources S i , Equation (A2) ( 15 % )
7: Compute volume sources S i j , Equation (A4) ( 13 % )
8: Compute right-hand side of Equation (A22) ( 3 % )
9: Compute ψ , α , β ˜ i , h i j , ξ i , Equation (40) ( 11 % )
10: Variable update, Equation (42) ( 2 % )
11: Use Equation (23) to compute the rest mass density ρ .
12: Compute E ψ , E α , E i β , E i j h , E ρ Equation (43) ( 1 % )
13: if  ( E ψ , E α , E i β , E i j h , E ρ < 10 6 )  then
14:  exit
In Figure 2, we plot in the upper two panels the speedup S p (top) and efficiency E p (bottom) of the parallelized part of the code (solid lines), as well as the corresponding measures S and E for the total code (dashed lines). As we mentioned above, S underestimates the real speedup as the input/output routines were neither optimized nor minimized (for diagnostic purposes). Thus, in the discussion below, we focus on the speedup S p and efficiency E p . One characteristic of the speedup is that for all resolutions, it reaches a maximum at ∼36 threads and drops slightly afterwards, from which point it continues to increase. The maximum speedup of the parallelized part of the code is 18–20 times the serial one (when ≲60 threads are used) which can be achieved with a minimum of ∼36 threads. At that point, the efficiency is ∼50%. At maximum speedup, the whole rotating neutron star code (including the serial routines that are nonparallelized, such as the calculation of the parameters Ω in Equation (20), C in Equation (23), and the coordinate scaling R 0 [8,16]) is ∼12, 13, and 14 times faster than the serial analog for resolutions H2, H3, and H4 and occurs at 36, 34, and 35 threads, respectively. This can be seen in Figure 2 on the lower three panels, where blue bars signify the parallelized routines of the code, red bars the serial part of the code, and yellow bars the memory copy between arrays. From this plot, we see that the parallelized code constitutes the vast majority of the total number of subroutines and is responsible for the achieved speedup. Also, we observe that the higher the resolution (H4), the larger the total speedup, which is a promising result for high-resolution campaigns.
In all tests presented in Figure 2, we used L = 12 terms in the Legendre expansion, Equation (41), and therefore all integrals, Equation (40). It is experimentally found that such a number of terms leads to accurate results without compromising the speed of the code. L = 12 is commonly used in all nonmagnetized rotating star calculations [7,8,9,10,11,12] as well as in the binary neutron star calculations [16,17] that we will mention in the next section. On the other hand, accurate magnetized rotating neutron stars or black hole-disk solutions require a larger number (≲60) of terms to be included in the Legendre expansions. In Figure 3, we plot the time of a single iteration (blue dots), as well as the time for the Poisson solvers alone (red dots), using the H3 resolution and a single core. Increasing the number of Legendre terms L increases the time spent on the Poisson solvers as
Time 0.32 ( L 12 ) 1.28 + c
where c = 9.52 . This fitting function is plotted by a solid yellow line. At the same time, the time spent on the whole iteration is also fitted by the same relation Equation (46), but c = 88.63 (as reported in Algorithm 1, line 9, the percentage of time spent for the Poisson solvers with respect to the whole iteration when L = 12 is approximately 11 % ) and is plotted with a purple curve. In other words, for a given resolution, the increase in the number of Legendre terms essentially affects the Poisson solvers as well as the whole iteration in the same manner and scale as ∼ L 1.28 .
In order to evaluate our new code with respect to the number L, we performed the same tests using the H4 resolution for three different numbers of Legendre terms L = 12 , 24 , 48 . The results are shown in the upper two panels of Figure 4 with red, blue, and yellow curves in server A. In addition, we show with a cyan curve the speedup and efficiency of the L = 24 run in server B. The first conclusion is that the speedup is approximately preserved when the number of Legendre terms is increased. All runs in server A have a maximum at ∼35 threads. Beyond that point, and similarly to Figure 2, the speedup drops and then starts to increase again. This behavior is qualitatively the same as the run with L = 24 at server B, with the maximum now happening at 40 threads and a speedup of larger than 20. Given than the server A CPUs have 36 cores while the server B CPUs have 40, we conclude that peak speedup with minimum amount of threads happens approximately at the number of cores a CPU has. The larger the number of cores, the larger the speedup will be. On the lower three panels, we plot the total performance time for L = 12 , 24 , 48 in the H4 resolution and server A. We find that the maximum speedup of the total rotating neutron star code (including the routines that are nonparallelized) is ∼14, 13, and 14 times faster than the serial analog in the H4 resolutions for L = 12 , 24 , 48 and occurs at 35, 36, and 35 threads, respectively. Therefore, the speedup is preserved when the number of Legendre terms is increased for the whole code as well, which is expected, given the fact that the parallelization scheme covers all of the main components of PCOCAL.

4.2. Binary Neutron Stars

Following the methods of Section 2.2 and Section 4, we test our new code in three resolutions as in Table 4. Resolution E2.5 has N r × N θ × N ϕ = 1,492,992 intervals in each of the three coordinates systems (two COCPs and one ARCP in Figure 1), while resolutions E3.0 and E3.5 have ∼1.3, and 2 times as many intervals in every dimension, i.e., 2.4 and 8 times more intervals in total, respectively. In all binary cases, we use L = 12 as the number of terms in the Legendre expansions. Notice that the BH coordinate system (COCP-BH, top-left, red patch in Figure 1) is now replaced by an NS coordinate system, similar to the blue, top-right patch COCP-NS. Therefore, there is no inner surface S a (no boundary conditions), and r a = 0 for the red patch in Figure 1 for the binary neutron/quark case.
In Algorithm 2, we sketch the most important steps taken for a binary neutron star solution using a single core in the E3.0 resolution. As in Algorithm 1, we report the percentage of time needed for the completion of each step with green fonts inside a parenthesis, while when such number is absent, it means that the time it took for completion was less than 1 % . The rest of the time is spent in the calculation of diagnostics as well as further output. Steps 2–14 are repeated iteratively until the condition in line 15 is fulfilled. The main differences between the RNS and NSNS modules are: (i) Steps 3–15 are performed in three coordinate systems (two for COCP-NS and the ARCP) as seen in Figure 1 instead of one in the RNS module; (ii) the calculation of every potential ψ , α , β ˜ i in the two COCP-NS coordinate systems is significantly more involved because of the excised sphere S e (the reason for the existence of S e in the COCP patches is explained in detail in [13,14,15]); (iii) the additional calculation of the velocity potential Φ (∼4%) (absent in the RNS module) is another important difference between the NSNS module and the RNS one; (iv) because for binary neutron stars we solve for conformally flat initial data, potentials h i j = 0 and, in addition, the source terms (Equation (A1)–(A3)) are significantly simpler as the magenta terms are zero.
As mentioned above, surface integrals (see Equation (40)) on S e do not exist in the single coordinate system of the RNS module. When computing those integrals as well as the surface integrals at S b and S a in a given coordinate system (e.g., on COCP-NS-1), the integrands are computed using the variables of another coordinate system (e.g., from COCP-NS-2). In this way, solutions between coordinate systems communicate between each other in order to achieve a smooth solution everywhere. Therefore, to compute the integrands on the surface integrals at S a , S b , and S e , three-dimensional interpolations from nearby points of another coordinate system is needed. In total, the Poisson solvers take ∼41% of the time of an iteration. The time of the Poisson solvers in each COCP-NS patch is ∼17%, while in the ARCP, it is ∼7%. The big difference between them is due to the fact that patch ARCP does not have an excised sphere S e . The surface integral in the off-center sphere S e is the most time-consuming operation (∼11%), and it involves the computation of the corresponding associated Legendre functions, which are five-dimensional arrays of ( r , θ , ϕ , , m ). In the current implementation, this time-consuming operation is performed on the fly every time such an integral is calculated in order to have a smaller memory footprint. Note that these functions do not change during the iteration procedure and in principle can only be calculated once. Such an array in the E3.5 resolution will be ∼9 GB.
Algorithm 2 Binary neutron star
1:procedure NSNS
2:for all Coordinate Systems A do
3:  Interpolate variables from SFC ( 3 % )
4:  Compute K i j ( 9 % )
5:  Compute volume source Equation (A1), S H
6:  Compute volume source Equation (A3), S tr
7:  Compute volume source Equation (A2), S i ( 6 % )
8:  Compute sources on excised surface S e ( 1 % )
9:  Compute ψ , α , β ˜ i Equation (40) ( 41 % )
10:  Variable update Equation (42) ( 1 % )
11:  Use Equation (35) to compute the rest mass density ρ .
12:  Compute Φ Equations (36) and (40) ( 4 % )
13:  Compute E ψ ( A ) , E α ( A ) , E i β ( A ) , E ρ ( A ) , E Φ ( A ) ( 1 % )
14:  Variable copy between CSs ( 2 % )
15:if  ( E ψ ( A ) , E α ( A ) , E i β ( A ) , E ρ ( A ) , E Φ ( A ) < 10 6
  for all A) then
16:  exit
In Figure 5, we plot in the upper two panels the speedup S p (top) and efficiency E p (bottom) of the parallelized part of the binary NSNS code (solid lines), as well as the corresponding measures S and E for the total code (dashed lines). Similar to the RNS module, Figure 2, we find that for all resolutions the speedup increases until a certain number of threads; then, it exhibits a sudden small drop, from which point it continues to increase with the number of threads. One difference with respect to Figure 2 is that the speedup curves are distinct for resolutions E2.5, E3.0, and E3.0, while for the RNS module we observe a broad overlap of these curves between resolutions H2, H3, H4. The reason for this behavior is the communication between the different coordinate systems in the binary code, which is absent in the single neutron star module. Despite that, the speedup of the parallelized code reaches values of 12–16 using just ∼36 threads. The efficiency at that point is ∼40%. This speedup can further increase if more than 60 threads are used. Another finding in Figure 5 is the fact that for the highest resolution E3.5, the speedup is broadly constant from ∼26 to ∼35 threads, which is due to the domination of data communication between the different grids in the calculation process. In the lower three panels of Figure 5, we also see that the total binary code (including the routines that are nonparallelized) is six, five, and five times faster than the serial analogue for resolutions E2.5, E3.0, and E3.5 and occurs at 33, 34, and 26 threads, respectively. The distribution of times in the whole code can be seen on the lower three panels of Figure 5. In the future, we will address the data communication and memory handling in order to make the binary speedup scale similarly to the RNS code. In practice, a binary neutron star in quasicircular orbit that took approximately six days of continuous computation in the E3.0 resolution with the COCAL code; with PCOCAL, it needs approximately one day using a modest amount of ∼30 threads.
The differences between the PCOCAL and COCAL for a binary neutron or quark star are ≲ 10 12 in all coordinate systems for the gravitational variables ψ , α , β i and fluid variables ρ , Φ , as well as for the constants Ω , C and R 0 that appear in the calculation.

5. Spinning Binary Quark Stars

Given the fact that the state of matter at supranuclear densities is an open question, there is the possibility that conventional neutron stars contain in their core a phase transition to strange quark matter, i.e., up, down, and strange free quarks. A quark-gluon plasma has been observed in heavy ion collision at CERN and RHIC [49]. Also, Bodmer and Witten [50,51] pointed out that it is possible that the ground state of matter at zero pressure and a large baryon number is not iron but strange quark matter. Thus, from a theoretical standpoint, one can have pure quark stars. In [11,12,52,53,54], we have computed rotating isolated axisymmetric, triaxial, and differentially rotating quark stars, while in [55], irrotational binary quark stars have been evolved in grid-based hydrodynamics. Here, we present an example using the PCOCAL code of a spinning binary quark star, where each companion has a spin along the axis of the orbital angular momentum.
As in our previous studies, the quark EOS is the MIT model with p = 1 3 ( ϵ 4 B ) or in a parametric form
p = K ρ 4 / 3 B ,
ϵ = 3 K ρ 4 / 3 + B
where B = ϵ s / 4 is the bag constant, which is set to 52.5 MeV fm 3 , and ϵ s is the surface energy density. The parameter ρ could be regarded as the rest mass density and K is constant. As explained in [54], changing K does not affect the EOS; thus, we choose this constant such that at the surface ρ s = ϵ s , i.e., h s = 1 . This is accomplished for
K = c 8 256 B 1 3 = 3.119 × 10 15 c m 3 s 2 g 1 / 3 .
Assuming ρ s = 1.4 ρ nuc , this EOS predicts a maximum spherical mass of a quark star of M max sph = 2.1 M with R max sph = 11.5 km .
Using the formalism described in Section 2.2 with a spin vector
s i = 0.13 ( y s , x s , 0 )
( x s , y s are coordinates with respect to the quark star center) in Equation (31), and solving Equations (10)–(12), (31), (35) and (36), we compute here a spinning binary quark star at 37.3 km separation and Arnowitt–Deser–Misner mass of M = 2.84 . The quasilocal spin [17] of each companion is J ql = 0.858 along the axis of orbital motion. This spin angular momentum corresponds to an approximate dimensionless spin of J ql / ( M / 2 ) 2 = 0.43 . In Figure 6, we plot the rest mass density (left quark star), velocity potential (right quark star), contour plots of the conformal factor ψ (green dashed lines), and velocity potential (brown dashed lines), as well as the fluid velocity with respect to the corotating frame. The direction of the velocity arrows show that the spin angular momentum is along the positive z-axis (contrary to the irrotational case) in accordance with Equation (50). From the density colorbar, we see that the central density ρ c is approximately 1.55 times the surface density ρ s . The nonzero surface density is characteristic of the self-bound quark stars, contrary to their neutron star analogs. For nonspinning (irrotational) binaries of the same surface density (and rest mass), the central density is higher and ρ c / ρ s = 1.63 . This behavior is similar to binary neutron stars as well as to isolated rotating neutron/quark stars. Note that in order to find the quasiequilibrium solution, a root finding method over the central quark star densities is needed, and therefore, a number of cycles (∼10) of Algorithm 2 is performed. Pointwise comparison between PCOCAL and COCAL solutions show differences ≲ 10 12 for all variables.

6. Conclusions

In this work, we presented a new efficient parallelized code, PCOCAL, for general relativistic compact object initial data. PCOCAL is based on the serial COCAL code (which has been tested for a wide range of astrophysical scenarios) and employs extensive OpenMP practices. To optimize PCOCAL, a thorough profiling of the serial COCAL code is performed for the first time. Both the single and binary neutron star modules have been examined in detail, and timing of each subroutine was performed. The parallelized module that solves the full set of Einstein equations for a single rotating neutron star is found to be 12–14 times faster than the corresponding serial code, with the parallel part being 18–20 times faster than the serial one. The parallelized module that solves for a binary neutron star system in quasiequilibrim is 5–6 times faster than the corresponding serial code, with the parallel part being 12–16 times faster than the serial one. As a novel example, we computed initial data for a spinning binary quark star system that could be a binary neutron star mimicker. The achieved speedup will help us explore a larger set of problems that require intensive calculations, as for example in the calculation of magnetized neutron stars.
As a step forward, we plan to revisit the data communication and memory handling of the binary module in order to achieve better speedups for the highest resolutions, as in the single rotating star module. In addition, we will perform domain decomposition in order to implement a combined MPI-OpenMP scheme.

Author Contributions

Conceptualization, A.T.; methodology, L.B., A.T. and K.U.; software, L.B., A.T. and K.U.; validation, L.B.; formal analysis, L.B. and A.T.; investigation, L.B. and A.T.; resources, A.T. and K.U.; data curation, L.B.; writing - original draft, L.B. and A.T.; writing - review & editing, A.T. and K.U.; visualization, L.B. and A.T.; supervision, A.T.; project administration, A.T.; funding acquisition, A.T. and K.U. All authors have read and agreed to the published version of the manuscript.

Funding

A.T. is supported by National Science Foundation Grants No. PHY-2308242 and No. OAC-2310548 awarded to the University of Illinois at Urbana-Champaign. A.T. acknowledges support from the National Center for Supercomputing Applications (NCSA) at the University of Illinois at Urbana-Champaign through the NCSA Fellows program. K.U. is supported by the JSPS Grant-in-Aid for Scientific Research (C) 22K03636 awarded to the University of the Ryukyus.

Data Availability Statement

The authors declare that there are no data associated with this manuscript.

Acknowledgments

A.T. thanks E. Zhou for useful discussions.

Conflicts of Interest

The authors declare no conflicts of interest.

Appendix A. Source Terms

The source terms S H , S i , S tr , and S i j in Equation (10)–(13) are
S H = 1 8 ψ R ˜ h i j D ˚ i D ˚ j ψ + γ ˜ i j C i j k D ˚ k ψ ψ 5 8 A ˜ i j A ˜ i j 2 3 K 2 2 π ρ H ψ 5 ,
S i = R ˜ i j β ˜ j h a b D ˚ a D ˚ b β ˜ i + γ ˜ a b [ D ˚ a ( C b i m β ˜ m ) + C a b m D ˜ m β ˜ i + C a i m D ˜ b β ˜ m ] 1 3 D ˚ i D ˚ j β ˜ j 2 α 2 ψ 6 A ˜ i j D ˚ j ψ 6 α + 4 α 3 D ˚ i K + γ ˜ j m D ˜ j u ˜ i m + 16 π α j i ,
S tr = α ψ 8 R ˜ h i j D ˚ i D ˚ j ( α ψ ) + γ ˜ i j C i j k D ˚ k ( α ψ ) + α ψ 5 7 8 A ˜ i j A ˜ i j + 5 12 K 2 ψ 5 L α n K + 2 π α ψ 5 ( ρ H + 2 S ) ,
S i j = 1 3 γ ˜ i j D ˚ k h a b D ˚ k h a b + 2 3 γ ˜ i j D ˚ k C a k a + 2 R ˜ i j LI + R ˜ i j NL + ψ 4 1 3 K A ˜ i j 2 A ˜ i k A ˜ j k + 1 α ψ 2 D ˚ i D ˚ j ( α ψ 2 ) + C i j k D ˚ k ( α ψ 2 ) + 4 D ˚ i ( α ψ ) D ˚ j ψ + 4 D ˚ i ψ D ˚ j ( α ψ ) 1 α L α n ( ψ 4 A ˜ i j ) 8 π S i j TF ,
where with magenta color, we signify terms that are due to the nonconformal flat contribution h i j . Such terms are zero in the IWM formulation used in the binary neutron star calculations of Section 2.2. We also define the conformally rescaled shift as β ˜ i = β i ; therefore, β ˜ i = γ ˜ i j β ˜ j = ψ 4 β i . The covariant derivatives associated with γ i j , γ ˜ i j , and f i j are, respectively, D , D ˜ , and D ˚ . It is
D i β k = D ˜ i β k + C ˜ i j k β j
D ˜ i β k = D ˚ i β k + C i j k β j
where
C ˜ i j k = 2 ψ ( γ ˜ i k D ˜ j ψ + γ ˜ j k D ˜ i ψ γ ˜ i j γ ˜ k m D ˜ m ψ )
C i j k = 1 2 γ ˜ k m ( D ˚ i h m j + D ˚ j h m i D ˚ m h i j )
and
C k j k = 1 2 γ ˜ D ˚ j γ ˜ = 0 , C ˜ k j k = 1 2 γ D ˜ j γ
as γ ˜ = f . In the case where Cartesian coordinates are used for the flat metric, i.e., f i j = δ i j , then D ˚ is the usual partial derivative and Δ ˚ is the Laplacian in Cartesian coordinates. The superscript TF means the trace-free part. The conformal trace-free extrinsic curvature is written as
A ˜ i j = 1 2 α [ ( L ˜ β ˜ ) i j u ˜ i j ] , u ˜ i j : = [ t γ ˜ i j ] TF ,
where L ˜ is the conformal Killing operator: ( L ˜ β ˜ ) i j = D ˜ i β ˜ j + D ˜ j β ˜ i 2 3 γ ˜ i j D ˜ k β ˜ k .
The matter sources that appear on the right-hand side of Equations (A1)–(A4) are
ρ H : = T μ ν n μ n ν ,
j i : = T μ ν γ i μ n ν ,
S : = T μ ν γ μ ν ,
S i j : = T μ ν γ i μ γ j ν .
Another important term in our system is the one that involves R ˜ i j , the 3D Ricci tensor associated with the conformal geometry γ ˜ i j . One can show [56] that
R ˜ i j = 1 2 Δ ˚ h i j + R ˜ i j LI + R ˜ i j NL ,
where
R ˜ i j LI : = 1 2 ( f i k D ˚ j Γ ˜ k + f j k D ˚ i Γ ˜ k ) , R ˜ i j NL : = 1 2 ( h a b D ˚ a D ˚ b h i j + D ˚ i h a b D ˚ b h a j + D ˚ j h a b D ˚ a h i b ) + 1 2 [ D ˚ i ( h k j Γ ˜ k ) + D ˚ j ( h i k Γ ˜ k ) ]
D ˚ i C k j k + C k m k C i j m Γ ˜ k C k i j C i m k C k j m ,
and
Γ ˜ i : = D ˚ j γ ˜ i j = D ˚ j h i j
Notice that the terms R ˜ i j LI , R ˜ i j NL enter into Equation (A4), which we discuss below. The nonlinear term R ˜ i j NL is second order in h i j and therefore smaller than the first-order terms R ˜ i j LI and Δ ˚ h i j in Equation (A15). The term R ˜ i j LI involves the gauge functions Γ ˜ i , which are the conformal connection functions in the BSSN formulation [57,58,59]. For initial data, in order for the whole system (A1)–(A4) to converge, these functions must be fixed [21,56]
Γ ˜ i = H i
where H i is known. Equation (A19) is related to our freedom in choosing spatial coordinates. In order to impose Equation (A19) to the solutions of the system Equation (A1)–(A4) and thereby having a self-consistent iteration scheme, an adjustment is necessary for the h i j . Following [43], (or [8] Equations (29)–(32)) gauge vector potentials ξ a are introduced through the transformation
δ γ i j δ γ i j D ˚ i ξ j D ˚ j ξ i ,
which are then used to adjust h i j as
h i j = h i j D ˚ i ξ j D ˚ j ξ i + 2 3 f i j D ˚ k ξ k .
Here, h i j are chosen to satisfy the condition D ˚ i h i j = H j given by (A18). The gauge vector potentials ξ i are then solved from the elliptic equations,
Δ ˚ ξ i = D ˚ j h i j 1 3 D ˚ i D ˚ j ξ j H i ,
and subsequently, the h i j are replaced by Equation (A21).

References

  1. Abbott, B.P.; Abbott, R.; Abbott, T.D.; Abernathy, M.R.; Acernese, F.; Ackley, K.; Adams, C.; Adams, T.; Addesso, P.; Adhikari, R.X.; et al. Observation of Gravitational Waves from a Binary Black Hole Merger. Phys. Rev. Lett. 2016, 116, 061102. [Google Scholar] [CrossRef]
  2. Abbott, B.P.; Abbott, R.; Abbott, T.; Acernese, F.; Ackley, K.; Adams, C.; Adams, T.; Addesso, P.; Adhikari, R.X.; Adya, V.B.; et al. GW170817: Observation of Gravitational Waves from a Binary Neutron Star Inspiral. Phys. Rev. Lett. 2017, 119, 161101. [Google Scholar] [CrossRef] [PubMed]
  3. Kozlova, A.; Golenetskii, S.; Aptekar, R.; Frederiks, D.; Svinkin, D.; Cline, T.; Hurley, K.; Connaughton, V.; Briggs, M.S.; Meegan, C.; et al. IPN Triangulation of GRB 170816A (short/hard). GRB Coordinates Network, Circular Service, No. 21517, #1 (2017). 2017, Volume 1517. Available online: https://ui.adsabs.harvard.edu/abs/2017GCN.21517....1K/abstract (accessed on 20 March 2024).
  4. Abbott, B.P. Multi-messenger Observations of a Binary Neutron Star Merger. Astrophys. J. Lett. 2017, 848, L12. [Google Scholar] [CrossRef]
  5. Abbott, B.P.; Abbott, R.; Abbott, T.D.; Acernese, F.; Ackley, K.; Adams, C.; Adams, T.; Addesso, P.; Adhikari, R.X.; Adya, V.B.; et al. Gravitational Waves and Gamma-Rays from a Binary Neutron Star Merger: GW170817 and GRB 170817A. Astrophys. J. Lett. 2017, 848, L13. [Google Scholar] [CrossRef]
  6. Abbott, B.P.; Abbott, R.; Abbott, T.D.; Acernese, F.; Ackley, K.; Adams, C.; Adams, T.; Addesso, P.; Adhikari, R.X.; Adya, V.B.; et al. Estimating the Contribution of Dynamical Ejecta in the Kilonova Associated with GW170817. Astrophys. J. Lett. 2017, 850, L39. [Google Scholar] [CrossRef]
  7. Huang, X.; Markakis, C.; Sugiyama, N.; Uryū, K. Quasi-equilibrium models for triaxially deformed rotating compact stars. Phys. Rev. D 2008, D78, 124023. [Google Scholar] [CrossRef]
  8. Uryū, K.; Tsokaros, A.; Galeazzi, F.; Hotta, H.; Sugimura, M.; Taniguchi, K.; Yoshida, S. New code for equilibriums and quasiequilibrium initial data of compact objects. III. Axisymmetric and triaxial rotating stars. Phys. Rev. D 2016, D93, 044056. [Google Scholar] [CrossRef]
  9. Uryū, K.; Tsokaros, A.; Baiotti, L.; Galeazzi, F.; Sugiyama, N.; Taniguchi, K.; Yoshida, S. Do triaxial supramassive compact stars exist? Phys. Rev. D 2016, 94, 101302. [Google Scholar] [CrossRef]
  10. Uryu, K.; Tsokaros, A.; Baiotti, L.; Galeazzi, F.; Taniguchi, K.; Yoshida, S. Modeling differential rotations of compact stars in equilibriums. Phys. Rev. D 2017, 96, 103011. [Google Scholar] [CrossRef]
  11. Zhou, E.; Tsokaros, A.; Rezzolla, L.; Xu, R.; Uryū, K. Uniformly rotating, axisymmetric and triaxial quark stars in general relativity. Phys. Rev. 2018, D97, 023013. [Google Scholar] [CrossRef]
  12. Zhou, E.; Tsokaros, A.; Uryu, K.; Xu, R.; Shibata, M. Differentially rotating strange star in general relativity. Phys. Rev. 2019, D100, 043015. [Google Scholar] [CrossRef]
  13. Uryū, K.; Tsokaros, A. New code for equilibriums and quasiequilibrium initial data of compact objects. Phys. Rev. D 2012, 85, 064014. [Google Scholar] [CrossRef]
  14. Tsokaros, A.; Uryū, K. Binary black hole circular orbits computed with cocal. J. Eng. Math. 2012, 82, 133–141. [Google Scholar] [CrossRef]
  15. Uryū, K.; Tsokaros, A.; Grandclement, P. New code for equilibriums and quasiequilibrium initial data of compact objects. II. Convergence tests and comparisons of binary black hole initial data. Phys. Rev. D 2012, D86, 104001. [Google Scholar] [CrossRef]
  16. Tsokaros, A.; Uryū, K.; Rezzolla, L. New code for quasiequilibrium initial data of binary neutron stars: Corotating, irrotational, and slowly spinning systems. Phys. Rev. D 2015, 91, 104030. [Google Scholar] [CrossRef]
  17. Tsokaros, A.; Uryu, K.; Ruiz, M.; Shapiro, S.L. Constant circulation sequences of binary neutron stars and their spin characterization. Phys. Rev. 2018, D98, 124019. [Google Scholar] [CrossRef]
  18. Uryu, K.; Gourgoulhon, E.; Markakis, C.; Fujisawa, K.; Tsokaros, A.; Eriguchi, Y. Equilibrium solutions of relativistic rotating stars with mixed poloidal and toroidal magnetic fields. Phys. Rev. 2014, D90, 101501. [Google Scholar] [CrossRef]
  19. Uryu, K.; Yoshida, S.; Gourgoulhon, E.; Markakis, C.; Fujisawa, K.; Tsokaros, A.; Taniguchi, K.; Eriguchi, Y. New code for equilibriums and quasiequilibrium initial data of compact objects. IV. Rotating relativistic stars with mixed poloidal and toroidal magnetic fields. Phys. Rev. 2019, D100, 123019. [Google Scholar] [CrossRef]
  20. Uryu, K.; Yoshida, S.; Gourgoulhon, E.; Markakis, C.; Fujisawa, K.; Tsokaros, A.; Taniguchi, K.; Zamani, M. Equilibriums of extremely magnetized compact stars with force-free magnetotunnels. Phys. Rev. D 2023, 107, 103016. [Google Scholar] [CrossRef]
  21. Tsokaros, A.; Uryu, K.; Shapiro, S.L. Complete initial value spacetimes containing black holes in general relativity: Application to black hole-disk systems. Phys. Rev. 2019, D99, 041501. [Google Scholar] [CrossRef]
  22. Uryū, K.; Eriguchi, Y. New numerical method for constructing quasiequilibrium sequences of irrotational binary neutron stars in general relativity. Phys. Rev. D 2000, 61, 124023. [Google Scholar] [CrossRef]
  23. Tsokaros, A.A.; Uryū, K. Numerical method for binary black hole/neutron star initial data: Code test. Phys. Rev. D 2007, 75, 044026. [Google Scholar] [CrossRef]
  24. Komatsu, H.; Eriguchi, Y.; Hachisu, I. Rapidly rotating general relativistic stars. I-Numerical method and its application to uniformly rotating polytropes. Mon. Not. R. Astron. Soc. 1989, 237, 355–379. [Google Scholar] [CrossRef]
  25. Komatsu, H.; Eriguchi, Y.; Hachisu, I. Rapidly rotating general relativistic stars. II–Differentially rotating polytropes. Mon. Not. R. Astron. Soc. 1989, 239, 153–171. [Google Scholar] [CrossRef]
  26. Ansorg, M.; Brügmann, B.; Tichy, W. A single-domain spectral method for black hole puncture data. Phys. Rev. D 2004, 70, 064011. [Google Scholar] [CrossRef]
  27. Langage Objet pour la RElativité Numérique. Available online: www.lorene.obspm.fr (accessed on 1 September 2008).
  28. Kadath Spectral Solver. Available online: https://kadath.obspm.fr (accessed on 1 May 2010).
  29. Grandclement, P. Kadath: A Spectral solver for theoretical physics. J. Comput. Phys. 2010, 229, 3334–3357. [Google Scholar] [CrossRef]
  30. Papenfort, L.J.; Tootle, S.D.; Grandclément, P.; Most, E.R.; Rezzolla, L. New public code for initial data of unequal-mass, spinning compact-object binaries. Phys. Rev. D 2021, 104, 024057. [Google Scholar] [CrossRef]
  31. Tichy, W. A New numerical method to construct binary neutron star initial data. Class. Quant. Grav. 2009, 26, 175018. [Google Scholar] [CrossRef]
  32. Pfeiffer, H.P.; Kidder, L.E.; Scheel, M.A.; Teukolsky, S.A. A multidomain spectral method for solving elliptic equations. Comput. Phys. Commun. 2003, 152, 253–273. [Google Scholar] [CrossRef]
  33. Rashti, A.; Fabbri, F.M.; Brügmann, B.; Chaurasia, S.V.; Dietrich, T.; Ujevic, M.; Tichy, W. New pseudospectral code for the construction of initial data. Phys. Rev. D 2022, 105, 104027. [Google Scholar] [CrossRef]
  34. Assumpcao, T.; Werneck, L.R.; Jacques, T.P.; Etienne, Z.B. Fast hyperbolic relaxation elliptic solver for numerical relativity: Conformally flat, binary puncture initial data. Phys. Rev. D 2022, 105, 104037. [Google Scholar] [CrossRef]
  35. Tsokaros, A.; Uryū, K. Methods for relativistic self-gravitating fluids: From binary neutron stars to black hole-disks and magnetized rotating neutron stars. Gen. Rel. Grav. 2022, 54, 52. [Google Scholar] [CrossRef]
  36. Isenberg, J.A. Waveless Approximation Theories of Gravity. Int. J. Mod. Phys. 2008, 17, 265–273. [Google Scholar] [CrossRef]
  37. Wilson, J.R.; Mathews, G.J. Relativistic hydrodynamics. In Frontiers in Numerical Relativity; Evans, C.R., Finn, L.S., Hobill, D.W., Eds.; Cambridge University Press: Cambridge, UK, 1989; pp. 306–314. [Google Scholar]
  38. Wilson, J.R.; Mathews, G.J. Instabilities in Close Neutron Star Binaries. Phys. Rev. Lett. 1995, 75, 4161. [Google Scholar] [CrossRef] [PubMed]
  39. Wilson, J.R.; Mathews, G.J.; Marronetti, P. Relativistic numerical model for close neutron-star binaries. Phys. Rev. D 1996, 54, 1317–1331. [Google Scholar] [CrossRef]
  40. Shibata, M.; Uryu, K.; Friedman, J.L. Deriving formulations for numerical computation of binary neutron stars in quasicircular orbits. Phys. Rev. 2004, D70, 044044. [Google Scholar] [CrossRef]
  41. Bonazzola, S.; Gourgoulhon, E.; Grandclement, P.; Novak, J. A constrained scheme for Einstein equations based on Dirac gauge and spherical coordinates. Phys. Rev. D 2004, 70, 104007. [Google Scholar] [CrossRef]
  42. Uryū, K.; Limousin, F.; Friedman, J.L.; Gourgoulhon, E.; Shibata, M. Binary Neutron Stars: Equilibrium Models beyond Spatial Conformal Flatness. Phys. Rev. Lett. 2006, 97, 171101. [Google Scholar] [CrossRef]
  43. Uryū, K.; Limousin, F.; Friedman, J.L.; Gourgoulhon, E.; Shibata, M. Non-conformally flat initial data for binary compact objects. Phys. Rev. D 2009, 80, 124004. [Google Scholar] [CrossRef]
  44. Bonazzola, S.; Gourgoulhon, E.; Marck, J.A. Relativistic formalism to compute quasiequilibrium configurations of nonsynchronized neutron star binaries. Phys. Rev. D 1997, 56, 7740–7749. [Google Scholar] [CrossRef]
  45. Asada, H. Formulation for the internal motion of quasiequilibrium configurations in general relativity. Phys. Rev. D 1998, 57, 7292–7298. [Google Scholar] [CrossRef]
  46. Shibata, M. Relativistic formalism for computation of irrotational binary stars in quasiequilibrium states. Phys. Rev. D 1998, 58, 024012. [Google Scholar] [CrossRef]
  47. Teukolsky, S.A. Irrotational Binary Neutron Stars in Quasi-Equilibrium in General Relativity. Astrophys. J. 1998, 504, 442–449. [Google Scholar] [CrossRef]
  48. Tichy, W. Initial data for binary neutron stars with arbitrary spins. Phys. Rev. D 2011, 84, 024041. [Google Scholar] [CrossRef]
  49. Rafelski, J. Melting Hadrons, Boiling Quarks. Eur. Phys. J. A 2015, 51, 114. [Google Scholar] [CrossRef]
  50. Bodmer, A.R. Collapsed Nuclei. Phys. Rev. D 1971, 4, 1601–1606. [Google Scholar] [CrossRef]
  51. Witten, E. Cosmic separation of phases. Phys. Rev. D 1984, 30, 272–285. [Google Scholar] [CrossRef]
  52. Zhou, E.; Tsokaros, A.; Rezzolla, L.; Xu, R. Maximum mass of axisymmetric rotating quark stars. Astron. Nachr. 2017, 338, 1044–1047. [Google Scholar] [CrossRef]
  53. Zhou, E.; Tsokaros, A.; Rezzolla, L.; Xu, R.; Uryū, K. Rotating Quark Stars in General Relativity. Universe 2018, 4, 48. [Google Scholar] [CrossRef]
  54. Zhou, E.; Kiuchi, K.; Shibata, M.; Tsokaros, A.; Uryu, K. Evolution of bare quark stars in full general relativity: Single star case. Phys. Rev. D 2021, 103, 123011. [Google Scholar] [CrossRef]
  55. Zhou, E.; Kiuchi, K.; Shibata, M.; Tsokaros, A.; Uryu, K. Evolution of equal mass binary bare quark stars in full general relativity: Could a supramassive merger remnant experience prompt collapse? Phys. Rev. D 2022, 106, 103030. [Google Scholar] [CrossRef]
  56. Shibata, M.; Sekiguchi, Y. Gravitational waves from axisymmetric rotating stellar core collapse to a neutron star in full general relativity. Phys. Rev. D 2004, 69, 084024. [Google Scholar] [CrossRef]
  57. Nakamura, T.; Oohara, K.; Kojima, Y. General Relativistic Collapse to Black Holes and Gravitational Waves from Black Holes. Prog. Theor. Phys. Suppl. 1987, 90, 1–218. [Google Scholar] [CrossRef]
  58. Shibata, M.; Nakamura, T. Evolution of three-dimensional gravitational waves: Harmonic slicing case. Phys. Rev. D 1995, 52, 5428–5444. [Google Scholar] [CrossRef]
  59. Baumgarte, T.W.; Shapiro, S.L. Numerical integration of Einstein’s field equations. Phys. Rev. D 1999, 59, 024007. [Google Scholar] [CrossRef]
Figure 1. A typical setup with multiple coordinate grid patches in the cocal code for a black hole–neutron star system. The left and right top patches are those for compact object coordinate patches (COCPs) centered at the black hole and the neutron star, respectively. The smallest circle with a thick curve in COCP-BH is the sphere S a , where the interior region is excised and certain boundary conditions are imposed. The ovals drawn in COCP-NS denote the neutron star. The bottom patch is that for asymptotic region coordinate patch (ARCP), centered at the mass center of the system. The arrows represent maps of potentials between the multiple patches. Note that the spheres S a , S b , and S e of these coordinate patches are distinct despite our use of a common symbol. The radius of each coordinate patch does not reflect the size used in actual computations.
Figure 1. A typical setup with multiple coordinate grid patches in the cocal code for a black hole–neutron star system. The left and right top patches are those for compact object coordinate patches (COCPs) centered at the black hole and the neutron star, respectively. The smallest circle with a thick curve in COCP-BH is the sphere S a , where the interior region is excised and certain boundary conditions are imposed. The ovals drawn in COCP-NS denote the neutron star. The bottom patch is that for asymptotic region coordinate patch (ARCP), centered at the mass center of the system. The arrows represent maps of potentials between the multiple patches. Note that the spheres S a , S b , and S e of these coordinate patches are distinct despite our use of a common symbol. The radius of each coordinate patch does not reflect the size used in actual computations.
Universe 10 00229 g001
Figure 2. Upper two panels: Speedup (top) and efficiency of the parallelized (solid lines) and total code (dashed lines) of a single rotating star module in the waveless formalism for three different resolutions, H2, H3, and H4. In all cases, the maximum number of terms in the Legendre expansion is L = 12 . The vertical dashed line denotes the number of cores/CPU of server A. Bottom three panels: Performance time of the whole code in the three resolutions.
Figure 2. Upper two panels: Speedup (top) and efficiency of the parallelized (solid lines) and total code (dashed lines) of a single rotating star module in the waveless formalism for three different resolutions, H2, H3, and H4. In all cases, the maximum number of terms in the Legendre expansion is L = 12 . The vertical dashed line denotes the number of cores/CPU of server A. Bottom three panels: Performance time of the whole code in the three resolutions.
Universe 10 00229 g002
Figure 3. Time for the Poisson solvers (red dots) as well as for a single iteration (blue dots) for the H3 resolution in a single core for various values of Legendre terms L. Solids lines represent fitting functions.
Figure 3. Time for the Poisson solvers (red dots) as well as for a single iteration (blue dots) for the H3 resolution in a single core for various values of Legendre terms L. Solids lines represent fitting functions.
Universe 10 00229 g003
Figure 4. Same as in Figure 2 but only for resolution H4 with L = 12 , 24 , 48 . Speedup and efficiency in a second server (server B) is also shown for L = 24 (cyan curve on the upper two panels). As in Figure 2, solid lines in the left panels correspond to S p and E p , while dashed lines correspond to S and E. Vertical dashed lines denote the number of cores/CPU of servers A and B.
Figure 4. Same as in Figure 2 but only for resolution H4 with L = 12 , 24 , 48 . Speedup and efficiency in a second server (server B) is also shown for L = 24 (cyan curve on the upper two panels). As in Figure 2, solid lines in the left panels correspond to S p and E p , while dashed lines correspond to S and E. Vertical dashed lines denote the number of cores/CPU of servers A and B.
Universe 10 00229 g004
Figure 5. Same as in Figure 2 but for binary neutron stars. The resolutions used are shown in Table 4 and are E2.5, E3.0, and E3.5. As in Figure 2, solid lines in the left panels correspond to S p and E p , while dashed lines correspond to S and E. Vertical dashed lines denote the number of cores/CPU of server A.
Figure 5. Same as in Figure 2 but for binary neutron stars. The resolutions used are shown in Table 4 and are E2.5, E3.0, and E3.5. As in Figure 2, solid lines in the left panels correspond to S p and E p , while dashed lines correspond to S and E. Vertical dashed lines denote the number of cores/CPU of server A.
Universe 10 00229 g005
Figure 6. A spinning binary quark star. The rest mass density ρ is shown for the star on the left, while the velocity potential Φ is plotted for the star on the right. Contour plots of the conformal factor ψ (green dashed lines) and the velocity potential Φ (brown dashed lines in the right quark star), as well as the fluid velocity with respect to the corotating observer, are shown.
Figure 6. A spinning binary quark star. The rest mass density ρ is shown for the star on the left, while the velocity potential Φ is plotted for the star on the right. Contour plots of the conformal factor ψ (green dashed lines) and the velocity potential Φ (brown dashed lines in the right quark star), as well as the fluid velocity with respect to the corotating observer, are shown.
Universe 10 00229 g006
Table 1. Summary of parameters used for single rotating star configurations. R ( θ , ϕ ) denotes the neutron star surface.
Table 1. Summary of parameters used for single rotating star configurations. R ( θ , ϕ ) denotes the neutron star surface.
r a :Radial coordinate where the grid r i starts.
r b :Radial coordinate where the grid r i ends.
r c :Radial coordinate between r a and r b where the grid changes from equidistant to non-equidistant.
N r :Total number of intervals Δ r i between r a and r b .
N r m :Number of intervals Δ r i in [ r a , r c ] .
N r f :Number of intervals Δ r i in [ 0 , R ( θ , ϕ ) ] .
N θ :Total number of intervals Δ θ i for θ [ 0 , π ] .
N ϕ :Total number of intervals Δ ϕ i for ϕ [ 0 , 2 π ] .
L:Number of multipole in the Legendre expansion.
Table 2. Summary of the grid the parameters used for the binary systems and, in particular, the binary neutron stars computed here. R ( θ , ϕ ) denotes the neutron star surface. Every patch has its own set of parameters above.
Table 2. Summary of the grid the parameters used for the binary systems and, in particular, the binary neutron stars computed here. R ( θ , ϕ ) denotes the neutron star surface. Every patch has its own set of parameters above.
r a :Radial coordinate where the radial grids start. For the COCP-NS patch it is r a = 0 .
r b :Radial coordinate where the radial grids end.
r c :Center of mass point. Excised sphere is located at 2 r c in the COCP patch.
r e :Radius of the excised sphere. Only in the COCP patch.
N r :Number of intervals Δ r i in [ r a , r b ] .
N r f :Number of intervals Δ r i in [ 0 , R ( θ , ϕ ) ] for the COCP-NS patch or in [ r a , r a + 1 ] for the ARCP patch.
N r m :Number of intervals Δ r i in [ r a , r c ] .
N θ :Number of intervals Δ θ j in [ 0 , π ] .
N ϕ :Number of intervals Δ ϕ k in [ 0 , 2 π ] .
L:Order of included multipoles.
Table 3. Three different resolutions used for the single rotating star tests. The parameters are shown in Table 1. The number of points that cover the largest star radius is N r f . Resolutions H2, H3, and H4 correspondingly use 2, 10.3, and 80.1 GB of RAM.
Table 3. Three different resolutions used for the single rotating star tests. The parameters are shown in Table 1. The number of points that cover the largest star radius is N r f . Resolutions H2, H3, and H4 correspondingly use 2, 10.3, and 80.1 GB of RAM.
Type r a r b r c N r N r m N r f N θ N ϕ
H20 10 6 1.2519280644848
H30 10 6 1.253841601289696
H40 10 6 1.25768320256192192
Table 4. Three different grid structure parameters used for the circular binary computation in COCAL. The amount of RAM used in each resolution is written in the first column. All variables are explained in Table 2, and the distances are in normalized quantities [16]. There are two COCP grids centered around each neutron star and one ARCP centered at the center of mass of the system (see Figure 1). Resolutions E2.5, E3.0, and E3.5 correspondingly use 5.0, 9.9, and 30.6 GB of RAM.
Table 4. Three different grid structure parameters used for the circular binary computation in COCAL. The amount of RAM used in each resolution is written in the first column. All variables are explained in Table 2, and the distances are in normalized quantities [16]. There are two COCP grids centered around each neutron star and one ARCP centered at the center of mass of the system (see Figure 1). Resolutions E2.5, E3.0, and E3.5 correspondingly use 5.0, 9.9, and 30.6 GB of RAM.
TypePatch r a r b r c r e N r f N r m N r N θ N ϕ L
E2.5 COCP 0.0 40 2.51 2.375 80151288727212
ARCP 5.0 10 6 6.25 2430288727212
E3.0 COCP 0.0 40 2.51 2.35 100188384969612
ARCP 5.0 10 6 6.25 3240384969612
E3.5 COCP 0.0 40 2.51 2.355 15228657614414412
ARCP 5.0 10 6 6.25 486057614414412
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.

Share and Cite

MDPI and ACS Style

Boukas, L.; Tsokaros, A.; Uryū, K. The Parallel Compact Object CALculator: An Efficient General Relativistic Initial Data Solver for Compact Objects. Universe 2024, 10, 229. https://doi.org/10.3390/universe10050229

AMA Style

Boukas L, Tsokaros A, Uryū K. The Parallel Compact Object CALculator: An Efficient General Relativistic Initial Data Solver for Compact Objects. Universe. 2024; 10(5):229. https://doi.org/10.3390/universe10050229

Chicago/Turabian Style

Boukas, Lambros, Antonios Tsokaros, and Kōji Uryū. 2024. "The Parallel Compact Object CALculator: An Efficient General Relativistic Initial Data Solver for Compact Objects" Universe 10, no. 5: 229. https://doi.org/10.3390/universe10050229

APA Style

Boukas, L., Tsokaros, A., & Uryū, K. (2024). The Parallel Compact Object CALculator: An Efficient General Relativistic Initial Data Solver for Compact Objects. Universe, 10(5), 229. https://doi.org/10.3390/universe10050229

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop