freddi


Namefreddi JSON
Version 2.0.0 PyPI version JSON
download
home_pagehttp://xray.sai.msu.ru/~malanchev/freddi/
SummaryCompute FRED light curves of LMXBs outbursts
upload_time2024-04-13 13:03:23
maintainerNone
docs_urlNone
authorKonstantin Malanchev
requires_python>=3.7
licenseGPLv3
keywords science astrophysics accretion
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # `Freddi` — compute FRED-like light curves of LMXB

## Table of contents

- [Overview](#overview)
- [Installation](#installation)
- [Usage](#usage)
- [Physical Background](#physical-background) 
- [Accretion disk wind](#accretion-disk-wind) 
- [Development guide](#development-guide)
- [Questions and comments](#questions-and-comments)
- [License](#license)
- [BibTex](#bibtex)

## Overview

The code solves 1-D evolution equation of Shakura-Sunyaev accretion alpha-disk
around black hole or neutron star. The code is developed to simulate fast-rise 
exponential-decay (FRED) light curves of low mass X-ray binaries (LMXBs). 
It has been first presented in the paper “Determination of the turbulent 
parameter in the accretion disks: effects of self-irradiation in 4U 1543-47 
during the 2002 outburst” by Lipunova & Malanchev (2017)
[2017MNRAS.468.4735L](http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L). 
Currently, the code can take into account self-irradiation of the disc, 
winds from the disc surface, disc-magnetosphere interactions. The related 
papers are Avakyan et al (2021) [2021AstL...47..377A](http://adsabs.harvard.edu/abs/2021AstL...47..377A)
and Lipunova et al (2021)
[2021arXiv211008076L](http://adsabs.harvard.edu/abs/2021arXiv211008076L).

`Freddi` is written on C++ and available as a couple of binary executables and
a Python module.

Note that the original `Freddi` version 1 introduced in Lipunova & Malanchev (2017)
[2017MNRAS.468.4735L](http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L) is still
available in the [`v1` git branch](https://github.com/hombit/freddi/tree/v1).

## Installation

### Executables

`Freddi` is represented by two binary executables: the black hole version
`freddi` and the neutron star version `freddi-ns`.

#### Docker

If you are familiar with [Docker](http://docker.com) then you can use
pre-compiled binaries inside Docker container:
```sh
docker run -v "`pwd`":/data --rm -ti ghcr.io/hombit/freddi freddi -d/data
docker run -v "`pwd`":/data --rm -ti ghcr.io/hombit/freddi freddi-ns --Bx=1e8 -d/data
```

#### Build from source

`Freddi` has following build dependencies:

- [Boost](http://www.boost.org/) 1.57+
- [CMake](https://cmake.org) with a back-end build system like Make or Ninja
- C++ compiler with C++17 support, e.g. `gcc` version 8+ or `clang` 5+

Get requirements on Debian based systems (e.g. Ubuntu):
```sh
apt-get install g++ cmake libboost-all-dev
```

On Red-Hat based systems (e.g. Fedora):
```sh
dnf install gcc-c++ cmake boost-devel
```

On macOS via [Homebrew](https://brew.sh):
```sh
brew install cmake boost
```

Get `Freddi` source code and compile it:
```sh
git clone https://github.com/hombit/freddi
cd freddi
mkdir cmake-build
cd cmake-build
cmake .. # -DSTATIC_LINKING=TRUE
cmake --build .
```

Uncomment `-DSTATIC_LINKING=TRUE` to link against static Boost libraries

Now you should have both `freddi` and `freddi-ns` executables in the build
directory. You can install these binaries and the default configuration
file `freddi.ini` by running
```sh
cmake --install . --prefix=PREFIX  # replace with preferable location
```

`Freddi` is known to be built on Linux and macOS.

### Python

[![PyPI version](https://badge.fury.io/py/freddi.svg)](https://badge.fury.io/py/freddi)

Python 2 isn't supported, use Python 3 instead.

`Freddi` pre-compiled x86-64 Linux packages for several Python versions
are available on <https://pypi.org/project/freddi/> and can be used as is,
while for other configurations you should have C++ compiler and Boost
libraries in your system before running this command:

```sh
# Please upgrade your pip
python3 -m pip install -U pip
# Depending on your Python setup, you need or need not --user flag
python3 -m pip install --user freddi
```

[`astropy`](https://astropy.org) is an optional requirement which must be
installed to use dimensional input via `Freddi.from_astropy`

## Usage

### Executables

`Freddi` runs from the command line with inline options and/or with configuration 
files. `Freddi` outputs file `freddi.dat` with distribution of various physical values 
over time. If `--fulldata` is specified then files `freddi_%d.dat` for each time step 
are created in the same directory with snapshot radial distributions. These data-files 
contain whitespace-separated data columns with header lines starting
with `#` symbol. You can set another prefix instead of `freddi` with `--prefix`
option and change the output directory with `--dir` option. If you choose the
Docker way and would like to specify the directory, then avoid using `--dir`
option and just replace `` "`pwd`" `` with some local path (for more details see
[Docker documentation](https://docs.docker.com/engine/tutorials/dockervolumes)).

#### <a name="usage-executables-options"> Options

The full list of command line options is viewed with `--help` option. Default
values are given in brackets.

```sh
./freddi --help
```

<details><summary>expand</summary>

```
Freddi: numerical calculation of accretion disk evolution:

General options::
  -h [ --help ]                    Produce help message
                                   
  --config arg                     Set filepath for additional configuration 
                                   file. There is no need to declare a 
                                   configuration file with the default name 
                                   freddi.ini
                                   
  --prefix arg (=freddi)           Set prefix for output filenames. Output file
                                   with distribution of parameters over time is
                                   PREFIX.dat
                                   
  --stdout                         Output temporal distribution to stdout 
                                   instead of PREFIX.dat file
                                   
  -d [ --dir ] arg (=.)            Choose the directory to write output files. 
                                   It should exist
                                   
  --precision arg (=12)            Number of digits to print into output files
                                   
  --tempsparsity arg (=1)          Output every k-th time moment
                                   
  --fulldata                       Output files PREFIX_%d.dat with radial 
                                   structure for every time step. Default is to
                                   output only PREFIX.dat with global disk 
                                   parameters for every time step
                                   

Basic binary and disk parameters
:
  -a [ --alpha ] arg               Alpha parameter of Shakura-Sunyaev model
                                   
  --alphacold arg                  Alpha parameter of cold disk, currently it 
                                   is used only for the critical maximum value 
                                   of the surface density of the cold disk 
                                   Sigma_minus (Lasota et al., 2008, A&A 486, 
                                   523) and the cooling front velocity (Ludwig 
                                   et al., 1994, A&A 290, 473), see 
                                   --Qirr2Qvishot. Default value is --alpha 
                                   divided by ten
                                   
  -M [ --Mx ] arg                  Mass of the central object, in the units of 
                                   solar masses
                                   
  --kerr arg (=0)                  Dimensionless Kerr parameter of the black 
                                   hole
                                   
  --Mopt arg                       Mass of the optical star, in units of solar 
                                   masses
                                   
  --rochelobefill arg (=1)         Dimensionless factor describing a size of 
                                   the optical star. Polar radius of the star 
                                   is rochelobefill * (polar radius of critical
                                   Roche lobe)
                                   
  --Topt arg (=0)                  Effective temperature of the optical star, 
                                   in units of Kelvins
                                   
  -P [ --period ] arg              Orbital period of the binary system, in 
                                   units of days
                                   
  --rin arg                        Inner radius of the disk, in the units of 
                                   the gravitational radius of the central 
                                   object GM/c^2. There is no need to set it 
                                   for a neutron star. If it isn't set for a 
                                   black hole then the radius of ISCO orbit is 
                                   used, defined by --Mx and --kerr values
                                   
  -R [ --rout ] arg                Outer radius of the disk, in units of solar 
                                   radius. If it isn't set then the tidal 
                                   radius is used, defined by --Mx, --Mopt and 
                                   --period values as 90% of the Roche lobe 
                                   radius (Papaloizou & Pringle, 1977, MNRAS, 
                                   181, 441; see also Artymowicz & Lubow, 1994,
                                   ApJ, 421, 651; http://xray.sai.msu.ru/~galja
                                   /images/tidal_radius.pdf)
                                   
  --risco arg                      Innermost stable circular orbit, in units of
                                   gravitational radius of the central object 
                                   GM/c^2. If it isn't set then the radius of 
                                   ISCO orbit is used defined by --Mx and 
                                   --kerr values
                                   

Parameters of the disk model:
  -O [ --opacity ] arg (=Kramers)  Opacity law: Kramers (varkappa ~ rho / 
                                   T^7/2) or OPAL (varkappa ~ rho / T^5/2)
                                   
  --Mdotout arg (=0)               Accretion rate onto the disk through its 
                                   outer radius
                                   
  --boundcond arg (=Teff)          Outer-boundary movement condition
                                   
                                   Values:
                                     Teff: outer radius of the disk moves 
                                   inwards to keep photosphere temperature of 
                                   the disk larger than some value. This value 
                                   is specified by --Thot option
                                     Tirr: outer radius of the disk moves 
                                   inwards to keep irradiation flux of the disk
                                   larger than some value. The value of this 
                                   minimal irradiation flux is 
                                   [Stefan-Boltzmann constant] * Tirr^4, where 
                                   Tirr is specified by --Thot option
                                   
  --Thot arg (=0)                  Minimum photosphere or irradiation 
                                   temperature at the outer edge of the hot 
                                   disk, Kelvin. For details see --boundcond 
                                   description
                                   
  --Qirr2Qvishot arg (=0)          Minimum Qirr / Qvis ratio at the outer edge 
                                   of the hot disk to switch the control over 
                                   the evolution of the hot disk radius: from 
                                   temperature-based regime to Sigma-based 
                                   cooling-front regime (see Lipunova et al. 
                                   (2021, Section 2.4) and Eq. A.1 in Lasota et
                                   al. 2008; --alpha value is used for 
                                   Sigma_plus and --alphacold value is used for
                                   Sigma_minus)
                                   
  --initialcond arg (=powerF)      Type of the initial condition for viscous 
                                   torque F or surface density Sigma
                                   
                                   Values:
                                     [NB! Here below dimensionless xi = (h - 
                                   h_in) / (h_out - h_in)]
                                   
                                     powerF: F ~ xi^powerorder, powerorder is 
                                   specified by --powerorder option
                                     linearF: F ~ xi, specific case of powerF 
                                   but can be normalised by --Mdot0, see its 
                                   description for details
                                     powerSigma: Sigma ~ xi^powerorder, 
                                   powerorder is specified by --powerorder 
                                   option
                                     sineF: F ~ sin( xi * pi/2 )
                                     gaussF: F ~ exp(-(xi-mu)**2 / 2 sigma**2),
                                   mu and sigma are specified by --gaussmu and 
                                   --gausssigma options
                                     quasistat: F ~ f(h/h_out) * xi * h_out/h, 
                                   where f is quasi-stationary solution found 
                                   in Lipunova & Shakura 2000. f(xi=0) = 0, 
                                   df/dxi(xi=1) = 0
                                   
  --F0 arg                         Initial maximum viscous torque in the disk, 
                                   dyn*cm. Can be overwritten via --Mdisk0 and 
                                   --Mdot0
                                   
  --Mdisk0 arg                     Initial disk mass, g. If both --F0 and 
                                   --Mdisk0 are specified then --Mdisk0 is 
                                   used. If both --Mdot0 and --Mdisk0 are 
                                   specified then --Mdot0 is used
                                   
  --Mdot0 arg                      Initial mass accretion rate through the 
                                   inner radius, g/s. If --F0, --Mdisk0 and 
                                   --Mdot0 are specified then --Mdot0 is used. 
                                   Works only when --initialcond is set to 
                                   linearF, sinusF or quasistat
                                   
  --powerorder arg                 Parameter for the powerlaw initial condition
                                   distribution. This option works only with 
                                   --initialcond=powerF or powerSigma
                                   
  --gaussmu arg                    Position of the maximum for Gauss 
                                   distribution, positive number not greater 
                                   than unity. This option works only with 
                                   --initialcond=gaussF
                                   
  --gausssigma arg                 Width of for Gauss distribution. This option
                                   works only with --initialcond=gaussF
                                   
  --windtype arg (=no)             Type of the wind
                                   
                                     no: no wind
                                     SS73C: super-Eddington spherical wind from
                                   Shakura-Sunyaev 1973
                                     ShieldsOscil1986: toy wind model from 
                                   Shields et al. 1986 which was used to obtain
                                   oscillations in the disk luminosity. 
                                   Requires --windC_w and --windR_w to be 
                                   specified
                                     Janiuk2015: super-Eddington wind from 
                                   Janiuk et al 2015. Requires --windA_0 and 
                                   --windB_1 to be specified
                                     Shields1986: thermal wind from Begelman et
                                   al. 1983 and Shields et al. 1986. Requires 
                                   --windXi_max, --windT_ic and --windPow to be
                                   specified
                                     Woods1996AGN: thermal AGN wind from Woods 
                                   et al. 1996. Requires --windC_0 and 
                                   --windT_ic to be specified
                                     Woods1996: thermal wind from Woods et al. 
                                   1996. Requires --windXi_max, --windT_ic and 
                                   --windPow to be specified
                                     toy: a toy wind model used in 
                                   arXiv:2105.11974, the mass loss rate is 
                                   proportional to the central accretion rate. 
                                   Requires --windC_w to be specified
                                   
  --windC_w arg                    The ratio of the mass loss rate due to wind 
                                   to the central accretion rate, |Mwind|/Macc
                                   
  --windR_w arg                    The ratio of the wind launch radius to the 
                                   outer disk radius, Rwind/Rout
                                   
  --windA_0 arg                    Dimensionless parameter characterizing the 
                                   strength of the super-Eddington wind in the 
                                   framework of the model Janiuk et al. 2015. 
                                   Effective value range from 10 to 25
                                   
  --windB_1 arg                    The quantity is of the order of unity. 
                                   Characterizes the relationship between the 
                                   change in energy per particle and virial 
                                   energy.
                                   E = B_1 * k * T
                                   
  --windXi_max arg                 Ionization parameter, the ratio of the 
                                   radiation and gas pressures
                                   
  --windT_ic arg                   Inverse Compton temperature, K. 
                                   Characterizes the hardness of the 
                                   irradiating spectrum
                                   
  --windPow arg                    Multiplicative coefficient to control wind 
                                   power
                                   
  --windC_0 arg                    Characteristic column density of the wind 
                                   mass loss rate from Woods et al. 1996 model,
                                   g/(s*cm^2). For AGN approx value is 3e-13 
                                   g/(s*cm^2)
                                   

Parameters of self-irradiation:
Qirr = Cirr * (H/r / 0.05)^irrindex * L * psi / (4 pi R^2), where psi is the angular distribution of X-ray radiation
:
  --Cirr arg (=0)                  Irradiation factor for the hot disk
                                   
  --irrindex arg (=0)              Irradiation index for the hot disk
                                   
  --Cirrcold arg (=0)              Irradiation factor for the cold disk
                                   
  --irrindexcold arg (=0)          Irradiation index for the cold disk
                                   
  --h2rcold arg (=0)               Semi-height to radius ratio for the cold 
                                   disk
                                   
  --angulardistdisk arg (=plane)   Angular distribution of the disk X-ray 
                                   radiation. Values: isotropic, plane
                                   

Parameters of flux calculation:
:
  --colourfactor arg (=1.7)        Colour factor to calculate X-ray flux
                                   
  --emin arg (=1)                  Minimum energy of X-ray band, keV
                                   
  --emax arg (=12)                 Maximum energy of X-ray band, keV
                                   
  --staralbedo arg (=0)            Part of X-ray radiation reflected by optical
                                   star, (1 - albedo) heats star's photosphere.
                                   Used only when --starflux is specified
                                   
  -i [ --inclination ] arg (=0)    Inclination of the system, degrees
                                   
  --ephemerist0 arg (=0)           Ephemeris for the time of the minimum of the
                                   orbital light curve T0, phase zero 
                                   corresponds to inferior conjunction of the 
                                   optical star, days
                                   
  --distance arg                   Distance to the system, kpc
                                   
  --colddiskflux                   Add Fnu for cold disk into output file. 
                                   Default output is for hot disk only
                                   
  --starflux                       Add Fnu for irradiated optical star into 
                                   output file. See --Topt, --starlod and 
                                   --h2rcold options. Default is output for the
                                   hot disk only
                                   
  --lambda arg                     Wavelength to calculate Fnu, Angstrom. You 
                                   can use this option multiple times. For each
                                   lambda one additional column with values of 
                                   spectral flux density Fnu [erg/s/cm^2/Hz] is
                                   produced
                                   
  --passband arg                   Path of a file containing tabulated passband
                                   for a photon counter detector, the first 
                                   column for wavelength in Angstrom, the 
                                   second column for transmission factor, 
                                   columns should be separated by spaces
                                   

Parameters of disk evolution calculation:
:
  --inittime arg (=0)              Initial time moment, days
                                   
  -T [ --time ] arg                Time interval to calculate evolution, days
                                   
  --tau arg                        Time step, days
                                   
  --Nx arg (=1000)                 Size of calculation grid
                                   
  --gridscale arg (=log)           Type of grid for angular momentum h: log or 
                                   linear
                                   
  --starlod arg (=3)               Level of detail of the optical star 3-D 
                                   model. The optical star is represented by a 
                                   triangular tile, the number of tiles is 20 *
                                   4^starlod
                                   


```
</details>

```sh
./freddi-ns --help
```

<details><summary>expand</summary>

```
Freddi NS: numerical calculation of accretion disk evolution:

General options::
  -h [ --help ]                         Produce help message
                                        
  --config arg                          Set filepath for additional 
                                        configuration file. There is no need to
                                        declare a configuration file with the 
                                        default name freddi.ini
                                        
  --prefix arg (=freddi)                Set prefix for output filenames. Output
                                        file with distribution of parameters 
                                        over time is PREFIX.dat
                                        
  --stdout                              Output temporal distribution to stdout 
                                        instead of PREFIX.dat file
                                        
  -d [ --dir ] arg (=.)                 Choose the directory to write output 
                                        files. It should exist
                                        
  --precision arg (=12)                 Number of digits to print into output 
                                        files
                                        
  --tempsparsity arg (=1)               Output every k-th time moment
                                        
  --fulldata                            Output files PREFIX_%d.dat with radial 
                                        structure for every time step. Default 
                                        is to output only PREFIX.dat with 
                                        global disk parameters for every time 
                                        step
                                        

Basic binary and disk parameters
:
  -a [ --alpha ] arg                    Alpha parameter of Shakura-Sunyaev 
                                        model
                                        
  --alphacold arg                       Alpha parameter of cold disk, currently
                                        it is used only for the critical 
                                        maximum value of the surface density of
                                        the cold disk Sigma_minus (Lasota et 
                                        al., 2008, A&A 486, 523) and the 
                                        cooling front velocity (Ludwig et al., 
                                        1994, A&A 290, 473), see 
                                        --Qirr2Qvishot. Default value is 
                                        --alpha divided by ten
                                        
  -M [ --Mx ] arg                       Mass of the central object, in the 
                                        units of solar masses
                                        
  --kerr arg (=0)                       Dimensionless Kerr parameter of the 
                                        black hole
                                        
  --Mopt arg                            Mass of the optical star, in units of 
                                        solar masses
                                        
  --rochelobefill arg (=1)              Dimensionless factor describing a size 
                                        of the optical star. Polar radius of 
                                        the star is rochelobefill * (polar 
                                        radius of critical Roche lobe)
                                        
  --Topt arg (=0)                       Effective temperature of the optical 
                                        star, in units of Kelvins
                                        
  -P [ --period ] arg                   Orbital period of the binary system, in
                                        units of days
                                        
  --rin arg                             Inner radius of the disk, in the units 
                                        of the gravitational radius of the 
                                        central object GM/c^2. There is no need
                                        to set it for a neutron star. If it 
                                        isn't set for a black hole then the 
                                        radius of ISCO orbit is used, defined 
                                        by --Mx and --kerr values
                                        
  -R [ --rout ] arg                     Outer radius of the disk, in units of 
                                        solar radius. If it isn't set then the 
                                        tidal radius is used, defined by --Mx, 
                                        --Mopt and --period values as 90% of 
                                        the Roche lobe radius (Papaloizou & 
                                        Pringle, 1977, MNRAS, 181, 441; see 
                                        also Artymowicz & Lubow, 1994, ApJ, 
                                        421, 651; http://xray.sai.msu.ru/~galja
                                        /images/tidal_radius.pdf)
                                        
  --risco arg                           Innermost stable circular orbit, in 
                                        units of gravitational radius of the 
                                        central object GM/c^2. If it isn't set 
                                        then the radius of ISCO orbit is used 
                                        defined by --Mx and --kerr values
                                        

Parameters of the disk model:
  -O [ --opacity ] arg (=Kramers)       Opacity law: Kramers (varkappa ~ rho / 
                                        T^7/2) or OPAL (varkappa ~ rho / T^5/2)
                                        
  --Mdotout arg (=0)                    Accretion rate onto the disk through 
                                        its outer radius
                                        
  --boundcond arg (=Teff)               Outer-boundary movement condition
                                        
                                        Values:
                                          Teff: outer radius of the disk moves 
                                        inwards to keep photosphere temperature
                                        of the disk larger than some value. 
                                        This value is specified by --Thot 
                                        option
                                          Tirr: outer radius of the disk moves 
                                        inwards to keep irradiation flux of the
                                        disk larger than some value. The value 
                                        of this minimal irradiation flux is 
                                        [Stefan-Boltzmann constant] * Tirr^4, 
                                        where Tirr is specified by --Thot 
                                        option
                                        
  --Thot arg (=0)                       Minimum photosphere or irradiation 
                                        temperature at the outer edge of the 
                                        hot disk, Kelvin. For details see 
                                        --boundcond description
                                        
  --Qirr2Qvishot arg (=0)               Minimum Qirr / Qvis ratio at the outer 
                                        edge of the hot disk to switch the 
                                        control over the evolution of the hot 
                                        disk radius: from temperature-based 
                                        regime to Sigma-based cooling-front 
                                        regime (see Lipunova et al. (2021, 
                                        Section 2.4) and Eq. A.1 in Lasota et 
                                        al. 2008; --alpha value is used for 
                                        Sigma_plus and --alphacold value is 
                                        used for Sigma_minus)
                                        
  --initialcond arg (=powerF)           Type of the initial condition for 
                                        viscous torque F or surface density 
                                        Sigma
                                        
                                        Values:
                                          [NB! Here below dimensionless xi = (h
                                        - h_in) / (h_out - h_in)]
                                        
                                          powerF: F ~ xi^powerorder, powerorder
                                        is specified by --powerorder option
                                          linearF: F ~ xi, specific case of 
                                        powerF but can be normalised by 
                                        --Mdot0, see its description for 
                                        details
                                          powerSigma: Sigma ~ xi^powerorder, 
                                        powerorder is specified by --powerorder
                                        option
                                          sineF: F ~ sin( xi * pi/2 )
                                          gaussF: F ~ exp(-(xi-mu)**2 / 2 
                                        sigma**2), mu and sigma are specified 
                                        by --gaussmu and --gausssigma options
                                          quasistat: F ~ f(h/h_out) * xi * 
                                        h_out/h, where f is quasi-stationary 
                                        solution found in Lipunova & Shakura 
                                        2000. f(xi=0) = 0, df/dxi(xi=1) = 0
                                          quasistat-ns: Distibution of the 
                                        initial viscous torque in the disc is  
                                        F = F0 * f_F(xi) * (1-h_in/h_out/xi) / 
                                        (1-h_in/h_out), where xi=h/h_out and 
                                        f_F(xi) is taken from Lipunova & 
                                        Shakura (2000)
                                        
  --F0 arg                              Initial maximum viscous torque in the 
                                        disk, dyn*cm. Can be overwritten via 
                                        --Mdisk0 and --Mdot0
                                        
  --Mdisk0 arg                          Initial disk mass, g. If both --F0 and 
                                        --Mdisk0 are specified then --Mdisk0 is
                                        used. If both --Mdot0 and --Mdisk0 are 
                                        specified then --Mdot0 is used
                                        
  --Mdot0 arg                           Initial mass accretion rate through the
                                        inner radius, g/s. If --F0, --Mdisk0 
                                        and --Mdot0 are specified then --Mdot0 
                                        is used. Works only when --initialcond 
                                        is set to linearF, sinusF or quasistat
                                        
  --powerorder arg                      Parameter for the powerlaw initial 
                                        condition distribution. This option 
                                        works only with --initialcond=powerF or
                                        powerSigma
                                        
  --gaussmu arg                         Position of the maximum for Gauss 
                                        distribution, positive number not 
                                        greater than unity. This option works 
                                        only with --initialcond=gaussF
                                        
  --gausssigma arg                      Width of for Gauss distribution. This 
                                        option works only with 
                                        --initialcond=gaussF
                                        
  --windtype arg (=no)                  Type of the wind
                                        
                                          no: no wind
                                          SS73C: super-Eddington spherical wind
                                        from Shakura-Sunyaev 1973
                                          ShieldsOscil1986: toy wind model from
                                        Shields et al. 1986 which was used to 
                                        obtain oscillations in the disk 
                                        luminosity. Requires --windC_w and 
                                        --windR_w to be specified
                                          Janiuk2015: super-Eddington wind from
                                        Janiuk et al 2015. Requires --windA_0 
                                        and --windB_1 to be specified
                                          Shields1986: thermal wind from 
                                        Begelman et al. 1983 and Shields et al.
                                        1986. Requires --windXi_max, --windT_ic
                                        and --windPow to be specified
                                          Woods1996AGN: thermal AGN wind from 
                                        Woods et al. 1996. Requires --windC_0 
                                        and --windT_ic to be specified
                                          Woods1996: thermal wind from Woods et
                                        al. 1996. Requires --windXi_max, 
                                        --windT_ic and --windPow to be 
                                        specified
                                          toy: a toy wind model used in 
                                        arXiv:2105.11974, the mass loss rate is
                                        proportional to the central accretion 
                                        rate. Requires --windC_w to be 
                                        specified
                                        
  --windC_w arg                         The ratio of the mass loss rate due to 
                                        wind to the central accretion rate, 
                                        |Mwind|/Macc
                                        
  --windR_w arg                         The ratio of the wind launch radius to 
                                        the outer disk radius, Rwind/Rout
                                        
  --windA_0 arg                         Dimensionless parameter characterizing 
                                        the strength of the super-Eddington 
                                        wind in the framework of the model 
                                        Janiuk et al. 2015. Effective value 
                                        range from 10 to 25
                                        
  --windB_1 arg                         The quantity is of the order of unity. 
                                        Characterizes the relationship between 
                                        the change in energy per particle and 
                                        virial energy.
                                        E = B_1 * k * T
                                        
  --windXi_max arg                      Ionization parameter, the ratio of the 
                                        radiation and gas pressures
                                        
  --windT_ic arg                        Inverse Compton temperature, K. 
                                        Characterizes the hardness of the 
                                        irradiating spectrum
                                        
  --windPow arg                         Multiplicative coefficient to control 
                                        wind power
                                        
  --windC_0 arg                         Characteristic column density of the 
                                        wind mass loss rate from Woods et al. 
                                        1996 model, g/(s*cm^2). For AGN approx 
                                        value is 3e-13 g/(s*cm^2)
                                        

Parameters of accreting neutron star:
:
  --nsprop arg (=dummy)                 Neutron star properties name: defines 
                                        geometry (default values of --Rx, 
                                        --Risco, and --freqx) and 
                                        accretion->radiation efficiency of NS
                                        
                                        Values:
                                          dummy: NS accretion->radiation 
                                        efficiency is R_g * (1 / R_x - 1 / 
                                        2R_in), default --freqx is 0, default 
                                        Rx is 1e6, default Risco is Kerr value
                                          newt: NS accretion->radiation 
                                        efficiency is a function of NS 
                                        frequency, calculated in Newtonian 
                                        mechanics (see Lipunova+2021), that's 
                                        why --freqx must be specified 
                                        explicitly
                                          sibgatullin-sunyaev2000: NS 
                                        accretion->radiation efficiency and 
                                        default values of Rx and Risco are 
                                        functions of NS frequency, calculated 
                                        for a specific equation of state for a 
                                        NS with weak magnetic field 
                                        (Sibgatullin & Sunyaev, 2000, Astronomy
                                        Letters, 26, 699), that's why --freqx 
                                        must be specified explicitly
                                        
  --freqx arg                           Accretor rotation frequency, Hz. This 
                                        parameter is not linked to --kerr, 
                                        which could be reconciled manually 
                                        (currently, --kerr is not needed for 
                                        freddi-ns)
                                        
  --Rx arg                              Accretor radius, cm
                                        
  --Bx arg                              Accretor polar magnetic induction, G
                                        
  --hotspotarea arg (=1)                Total area of the region on the 
                                        accretor radiating because of 
                                        accretion, normalized by the accretor 
                                        surface area
                                        
  --epsilonAlfven arg (=1)              Magnetosphere radius in units of the 
                                        Alfven radius, which is defined as 
                                        (mu^4/G/M/sqrt(Mdot))^(1/7)
                                        
  --inversebeta arg (=0)                Not currently in use
                                        
  --Rdead arg (=0)                      Maximum inner radius of the disk that 
                                        can be achieved, cm
                                        
  --fptype arg (=no-outflow)            Scenario to determine the fraction fp 
                                        of accreted mass. The rest of the disk 
                                        inner accretion rate is propelled away.
                                        
                                        Values:
                                          no-outflow: the matter reaching the 
                                        inner disk radius always falls onto NS,
                                        fp = 1
                                          propeller: the matter always flows 
                                        away, fp = 0
                                          corotation-block: like 'no-outflow' 
                                        when the inner disk radius is smaller 
                                        than the corotation radius, like 
                                        'propeller' otherwise
                                          geometrical: experimental. 
                                        Generalization of 'corotation-block' 
                                        for the case of misaligned NS magnetic 
                                        axis. Requires --fp-geometrical-chi to 
                                        be specified
                                          eksi-kutlu2010: Under construction
                                          romanova2018: fp is an analytical 
                                        function of the fastness, found from 
                                        MHD simulations by Romanova et al. 
                                        (2018, NewA, 62, 94): fp = 1 - 
                                        par1*fastness^par2. This requires 
                                        --romanova2018-par1 and 
                                        --romanova2018-par2 to be specified
                                        
  --fp-geometrical-chi arg              angle between the disk rotation axis 
                                        and the NS magnetic axis, used for 
                                        --fptype=geometrical, degrees
                                        
  --romanova2018-par1 arg               par1 value for --fptype=romanova2018 
                                        and --kappattype=romanova2018
                                        
  --romanova2018-par2 arg               par2 value for --fptype=romanova2018 
                                        and --kappattype=romanova2018
                                        
  --kappattype arg (=const)             kappa_t describes how strong is the 
                                        interaction between the NS 
                                        magnetosphere and disk: total 
                                        (accelerating) magnetic torque applied 
                                        to the disc is kappa_t(R) * mu^2 / R^3.
                                        
                                        Values:
                                          const: doesn't depend on radius, 
                                        kappa_t = value. Requires 
                                        --kappat-const-value to be specified
                                          corstep: kappa_t can be different 
                                        inside and outside the corotation 
                                        radius. Requires --kappat-corstep-in 
                                        and --kappat-corstep-out to be 
                                        specified
                                          romanova2018: experimental. Similar 
                                        to corstep option, but the outside 
                                        value is reduced by the portion taken 
                                        away by the outflow (see Table 2 of 
                                        Romanova+2018, NewA, 62, 94). Requires 
                                        --kappat-romanova2018-in, 
                                        --kappat-romanova2018-out 
                                        --romanova2018-par1 and --romanova-par2
                                        to be specified
                                        
  --kappat-const-value arg (=0.33333333333333331)
                                        kappa_t value for --kappattype=const
                                        
  --kappat-corstep-in arg (=0.33333333333333331)
                                        kappa_t value inside the corotation 
                                        radius for --kappattype=corstep
                                        
  --kappat-corstep-out arg (=0.33333333333333331)
                                        kappa_t value outside the corotation 
                                        radius for --kappattype=corstep
                                        
  --kappat-romanova2018-in arg (=0.33333333333333331)
                                        kappa_t value inside the corotation 
                                        radius for --kappattype=romanova2018
                                        
  --kappat-romanova2018-out arg (=0.33333333333333331)
                                        kappa_t value outside the corotation 
                                        radius for --kappattype=romanova2018
                                        
  --nsgravredshift arg (=off)           Neutron star gravitational redshift 
                                        flag.
                                        
                                        Values:
                                          off: gravitational redshift is not 
                                        taken into account
                                          on: redshift is (1 - R_sch / Rx), 
                                        where R_sch = 2GM/c^2
                                        

Parameters of self-irradiation:
Qirr = Cirr * (H/r / 0.05)^irrindex * L * psi / (4 pi R^2), where psi is the angular distribution of X-ray radiation
:
  --Cirr arg (=0)                       Irradiation factor for the hot disk
                                        
  --irrindex arg (=0)                   Irradiation index for the hot disk
                                        
  --Cirrcold arg (=0)                   Irradiation factor for the cold disk
                                        
  --irrindexcold arg (=0)               Irradiation index for the cold disk
                                        
  --h2rcold arg (=0)                    Semi-height to radius ratio for the 
                                        cold disk
                                        
  --angulardistdisk arg (=plane)        Angular distribution of the disk X-ray 
                                        radiation. Values: isotropic, plane
                                        
  --angulardistns arg (=isotropic)      Flag to calculate angular distribution 
                                        the NS emission. Values: isotropic, 
                                        plane
                                        

Parameters of flux calculation:
:
  --colourfactor arg (=1.7)             Colour factor to calculate X-ray flux
                                        
  --emin arg (=1)                       Minimum energy of X-ray band, keV
                                        
  --emax arg (=12)                      Maximum energy of X-ray band, keV
                                        
  --staralbedo arg (=0)                 Part of X-ray radiation reflected by 
                                        optical star, (1 - albedo) heats star's
                                        photosphere. Used only when --starflux 
                                        is specified
                                        
  -i [ --inclination ] arg (=0)         Inclination of the system, degrees
                                        
  --ephemerist0 arg (=0)                Ephemeris for the time of the minimum 
                                        of the orbital light curve T0, phase 
                                        zero corresponds to inferior 
                                        conjunction of the optical star, days
                                        
  --distance arg                        Distance to the system, kpc
                                        
  --colddiskflux                        Add Fnu for cold disk into output file.
                                        Default output is for hot disk only
                                        
  --starflux                            Add Fnu for irradiated optical star 
                                        into output file. See --Topt, --starlod
                                        and --h2rcold options. Default is 
                                        output for the hot disk only
                                        
  --lambda arg                          Wavelength to calculate Fnu, Angstrom. 
                                        You can use this option multiple times.
                                        For each lambda one additional column 
                                        with values of spectral flux density 
                                        Fnu [erg/s/cm^2/Hz] is produced
                                        
  --passband arg                        Path of a file containing tabulated 
                                        passband for a photon counter detector,
                                        the first column for wavelength in 
                                        Angstrom, the second column for 
                                        transmission factor, columns should be 
                                        separated by spaces
                                        

Parameters of disk evolution calculation:
:
  --inittime arg (=0)                   Initial time moment, days
                                        
  -T [ --time ] arg                     Time interval to calculate evolution, 
                                        days
                                        
  --tau arg                             Time step, days
                                        
  --Nx arg (=1000)                      Size of calculation grid
                                        
  --gridscale arg (=log)                Type of grid for angular momentum h: 
                                        log or linear
                                        
  --starlod arg (=3)                    Level of detail of the optical star 3-D
                                        model. The optical star is represented 
                                        by a triangular tile, the number of 
                                        tiles is 20 * 4^starlod
                                        


```
</details>

**Write which options are mandatory**

Also you can use `freddi.ini` configuration file to store options. This [INI
file](https://en.wikipedia.org/wiki/INI_file) contains lines `option=value`,
option names are the as provided by the help message above. Command line option
overwrites configuration file option. For example, [see
default](https://github.com/hombit/freddi/blob/master/freddi.ini) `freddi.ini`.

Paths where this file is searched are `./freddi.ini` (execution path),
`$HOME/.config/freddi/freddi.ini`, `/usr/local/etc/freddi.ini` and
`/etc/freddi.ini`. You can provide configuration file to Docker container as a
volume: `` -v "`pwd`/freddi.ini":/etc/freddi.ini ``.

#### Output values

`Freddi` outputs time; the accretion rate; the mass of the hot part of the disk;
the outer radius of the hot zone; the irradiation factor; the relative
half-height, effective and irradiation temperature, ratio of the irradiation to
viscous flux at the outer radius of the hot zone; X-ray luminosity (erg/s) in
the band from E\_min to E\_max (`--emin` and `--emax` options); the optical
magnitudes in *U*, *B*, *V*, *R*, *I*, and *J* band ([Allen's Astrophysical
Quantities, Cox 2015](http://www.springer.com/book/9780387951898)); the spectral density flux (erg/s/cm^2/Hz) at some wavelengths set by one or more `--lambda` options.

Snapshot distributions at each time step, if produced, contain the following
data: radial coordinate in terms of the specific angular momentum, radius,
viscous torque, surface density, effective temperature Teff, viscous temperature
Tvis, irradiation temperature Tirr, and the absolute half-height of the disk.

#### <a name="usage-executables-example"></a> Example

The following arguments instruct `Freddi` to calculate the decay of the outburst
in the disk with the constant outer radius equal to 1 solar radius. The Kerr
black hole at the distance of 5 kpc has the mass of 9 solar masses, and the
Kerr's parameter is 0.4. The outer disk is irradiated with Cirr=1e-3.
**Discuss all options used in the example***

```sh
./freddi --alpha=0.5 --Mx=9 --rout=1 --period=0.5 --Mopt=0.5 --time=50 \
  --tau=0.25 --dir=data/ --F0=2e+37 --colourfactor=1.7 --Nx=1000 \
  --distance=5 --gridscale=log --kerr=0.4 --Cirr=0.001 --opacity=OPAL \
  --initialcond=quasistat --windtype=Woods1996 --windXi_max=10 --windT_ic=1e8 \
  --windPow=1 
```

### Python

Python bindings can be used as a convenient way to run and analyse Freddi
simulations.

#### Initializing

You can prepare simulation set-up initializing `Freddi`
(for black hole accretion disk) or `FreddiNeutronStar` (for NS) class instance.
These classes accept keyword-only arguments which have the same names and
meanings as [command line options](#usage-executables-options), but with three
major exceptions:
 1. Python package doesn't provide any file output functionality, that's why output arguments like `config`, `dir`, `fulldata`, `starflux`, `lambda` or `passband` are missed;
 2. all values are assumed to be in CGS units, but you can use `Freddi.from_asrtopy` for dimensional values (see details bellow);
 3. parameters of wind, NS `fp` and NS `kappa` models are passed as dictionaries (see specification bellow).

The following code snippet would set-up roughly the same simulation as
[the command-line example](#usage-executables-example)

```python
from freddi import Freddi

freddi = Freddi(
    alpha=0.5, Mx=9*2e33, rout=1*7e10, period=0.5*86400, Mopt=0.5*2e33,
    time=50*86400, tau=0.25*86400, F0=2e+37, colourfactor=1.7, Nx=1000,
    distance=5*3e21, gridscale='log', kerr=0.4, Cirr=0.001, opacity='OPAL',
    initialcond='quasistat', wind='Woods1996',
    windparams=dict(Xi_max=10, T_iC=1e8, W_pow=1),
)
```

Alternatively we can do the same using `from_astropy` class-method which casts
all [`astropy.units.Quantity`](https://docs.astropy.org/en/stable/units/quantity.html)
objects to CGS values. Note that dimensionality isn't checked, and technically
it just does `arg.cgs.value` for every `Quantity` argument.

```python
import astropy.units as u
from freddi import Freddi

freddi = Freddi.from_astropy(
    alpha=0.5, Mx=9*u.Msun, rout=1*u.Rsun, period=0.5*u.day, Mopt=0.5*u.Msun,
    time=50*u.day, tau=0.25*u.day, F0=2e+37, colourfactor=1.7, Nx=1000,
    distance=5*u.kpc, gridscale='log', kerr=0.4, Cirr=0.001, opacity='OPAL',
    initialcond='quasistat', wind='Woods1996',
    windparams=dict(Xi_max=10, T_iC=1e8*u.K, W_pow=1),
)
```

Wind model parameters are specified by `windparams` argument which should be
a `dict` instance with string keys and numeric values. Command option to 
`windparams` keys relation is: `--windC_w -> C_w`, `--windR_w -> R_w`,
`--windA_0 -> A_0`, `--windB_1 -> B_1`, `--windXi_max -> Xi_max`,
`windT_ic -> T_ic`, `--windPow -> Pow`, `windC_0 -> C_0`.

Neutron star f_p model parameters are specified by `fpparams` mapping with the
same structure as `windparams`. Command options to `fpparams` keys relation is:
`--fp-geometrical-chi -> chi`, `romanova2018-par1 -> par1`,
`romanova2018-par2 -> par2`.

Neutron star kappa_t model parameters are specified by `kappatparams` mapping
with the same structure as `windparams`. Command options to the mapping keys
relation is: `--kappat-const-value -> value`, `--kappat-corstep-in -> in`,
`kappat-corstep-out -> out`, `--kappat-romanova2018-in -> in`,
`--kappat-romanova2018-out -> out`, `romanova2018-par1 -> par1`,
`--romanova2018-par2 -> par2`

#### Running

There are two ways to run a simulation: iterating over time steps, and run the
whole simulation in one shot. Note that in both cases your `Freddi` object is
mutating and represents the current state of the accretion disk.

Here we use iterator interface which yields another `Freddi` object for each
time moment.

```python
import astropy.units as u
from freddi import Freddi

freddi = Freddi.from_astropy(
    alpha=0.5, Mx=9*u.Msun, rout=1*u.Rsun, period=0.5*u.day, Mopt=0.5*u.Msun,
    time=20*u.day, tau=1.0*u.day, Mdot0=5e18, distance=10*u.kpc,
    initialcond='quasistat',
)

for state in freddi:
    print(f't = {state.t} s, Mdot = {state.Mdot:g} g/s')
assert state.t == freddi.t
```

In this example we run a simulation via `.evolve()` method which returns
`EvolutionResult` object keeping all evolution states internally and providing
temporal distribution of disk's properties.

```python
import astropy.units as u
import matplotlib.pyplot as plt
from freddi import Freddi

freddi = Freddi.from_astropy(
    alpha=0.5, Mx=9*u.Msun, rout=1*u.Rsun, period=0.5*u.day, Mopt=0.5*u.Msun,
    time=20*u.day, tau=1.0*u.day, Mdot0=5e18, distance=10*u.kpc,
    initialcond='quasistat',
)

result = freddi.evolve()
assert result.t[-1] == freddi.t

# Plot Mdot(t)
plt.figure()
plt.title('Freddi disk evolution: accretion rate')
plt.xlabel('t, day')
plt.ylabel(r'$\dot{M}$, g/cm')
plt.plot(result.t / 86400, result.Mdot)
plt.show()

# Plot all F(h) profiles
plt.figure()
plt.title('Freddi disk evolution: viscous torque')
plt.xlabel('r, cm')
plt.ylabel('F, dyn cm')
plt.xscale('log')
plt.yscale('log')
plt.plot(result.R.T, result.F.T)
plt.show()

# Plot evolution of effective temperature of the outer hot disk ring
plt.figure()
plt.title('Freddi disk evolution: outer effective temperature')
plt.xlabel('t, day')
plt.ylabel('T, K')
plt.plot(result.t / 86400, result.last_Tph)
plt.show()
```

#### Properties and methods

`Freddi`, `FreddiNeutronStar` and `EvolutionResult` objects contain dozens of
properties returning various physical values like `t` for time moment,
`Mdot` for accretion rate onto central object, `R` for radius, `F` for torque,
`Tph` for effective temperature and so on. `first_*` and `last_*` properties
are used to access innermost and outermost hot disk values of radial-distributed
quantities. The complete list of properties can be obtained by `dir(Freddi)` or
`dir(FreddiNeutronStar)`. Note that the most properties are lazy-evaluated and
require some time to access first time. `EvolutionResult` provides all the
same properties as underlying `Freddi` or `FreddiNeutronStar` objects but with
additional array dimension for temporal distribution, so if `Freddi.Lx` is a
scalar then `EvolutionResult.Lx` is an 1-D `numpy` array of `(Nt,)` shape,
if `Freddi.Sigma` is an 1-D array of `(Nx,)` shape, then
`EvolutionResult.Sigma` is an 2-D array of `(Nt, Nx)` shape. Also, note that if
disk shrinks during a simulation, the missing values of `EvolutionResult`
properties are filled by NaN.

All three classes have `flux(lmbd, region='hot', phase=None)` method which can
be used to find spectral flux density per unit frequency for optical
emission. `lmbd` argument can be a scalar or a multidimensional `numpy` array
of required wavelengths in cm; `region` could be one of "hot" (hot disk),
"cold" (cold disk), "disk" ("hot" + "cold"), "star" (companion star), and
"all" ("hot" + "cold" + "star"); `phase` is a binary system orbital phase in
radians, it is required for `region="star"` and `region="all"` only, it can be
calculated as `2π t / period + constant`.

All properties and methods return values in CGS units.

## Physical Background

`Freddi` — Fast Rise Exponential Decay: accretion Disk model Implementation — is
designed to solve the differential equation of the viscous evolution of the
Shakura-Sunyaev accretion disk in a stellar binary system. Shakura-Sunyaev disk
is the standard model of accretion of plasma onto the cosmic bodies, like
neutron stars or black holes. Viscous evolution of the accretion disks exibits
itself, for example, in X-ray outbursts of binary stars. Usually, the outbursts
last for several tens of days and many of them are observed by orbital
observatories.

The basic equation of the viscous evolution relates the surface density and
viscous stresses and is of diffusion type. Evolution of the accretion rate can
be found on solving the equation. The distribution of viscous stresss defines
the emission from the source.

The standard model for the accretion disk is implied, which is developed by
[Shakura & Sunyaev (1973)](http://adsabs.harvard.edu/abs/1973A%26A....24..337S).
The inner boundary of the disk is at the ISCO or can be explicitely set. The
boundary conditions in the disk are the zero stress at the inner boundary and
the zero accretion rate at the outer boundary. The conditions are suitable
during the outbursts in X-ray binary transients with black holes.

In a binary system, the accretion disk is radially confined. In `Freddi`, the
outer radius of the disk can be set explicitely or calculated as 90% of the 
Roche lobe size to aproximate the tidal truncation radius obtained by 
[Papaloizou & Pringle (1977)](https://ui.adsabs.harvard.edu/abs/1977MNRAS.181..441P), see  --rout help for details.

The parameters at the disk central plane are defined by the analytic
approximations ([Suleimanov et al. 2007](http://adsabs.harvard.edu/abs/2007ARep...51..549S)), valid for the
effective surface temperatures from 10 000 to 100 000 K, approximately. It is
assumed that the gas pressure dominates, the gas is completely ionized, and the
photon opacity is defined by the free-free and free-bound transitions. Opacity
law is for the solar element abundancies and can be chosen from two types: (1)
Kramers' opacity: kappa = 5e24 rho/T\^(7/2) cm2/g (2) approximation to OPAL
tables: kappa = 1.5e20 rho/T\^(5/2) cm2/g ([Bell & Lin
1994](http://adsabs.harvard.edu/abs/1994ApJ...427..987B))

The disk at each radius is in the "hot" state if the gas is completely ionized.
Otherwise, the disk is considered to be "cold" locally. Alpha-parameter in the
cold parts of the disk is appreciably lower than in the hot parts. Thus the
viscous evolution of the disk should proceed more effectively in the hot parts
of the disk. To simulate this, `Freddi` has an option to control the outer
radius of the hot evolving disk. We assume that the evolution goes through the
quasi-stationary states in the hot zone of variable size. By default, the hot
zone has the constant size, equal to the tidal radius.

The initial distribution of the matter in the disk should be specified with
`--initialcond` option. `Freddi` can start from several types of initial
distributions: power-law distribution of the surface density
`--initialcond=powerSigma`, power-law `--initialcond=powerF` or sinus-law
`--initialcond=sinusF` distribution of the viscous torque, quasi-stationary
distribution `--initialcond=quasistat`. The choice of the initial distribution
defines what type of evolution is to be calculated.

Starting from the quasi-stationary or `sinusF` distribution, the solution
describes the decaying part of the outburst. Zero-time accretion rate through
the inner edge can be set. In other cases, the rise to the peak is also
computed. Then, initial value of viscous torque at the outer radius (can be set
by `--F0`) defines uniquely the initial mass of the disk.

Self-irradiation by the central X-rays heats the outer parts of the disk. A
fraction of the bolometric flux is supposed to illuminate the disk surface. This
results in the larger size of the hot disk if such model is assumed. Also, the
optical flux is increased because the flux outgoing from the disk surface is
proportional to Teff\^4 = Tvis\^4+Tirr\^4. Self-irradiation of the disk is
included in the computation if irradiation parameter is not zero. The simplest
way is to set a constant irradiation factor `--Cirr` (the studies of X-ray novae
suggest the range for Cirr 1e-5—5e-3).

Observed flux depends on the distance to the source and the inclination of the
disk plane. The inclination angle is the angle between the line of sight and the
normal to the disk. The flux, emitted from the disk surface, is defined by the
sum of the visous and irradiating flux, where the viscous flux is calculated
taking into account general relativity effects near the black hole, following
[Page & Thorne
(1974)](http://adsabs.harvard.edu/cgi-bin/nph-bib_query?bibcode=1974ApJ...191..499P)
and [Riffert & Herold (1995)](http://adsabs.harvard.edu/cgi-bin/nph-bib\_query?bibcode=1995ApJ...450..508R).


### Accretion disk wind

Presumably, during an outburst there is an outflow in the form of a wind from the 
accretion disk around the compact object. The presence of such a wind in the LMXBs is supported
by modern observations indicating the expansion of ionized matter. Such an outflow of matter,
being an additional  source of angular momentum transfer in the disk, can strongly influence 
its viscous evolution. 

However, the nature of such winds and their  physical characteristics are an open question.
Namely, there are three mechanisms which are considered:
heating of matter by central radiation in optically thin regions of the disk 
([Begelman et al. 1983](https://ui.adsabs.harvard.edu/abs/1983ApJ...271...70B), 
[Shields et al. 1986](https://ui.adsabs.harvard.edu/abs/1986ApJ...306...90S), 
[Woods et al. 1996](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W)), 
the pressure of the magnetic field of the disk
([Blandford & Payne 1982](https://ui.adsabs.harvard.edu/abs/1982MNRAS.199..883B), 
[Habibi & Abbassi 2019](https://ui.adsabs.harvard.edu/abs/2019ApJ...887..256H), 
[Nixon & Pringle 2019](https://ui.adsabs.harvard.edu/abs/2019A%26A...628A.121N))
and the pressure of local radiation at super-Eddington accretion rates
([Shakura & Sunyaev 1973](http://adsabs.harvard.edu/abs/1973A%26A....24..337S), 
[Proga & Kallman 2002](https://ui.adsabs.harvard.edu/abs/2002ApJ...565..455P)). 

`Freddi` is modernized in such a way that it is able to solve the viscous evolution 
equation with an inhomogeneous term that is responsible for the presence of the disk wind.
This term is the dependence of the surface density of the wind mass-loss rate on 
the distance along the disk's surface. Different forms of such dependence correspond 
to different wind models, and to different classes within `Freddi`. 


One can choose a wind model by setting the
`--windtype` option. The thermal wind model ([Woods et al. 1996](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W)),
which implies that the outflow of matter occurs due to the heating of the outer parts of the disk
by a central radiation source, can be chosen by setting `--windtype=Woods1996`. 
The option `--windtype=Janiuk15` corresponds to the model from work [Janiuk et al. (2015)](https://ui.adsabs.harvard.edu/abs/2015A%26A...574A..92J)
where the wind is started in the super-Eddington regime.
When choosing option `--windtype=Janiuk15`, the you must also specify the values of
the super-Eddington wind parameters with `--windA0` and `--windB1` options.
You can also select the `--windtype=toy` option, which corresponds to a toy wind model when the user sets 
the wind strength relatively to the accretion rate using the option `--windPow`.

#### Compton-heated wind

At the moment, `Freddi` is more focused on simulating outbursts taking into account the thermal wind (`--windtype=Woods1996` option). 
For a better understanding, let's discuss a little the physics of the process of launching such a wind 
and its parameters in the code.

In the standard accretion disk model by [Shakura & Sunyaev (1973)](http://adsabs.harvard.edu/abs/1973A%26A....24..337S) 
the disk is concave, and, as a result, the disk surface is exposed to the central radiation, 
which heats the disk material. As a result, the heated matter, starting from a certain radius, 
begins to leave the accretion disk. This process of heating the matter of the accretion disk by means of Compoton
processes was developed in [Begelman et al. (1983)](https://ui.adsabs.harvard.edu/abs/1983ApJ...271...70B) and 
[Shields et al. (1986)](https://ui.adsabs.harvard.edu/abs/1986ApJ...306...90S). 
In a later work [Woods et al. (1996)](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W), 
two-dimensional magnetohydrodynamic calculations were performed and the 
results of [Shields et al. (1986)](https://ui.adsabs.harvard.edu/abs/1986ApJ...306...90S) were generalized. 
[Woods et al. (1996)](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W) give an expression for the surface density of the mass 
loss rate as a function of distance along the disk's surface. This function is used in `Freddi` 
to taking thermal wind into account.

Choosing option `--windtype=Woods1996`, it is necessary to set the value of the ionization parameter Xi
(which is proportional to the ratio of the radiation and gas pressures) by the option `--windXi_max` and the Compoton temperature T_ic 
(which determines the hardness of the irradiating spectrum and the size of the region where the wind operates) by the option `--windT_ic`. 

### Companion star irradiation

We use a simple model of irradiated star to simulate periodic variability and
X-ray thermalization by a companion's photosphere. Our model assumes that the
companion star's shape corresponds to equipotential surface which size is set
by `--rochelobefill` option, unity means that star fills its Roche lobe, any
smaller value decreases star's polar radius correspondingly. Technically,
star's surface is built from `20 * 4^starlod` triangles, use `--starlod` to
set level of detail, `--starlod=3` should give few percent precision. Every
triangle has black-body spectrum with bolometric luminosity given by a sum of
star's own luminosity (set by `--Topt`) and irradiation flux multiplied by 
unity minus albedo (set by `--staralbedo`).

Please note that the model is limited and doesn't implement limb darking or
eclipsing.

## Development guide

### Source code and tests

`Freddi` uses [Cmake](https://cmake.org) as a build system.

The C++ source code is located in `cpp` folder which has following structure:
- `main.cpp` and `main-ns.cpp` implements `main()` function for `freddi` and `freddi-ns` correspondingly;
- `include` for library header files, it has `ns` sub-folder for neutron star related stuff;
- `src` for library C++ files, it also has `ns` sub-folder;
- `test` provides library unit tests;
- `pywrap` has both header and source files for `Boost::Python`/`Boost::NumPy` bindings.

Note, that we require C++17 standard (while not having idiomatic C++17 code),
and require code to be compiled by modern GCC and CLang on Linux. Please write
unit tests where you can and use `ctest` to check they pass.

The Python project is specified by `pyproject.toml` (which just lists build
requirements), `setup.py` and `MANIFEST.in` files, we use
[`scikit-build`](https://scikit-build.readthedocs.io/) as a build system.
`scikit-build` uses Python-related section of `CMakeLists.txt` to build C++
source code into Python extension, and accomplish it with Python files located
in `python/freddi` directory. Use `python setup.py build_ext` to build the
extension, optionally with `-DSTATIC_LINKING=TRUE` to link `Boost::Filesystem`,
`Boost::Python` and `Boost::NumPy` statically. Please, pay attention to two
last libraries, because they should be built against the same Python version as
you use.

`python/test` contains some tests, you can run them by `python3 setup.py test`.
- `test_freddi.py` and `test_ns.py` contain unit tests for Python source;
- `test_analytical.py` contains integration tests to compare analytical solutions of the equation of disk viscous evolution with the numerical solutions of `Freddi`;
- `regression.py` contains regression tests to be sure that 1) the `Freddi` output is stable, and 2) the Python code gives the same results as binary executables do.

The regression test data are located in `python/test/data`. Sometimes you need
to update these regression data, for example when you introduce new
command-line option with a default value, add new output column or fix some bug
in physical model. For these purposes you can use `generate_test_data.sh`
script located in this folder.

`Dockerfile` is used to build a Docker image with statically-linked binaries,
and `Dockerfile.python` is used to build a Docker image with
[`manylinux`](https://github.com/pypa/manylinux)-compatible Python wheels.


### Continuous integration

We use [Github Actions](https://github.com/hombit/freddi/actions) as a
continuous integration (CI) system. The workflow file is located in
`.github/workflows/main.yml` and a couple of auxiliary files are located in
`.ci` folder. CI allows us to test new commits to prevent different bugs:
- `gcc` and `clang` actions test binaries building, execute sample `Freddi` programs, run C++ unit tests, perform C++ regression tests, and check the consistency of the `Readme.md` with programs' `--help` output
- `cpython` action builds Python extension module and runs all Python tests
- `docker-exe` builds a Docker image using `Dockerfile` and execute sample `Freddi` programs inside a Docker container
- `docker-python` builds a Docker image using `Dockefile.python`, uses wheels it has built to build Python Docker images for several Python versions using `.ci/Dockerfile-test-wheels`, and runs sample Python scripts with `freddi.Freddi` class

### This Readme

Please keep Readme updated. You can update the help messages in the
[Usage](#usage) section using `.ci/update-help-readme.py` script.

### Release new version

Check-list:

- [ ] Update version in `setup.py` and commit it
- [ ] Create `git` tag
  ```sh
  git tag $VERSION
  ```
- [ ] Build new `freddi` image using `Dockerfile`
  ```sh
  docker buildx build --push --platform linux/arm64,linux/amd64 --tag ghcr.io/hombit/freddi:$VERSION .
  docker pull ghcr.io/hombit/freddi:$VERSION
  docker tag ghcr.io/hombit/freddi:$VERSION ghcr.io/hombit/freddi:latest
  docker push ghcr.io/hombit/freddi:latest
  ```
- [ ] Build new `freddi-python` image using `Dockerfile.python`
  ```sh
  docker buildx build --push --platform linux/arm64,linux/amd64 --tag ghcr.io/hombit/freddi-python:$VERSION -f Dockerfile.python .
  docker pull ghcr.io/hombit/freddi-python:$VERSION
  docker tag ghcr.io/hombit/freddi-python:$VERSION ghcr.io/hombit/freddi-python:latest
  docker push ghcr.io/hombit/freddi-python:latest
  ```
- [ ] Upload wheels onto PyPi.org
  ```sh
  docker run --rm -ti ghcr.io/hombit/freddi-python:$VERSION sh -c "python3.7 -m twine upload /dist/*.tar.gz" # sdist
  docker run --rm -ti --platform linux/amd64 ghcr.io/hombit/freddi-python:$VERSION sh -c "python3.7 -m twine upload /dist/*.whl" # bdist x86_64
  docker run --rm -ti --platform linux/arm64 ghcr.io/hombit/freddi-python:$VERSION sh -c "python3.7 -m twine upload /dist/*.whl" # bdist aarch64
  ```
- [ ] [Optional] Build executables for GitHub release
- [ ] [Optional] Build and upload macOS wheels
- [ ] Crate new GitHub release


## Questions and comments

If you have any problems, questions, or comments, please address them to
[Issues](https://github.com/hombit/freddi/issues) or to hombit\@gmail.com

## License

Copyright (c) 2016–2022, Konstantin L. Malanchev, Galina V. Lipunova & Artur L. Avakyan.

`Freddi` is distributed under the terms of the
[GPLv3](https://www.gnu.org/licenses/gpl-3.0.html).

Please, accompany any results obtained using this code with reference to
Lipunova & Malanchev (2017)
[2017MNRAS.468.4735L](http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L),
for the case of windy calculations please also refer Avakyan et al. (2021)
[2021AstL...47..377A](http://adsabs.harvard.edu/abs/2021AstL...47..377A),
and for the case of magnetised neutron star please also refer Lipunova et al. (2021)
[2021arXiv211008076L](http://adsabs.harvard.edu/abs/2021arXiv211008076L).


## BibTex
```bibtex
@ARTICLE{2017MNRAS.468.4735L,
   author = { {Lipunova}, G.~V. and {Malanchev}, K.~L.},
    title = "{Determination of the turbulent parameter in accretion discs: effects of self-irradiation in 4U 1543{\minus}47 during the 2002 outburst}",
  journal = {\mnras},
archivePrefix = "arXiv",
   eprint = {1610.01399},
 primaryClass = "astro-ph.HE",
 keywords = {accretion, accretion discs, methods: numerical, binaries: close, stars: black holes, X-rays: individual: 4U 1543-47},
     year = 2017,
    month = jul,
   volume = 468,
    pages = {4735-4747},
      doi = {10.1093/mnras/stx768},
   adsurl = {http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L},
  adsnote = {Provided by the SAO/NASA Astrophysics Data System}
}

@ARTICLE{2021AstL...47..377A,
       author = {{Avakyan}, A.~L. and {Lipunova}, G.~V. and {Malanchev}, K.~L. and {Shakura}, N.~I.},
        title = "{Change in the Orbital Period of a Binary System Due to an Outburst in a Windy Accretion Disk}",
      journal = {Astronomy Letters},
     keywords = {X-ray binaries, wind, transients, period, accretion, Astrophysics - High Energy Astrophysical Phenomena},
         year = 2021,
        month = jun,
       volume = {47},
       number = {6},
        pages = {377-389},
          doi = {10.1134/S1063773721050017},
archivePrefix = {arXiv},
       eprint = {2105.11974},
 primaryClass = {astro-ph.HE},
       adsurl = {https://ui.adsabs.harvard.edu/abs/2021AstL...47..377A},
      adsnote = {Provided by the SAO/NASA Astrophysics Data System}
}

@ARTICLE{2021arXiv211008076L,
       author = {{Lipunova}, Galina and {Malanchev}, Konstantin and {Tsygankov}, Sergey and {Shakura}, Nikolai and {Tavleev}, Andrei and {Kolesnikov}, Dmitry},
        title = "{Physical modeling of viscous disc evolution around magnetized neutron star. Aql X-1 2013 outburst decay}",
      journal = {arXiv e-prints},
     keywords = {Astrophysics - High Energy Astrophysical Phenomena, Astrophysics - Solar and Stellar Astrophysics},
         year = 2021,
        month = oct,
          eid = {arXiv:2110.08076},
        pages = {arXiv:2110.08076},
archivePrefix = {arXiv},
       eprint = {2110.08076},
 primaryClass = {astro-ph.HE},
       adsurl = {https://ui.adsabs.harvard.edu/abs/2021arXiv211008076L},
      adsnote = {Provided by the SAO/NASA Astrophysics Data System}
}
```

            

Raw data

            {
    "_id": null,
    "home_page": "http://xray.sai.msu.ru/~malanchev/freddi/",
    "name": "freddi",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": null,
    "keywords": "science astrophysics accretion",
    "author": "Konstantin Malanchev",
    "author_email": "malanchev@sai.msu.ru",
    "download_url": "https://files.pythonhosted.org/packages/cc/73/1b08d794d2603de3b1e4dba350bfee7ce4a2c442e3daadeae5e593a67e26/freddi-2.0.0.tar.gz",
    "platform": null,
    "description": "# `Freddi` \u2014 compute FRED-like light curves of LMXB\n\n## Table of contents\n\n- [Overview](#overview)\n- [Installation](#installation)\n- [Usage](#usage)\n- [Physical Background](#physical-background) \n- [Accretion disk wind](#accretion-disk-wind) \n- [Development guide](#development-guide)\n- [Questions and comments](#questions-and-comments)\n- [License](#license)\n- [BibTex](#bibtex)\n\n## Overview\n\nThe code solves 1-D evolution equation of Shakura-Sunyaev accretion alpha-disk\naround black hole or neutron star. The code is developed to simulate fast-rise \nexponential-decay (FRED) light curves of low mass X-ray binaries (LMXBs). \nIt has been first presented in the paper \u201cDetermination of the turbulent \nparameter in the accretion disks: effects of self-irradiation in 4U 1543-47 \nduring the 2002 outburst\u201d by Lipunova & Malanchev (2017)\n[2017MNRAS.468.4735L](http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L). \nCurrently, the code can take into account self-irradiation of the disc, \nwinds from the disc surface, disc-magnetosphere interactions. The related \npapers are Avakyan et al (2021) [2021AstL...47..377A](http://adsabs.harvard.edu/abs/2021AstL...47..377A)\nand Lipunova et al (2021)\n[2021arXiv211008076L](http://adsabs.harvard.edu/abs/2021arXiv211008076L).\n\n`Freddi` is written on C++ and available as a couple of binary executables and\na Python module.\n\nNote that the original `Freddi` version 1 introduced in Lipunova & Malanchev (2017)\n[2017MNRAS.468.4735L](http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L) is still\navailable in the [`v1` git branch](https://github.com/hombit/freddi/tree/v1).\n\n## Installation\n\n### Executables\n\n`Freddi` is represented by two binary executables: the black hole version\n`freddi` and the neutron star version `freddi-ns`.\n\n#### Docker\n\nIf you are familiar with [Docker](http://docker.com) then you can use\npre-compiled binaries inside Docker container:\n```sh\ndocker run -v \"`pwd`\":/data --rm -ti ghcr.io/hombit/freddi freddi -d/data\ndocker run -v \"`pwd`\":/data --rm -ti ghcr.io/hombit/freddi freddi-ns --Bx=1e8 -d/data\n```\n\n#### Build from source\n\n`Freddi` has following build dependencies:\n\n- [Boost](http://www.boost.org/) 1.57+\n- [CMake](https://cmake.org) with a back-end build system like Make or Ninja\n- C++ compiler with C++17 support, e.g. `gcc` version 8+ or `clang` 5+\n\nGet requirements on Debian based systems (e.g. Ubuntu):\n```sh\napt-get install g++ cmake libboost-all-dev\n```\n\nOn Red-Hat based systems (e.g. Fedora):\n```sh\ndnf install gcc-c++ cmake boost-devel\n```\n\nOn macOS via [Homebrew](https://brew.sh):\n```sh\nbrew install cmake boost\n```\n\nGet `Freddi` source code and compile it:\n```sh\ngit clone https://github.com/hombit/freddi\ncd freddi\nmkdir cmake-build\ncd cmake-build\ncmake .. # -DSTATIC_LINKING=TRUE\ncmake --build .\n```\n\nUncomment `-DSTATIC_LINKING=TRUE` to link against static Boost libraries\n\nNow you should have both `freddi` and `freddi-ns` executables in the build\ndirectory. You can install these binaries and the default configuration\nfile `freddi.ini` by running\n```sh\ncmake --install . --prefix=PREFIX  # replace with preferable location\n```\n\n`Freddi` is known to be built on Linux and macOS.\n\n### Python\n\n[![PyPI version](https://badge.fury.io/py/freddi.svg)](https://badge.fury.io/py/freddi)\n\nPython\u00a02 isn't supported, use Python\u00a03 instead.\n\n`Freddi` pre-compiled x86-64 Linux packages for several Python versions\nare available on <https://pypi.org/project/freddi/> and can be used as is,\nwhile for other configurations you should have C++ compiler and Boost\nlibraries in your system before running this command:\n\n```sh\n# Please upgrade your pip\npython3 -m pip install -U pip\n# Depending on your Python setup, you need or need not --user flag\npython3 -m pip install --user freddi\n```\n\n[`astropy`](https://astropy.org) is an optional requirement which must be\ninstalled to use dimensional input via `Freddi.from_astropy`\n\n## Usage\n\n### Executables\n\n`Freddi` runs from the command line with inline options and/or with configuration \nfiles. `Freddi` outputs file `freddi.dat` with distribution of various physical values \nover time. If `--fulldata` is specified then files `freddi_%d.dat` for each time step \nare created in the same directory with snapshot radial distributions. These data-files \ncontain whitespace-separated data columns with header lines starting\nwith `#` symbol. You can set another prefix instead of `freddi` with `--prefix`\noption and change the output directory with `--dir` option. If you choose the\nDocker way and would like to specify the directory, then avoid using `--dir`\noption and just replace `` \"`pwd`\" `` with some local path (for more details see\n[Docker documentation](https://docs.docker.com/engine/tutorials/dockervolumes)).\n\n#### <a name=\"usage-executables-options\"> Options\n\nThe full list of command line options is viewed with `--help` option. Default\nvalues are given in brackets.\n\n```sh\n./freddi --help\n```\n\n<details><summary>expand</summary>\n\n```\nFreddi: numerical calculation of accretion disk evolution:\n\nGeneral options::\n  -h [ --help ]                    Produce help message\n                                   \n  --config arg                     Set filepath for additional configuration \n                                   file. There is no need to declare a \n                                   configuration file with the default name \n                                   freddi.ini\n                                   \n  --prefix arg (=freddi)           Set prefix for output filenames. Output file\n                                   with distribution of parameters over time is\n                                   PREFIX.dat\n                                   \n  --stdout                         Output temporal distribution to stdout \n                                   instead of PREFIX.dat file\n                                   \n  -d [ --dir ] arg (=.)            Choose the directory to write output files. \n                                   It should exist\n                                   \n  --precision arg (=12)            Number of digits to print into output files\n                                   \n  --tempsparsity arg (=1)          Output every k-th time moment\n                                   \n  --fulldata                       Output files PREFIX_%d.dat with radial \n                                   structure for every time step. Default is to\n                                   output only PREFIX.dat with global disk \n                                   parameters for every time step\n                                   \n\nBasic binary and disk parameters\n:\n  -a [ --alpha ] arg               Alpha parameter of Shakura-Sunyaev model\n                                   \n  --alphacold arg                  Alpha parameter of cold disk, currently it \n                                   is used only for the critical maximum value \n                                   of the surface density of the cold disk \n                                   Sigma_minus (Lasota et al., 2008, A&A 486, \n                                   523) and the cooling front velocity (Ludwig \n                                   et al., 1994, A&A 290, 473), see \n                                   --Qirr2Qvishot. Default value is --alpha \n                                   divided by ten\n                                   \n  -M [ --Mx ] arg                  Mass of the central object, in the units of \n                                   solar masses\n                                   \n  --kerr arg (=0)                  Dimensionless Kerr parameter of the black \n                                   hole\n                                   \n  --Mopt arg                       Mass of the optical star, in units of solar \n                                   masses\n                                   \n  --rochelobefill arg (=1)         Dimensionless factor describing a size of \n                                   the optical star. Polar radius of the star \n                                   is rochelobefill * (polar radius of critical\n                                   Roche lobe)\n                                   \n  --Topt arg (=0)                  Effective temperature of the optical star, \n                                   in units of Kelvins\n                                   \n  -P [ --period ] arg              Orbital period of the binary system, in \n                                   units of days\n                                   \n  --rin arg                        Inner radius of the disk, in the units of \n                                   the gravitational radius of the central \n                                   object GM/c^2. There is no need to set it \n                                   for a neutron star. If it isn't set for a \n                                   black hole then the radius of ISCO orbit is \n                                   used, defined by --Mx and --kerr values\n                                   \n  -R [ --rout ] arg                Outer radius of the disk, in units of solar \n                                   radius. If it isn't set then the tidal \n                                   radius is used, defined by --Mx, --Mopt and \n                                   --period values as 90% of the Roche lobe \n                                   radius (Papaloizou & Pringle, 1977, MNRAS, \n                                   181, 441; see also Artymowicz & Lubow, 1994,\n                                   ApJ, 421, 651; http://xray.sai.msu.ru/~galja\n                                   /images/tidal_radius.pdf)\n                                   \n  --risco arg                      Innermost stable circular orbit, in units of\n                                   gravitational radius of the central object \n                                   GM/c^2. If it isn't set then the radius of \n                                   ISCO orbit is used defined by --Mx and \n                                   --kerr values\n                                   \n\nParameters of the disk model:\n  -O [ --opacity ] arg (=Kramers)  Opacity law: Kramers (varkappa ~ rho / \n                                   T^7/2) or OPAL (varkappa ~ rho / T^5/2)\n                                   \n  --Mdotout arg (=0)               Accretion rate onto the disk through its \n                                   outer radius\n                                   \n  --boundcond arg (=Teff)          Outer-boundary movement condition\n                                   \n                                   Values:\n                                     Teff: outer radius of the disk moves \n                                   inwards to keep photosphere temperature of \n                                   the disk larger than some value. This value \n                                   is specified by --Thot option\n                                     Tirr: outer radius of the disk moves \n                                   inwards to keep irradiation flux of the disk\n                                   larger than some value. The value of this \n                                   minimal irradiation flux is \n                                   [Stefan-Boltzmann constant] * Tirr^4, where \n                                   Tirr is specified by --Thot option\n                                   \n  --Thot arg (=0)                  Minimum photosphere or irradiation \n                                   temperature at the outer edge of the hot \n                                   disk, Kelvin. For details see --boundcond \n                                   description\n                                   \n  --Qirr2Qvishot arg (=0)          Minimum Qirr / Qvis ratio at the outer edge \n                                   of the hot disk to switch the control over \n                                   the evolution of the hot disk radius: from \n                                   temperature-based regime to Sigma-based \n                                   cooling-front regime (see Lipunova et al. \n                                   (2021, Section 2.4) and Eq. A.1 in Lasota et\n                                   al. 2008; --alpha value is used for \n                                   Sigma_plus and --alphacold value is used for\n                                   Sigma_minus)\n                                   \n  --initialcond arg (=powerF)      Type of the initial condition for viscous \n                                   torque F or surface density Sigma\n                                   \n                                   Values:\n                                     [NB! Here below dimensionless xi = (h - \n                                   h_in) / (h_out - h_in)]\n                                   \n                                     powerF: F ~ xi^powerorder, powerorder is \n                                   specified by --powerorder option\n                                     linearF: F ~ xi, specific case of powerF \n                                   but can be normalised by --Mdot0, see its \n                                   description for details\n                                     powerSigma: Sigma ~ xi^powerorder, \n                                   powerorder is specified by --powerorder \n                                   option\n                                     sineF: F ~ sin( xi * pi/2 )\n                                     gaussF: F ~ exp(-(xi-mu)**2 / 2 sigma**2),\n                                   mu and sigma are specified by --gaussmu and \n                                   --gausssigma options\n                                     quasistat: F ~ f(h/h_out) * xi * h_out/h, \n                                   where f is quasi-stationary solution found \n                                   in Lipunova & Shakura 2000. f(xi=0) = 0, \n                                   df/dxi(xi=1) = 0\n                                   \n  --F0 arg                         Initial maximum viscous torque in the disk, \n                                   dyn*cm. Can be overwritten via --Mdisk0 and \n                                   --Mdot0\n                                   \n  --Mdisk0 arg                     Initial disk mass, g. If both --F0 and \n                                   --Mdisk0 are specified then --Mdisk0 is \n                                   used. If both --Mdot0 and --Mdisk0 are \n                                   specified then --Mdot0 is used\n                                   \n  --Mdot0 arg                      Initial mass accretion rate through the \n                                   inner radius, g/s. If --F0, --Mdisk0 and \n                                   --Mdot0 are specified then --Mdot0 is used. \n                                   Works only when --initialcond is set to \n                                   linearF, sinusF or quasistat\n                                   \n  --powerorder arg                 Parameter for the powerlaw initial condition\n                                   distribution. This option works only with \n                                   --initialcond=powerF or powerSigma\n                                   \n  --gaussmu arg                    Position of the maximum for Gauss \n                                   distribution, positive number not greater \n                                   than unity. This option works only with \n                                   --initialcond=gaussF\n                                   \n  --gausssigma arg                 Width of for Gauss distribution. This option\n                                   works only with --initialcond=gaussF\n                                   \n  --windtype arg (=no)             Type of the wind\n                                   \n                                     no: no wind\n                                     SS73C: super-Eddington spherical wind from\n                                   Shakura-Sunyaev 1973\n                                     ShieldsOscil1986: toy wind model from \n                                   Shields et al. 1986 which was used to obtain\n                                   oscillations in the disk luminosity. \n                                   Requires --windC_w and --windR_w to be \n                                   specified\n                                     Janiuk2015: super-Eddington wind from \n                                   Janiuk et al 2015. Requires --windA_0 and \n                                   --windB_1 to be specified\n                                     Shields1986: thermal wind from Begelman et\n                                   al. 1983 and Shields et al. 1986. Requires \n                                   --windXi_max, --windT_ic and --windPow to be\n                                   specified\n                                     Woods1996AGN: thermal AGN wind from Woods \n                                   et al. 1996. Requires --windC_0 and \n                                   --windT_ic to be specified\n                                     Woods1996: thermal wind from Woods et al. \n                                   1996. Requires --windXi_max, --windT_ic and \n                                   --windPow to be specified\n                                     toy: a toy wind model used in \n                                   arXiv:2105.11974, the mass loss rate is \n                                   proportional to the central accretion rate. \n                                   Requires --windC_w to be specified\n                                   \n  --windC_w arg                    The ratio of the mass loss rate due to wind \n                                   to the central accretion rate, |Mwind|/Macc\n                                   \n  --windR_w arg                    The ratio of the wind launch radius to the \n                                   outer disk radius, Rwind/Rout\n                                   \n  --windA_0 arg                    Dimensionless parameter characterizing the \n                                   strength of the super-Eddington wind in the \n                                   framework of the model Janiuk et al. 2015. \n                                   Effective value range from 10 to 25\n                                   \n  --windB_1 arg                    The quantity is of the order of unity. \n                                   Characterizes the relationship between the \n                                   change in energy per particle and virial \n                                   energy.\n                                   E = B_1 * k * T\n                                   \n  --windXi_max arg                 Ionization parameter, the ratio of the \n                                   radiation and gas pressures\n                                   \n  --windT_ic arg                   Inverse Compton temperature, K. \n                                   Characterizes the hardness of the \n                                   irradiating spectrum\n                                   \n  --windPow arg                    Multiplicative coefficient to control wind \n                                   power\n                                   \n  --windC_0 arg                    Characteristic column density of the wind \n                                   mass loss rate from Woods et al. 1996 model,\n                                   g/(s*cm^2). For AGN approx value is 3e-13 \n                                   g/(s*cm^2)\n                                   \n\nParameters of self-irradiation:\nQirr = Cirr * (H/r / 0.05)^irrindex * L * psi / (4 pi R^2), where psi is the angular distribution of X-ray radiation\n:\n  --Cirr arg (=0)                  Irradiation factor for the hot disk\n                                   \n  --irrindex arg (=0)              Irradiation index for the hot disk\n                                   \n  --Cirrcold arg (=0)              Irradiation factor for the cold disk\n                                   \n  --irrindexcold arg (=0)          Irradiation index for the cold disk\n                                   \n  --h2rcold arg (=0)               Semi-height to radius ratio for the cold \n                                   disk\n                                   \n  --angulardistdisk arg (=plane)   Angular distribution of the disk X-ray \n                                   radiation. Values: isotropic, plane\n                                   \n\nParameters of flux calculation:\n:\n  --colourfactor arg (=1.7)        Colour factor to calculate X-ray flux\n                                   \n  --emin arg (=1)                  Minimum energy of X-ray band, keV\n                                   \n  --emax arg (=12)                 Maximum energy of X-ray band, keV\n                                   \n  --staralbedo arg (=0)            Part of X-ray radiation reflected by optical\n                                   star, (1 - albedo) heats star's photosphere.\n                                   Used only when --starflux is specified\n                                   \n  -i [ --inclination ] arg (=0)    Inclination of the system, degrees\n                                   \n  --ephemerist0 arg (=0)           Ephemeris for the time of the minimum of the\n                                   orbital light curve T0, phase zero \n                                   corresponds to inferior conjunction of the \n                                   optical star, days\n                                   \n  --distance arg                   Distance to the system, kpc\n                                   \n  --colddiskflux                   Add Fnu for cold disk into output file. \n                                   Default output is for hot disk only\n                                   \n  --starflux                       Add Fnu for irradiated optical star into \n                                   output file. See --Topt, --starlod and \n                                   --h2rcold options. Default is output for the\n                                   hot disk only\n                                   \n  --lambda arg                     Wavelength to calculate Fnu, Angstrom. You \n                                   can use this option multiple times. For each\n                                   lambda one additional column with values of \n                                   spectral flux density Fnu [erg/s/cm^2/Hz] is\n                                   produced\n                                   \n  --passband arg                   Path of a file containing tabulated passband\n                                   for a photon counter detector, the first \n                                   column for wavelength in Angstrom, the \n                                   second column for transmission factor, \n                                   columns should be separated by spaces\n                                   \n\nParameters of disk evolution calculation:\n:\n  --inittime arg (=0)              Initial time moment, days\n                                   \n  -T [ --time ] arg                Time interval to calculate evolution, days\n                                   \n  --tau arg                        Time step, days\n                                   \n  --Nx arg (=1000)                 Size of calculation grid\n                                   \n  --gridscale arg (=log)           Type of grid for angular momentum h: log or \n                                   linear\n                                   \n  --starlod arg (=3)               Level of detail of the optical star 3-D \n                                   model. The optical star is represented by a \n                                   triangular tile, the number of tiles is 20 *\n                                   4^starlod\n                                   \n\n\n```\n</details>\n\n```sh\n./freddi-ns --help\n```\n\n<details><summary>expand</summary>\n\n```\nFreddi NS: numerical calculation of accretion disk evolution:\n\nGeneral options::\n  -h [ --help ]                         Produce help message\n                                        \n  --config arg                          Set filepath for additional \n                                        configuration file. There is no need to\n                                        declare a configuration file with the \n                                        default name freddi.ini\n                                        \n  --prefix arg (=freddi)                Set prefix for output filenames. Output\n                                        file with distribution of parameters \n                                        over time is PREFIX.dat\n                                        \n  --stdout                              Output temporal distribution to stdout \n                                        instead of PREFIX.dat file\n                                        \n  -d [ --dir ] arg (=.)                 Choose the directory to write output \n                                        files. It should exist\n                                        \n  --precision arg (=12)                 Number of digits to print into output \n                                        files\n                                        \n  --tempsparsity arg (=1)               Output every k-th time moment\n                                        \n  --fulldata                            Output files PREFIX_%d.dat with radial \n                                        structure for every time step. Default \n                                        is to output only PREFIX.dat with \n                                        global disk parameters for every time \n                                        step\n                                        \n\nBasic binary and disk parameters\n:\n  -a [ --alpha ] arg                    Alpha parameter of Shakura-Sunyaev \n                                        model\n                                        \n  --alphacold arg                       Alpha parameter of cold disk, currently\n                                        it is used only for the critical \n                                        maximum value of the surface density of\n                                        the cold disk Sigma_minus (Lasota et \n                                        al., 2008, A&A 486, 523) and the \n                                        cooling front velocity (Ludwig et al., \n                                        1994, A&A 290, 473), see \n                                        --Qirr2Qvishot. Default value is \n                                        --alpha divided by ten\n                                        \n  -M [ --Mx ] arg                       Mass of the central object, in the \n                                        units of solar masses\n                                        \n  --kerr arg (=0)                       Dimensionless Kerr parameter of the \n                                        black hole\n                                        \n  --Mopt arg                            Mass of the optical star, in units of \n                                        solar masses\n                                        \n  --rochelobefill arg (=1)              Dimensionless factor describing a size \n                                        of the optical star. Polar radius of \n                                        the star is rochelobefill * (polar \n                                        radius of critical Roche lobe)\n                                        \n  --Topt arg (=0)                       Effective temperature of the optical \n                                        star, in units of Kelvins\n                                        \n  -P [ --period ] arg                   Orbital period of the binary system, in\n                                        units of days\n                                        \n  --rin arg                             Inner radius of the disk, in the units \n                                        of the gravitational radius of the \n                                        central object GM/c^2. There is no need\n                                        to set it for a neutron star. If it \n                                        isn't set for a black hole then the \n                                        radius of ISCO orbit is used, defined \n                                        by --Mx and --kerr values\n                                        \n  -R [ --rout ] arg                     Outer radius of the disk, in units of \n                                        solar radius. If it isn't set then the \n                                        tidal radius is used, defined by --Mx, \n                                        --Mopt and --period values as 90% of \n                                        the Roche lobe radius (Papaloizou & \n                                        Pringle, 1977, MNRAS, 181, 441; see \n                                        also Artymowicz & Lubow, 1994, ApJ, \n                                        421, 651; http://xray.sai.msu.ru/~galja\n                                        /images/tidal_radius.pdf)\n                                        \n  --risco arg                           Innermost stable circular orbit, in \n                                        units of gravitational radius of the \n                                        central object GM/c^2. If it isn't set \n                                        then the radius of ISCO orbit is used \n                                        defined by --Mx and --kerr values\n                                        \n\nParameters of the disk model:\n  -O [ --opacity ] arg (=Kramers)       Opacity law: Kramers (varkappa ~ rho / \n                                        T^7/2) or OPAL (varkappa ~ rho / T^5/2)\n                                        \n  --Mdotout arg (=0)                    Accretion rate onto the disk through \n                                        its outer radius\n                                        \n  --boundcond arg (=Teff)               Outer-boundary movement condition\n                                        \n                                        Values:\n                                          Teff: outer radius of the disk moves \n                                        inwards to keep photosphere temperature\n                                        of the disk larger than some value. \n                                        This value is specified by --Thot \n                                        option\n                                          Tirr: outer radius of the disk moves \n                                        inwards to keep irradiation flux of the\n                                        disk larger than some value. The value \n                                        of this minimal irradiation flux is \n                                        [Stefan-Boltzmann constant] * Tirr^4, \n                                        where Tirr is specified by --Thot \n                                        option\n                                        \n  --Thot arg (=0)                       Minimum photosphere or irradiation \n                                        temperature at the outer edge of the \n                                        hot disk, Kelvin. For details see \n                                        --boundcond description\n                                        \n  --Qirr2Qvishot arg (=0)               Minimum Qirr / Qvis ratio at the outer \n                                        edge of the hot disk to switch the \n                                        control over the evolution of the hot \n                                        disk radius: from temperature-based \n                                        regime to Sigma-based cooling-front \n                                        regime (see Lipunova et al. (2021, \n                                        Section 2.4) and Eq. A.1 in Lasota et \n                                        al. 2008; --alpha value is used for \n                                        Sigma_plus and --alphacold value is \n                                        used for Sigma_minus)\n                                        \n  --initialcond arg (=powerF)           Type of the initial condition for \n                                        viscous torque F or surface density \n                                        Sigma\n                                        \n                                        Values:\n                                          [NB! Here below dimensionless xi = (h\n                                        - h_in) / (h_out - h_in)]\n                                        \n                                          powerF: F ~ xi^powerorder, powerorder\n                                        is specified by --powerorder option\n                                          linearF: F ~ xi, specific case of \n                                        powerF but can be normalised by \n                                        --Mdot0, see its description for \n                                        details\n                                          powerSigma: Sigma ~ xi^powerorder, \n                                        powerorder is specified by --powerorder\n                                        option\n                                          sineF: F ~ sin( xi * pi/2 )\n                                          gaussF: F ~ exp(-(xi-mu)**2 / 2 \n                                        sigma**2), mu and sigma are specified \n                                        by --gaussmu and --gausssigma options\n                                          quasistat: F ~ f(h/h_out) * xi * \n                                        h_out/h, where f is quasi-stationary \n                                        solution found in Lipunova & Shakura \n                                        2000. f(xi=0) = 0, df/dxi(xi=1) = 0\n                                          quasistat-ns: Distibution of the \n                                        initial viscous torque in the disc is  \n                                        F = F0 * f_F(xi) * (1-h_in/h_out/xi) / \n                                        (1-h_in/h_out), where xi=h/h_out and \n                                        f_F(xi) is taken from Lipunova & \n                                        Shakura (2000)\n                                        \n  --F0 arg                              Initial maximum viscous torque in the \n                                        disk, dyn*cm. Can be overwritten via \n                                        --Mdisk0 and --Mdot0\n                                        \n  --Mdisk0 arg                          Initial disk mass, g. If both --F0 and \n                                        --Mdisk0 are specified then --Mdisk0 is\n                                        used. If both --Mdot0 and --Mdisk0 are \n                                        specified then --Mdot0 is used\n                                        \n  --Mdot0 arg                           Initial mass accretion rate through the\n                                        inner radius, g/s. If --F0, --Mdisk0 \n                                        and --Mdot0 are specified then --Mdot0 \n                                        is used. Works only when --initialcond \n                                        is set to linearF, sinusF or quasistat\n                                        \n  --powerorder arg                      Parameter for the powerlaw initial \n                                        condition distribution. This option \n                                        works only with --initialcond=powerF or\n                                        powerSigma\n                                        \n  --gaussmu arg                         Position of the maximum for Gauss \n                                        distribution, positive number not \n                                        greater than unity. This option works \n                                        only with --initialcond=gaussF\n                                        \n  --gausssigma arg                      Width of for Gauss distribution. This \n                                        option works only with \n                                        --initialcond=gaussF\n                                        \n  --windtype arg (=no)                  Type of the wind\n                                        \n                                          no: no wind\n                                          SS73C: super-Eddington spherical wind\n                                        from Shakura-Sunyaev 1973\n                                          ShieldsOscil1986: toy wind model from\n                                        Shields et al. 1986 which was used to \n                                        obtain oscillations in the disk \n                                        luminosity. Requires --windC_w and \n                                        --windR_w to be specified\n                                          Janiuk2015: super-Eddington wind from\n                                        Janiuk et al 2015. Requires --windA_0 \n                                        and --windB_1 to be specified\n                                          Shields1986: thermal wind from \n                                        Begelman et al. 1983 and Shields et al.\n                                        1986. Requires --windXi_max, --windT_ic\n                                        and --windPow to be specified\n                                          Woods1996AGN: thermal AGN wind from \n                                        Woods et al. 1996. Requires --windC_0 \n                                        and --windT_ic to be specified\n                                          Woods1996: thermal wind from Woods et\n                                        al. 1996. Requires --windXi_max, \n                                        --windT_ic and --windPow to be \n                                        specified\n                                          toy: a toy wind model used in \n                                        arXiv:2105.11974, the mass loss rate is\n                                        proportional to the central accretion \n                                        rate. Requires --windC_w to be \n                                        specified\n                                        \n  --windC_w arg                         The ratio of the mass loss rate due to \n                                        wind to the central accretion rate, \n                                        |Mwind|/Macc\n                                        \n  --windR_w arg                         The ratio of the wind launch radius to \n                                        the outer disk radius, Rwind/Rout\n                                        \n  --windA_0 arg                         Dimensionless parameter characterizing \n                                        the strength of the super-Eddington \n                                        wind in the framework of the model \n                                        Janiuk et al. 2015. Effective value \n                                        range from 10 to 25\n                                        \n  --windB_1 arg                         The quantity is of the order of unity. \n                                        Characterizes the relationship between \n                                        the change in energy per particle and \n                                        virial energy.\n                                        E = B_1 * k * T\n                                        \n  --windXi_max arg                      Ionization parameter, the ratio of the \n                                        radiation and gas pressures\n                                        \n  --windT_ic arg                        Inverse Compton temperature, K. \n                                        Characterizes the hardness of the \n                                        irradiating spectrum\n                                        \n  --windPow arg                         Multiplicative coefficient to control \n                                        wind power\n                                        \n  --windC_0 arg                         Characteristic column density of the \n                                        wind mass loss rate from Woods et al. \n                                        1996 model, g/(s*cm^2). For AGN approx \n                                        value is 3e-13 g/(s*cm^2)\n                                        \n\nParameters of accreting neutron star:\n:\n  --nsprop arg (=dummy)                 Neutron star properties name: defines \n                                        geometry (default values of --Rx, \n                                        --Risco, and --freqx) and \n                                        accretion->radiation efficiency of NS\n                                        \n                                        Values:\n                                          dummy: NS accretion->radiation \n                                        efficiency is R_g * (1 / R_x - 1 / \n                                        2R_in), default --freqx is 0, default \n                                        Rx is 1e6, default Risco is Kerr value\n                                          newt: NS accretion->radiation \n                                        efficiency is a function of NS \n                                        frequency, calculated in Newtonian \n                                        mechanics (see Lipunova+2021), that's \n                                        why --freqx must be specified \n                                        explicitly\n                                          sibgatullin-sunyaev2000: NS \n                                        accretion->radiation efficiency and \n                                        default values of Rx and Risco are \n                                        functions of NS frequency, calculated \n                                        for a specific equation of state for a \n                                        NS with weak magnetic field \n                                        (Sibgatullin & Sunyaev, 2000, Astronomy\n                                        Letters, 26, 699), that's why --freqx \n                                        must be specified explicitly\n                                        \n  --freqx arg                           Accretor rotation frequency, Hz. This \n                                        parameter is not linked to --kerr, \n                                        which could be reconciled manually \n                                        (currently, --kerr is not needed for \n                                        freddi-ns)\n                                        \n  --Rx arg                              Accretor radius, cm\n                                        \n  --Bx arg                              Accretor polar magnetic induction, G\n                                        \n  --hotspotarea arg (=1)                Total area of the region on the \n                                        accretor radiating because of \n                                        accretion, normalized by the accretor \n                                        surface area\n                                        \n  --epsilonAlfven arg (=1)              Magnetosphere radius in units of the \n                                        Alfven radius, which is defined as \n                                        (mu^4/G/M/sqrt(Mdot))^(1/7)\n                                        \n  --inversebeta arg (=0)                Not currently in use\n                                        \n  --Rdead arg (=0)                      Maximum inner radius of the disk that \n                                        can be achieved, cm\n                                        \n  --fptype arg (=no-outflow)            Scenario to determine the fraction fp \n                                        of accreted mass. The rest of the disk \n                                        inner accretion rate is propelled away.\n                                        \n                                        Values:\n                                          no-outflow: the matter reaching the \n                                        inner disk radius always falls onto NS,\n                                        fp = 1\n                                          propeller: the matter always flows \n                                        away, fp = 0\n                                          corotation-block: like 'no-outflow' \n                                        when the inner disk radius is smaller \n                                        than the corotation radius, like \n                                        'propeller' otherwise\n                                          geometrical: experimental. \n                                        Generalization of 'corotation-block' \n                                        for the case of misaligned NS magnetic \n                                        axis. Requires --fp-geometrical-chi to \n                                        be specified\n                                          eksi-kutlu2010: Under construction\n                                          romanova2018: fp is an analytical \n                                        function of the fastness, found from \n                                        MHD simulations by Romanova et al. \n                                        (2018, NewA, 62, 94): fp = 1 - \n                                        par1*fastness^par2. This requires \n                                        --romanova2018-par1 and \n                                        --romanova2018-par2 to be specified\n                                        \n  --fp-geometrical-chi arg              angle between the disk rotation axis \n                                        and the NS magnetic axis, used for \n                                        --fptype=geometrical, degrees\n                                        \n  --romanova2018-par1 arg               par1 value for --fptype=romanova2018 \n                                        and --kappattype=romanova2018\n                                        \n  --romanova2018-par2 arg               par2 value for --fptype=romanova2018 \n                                        and --kappattype=romanova2018\n                                        \n  --kappattype arg (=const)             kappa_t describes how strong is the \n                                        interaction between the NS \n                                        magnetosphere and disk: total \n                                        (accelerating) magnetic torque applied \n                                        to the disc is kappa_t(R) * mu^2 / R^3.\n                                        \n                                        Values:\n                                          const: doesn't depend on radius, \n                                        kappa_t = value. Requires \n                                        --kappat-const-value to be specified\n                                          corstep: kappa_t can be different \n                                        inside and outside the corotation \n                                        radius. Requires --kappat-corstep-in \n                                        and --kappat-corstep-out to be \n                                        specified\n                                          romanova2018: experimental. Similar \n                                        to corstep option, but the outside \n                                        value is reduced by the portion taken \n                                        away by the outflow (see Table 2 of \n                                        Romanova+2018, NewA, 62, 94). Requires \n                                        --kappat-romanova2018-in, \n                                        --kappat-romanova2018-out \n                                        --romanova2018-par1 and --romanova-par2\n                                        to be specified\n                                        \n  --kappat-const-value arg (=0.33333333333333331)\n                                        kappa_t value for --kappattype=const\n                                        \n  --kappat-corstep-in arg (=0.33333333333333331)\n                                        kappa_t value inside the corotation \n                                        radius for --kappattype=corstep\n                                        \n  --kappat-corstep-out arg (=0.33333333333333331)\n                                        kappa_t value outside the corotation \n                                        radius for --kappattype=corstep\n                                        \n  --kappat-romanova2018-in arg (=0.33333333333333331)\n                                        kappa_t value inside the corotation \n                                        radius for --kappattype=romanova2018\n                                        \n  --kappat-romanova2018-out arg (=0.33333333333333331)\n                                        kappa_t value outside the corotation \n                                        radius for --kappattype=romanova2018\n                                        \n  --nsgravredshift arg (=off)           Neutron star gravitational redshift \n                                        flag.\n                                        \n                                        Values:\n                                          off: gravitational redshift is not \n                                        taken into account\n                                          on: redshift is (1 - R_sch / Rx), \n                                        where R_sch = 2GM/c^2\n                                        \n\nParameters of self-irradiation:\nQirr = Cirr * (H/r / 0.05)^irrindex * L * psi / (4 pi R^2), where psi is the angular distribution of X-ray radiation\n:\n  --Cirr arg (=0)                       Irradiation factor for the hot disk\n                                        \n  --irrindex arg (=0)                   Irradiation index for the hot disk\n                                        \n  --Cirrcold arg (=0)                   Irradiation factor for the cold disk\n                                        \n  --irrindexcold arg (=0)               Irradiation index for the cold disk\n                                        \n  --h2rcold arg (=0)                    Semi-height to radius ratio for the \n                                        cold disk\n                                        \n  --angulardistdisk arg (=plane)        Angular distribution of the disk X-ray \n                                        radiation. Values: isotropic, plane\n                                        \n  --angulardistns arg (=isotropic)      Flag to calculate angular distribution \n                                        the NS emission. Values: isotropic, \n                                        plane\n                                        \n\nParameters of flux calculation:\n:\n  --colourfactor arg (=1.7)             Colour factor to calculate X-ray flux\n                                        \n  --emin arg (=1)                       Minimum energy of X-ray band, keV\n                                        \n  --emax arg (=12)                      Maximum energy of X-ray band, keV\n                                        \n  --staralbedo arg (=0)                 Part of X-ray radiation reflected by \n                                        optical star, (1 - albedo) heats star's\n                                        photosphere. Used only when --starflux \n                                        is specified\n                                        \n  -i [ --inclination ] arg (=0)         Inclination of the system, degrees\n                                        \n  --ephemerist0 arg (=0)                Ephemeris for the time of the minimum \n                                        of the orbital light curve T0, phase \n                                        zero corresponds to inferior \n                                        conjunction of the optical star, days\n                                        \n  --distance arg                        Distance to the system, kpc\n                                        \n  --colddiskflux                        Add Fnu for cold disk into output file.\n                                        Default output is for hot disk only\n                                        \n  --starflux                            Add Fnu for irradiated optical star \n                                        into output file. See --Topt, --starlod\n                                        and --h2rcold options. Default is \n                                        output for the hot disk only\n                                        \n  --lambda arg                          Wavelength to calculate Fnu, Angstrom. \n                                        You can use this option multiple times.\n                                        For each lambda one additional column \n                                        with values of spectral flux density \n                                        Fnu [erg/s/cm^2/Hz] is produced\n                                        \n  --passband arg                        Path of a file containing tabulated \n                                        passband for a photon counter detector,\n                                        the first column for wavelength in \n                                        Angstrom, the second column for \n                                        transmission factor, columns should be \n                                        separated by spaces\n                                        \n\nParameters of disk evolution calculation:\n:\n  --inittime arg (=0)                   Initial time moment, days\n                                        \n  -T [ --time ] arg                     Time interval to calculate evolution, \n                                        days\n                                        \n  --tau arg                             Time step, days\n                                        \n  --Nx arg (=1000)                      Size of calculation grid\n                                        \n  --gridscale arg (=log)                Type of grid for angular momentum h: \n                                        log or linear\n                                        \n  --starlod arg (=3)                    Level of detail of the optical star 3-D\n                                        model. The optical star is represented \n                                        by a triangular tile, the number of \n                                        tiles is 20 * 4^starlod\n                                        \n\n\n```\n</details>\n\n**Write which options are mandatory**\n\nAlso you can use `freddi.ini` configuration file to store options. This [INI\nfile](https://en.wikipedia.org/wiki/INI_file) contains lines `option=value`,\noption names are the as provided by the help message above. Command line option\noverwrites configuration file option. For example, [see\ndefault](https://github.com/hombit/freddi/blob/master/freddi.ini) `freddi.ini`.\n\nPaths where this file is searched are `./freddi.ini` (execution path),\n`$HOME/.config/freddi/freddi.ini`, `/usr/local/etc/freddi.ini` and\n`/etc/freddi.ini`. You can provide configuration file to Docker container as a\nvolume: `` -v \"`pwd`/freddi.ini\":/etc/freddi.ini ``.\n\n#### Output values\n\n`Freddi` outputs time; the accretion rate; the mass of the hot part of the disk;\nthe outer radius of the hot zone; the irradiation factor; the relative\nhalf-height, effective and irradiation temperature, ratio of the irradiation to\nviscous flux at the outer radius of the hot zone; X-ray luminosity (erg/s) in\nthe band from E\\_min to E\\_max (`--emin` and `--emax` options); the optical\nmagnitudes in *U*, *B*, *V*, *R*, *I*, and *J* band ([Allen's Astrophysical\nQuantities, Cox 2015](http://www.springer.com/book/9780387951898)); the spectral density flux (erg/s/cm^2/Hz) at some wavelengths set by one or more `--lambda` options.\n\nSnapshot distributions at each time step, if produced, contain the following\ndata: radial coordinate in terms of the specific angular momentum, radius,\nviscous torque, surface density, effective temperature Teff, viscous temperature\nTvis, irradiation temperature Tirr, and the absolute half-height of the disk.\n\n#### <a name=\"usage-executables-example\"></a> Example\n\nThe following arguments instruct `Freddi` to calculate the decay of the outburst\nin the disk with the constant outer radius equal to 1 solar radius. The Kerr\nblack hole at the distance of 5 kpc has the mass of 9 solar masses, and the\nKerr's parameter is 0.4. The outer disk is irradiated with Cirr=1e-3.\n**Discuss all options used in the example***\n\n```sh\n./freddi --alpha=0.5 --Mx=9 --rout=1 --period=0.5 --Mopt=0.5 --time=50 \\\n  --tau=0.25 --dir=data/ --F0=2e+37 --colourfactor=1.7 --Nx=1000 \\\n  --distance=5 --gridscale=log --kerr=0.4 --Cirr=0.001 --opacity=OPAL \\\n  --initialcond=quasistat --windtype=Woods1996 --windXi_max=10 --windT_ic=1e8 \\\n  --windPow=1 \n```\n\n### Python\n\nPython bindings can be used as a convenient way to run and analyse Freddi\nsimulations.\n\n#### Initializing\n\nYou can prepare simulation set-up initializing `Freddi`\n(for black hole accretion disk) or `FreddiNeutronStar` (for NS) class instance.\nThese classes accept keyword-only arguments which have the same names and\nmeanings as [command line options](#usage-executables-options), but with three\nmajor exceptions:\n 1. Python package doesn't provide any file output functionality, that's why output arguments like `config`, `dir`, `fulldata`, `starflux`, `lambda` or `passband` are missed;\n 2. all values are assumed to be in CGS units, but you can use `Freddi.from_asrtopy` for dimensional values (see details bellow);\n 3. parameters of wind, NS `fp` and NS `kappa` models are passed as dictionaries (see specification bellow).\n\nThe following code snippet would set-up roughly the same simulation as\n[the command-line example](#usage-executables-example)\n\n```python\nfrom freddi import Freddi\n\nfreddi = Freddi(\n    alpha=0.5, Mx=9*2e33, rout=1*7e10, period=0.5*86400, Mopt=0.5*2e33,\n    time=50*86400, tau=0.25*86400, F0=2e+37, colourfactor=1.7, Nx=1000,\n    distance=5*3e21, gridscale='log', kerr=0.4, Cirr=0.001, opacity='OPAL',\n    initialcond='quasistat', wind='Woods1996',\n    windparams=dict(Xi_max=10, T_iC=1e8, W_pow=1),\n)\n```\n\nAlternatively we can do the same using `from_astropy` class-method which casts\nall [`astropy.units.Quantity`](https://docs.astropy.org/en/stable/units/quantity.html)\nobjects to CGS values. Note that dimensionality isn't checked, and technically\nit just does `arg.cgs.value` for every `Quantity` argument.\n\n```python\nimport astropy.units as u\nfrom freddi import Freddi\n\nfreddi = Freddi.from_astropy(\n    alpha=0.5, Mx=9*u.Msun, rout=1*u.Rsun, period=0.5*u.day, Mopt=0.5*u.Msun,\n    time=50*u.day, tau=0.25*u.day, F0=2e+37, colourfactor=1.7, Nx=1000,\n    distance=5*u.kpc, gridscale='log', kerr=0.4, Cirr=0.001, opacity='OPAL',\n    initialcond='quasistat', wind='Woods1996',\n    windparams=dict(Xi_max=10, T_iC=1e8*u.K, W_pow=1),\n)\n```\n\nWind model parameters are specified by `windparams` argument which should be\na `dict` instance with string keys and numeric values. Command option to \n`windparams` keys relation is: `--windC_w -> C_w`, `--windR_w -> R_w`,\n`--windA_0 -> A_0`, `--windB_1 -> B_1`, `--windXi_max -> Xi_max`,\n`windT_ic -> T_ic`, `--windPow -> Pow`, `windC_0 -> C_0`.\n\nNeutron star f_p model parameters are specified by `fpparams` mapping with the\nsame structure as `windparams`. Command options to `fpparams` keys relation is:\n`--fp-geometrical-chi -> chi`, `romanova2018-par1 -> par1`,\n`romanova2018-par2 -> par2`.\n\nNeutron star kappa_t model parameters are specified by `kappatparams` mapping\nwith the same structure as `windparams`. Command options to the mapping keys\nrelation is: `--kappat-const-value -> value`, `--kappat-corstep-in -> in`,\n`kappat-corstep-out -> out`, `--kappat-romanova2018-in -> in`,\n`--kappat-romanova2018-out -> out`, `romanova2018-par1 -> par1`,\n`--romanova2018-par2 -> par2`\n\n#### Running\n\nThere are two ways to run a simulation: iterating over time steps, and run the\nwhole simulation in one shot. Note that in both cases your `Freddi` object is\nmutating and represents the current state of the accretion disk.\n\nHere we use iterator interface which yields another `Freddi` object for each\ntime moment.\n\n```python\nimport astropy.units as u\nfrom freddi import Freddi\n\nfreddi = Freddi.from_astropy(\n    alpha=0.5, Mx=9*u.Msun, rout=1*u.Rsun, period=0.5*u.day, Mopt=0.5*u.Msun,\n    time=20*u.day, tau=1.0*u.day, Mdot0=5e18, distance=10*u.kpc,\n    initialcond='quasistat',\n)\n\nfor state in freddi:\n    print(f't = {state.t} s, Mdot = {state.Mdot:g} g/s')\nassert state.t == freddi.t\n```\n\nIn this example we run a simulation via `.evolve()` method which returns\n`EvolutionResult` object keeping all evolution states internally and providing\ntemporal distribution of disk's properties.\n\n```python\nimport astropy.units as u\nimport matplotlib.pyplot as plt\nfrom freddi import Freddi\n\nfreddi = Freddi.from_astropy(\n    alpha=0.5, Mx=9*u.Msun, rout=1*u.Rsun, period=0.5*u.day, Mopt=0.5*u.Msun,\n    time=20*u.day, tau=1.0*u.day, Mdot0=5e18, distance=10*u.kpc,\n    initialcond='quasistat',\n)\n\nresult = freddi.evolve()\nassert result.t[-1] == freddi.t\n\n# Plot Mdot(t)\nplt.figure()\nplt.title('Freddi disk evolution: accretion rate')\nplt.xlabel('t, day')\nplt.ylabel(r'$\\dot{M}$, g/cm')\nplt.plot(result.t / 86400, result.Mdot)\nplt.show()\n\n# Plot all F(h) profiles\nplt.figure()\nplt.title('Freddi disk evolution: viscous torque')\nplt.xlabel('r, cm')\nplt.ylabel('F, dyn cm')\nplt.xscale('log')\nplt.yscale('log')\nplt.plot(result.R.T, result.F.T)\nplt.show()\n\n# Plot evolution of effective temperature of the outer hot disk ring\nplt.figure()\nplt.title('Freddi disk evolution: outer effective temperature')\nplt.xlabel('t, day')\nplt.ylabel('T, K')\nplt.plot(result.t / 86400, result.last_Tph)\nplt.show()\n```\n\n#### Properties and methods\n\n`Freddi`, `FreddiNeutronStar` and `EvolutionResult` objects contain dozens of\nproperties returning various physical values like `t` for time moment,\n`Mdot` for accretion rate onto central object, `R` for radius, `F` for torque,\n`Tph` for effective temperature and so on. `first_*` and `last_*` properties\nare used to access innermost and outermost hot disk values of radial-distributed\nquantities. The complete list of properties can be obtained by `dir(Freddi)` or\n`dir(FreddiNeutronStar)`. Note that the most properties are lazy-evaluated and\nrequire some time to access first time. `EvolutionResult` provides all the\nsame properties as underlying `Freddi` or `FreddiNeutronStar` objects but with\nadditional array dimension for temporal distribution, so if `Freddi.Lx` is a\nscalar then `EvolutionResult.Lx` is an 1-D `numpy` array of `(Nt,)` shape,\nif `Freddi.Sigma` is an 1-D array of `(Nx,)` shape, then\n`EvolutionResult.Sigma` is an 2-D array of `(Nt, Nx)` shape. Also, note that if\ndisk shrinks during a simulation, the missing values of `EvolutionResult`\nproperties are filled by NaN.\n\nAll three classes have `flux(lmbd, region='hot', phase=None)` method which can\nbe used to find spectral flux density per unit frequency for optical\nemission. `lmbd` argument can be a scalar or a multidimensional `numpy` array\nof required wavelengths in cm; `region` could be one of \"hot\" (hot disk),\n\"cold\" (cold disk), \"disk\" (\"hot\" + \"cold\"), \"star\" (companion star), and\n\"all\" (\"hot\" + \"cold\" + \"star\"); `phase` is a binary system orbital phase in\nradians, it is required for `region=\"star\"` and `region=\"all\"` only, it can be\ncalculated as `2\u03c0 t / period + constant`.\n\nAll properties and methods return values in CGS units.\n\n## Physical Background\n\n`Freddi` \u2014 Fast Rise Exponential Decay: accretion Disk model Implementation \u2014 is\ndesigned to solve the differential equation of the viscous evolution of the\nShakura-Sunyaev accretion disk in a stellar binary system. Shakura-Sunyaev disk\nis the standard model of accretion of plasma onto the cosmic bodies, like\nneutron stars or black holes. Viscous evolution of the accretion disks exibits\nitself, for example, in X-ray outbursts of binary stars. Usually, the outbursts\nlast for several tens of days and many of them are observed by orbital\nobservatories.\n\nThe basic equation of the viscous evolution relates the surface density and\nviscous stresses and is of diffusion type. Evolution of the accretion rate can\nbe found on solving the equation. The distribution of viscous stresss defines\nthe emission from the source.\n\nThe standard model for the accretion disk is implied, which is developed by\n[Shakura & Sunyaev (1973)](http://adsabs.harvard.edu/abs/1973A%26A....24..337S).\nThe inner boundary of the disk is at the ISCO or can be explicitely set. The\nboundary conditions in the disk are the zero stress at the inner boundary and\nthe zero accretion rate at the outer boundary. The conditions are suitable\nduring the outbursts in X-ray binary transients with black holes.\n\nIn a binary system, the accretion disk is radially confined. In `Freddi`, the\nouter radius of the disk can be set explicitely or calculated as 90% of the \nRoche lobe size to aproximate the tidal truncation radius obtained by \n[Papaloizou & Pringle (1977)](https://ui.adsabs.harvard.edu/abs/1977MNRAS.181..441P), see  --rout help for details.\n\nThe parameters at the disk central plane are defined by the analytic\napproximations ([Suleimanov et al. 2007](http://adsabs.harvard.edu/abs/2007ARep...51..549S)), valid for the\neffective surface temperatures from 10 000 to 100 000 K, approximately. It is\nassumed that the gas pressure dominates, the gas is completely ionized, and the\nphoton opacity is defined by the free-free and free-bound transitions. Opacity\nlaw is for the solar element abundancies and can be chosen from two types: (1)\nKramers' opacity: kappa = 5e24 rho/T\\^(7/2) cm2/g (2) approximation to OPAL\ntables: kappa = 1.5e20 rho/T\\^(5/2) cm2/g ([Bell & Lin\n1994](http://adsabs.harvard.edu/abs/1994ApJ...427..987B))\n\nThe disk at each radius is in the \"hot\" state if the gas is completely ionized.\nOtherwise, the disk is considered to be \"cold\" locally. Alpha-parameter in the\ncold parts of the disk is appreciably lower than in the hot parts. Thus the\nviscous evolution of the disk should proceed more effectively in the hot parts\nof the disk. To simulate this, `Freddi` has an option to control the outer\nradius of the hot evolving disk. We assume that the evolution goes through the\nquasi-stationary states in the hot zone of variable size. By default, the hot\nzone has the constant size, equal to the tidal radius.\n\nThe initial distribution of the matter in the disk should be specified with\n`--initialcond` option. `Freddi` can start from several types of initial\ndistributions: power-law distribution of the surface density\n`--initialcond=powerSigma`, power-law `--initialcond=powerF` or sinus-law\n`--initialcond=sinusF` distribution of the viscous torque, quasi-stationary\ndistribution `--initialcond=quasistat`. The choice of the initial distribution\ndefines what type of evolution is to be calculated.\n\nStarting from the quasi-stationary or `sinusF` distribution, the solution\ndescribes the decaying part of the outburst. Zero-time accretion rate through\nthe inner edge can be set. In other cases, the rise to the peak is also\ncomputed. Then, initial value of viscous torque at the outer radius (can be set\nby `--F0`) defines uniquely the initial mass of the disk.\n\nSelf-irradiation by the central X-rays heats the outer parts of the disk. A\nfraction of the bolometric flux is supposed to illuminate the disk surface. This\nresults in the larger size of the hot disk if such model is assumed. Also, the\noptical flux is increased because the flux outgoing from the disk surface is\nproportional to Teff\\^4 = Tvis\\^4+Tirr\\^4. Self-irradiation of the disk is\nincluded in the computation if irradiation parameter is not zero. The simplest\nway is to set a constant irradiation factor `--Cirr` (the studies of X-ray novae\nsuggest the range for Cirr 1e-5\u20145e-3).\n\nObserved flux depends on the distance to the source and the inclination of the\ndisk plane. The inclination angle is the angle between the line of sight and the\nnormal to the disk. The flux, emitted from the disk surface, is defined by the\nsum of the visous and irradiating flux, where the viscous flux is calculated\ntaking into account general relativity effects near the black hole, following\n[Page & Thorne\n(1974)](http://adsabs.harvard.edu/cgi-bin/nph-bib_query?bibcode=1974ApJ...191..499P)\nand [Riffert & Herold (1995)](http://adsabs.harvard.edu/cgi-bin/nph-bib\\_query?bibcode=1995ApJ...450..508R).\n\n\n### Accretion disk wind\n\nPresumably, during an outburst there is an outflow in the form of a wind from the \naccretion disk around the compact object. The presence of such a wind in the LMXBs is supported\nby modern observations indicating the expansion of ionized matter. Such an outflow of matter,\nbeing an additional  source of angular momentum transfer in the disk, can strongly influence \nits viscous evolution. \n\nHowever, the nature of such winds and their  physical characteristics are an open question.\nNamely, there are three mechanisms which are considered:\nheating of matter by central radiation in optically thin regions of the disk \n([Begelman et al. 1983](https://ui.adsabs.harvard.edu/abs/1983ApJ...271...70B), \n[Shields et al. 1986](https://ui.adsabs.harvard.edu/abs/1986ApJ...306...90S), \n[Woods et al. 1996](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W)), \nthe pressure of the magnetic field of the disk\n([Blandford & Payne 1982](https://ui.adsabs.harvard.edu/abs/1982MNRAS.199..883B), \n[Habibi & Abbassi 2019](https://ui.adsabs.harvard.edu/abs/2019ApJ...887..256H), \n[Nixon & Pringle 2019](https://ui.adsabs.harvard.edu/abs/2019A%26A...628A.121N))\nand the pressure of local radiation at super-Eddington accretion rates\n([Shakura & Sunyaev 1973](http://adsabs.harvard.edu/abs/1973A%26A....24..337S), \n[Proga & Kallman 2002](https://ui.adsabs.harvard.edu/abs/2002ApJ...565..455P)). \n\n`Freddi` is modernized in such a way that it is able to solve the viscous evolution \nequation with an inhomogeneous term that is responsible for the presence of the disk wind.\nThis term is the dependence of the surface density of the wind mass-loss rate on \nthe distance along the disk's surface. Different forms of such dependence correspond \nto different wind models, and to different classes within `Freddi`. \n\n\nOne can choose a wind model by setting the\n`--windtype` option. The thermal wind model ([Woods et al. 1996](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W)),\nwhich implies that the outflow of matter occurs due to the heating of the outer parts of the disk\nby a central radiation source, can be chosen by setting `--windtype=Woods1996`. \nThe option `--windtype=Janiuk15` corresponds to the model from work [Janiuk et al. (2015)](https://ui.adsabs.harvard.edu/abs/2015A%26A...574A..92J)\nwhere the wind is started in the super-Eddington regime.\nWhen choosing option `--windtype=Janiuk15`, the you must also specify the values of\nthe super-Eddington wind parameters with `--windA0` and `--windB1` options.\nYou can also select the `--windtype=toy` option, which corresponds to a toy wind model when the user sets \nthe wind strength relatively to the accretion rate using the option `--windPow`.\n\n#### Compton-heated wind\n\nAt the moment, `Freddi` is more focused on simulating outbursts taking into account the thermal wind (`--windtype=Woods1996` option). \nFor a better understanding, let's discuss a little the physics of the process of launching such a wind \nand its parameters in the code.\n\nIn the standard accretion disk model by [Shakura & Sunyaev (1973)](http://adsabs.harvard.edu/abs/1973A%26A....24..337S) \nthe disk is concave, and, as a result, the disk surface is exposed to the central radiation, \nwhich heats the disk material. As a result, the heated matter, starting from a certain radius, \nbegins to leave the accretion disk. This process of heating the matter of the accretion disk by means of Compoton\nprocesses was developed in [Begelman et al. (1983)](https://ui.adsabs.harvard.edu/abs/1983ApJ...271...70B) and \n[Shields et al. (1986)](https://ui.adsabs.harvard.edu/abs/1986ApJ...306...90S). \nIn a later work [Woods et al. (1996)](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W), \ntwo-dimensional magnetohydrodynamic calculations were performed and the \nresults of [Shields et al. (1986)](https://ui.adsabs.harvard.edu/abs/1986ApJ...306...90S) were generalized. \n[Woods et al. (1996)](https://ui.adsabs.harvard.edu/abs/1996ApJ...461..767W) give an expression for the surface density of the mass \nloss rate as a function of distance along the disk's surface. This function is used in `Freddi` \nto taking thermal wind into account.\n\nChoosing option `--windtype=Woods1996`, it is necessary to set the value of the ionization parameter Xi\n(which is proportional to the ratio of the radiation and gas pressures) by the option `--windXi_max` and the Compoton temperature T_ic \n(which determines the hardness of the irradiating spectrum and the size of the region where the wind operates) by the option `--windT_ic`. \n\n### Companion star irradiation\n\nWe use a simple model of irradiated star to simulate periodic variability and\nX-ray thermalization by a companion's photosphere. Our model assumes that the\ncompanion star's shape corresponds to equipotential surface which size is set\nby `--rochelobefill` option, unity means that star fills its Roche lobe, any\nsmaller value decreases star's polar radius correspondingly. Technically,\nstar's surface is built from `20 * 4^starlod` triangles, use `--starlod` to\nset level of detail, `--starlod=3` should give few percent precision. Every\ntriangle has black-body spectrum with bolometric luminosity given by a sum of\nstar's own luminosity (set by `--Topt`) and irradiation flux multiplied by \nunity minus albedo (set by `--staralbedo`).\n\nPlease note that the model is limited and doesn't implement limb darking or\neclipsing.\n\n## Development guide\n\n### Source code and tests\n\n`Freddi` uses [Cmake](https://cmake.org) as a build system.\n\nThe C++ source code is located in `cpp` folder which has following structure:\n- `main.cpp` and `main-ns.cpp` implements `main()` function for `freddi` and `freddi-ns` correspondingly;\n- `include` for library header files, it has `ns` sub-folder for neutron star related stuff;\n- `src` for library C++ files, it also has `ns` sub-folder;\n- `test` provides library unit tests;\n- `pywrap` has both header and source files for `Boost::Python`/`Boost::NumPy` bindings.\n\nNote, that we require C++17 standard (while not having idiomatic C++17 code),\nand require code to be compiled by modern GCC and CLang on Linux. Please write\nunit tests where you can and use `ctest` to check they pass.\n\nThe Python project is specified by `pyproject.toml` (which just lists build\nrequirements), `setup.py` and `MANIFEST.in` files, we use\n[`scikit-build`](https://scikit-build.readthedocs.io/) as a build system.\n`scikit-build` uses Python-related section of `CMakeLists.txt` to build C++\nsource code into Python extension, and accomplish it with Python files located\nin `python/freddi` directory. Use `python setup.py build_ext` to build the\nextension, optionally with `-DSTATIC_LINKING=TRUE` to link `Boost::Filesystem`,\n`Boost::Python` and `Boost::NumPy` statically. Please, pay attention to two\nlast libraries, because they should be built against the same Python version as\nyou use.\n\n`python/test` contains some tests, you can run them by `python3 setup.py test`.\n- `test_freddi.py` and `test_ns.py` contain unit tests for Python source;\n- `test_analytical.py` contains integration tests to compare analytical solutions of the equation of disk viscous evolution with the numerical solutions of `Freddi`;\n- `regression.py` contains regression tests to be sure that 1) the `Freddi` output is stable, and 2) the Python code gives the same results as binary executables do.\n\nThe regression test data are located in `python/test/data`. Sometimes you need\nto update these regression data, for example when you introduce new\ncommand-line option with a default value, add new output column or fix some bug\nin physical model. For these purposes you can use `generate_test_data.sh`\nscript located in this folder.\n\n`Dockerfile` is used to build a Docker image with statically-linked binaries,\nand `Dockerfile.python` is used to build a Docker image with\n[`manylinux`](https://github.com/pypa/manylinux)-compatible Python wheels.\n\n\n### Continuous integration\n\nWe use [Github Actions](https://github.com/hombit/freddi/actions) as a\ncontinuous integration (CI) system. The workflow file is located in\n`.github/workflows/main.yml` and a couple of auxiliary files are located in\n`.ci` folder. CI allows us to test new commits to prevent different bugs:\n- `gcc` and `clang` actions test binaries building, execute sample `Freddi` programs, run C++ unit tests, perform C++ regression tests, and check the consistency of the `Readme.md` with programs' `--help` output\n- `cpython` action builds Python extension module and runs all Python tests\n- `docker-exe` builds a Docker image using `Dockerfile` and execute sample `Freddi` programs inside a Docker container\n- `docker-python` builds a Docker image using `Dockefile.python`, uses wheels it has built to build Python Docker images for several Python versions using `.ci/Dockerfile-test-wheels`, and runs sample Python scripts with `freddi.Freddi` class\n\n### This Readme\n\nPlease keep Readme updated. You can update the help messages in the\n[Usage](#usage) section using `.ci/update-help-readme.py` script.\n\n### Release new version\n\nCheck-list:\n\n- [ ] Update version in `setup.py` and commit it\n- [ ] Create `git` tag\n  ```sh\n  git tag $VERSION\n  ```\n- [ ] Build new `freddi` image using `Dockerfile`\n  ```sh\n  docker buildx build --push --platform linux/arm64,linux/amd64 --tag ghcr.io/hombit/freddi:$VERSION .\n  docker pull ghcr.io/hombit/freddi:$VERSION\n  docker tag ghcr.io/hombit/freddi:$VERSION ghcr.io/hombit/freddi:latest\n  docker push ghcr.io/hombit/freddi:latest\n  ```\n- [ ] Build new `freddi-python` image using `Dockerfile.python`\n  ```sh\n  docker buildx build --push --platform linux/arm64,linux/amd64 --tag ghcr.io/hombit/freddi-python:$VERSION -f Dockerfile.python .\n  docker pull ghcr.io/hombit/freddi-python:$VERSION\n  docker tag ghcr.io/hombit/freddi-python:$VERSION ghcr.io/hombit/freddi-python:latest\n  docker push ghcr.io/hombit/freddi-python:latest\n  ```\n- [ ] Upload wheels onto PyPi.org\n  ```sh\n  docker run --rm -ti ghcr.io/hombit/freddi-python:$VERSION sh -c \"python3.7 -m twine upload /dist/*.tar.gz\" # sdist\n  docker run --rm -ti --platform linux/amd64 ghcr.io/hombit/freddi-python:$VERSION sh -c \"python3.7 -m twine upload /dist/*.whl\" # bdist x86_64\n  docker run --rm -ti --platform linux/arm64 ghcr.io/hombit/freddi-python:$VERSION sh -c \"python3.7 -m twine upload /dist/*.whl\" # bdist aarch64\n  ```\n- [ ] [Optional] Build executables for GitHub release\n- [ ] [Optional] Build and upload macOS wheels\n- [ ] Crate new GitHub release\n\n\n## Questions and comments\n\nIf you have any problems, questions, or comments, please address them to\n[Issues](https://github.com/hombit/freddi/issues) or to hombit\\@gmail.com\n\n## License\n\nCopyright (c) 2016\u20132022, Konstantin L. Malanchev, Galina V. Lipunova & Artur L. Avakyan.\n\n`Freddi` is distributed under the terms of the\n[GPLv3](https://www.gnu.org/licenses/gpl-3.0.html).\n\nPlease, accompany any results obtained using this code with reference to\nLipunova & Malanchev (2017)\n[2017MNRAS.468.4735L](http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L),\nfor the case of windy calculations please also refer Avakyan\u00a0et\u00a0al.\u00a0(2021)\n[2021AstL...47..377A](http://adsabs.harvard.edu/abs/2021AstL...47..377A),\nand for the case of magnetised neutron star please also refer Lipunova et al. (2021)\n[2021arXiv211008076L](http://adsabs.harvard.edu/abs/2021arXiv211008076L).\n\n\n## BibTex\n```bibtex\n@ARTICLE{2017MNRAS.468.4735L,\n   author = { {Lipunova}, G.~V. and {Malanchev}, K.~L.},\n    title = \"{Determination of the turbulent parameter in accretion discs: effects of self-irradiation in 4U 1543{\\minus}47 during the 2002 outburst}\",\n  journal = {\\mnras},\narchivePrefix = \"arXiv\",\n   eprint = {1610.01399},\n primaryClass = \"astro-ph.HE\",\n keywords = {accretion, accretion discs, methods: numerical, binaries: close, stars: black holes, X-rays: individual: 4U 1543-47},\n     year = 2017,\n    month = jul,\n   volume = 468,\n    pages = {4735-4747},\n      doi = {10.1093/mnras/stx768},\n   adsurl = {http://adsabs.harvard.edu/abs/2017MNRAS.468.4735L},\n  adsnote = {Provided by the SAO/NASA Astrophysics Data System}\n}\n\n@ARTICLE{2021AstL...47..377A,\n       author = {{Avakyan}, A.~L. and {Lipunova}, G.~V. and {Malanchev}, K.~L. and {Shakura}, N.~I.},\n        title = \"{Change in the Orbital Period of a Binary System Due to an Outburst in a Windy Accretion Disk}\",\n      journal = {Astronomy Letters},\n     keywords = {X-ray binaries, wind, transients, period, accretion, Astrophysics - High Energy Astrophysical Phenomena},\n         year = 2021,\n        month = jun,\n       volume = {47},\n       number = {6},\n        pages = {377-389},\n          doi = {10.1134/S1063773721050017},\narchivePrefix = {arXiv},\n       eprint = {2105.11974},\n primaryClass = {astro-ph.HE},\n       adsurl = {https://ui.adsabs.harvard.edu/abs/2021AstL...47..377A},\n      adsnote = {Provided by the SAO/NASA Astrophysics Data System}\n}\n\n@ARTICLE{2021arXiv211008076L,\n       author = {{Lipunova}, Galina and {Malanchev}, Konstantin and {Tsygankov}, Sergey and {Shakura}, Nikolai and {Tavleev}, Andrei and {Kolesnikov}, Dmitry},\n        title = \"{Physical modeling of viscous disc evolution around magnetized neutron star. Aql X-1 2013 outburst decay}\",\n      journal = {arXiv e-prints},\n     keywords = {Astrophysics - High Energy Astrophysical Phenomena, Astrophysics - Solar and Stellar Astrophysics},\n         year = 2021,\n        month = oct,\n          eid = {arXiv:2110.08076},\n        pages = {arXiv:2110.08076},\narchivePrefix = {arXiv},\n       eprint = {2110.08076},\n primaryClass = {astro-ph.HE},\n       adsurl = {https://ui.adsabs.harvard.edu/abs/2021arXiv211008076L},\n      adsnote = {Provided by the SAO/NASA Astrophysics Data System}\n}\n```\n",
    "bugtrack_url": null,
    "license": "GPLv3",
    "summary": "Compute FRED light curves of LMXBs outbursts",
    "version": "2.0.0",
    "project_urls": {
        "Homepage": "http://xray.sai.msu.ru/~malanchev/freddi/"
    },
    "split_keywords": [
        "science",
        "astrophysics",
        "accretion"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a990076e010d2ffdf2557e9608a08a11a301e3151b2cd7c660bdb3a1e48f0ca6",
                "md5": "b8d9a8885045c0a5a039db834ac60d49",
                "sha256": "b10866721676d0308ab96877668d7ccf2788fa56176243891910f2311f6c0619"
            },
            "downloads": -1,
            "filename": "freddi-2.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "has_sig": false,
            "md5_digest": "b8d9a8885045c0a5a039db834ac60d49",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": ">=3.7",
            "size": 408381,
            "upload_time": "2024-04-13T13:03:51",
            "upload_time_iso_8601": "2024-04-13T13:03:51.716080Z",
            "url": "https://files.pythonhosted.org/packages/a9/90/076e010d2ffdf2557e9608a08a11a301e3151b2cd7c660bdb3a1e48f0ca6/freddi-2.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "6685cccf9db2f44a69a28eb7c25d369d2c047dc7eb4f93481dfbf7811800e716",
                "md5": "d68f0d6ffb84482adc2b9c843888b64b",
                "sha256": "e3d238ed54c91149fee2ba24ffaa330ffc231c0f4a58164b4615696cbf31fc18"
            },
            "downloads": -1,
            "filename": "freddi-2.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "has_sig": false,
            "md5_digest": "d68f0d6ffb84482adc2b9c843888b64b",
            "packagetype": "bdist_wheel",
            "python_version": "cp311",
            "requires_python": ">=3.7",
            "size": 408454,
            "upload_time": "2024-04-13T13:03:53",
            "upload_time_iso_8601": "2024-04-13T13:03:53.366485Z",
            "url": "https://files.pythonhosted.org/packages/66/85/cccf9db2f44a69a28eb7c25d369d2c047dc7eb4f93481dfbf7811800e716/freddi-2.0.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "bae77e57dcdcc3c37237b250eab59036ea496eed4428d8c5e022137da5a8ea52",
                "md5": "2ff33fcc23769bec6f1a0366f02b8b64",
                "sha256": "be2f3b9773c4612bb7040b7c2378c585d882194b454baa9f918b644d5dee16f2"
            },
            "downloads": -1,
            "filename": "freddi-2.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "has_sig": false,
            "md5_digest": "2ff33fcc23769bec6f1a0366f02b8b64",
            "packagetype": "bdist_wheel",
            "python_version": "cp312",
            "requires_python": ">=3.7",
            "size": 409338,
            "upload_time": "2024-04-13T13:03:55",
            "upload_time_iso_8601": "2024-04-13T13:03:55.047987Z",
            "url": "https://files.pythonhosted.org/packages/ba/e7/7e57dcdcc3c37237b250eab59036ea496eed4428d8c5e022137da5a8ea52/freddi-2.0.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "243a5e3b99f656d9e8d6dce1bb8edac6c26cb599cf843c5aa57fdb4f865498f7",
                "md5": "da81f4dec0b817fc3e330d378acaf502",
                "sha256": "fff20683a1ff9bbb0247672a9608971d6baa127158422bfa7daa8e237be073b9"
            },
            "downloads": -1,
            "filename": "freddi-2.0.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "has_sig": false,
            "md5_digest": "da81f4dec0b817fc3e330d378acaf502",
            "packagetype": "bdist_wheel",
            "python_version": "cp37",
            "requires_python": ">=3.7",
            "size": 397374,
            "upload_time": "2024-04-13T13:03:56",
            "upload_time_iso_8601": "2024-04-13T13:03:56.772063Z",
            "url": "https://files.pythonhosted.org/packages/24/3a/5e3b99f656d9e8d6dce1bb8edac6c26cb599cf843c5aa57fdb4f865498f7/freddi-2.0.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "0e57f48c5b02389ddcec3a9d35251f97dc3f1737f9cff7b1fb2494ef7a322b98",
                "md5": "a0de8f7b39866bf6e227bfcf59436e26",
                "sha256": "ffbdb1be53cb2746df48a62ee069d4ea9a5dd3f125bb4f3eb14d1ee852a3854f"
            },
            "downloads": -1,
            "filename": "freddi-2.0.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "has_sig": false,
            "md5_digest": "a0de8f7b39866bf6e227bfcf59436e26",
            "packagetype": "bdist_wheel",
            "python_version": "cp38",
            "requires_python": ">=3.7",
            "size": 408731,
            "upload_time": "2024-04-13T13:03:57",
            "upload_time_iso_8601": "2024-04-13T13:03:57.943351Z",
            "url": "https://files.pythonhosted.org/packages/0e/57/f48c5b02389ddcec3a9d35251f97dc3f1737f9cff7b1fb2494ef7a322b98/freddi-2.0.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "789fb987a2da22cde7cb60cb251233c1784f34c9d87bdeed281a2f1c323c09b3",
                "md5": "747f68c6b9c408f4b19b835335e2681b",
                "sha256": "d552e3939c33a5c3ef9ff2f29b8a812b0d2f7bb1abb34bef7114655b38924996"
            },
            "downloads": -1,
            "filename": "freddi-2.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "has_sig": false,
            "md5_digest": "747f68c6b9c408f4b19b835335e2681b",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": ">=3.7",
            "size": 408449,
            "upload_time": "2024-04-13T13:03:59",
            "upload_time_iso_8601": "2024-04-13T13:03:59.710636Z",
            "url": "https://files.pythonhosted.org/packages/78/9f/b987a2da22cde7cb60cb251233c1784f34c9d87bdeed281a2f1c323c09b3/freddi-2.0.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "cc731b08d794d2603de3b1e4dba350bfee7ce4a2c442e3daadeae5e593a67e26",
                "md5": "8c1a17c02c77fad44afa2460d379a7b8",
                "sha256": "0ac8a820bfd1b007625bb6fc4816818c93c8a31154709a80006ca671145173bf"
            },
            "downloads": -1,
            "filename": "freddi-2.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "8c1a17c02c77fad44afa2460d379a7b8",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 131892,
            "upload_time": "2024-04-13T13:03:23",
            "upload_time_iso_8601": "2024-04-13T13:03:23.658895Z",
            "url": "https://files.pythonhosted.org/packages/cc/73/1b08d794d2603de3b1e4dba350bfee7ce4a2c442e3daadeae5e593a67e26/freddi-2.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-04-13 13:03:23",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "freddi"
}
        
Elapsed time: 0.22487s