/******************************************************************************* * This file is part of SWIFT. * Copyright (c) 2021 Willem Elbers (whe@willemelbers.com) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published * by the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see . * ******************************************************************************/ #ifndef SWIFT_DEFAULT_FERMI_DIRAC_H #define SWIFT_DEFAULT_FERMI_DIRAC_H /* Standard headers */ #include #include /* Faster exponential */ #include "exp.h" /** * @brief Calculate the neutrino density at the particle's location in phase * space, according to the 0th order background model: f_0(x,p,t). * * @param z Argument of the FD function: z = p/kbT */ INLINE static float fermi_dirac_density(float z) { return 1.f / (optimized_expf(z) + 1.f); } /** * @brief Return a microscopic neutrino mass in eV based on the particle seed. * We simply cycle through the masses defined in the cosmology. * * @param N_nu Number of distinct neutrino masses * @param m_eV_array Array of masses in eV * @param seed The seed of the neutrino particle */ INLINE static double neutrino_seed_to_mass(const int N_nu, const double *m_eV_array, uint64_t seed) { return m_eV_array[(int)(seed % N_nu)]; } /** * @brief Return the particle mass degeneracy based on the particle seed. * We simply cycle through the distinct masses defined in the cosmology. * * @param N_nu Number of distinct neutrino masses * @param deg_array Array of degeneracies * @param seed The seed of the neutrino particle */ INLINE static double neutrino_seed_to_degeneracy(const int N_nu, const double *deg_array, uint64_t seed) { return deg_array[(int)(seed % N_nu)]; } double neutrino_seed_to_fermi_dirac(uint64_t seed); void neutrino_seed_to_direction(uint64_t seed, double n[3]); #endif /* SWIFT_DEFAULT_FERMI_DIRAC_H */