Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Alternative Conditional Mass Functions #370

Open
daviesje opened this issue Mar 28, 2024 · 0 comments · Fixed by #388
Open

Alternative Conditional Mass Functions #370

daviesje opened this issue Mar 28, 2024 · 0 comments · Fixed by #388
Assignees
Labels
context: C backend Changes occur predominantly in the C code context: v4-prep This issue regards changes to the v4-prep branch type: feature: accuracy New code that improves overall accuracy/concistency type: feature: physical New physical feature to be included

Comments

@daviesje
Copy link
Contributor

Different halo mass functions have been handled previously by rescaling the integrals on the grid, which were calculated using the Extended Press-Schechter conditional mass function, to the mean values of a specified unconditional mass function. This was done separately for ionising emissivity and star formation rate density so that we always had the correct mean.

With a discrete halo catalogue this is not possible. We could apply the same corrections to the HaloBox grids, but then the emissivity grids would be inconsistent with the halo mass catalogues. Alternatives include:

  • Implementing Sheth-Tormen (https://arxiv.org/pdf/astro-ph/0105113.pdf) and/or Delos (https://arxiv.org/pdf/2311.17986.pdf) conditional mass functions. In theory these should be much more accurate mass functions which could remove the necessity for mean fixing in all models. There are implementations of these CMFs in the code but they are not working. First samples drawn from them currently fit expected distributions very well, but drawing progenitors from these distributions quickly results huge errors. The Delos paper specifically warns that short timesteps (high delta) cause the conditional mass functions to not match random walk results, however I would still expect samples drawn from the CMF to sum to the unconditional mass function across all conditions, as long as it always integrates to one. I am unsure at the moment if there is a bug in the implementation or if the approach itself is restricted to Extended Press-Schechter somehow.
  • Rescaling the EPS mass function: This has been notably done in binary-split merger tree construction (Parkinson+08), where scaling terms are added to the EPS CMF (with condition scale and density) so that the final halo populations match expected results (usually an N-body).
  • Rescaling unconditional mass functions: Different forms have been implemented in https://arxiv.org/pdf/0803.1954.pdf, https://arxiv.org/pdf/1702.01788.pdf, which rescale a given unconditional mass function, resulting in a CMF that can be used.
@daviesje daviesje added context: C backend Changes occur predominantly in the C code context: v4-prep This issue regards changes to the v4-prep branch type: feature: physical New physical feature to be included type: feature: accuracy New code that improves overall accuracy/concistency labels Mar 28, 2024
@daviesje daviesje moved this to Ready in 21cmFAST v4 Apr 2, 2024
@daviesje daviesje moved this from Ready to In progress in 21cmFAST v4 Apr 12, 2024
@daviesje daviesje self-assigned this Apr 12, 2024
@daviesje daviesje moved this from In progress to In review in 21cmFAST v4 May 15, 2024
@daviesje daviesje linked a pull request May 15, 2024 that will close this issue
@daviesje daviesje moved this from In review to Done in 21cmFAST v4 May 20, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
context: C backend Changes occur predominantly in the C code context: v4-prep This issue regards changes to the v4-prep branch type: feature: accuracy New code that improves overall accuracy/concistency type: feature: physical New physical feature to be included
Projects
Status: Done
Development

Successfully merging a pull request may close this issue.

1 participant