Skip to main content

Linear regression of data sets with correlated and uncorrelated uncertainties.

Project description

Mahon linear regression

pypi tests Coverage Status pre-commit.ci status License: MIT Code style: black

The goal of this project is to provide a python package that allows to calculate linear regressions on data sets with uncertainties. Linear regressions can be performed for correlated and uncorrelated uncertainties. The calculations follow the methodology published by Mahon (1996). Typographical errors that were made in that work have been corrected. A method to allow calculating a linear regression through a fixed point, avoiding previously made errors, is also provided.

Installation

The package can be installed from pypi via:

pip install mahon

Usage

Below is an example on how to use the package.

>>> import numpy as np
>>> from mahon import LinReg

>>> # some data
>>> xdata = np.array([1, 2, 3.1, 4.9])
>>> ydata = np.array([1.1, 1.9, 3, 5.5])

>>> # some uncertainty and correlation
>>> xunc = 0.05 * xdata
>>> yunc = 0.073 * ydata
>>> rho = np.zeros_like(xdata) + 0.5

>>> # do regression
>>> my_reg = LinReg(xdata, xunc, ydata, yunc, rho)

>>> # print out the parameters and their uncertainties
>>> my_reg.slope
(0.9983617286559998, 0.0684389236571533)
>>> my_reg.intercept
(0.05545339135826666, 0.11811730191506546)
>>> my_reg.mswd
2.5105964767246842

Detailed example on how to use the class for fitting and plotting the results can be found in this Jupyter notebook.

Development & Contributing

If you would like to contribute, clone the GitHub repo and then install the package locally from within the folder via:

pip install -e .[dev]

If you also want to install the full test environment, run:

pip install -e .[dev,test]

Code auto formatting is implemented using pre-commit hooks. Full testing of the package can be done with nox.

Please feel free to raise issues on GitHub and open pull requests if you have a feature to be added. Tests and adequate docstrings should be provided along with your new code.

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

mahon-0.2.0.tar.gz (21.6 kB view details)

Uploaded Source

Built Distribution

mahon-0.2.0-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file mahon-0.2.0.tar.gz.

File metadata

  • Download URL: mahon-0.2.0.tar.gz
  • Upload date:
  • Size: 21.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.27.1

File hashes

Hashes for mahon-0.2.0.tar.gz
Algorithm Hash digest
SHA256 0ec230904f959fba6bcd1a9f9d5a51acbde6eaa7579c8597dc1f2474dc12e75b
MD5 efddf625ed6b774ea6b5e74c41e8ffe4
BLAKE2b-256 180c450fcbc3e4240e6e4021bb28a7f9d010ee3f8933113eb6a81432ea8aed27

See more details on using hashes here.

File details

Details for the file mahon-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: mahon-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.27.1

File hashes

Hashes for mahon-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3071149eda5d2ec4afdb7a962093fdc8b454eb277310ab27483cb962beebec49
MD5 022408771cb46b606c026aa74cc73060
BLAKE2b-256 1bdc860801c586b664547419d8342d19a9933a6bbfe208cd43fa820de2b4d9f5

See more details on using hashes here.

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