Skip to main content

CosmoForge: umbrella metapackage installing cosmocore, qube-qml, and picslike.

Project description

CosmoForge logo (light) CosmoForge logo (dark)

Build Status Documentation Status codecov PyPI Code style: Ruff Python License

📚 Complete Documentation | Installation Guide | Quick Start | API Reference

CosmoForge is a comprehensive Python framework for power spectrum estimation and likelihood analysis of spin-0 and spin-2 fields on the sphere, using Fisher matrix, Quadratic Maximum Likelihood (QML), and pixel-based likelihood methods. While widely applicable to any sky signal (e.g. CMB, galaxy surveys, 21 cm), it is particularly optimized for the analysis of partial-sky, noisy observations with complex noise covariance.

Overview

CosmoForge consists of several interconnected packages designed for efficient and accurate cosmological parameter estimation:

  • cosmocore: Core functionality for cosmological analysis including field management, matrix operations, and I/O utilities
  • qube-qml: QML and Fisher matrix implementations for power spectrum estimation (imported as qube)
  • picslike: Pixel-based Inference with Correlated-Skies Likelihood — pixel-space likelihood analysis for parameter estimation

Features

  • Fisher Matrix Analysis: Fast Fisher matrix computation for cosmological parameter forecasting
  • QML Power Spectrum Estimation: Quadratic Maximum Likelihood estimation for optimal power spectrum recovery
  • Pixel-Based Likelihood: Direct likelihood evaluation in map pixel space for parameter estimation
  • MPI Parallelization: Efficient parallel computation support for large-scale analyses
  • HEALPix Integration: Full support for HEALPix pixelization scheme
  • Flexible Field Management: Support for scalar (spin-0) and tensor (spin-2) fields
  • Beam and Noise Modeling: Comprehensive instrumental effects modeling

Installation

📖 For detailed installation instructions, see the Installation Guide

Requirements

  • Python 3.11–3.13
  • NumPy, SciPy
  • healpy
  • mpi4py (for parallel computation)

Install from PyPI

The umbrella distribution installs all three subpackages:

pip install cosmoforge

Or pick subpackages individually:

pip install cosmocore       # core utilities only
pip install qube-qml        # adds QML / Fisher (imported as `qube`)
pip install picslike        # adds pixel-space likelihood

Install from source

git clone https://github.com/ggalloni/CosmoForge.git
cd CosmoForge
uv sync --all-packages --all-extras --dev

Quick Start

🚀 For comprehensive tutorials and examples, visit the Quick Start Guide and Tutorials

Fisher Matrix Analysis

from qube import Fisher

# Initialize Fisher analysis
fisher = Fisher("config/fisher_config.yaml")
fisher.run()

# Get Fisher matrix
fisher_matrix = fisher.get_fisher_matrix()

QML Power Spectrum Estimation

from qube import Spectra

# Initialize QML analysis
qml = Spectra("config/qml_config.yaml")
qml.run()

# Get power spectra
power_spectra = qml.get_power_spectra()
noise_bias = qml.get_noise_bias()

Pixel-Based Likelihood Analysis

from picslike import PICSLike

# Initialize pixel-based likelihood
picslike = PICSLike(params_file="config/picslike_config.yaml")
picslike.run()

# Get results
chi_squared = picslike.get_chi_squared()
best_fit = picslike.get_best_fit()

Using with Precomputed Fisher

from qube import Fisher, Spectra

# Compute Fisher matrix first
fisher = Fisher("config/fisher_config.yaml")
fisher.run()

# Reuse Fisher computation for QML
qml = Spectra("config/qml_config.yaml", fisher=fisher)
qml.run()

Package Structure

CosmoForge/
├── src/
│   ├── cosmoforge.cosmocore/    # Core functionality (published as `cosmocore`)
│   ├── cosmoforge.qube/         # QML and Fisher analysis (published as `qube-qml`, imported as `qube`)
│   ├── cosmoforge.picslike/     # Pixel-space likelihood (published as `picslike`)
│   └── cosmoforge.meta/         # Umbrella metapackage (published as `cosmoforge`)
├── tests/                       # Test suite
├── docs/                        # Documentation
└── examples/                    # Example configurations

Configuration

CosmoForge uses YAML configuration files to specify analysis parameters:

# Example configuration
nside: 4
lmax: 16
fields: "TEB"
maskfile: "data/mask.fits"
inputclfile: "data/fiducial_cls.txt"
# ... additional parameters

Testing

Run the test suite:

# Run all tests
uv run pytest

# Run specific package tests
uv run --package cosmocore pytest src/cosmoforge.cosmocore/tests/
uv run --package qube pytest src/cosmoforge.qube/tests/
uv run --package picslike pytest src/cosmoforge.picslike/tests/

Performance

CosmoForge is designed for high-performance cosmological analysis:

  • Numba JIT compilation for critical mathematical operations
  • MPI parallelization for distributed computing
  • Optimized matrix operations using LAPACK/BLAS
  • Memory-efficient algorithms for large datasets

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests for new functionality
  5. Submit a pull request

License

[Add license information]

Citation

If you use CosmoForge in your research, please cite:

Galloni, G. & Pagano, L., CosmoForge I: A unified framework for QML power spectrum estimation and pixel-based likelihood analysis, arXiv:2605.21149 (2026).

@article{GalloniPagano_CosmoForgeI,
    author        = {Galloni, G. and Pagano, L.},
    title         = {{CosmoForge I}: A unified framework for {QML} power spectrum estimation and pixel-based likelihood analysis},
    year          = {2026},
    eprint        = {2605.21149},
    archivePrefix = {arXiv},
    primaryClass  = {astro-ph.CO},
}

Support

📖 Complete documentation is available at: https://cosmoforge.readthedocs.io/en/latest/

For questions and support:

  • Open an issue on GitHub
  • Contact: [contact information]

Acknowledgments

CosmoForge builds upon established cosmological analysis methods and libraries:

  • HEALPix for pixelization
  • NumPy/SciPy for numerical computations
  • MPI for parallelization

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

cosmoforge-1.0.1.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

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

cosmoforge-1.0.1-py3-none-any.whl (3.9 kB view details)

Uploaded Python 3

File details

Details for the file cosmoforge-1.0.1.tar.gz.

File metadata

  • Download URL: cosmoforge-1.0.1.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cosmoforge-1.0.1.tar.gz
Algorithm Hash digest
SHA256 9c386833853caf048c1701467d2e421cbbfa2c5bf67cac4c8fa2bf045f46ff57
MD5 d3b59d9fb65d893cc6a05c3ef2aef15b
BLAKE2b-256 782071698158ae4fb3b81fff8ec086e78a907b3a2091f43dc421bf03134e66cc

See more details on using hashes here.

Provenance

The following attestation bundles were made for cosmoforge-1.0.1.tar.gz:

Publisher: publish.yml on ggalloni/CosmoForge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cosmoforge-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: cosmoforge-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 3.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cosmoforge-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 48e7ed096dec84d82d7906cba25d4ae50bcc1564d415d8a2e4ea45b8767b98f1
MD5 469263b056ca6fb877de21e1d49def34
BLAKE2b-256 b4957d4d060a88797bb90befac47ce911126dc01bf5bfac21bda576323d8b1ab

See more details on using hashes here.

Provenance

The following attestation bundles were made for cosmoforge-1.0.1-py3-none-any.whl:

Publisher: publish.yml on ggalloni/CosmoForge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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