Skip to main content

A Python 3 library to make psychrometric charts and overlay information on them.

Project description

It implements a useful collection of psychrometric equations for moisture and humid air calculations, and the generation of beautiful and high customizable psychrometric charts in SVG with matplotlib.

Calculations are made by implementing experimental equations extracted from recognized sources, such as the 2009 ASHRAE Handbook—Fundamentals (SI).

Install

Clone it from Github if you want to run the tests, or simply:

pip install psychrochart

Features

  • SI units (with temperatures in celsius for better readability).

  • Easy style customization with a JSON template (colors, line styles and line widths).

  • Psychrometric charts within temperature and humidity ratio ranges, for any pressure, with:

    • Saturation line

    • Constant RH lines

    • Constant enthalpy lines

    • Constant wet-bulb temperature lines

    • Constant specific volume lines

    • Constant dry-bulb temperature lines (internal orthogonal grid, vertical)

    • Constant humidity ratio lines (internal orthogonal grid, horizontal)

  • Plot legend for each family of lines

  • Specify labels for each family of lines

  • Overlay points and zones

  • Export SVG files

  • Tested against example tables from http://www.engineeringtoolbox.com

  • ~100 % code coverage.

The ranges of temperature, humidity and pressure where this library should provide good results are within the normal environments for people to live in. Don’t expect right results if doing other type of thermodynamic calculations. Over saturated water vapor states are not implemented.

Changelog

  • v0.1.0: Initial version.

  • v0.1.1: Minor plotting fixes, set axis position, define P with altitude_m or pressure_kpa, reuse plot removing annotations (chart.remove_annotations). Axes as internal prop, lazy plotting, save to disk helper (chart.save).

  • v0.1.2: Add agg module to set that matplotlib backend.

  • v0.1.3: Add custom params for plotting styles, option to exclude first and last tick (constant_{humid/temp}_label_include_limits).

  • v0.1.4: Customize labels and its locations for families of psychrometric curves.

  • v0.1.5: Add Arrows, compatibility with the Home Assistant component psychrometrics.

  • v0.1.6: Some cleaning, better typing, flake8, added tox.ini.

  • v0.1.7: Methods to clean the plot (.close_fig()) and to remove the legend (.remove_legend()).

  • v0.1.8: Memleak with savefig.

  • v0.1.10: Fix plot limits, do not use pyplot, axes are not optional.

  • v0.1.11: Add optional Axes as argument for PsychroChart.plot.

Usage

from psychrochart.chart import PsychroChart
import matplotlib.pyplot as plt

axes = PsychroChart().plot(ax=plt.gca())
plt.show()

Tests

To run the tests, clone the repository and run:

py.test --cov=psychrochart -v --cov-report html

to generate the coverage reports.

License

MIT license, so do with it as you like ;-)

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

psychrochart-0.1.11.tar.gz (20.5 kB view details)

Uploaded Source

Built Distribution

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

psychrochart-0.1.11-py2.py3-none-any.whl (24.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file psychrochart-0.1.11.tar.gz.

File metadata

  • Download URL: psychrochart-0.1.11.tar.gz
  • Upload date:
  • Size: 20.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for psychrochart-0.1.11.tar.gz
Algorithm Hash digest
SHA256 c10d19900131779603435dcf7cf19dee55b479a7dcdb68f14789749eca641e7d
MD5 45dcce21a7cdff990060b8c611942cec
BLAKE2b-256 cf5ff66dbf725ed0278ba2cc8652fcf46c5ca4bd912af68461443785d0116bca

See more details on using hashes here.

File details

Details for the file psychrochart-0.1.11-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for psychrochart-0.1.11-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 51cfc26345e8875ba2e5f8a6f925fe40167e08e3e4d0c93ed99f16116801429b
MD5 76a2550669afdcd1a88909ede0ad29cf
BLAKE2b-256 aeaab6283c4b265adadc8d1291d878762af5048139306f347a4ed0aba6b33588

See more details on using hashes here.

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