/*******************************************************************************
 * 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 */