Skip to main content

This package evaluates the signatures of diffuse boosted dark matter by supernova neutrinos in the early Universe

Project description

Python License ArXiv

dukes: DiffUse-boosted darK mattEr by Supernova neutrinos

dukes is a pyhon package for evaluating the signatures of diffuse boosted dark matter by supernova neutrinos in the early Universe based on arXiv:2404.08528. It also supports an experimental feature that implements particle-model-dependent differential cross sections for DM-neutrino and DM-electron.

Citation

If you use this package or part of the code in your research, please cite the following:

  1. Yen-Hsun Lin and Meng-Ru Wu, Echoes of darkness: Supernova-neutrino-boosted dark matter from all galaxies, arXiv:2404.08528
  2. dukes: https://github.com/yenhsunlin/dukes

Installation

To install, excute the following command on the prompt

$ pip install dukes

and everything should be processed on-the-fly.

Dependency

dukes requires python >= 3.8 and the following packages

  • numpy >= 1.20.0
  • scipy >= 1.10.0
  • vegas >= 6.0.1

where vegas is a the backend engine for evaluating multidimensional integrals based on adaptive Monte Carlo vegas algorithm, see its homepage: https://pypi.org/project/vegas/.

Other packages, e.g. gvar, maybe required by these dependencies during the installation. The versions of these dependencies are not strict, but are recommended to update to the latest ones to avoid incompatibility.

Usage

We briefly summarize the usage in this section and a comprehensive tutorial can be found in the jupyter notebook in tutorial/tutorial.ipynb.

To import, do

>>> import dukes

in python terminal and is similar in the jupyter notebook. All module functions named funcname can be called by typing dukes.funcname.

Examples

Boosted dark matter velocity

A boosted dark matter (BDM) with mass $m_\chi$ and kinetic energy $T_\chi$ has the velocity $v_\chi$,

$$ \frac{v_\chi}{c} = \frac{\sqrt{T_\chi(2m_\chi+T_\chi)}}{m_\chi+T_\chi}. $$

Let $T_\chi=$ Tx and $=m_\chi=$ mx, the corresponding function that evaluates $v_\chi/c$ is

>>> Tx,mx = 5,1  # MeV
>>> dukes.vBDM(Tx,mx)
0.9860132971832694

The diffuse BDM flux

The averaged diffuse BDM (DBDM) flux at redshift $z=0$ is given by

$$ \frac{d\Phi_\chi}{dT_\chi} = \frac{v_\chi}{H_0} \int_0^{z_{\rm max}} \frac{dz}{\varepsilon(z)} \int dM_G \frac{d\Gamma_{{\rm SN}}(z)}{dM_G}\frac{d\bar N_\chi(M_G)}{dT_\chi^\prime}. $$

Same as the above example,

>>> dukes.flux(Tx,mx,usefit=True,nitn=10,neval=50000)
4.422705310516041e-08

as in MeV−1 cm−2 s−1.

Throughout the entire package, we have implemented the differential DM-neutrino scattering cross section in CM frame is isotropic and energy-independent

$$ \frac{d\sigma_{\chi \nu}}{d\Omega_{\rm CM}}=10^{-35}{\rm cm^2sr^{-1}}. $$

The argument usefit is to turn on/off the fitting function used in obtaining the average supernova position on the galactic plane for galaxy with baryonic mass $M_G$. If usefit=False, the function will call galacticDensityProfile to evaluate the area density for galaxy with arbitrary $M_G$. It requires quadrature integration quad from scipy and the computation time surges accordingly, but the accuracy is improved insignificantly.

The arguments nitn and neval are passed to vegas and determine how many chains of iteration and how many numbers to be evaluated in each chain. Increasing them will improve the accuracy of the results but also cost longer computation time. We relegate the detail to vegas documentation.

Physical constants

We have a class named constant that contains multiple physical constants and conversion factors frequently used in this package. For instance, electron mass

>>> dukes.constant.me
0.511

as in MeV and the speed of light

>>> dukes.constant.c
29980000000.0

as in cm s−1. Conversion factors such as converting kiloparsec to centimeters

>>> dukes.constant.kpc2cm
3.085e21

and year to seconds

>>> dukes.constant.year2Seconds
31556926

Scripting

In python script (see tests/dukes_example.py), one can write

# dukes_example.py

import sys
import dukes

if __name__ == '__main__':

    Tx = float(sys.argv[1])  # DM kinetic energy, MeV
    mx = float(sys.argv[2])  # DM mass, MeV
    vx = dukes.vBDM(Tx,mx)   # BDM velocity
    
    print(vx)                # Print the BDM velocity

and excute this on the prompt

$ python dukes_example.py 5 1
0.9860132971832694

or whatever style you like!

Bugs and troubleshooting

Please report to the author, Yen-Hsun Lin, via yenhsun@phys.ncku.edu.tw.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dukes-1.4.0.tar.gz (718.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dukes-1.4.0-py3-none-any.whl (717.8 kB view details)

Uploaded Python 3

File details

Details for the file dukes-1.4.0.tar.gz.

File metadata

  • Download URL: dukes-1.4.0.tar.gz
  • Upload date:
  • Size: 718.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.7

File hashes

Hashes for dukes-1.4.0.tar.gz
Algorithm Hash digest
SHA256 b91e5e63b4178695b033ceb66ed926566488584e6cb1bb4f22d11b9d22cdc507
MD5 fac25cab4a7f4e87e75b0a0baca0b8fd
BLAKE2b-256 74a9584b32c9e277d3841cd99ffbd647e02c86953cd4e4faf50252fdb7345765

See more details on using hashes here.

File details

Details for the file dukes-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: dukes-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 717.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.7

File hashes

Hashes for dukes-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 de0a9fc88b71fe01fd1bc4478193a0b49297db1d276f9f9dd7eaffe3d9a03be7
MD5 07284e42c9d38ab61870b88f51469b41
BLAKE2b-256 3d1c8159b6841ee796cb26b991b89bdaf82659c7d4888747790cd6688ea518ad

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page