Skip to main content

Fast matrix-based visibility simulator with interface to CPU and GPU

Project description

https://github.com/hera-team/matvis/workflows/Tests/badge.svg https://badge.fury.io/py/vis-cpu.svg https://codecov.io/gh/hera-team/matvis/branch/main/graph/badge.svg https://img.shields.io/badge/code%20style-black-000000.svg

Fast matrix-based visibility simulator capable of running on CPU and GPU.

Description

matvis is a fast Python matrix-based interferometric visibility simulator with both CPU and GPU implementations.

It is applicable to wide field-of-view instruments such as the Hydrogen Epoch of Reionization Array (HERA) and the Square Kilometre Array (SKA), as it does not make any approximations of the visibility integral (such as the flat-sky approximation). The only approximation made is that the sky is a collection of point sources, which is valid for sky models that intrinsically consist of point-sources, but is an approximation for diffuse sky models.

An example wrapper for the main matvis simulator function is provided in this package (matvis.simulate_vis()).

Features

  • Matrix-based algorithm is fast and scales well to large numbers of antennas.

  • Supports both CPU and GPU implementations as drop-in replacements for each other.

  • Supports both dense and sparse sky models.

  • Includes a wrapper for simulating multiple frequencies and setting up the simulation.

  • No approximations of the visibility integral (such as the flat-sky approximation).

  • Arbitrary primary beams per-antenna using the pyuvdata.UVBeam class.

Limitations

  • Currently no support for polarized sky models.

  • Currently no way of taking advantage of baseline redundancy to speed up simulations.

  • Diffuse sky models must be pixelised, which may not be the best basis-function for some sky models.

Installation

pip install matvis.

If you want to use the GPU functions, install with pip install matvis[gpu].

Developers

Run pre-commit install before working on this code.

Read the Docs

https://matvis.readthedocs.io/en/latest/

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

matvis-1.3.0.tar.gz (2.3 MB view details)

Uploaded Source

Built Distribution

matvis-1.3.0-py2.py3-none-any.whl (2.1 MB view details)

Uploaded Python 2 Python 3

File details

Details for the file matvis-1.3.0.tar.gz.

File metadata

  • Download URL: matvis-1.3.0.tar.gz
  • Upload date:
  • Size: 2.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for matvis-1.3.0.tar.gz
Algorithm Hash digest
SHA256 015eb3eba32aea7f68fd6676d9eaf8d5d7ed70b401f5c8c2b4ef857b256a5ce1
MD5 fce48d13fd2b72cb83f7b837da285cfd
BLAKE2b-256 d0ad64f1b20635d22d451bb8815bc53ba1376cce0aa6dd74e1e11e450e2fdeda

See more details on using hashes here.

Provenance

The following attestation bundles were made for matvis-1.3.0.tar.gz:

Publisher: publish-to-pypi.yaml on HERA-Team/matvis

Attestations:

File details

Details for the file matvis-1.3.0-py2.py3-none-any.whl.

File metadata

  • Download URL: matvis-1.3.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 2.1 MB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for matvis-1.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 3049a6750c40c47e7816ddcb6dbfd10a7681e588676b468acfda9541c82bfd74
MD5 c8084d402907347dc969f53bc09a065e
BLAKE2b-256 224bbe5f0bfdd8b739eebda78c490202b10a029fe760bd6a742ed4b2f16c05fe

See more details on using hashes here.

Provenance

The following attestation bundles were made for matvis-1.3.0-py2.py3-none-any.whl:

Publisher: publish-to-pypi.yaml on HERA-Team/matvis

Attestations:

Supported by

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