Skip to main content

A Python module for performing thermodynamic calculations used in teaching ME40 at the University of California, Berkeley.

Project description

pyCalor

This Python module was developed in the Department of Mechanical Engineering at the University of California, Berkeley. It is used for teaching undergraduate thermodynamics (ME40).

The software package contains classes state and process. The following is the description of their use. You can also get the built-in information by typing the following statements in the Python command line:

from pyCalor import thermo as th

print(th.state.__doc__)

print(th.process.__doc__)

Class state

A call

from pyCalor import thermo as th

st = th.state(substance, property1=value1, property2=value2, name="A")

creates an object of class state. Each such object contains the following fields:

- name description
st.p pressure (in units of kPa)
st.t temperature (in units of K)
st.v specific volume (in units of m3/kg)
st.u specific energy (in units of kJ/kg)
st.h specific enthalpy (in units of kJ/kg)
st.s specific entropy (in units of kJ/kg K)
st.x quality (fraction)
st.molW molecular weight (in units of kg/kmol)
st.R gas constant (in units of kJ/kg K)
st.substance 'water', 'air', 'nitrogen', ... ()

The property values are in the “base units”; they can be viewed by issuing a command:

state.units

Examples:

from pyCalor import thermo as th

th.state.units

st1 = th.state('water', p=(1,'bar'), v=0.1, name="1")

st1.plot("pv") # supported plots are: "pv","Ts","ph"

st2 = th.state('R134a', x=1, t=300, name="B")

st2.plot("Ts", isoProp="v")

st3 = th.state('air', p=(1,'Mpa'), t=(10,'c'))

st3.name = "2a"

This information can also be viewed in the programming environment;

th.state.__doc__

Class process

A call

from pyCalor import thermo as th

pr = th.process([(state1,state2),(state2,state3),...])

creates an object of class process. An object of this class represent a simple process, from st1 to st2,

pr = th.process(st1,st2)

a simple cyclic process,

pr = th.process([(st1,st2),(st2,st3),(st3,st4),(st4,st1)]),

which can also be created as

pr = th.process(st1,st2,st3,st4,st1),

or any complex process, but for a single working fluid.

You can access process object properties by the following calls

description
pr.StateList returns a list of state objects
pr.isoProp(st1,st2) returns a dictionary of {isoProperty: value,...} for process st1st2

Once you created process object pr, you can display its states on a thermodynamic diagram via

pr.plot('ts')

to display process pr on a T-s diagram; you may likewise to make such plot in other coordinates, like 'pv', 'ph', etc.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

pycalor-1.0.10-py3-none-any.whl (23.0 kB view details)

Uploaded Python 3

File details

Details for the file pycalor-1.0.10-py3-none-any.whl.

File metadata

  • Download URL: pycalor-1.0.10-py3-none-any.whl
  • Upload date:
  • Size: 23.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.5

File hashes

Hashes for pycalor-1.0.10-py3-none-any.whl
Algorithm Hash digest
SHA256 02527aafb2d6066c8e996f2bf0369ec11f5616b8f617de4871b50d580339dbd1
MD5 fa0d6b56a9eca0854295e806e7fa2648
BLAKE2b-256 08d7d02748536d545b24786ce290c2eab5bbbfe4b0a87da070b08d5521166002

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