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:

th.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")

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

fig1.savefig("figure_1.jpg")

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

st3.name = "2a"

This information can also be viewed in the programming environment:

print(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

fig2 = 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. You can also save this figure via

fig2.savefig("figure_2.pdf")

This information can also be viewed in the programming environment:

print(th.process.__doc__)

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.17-py3-none-any.whl (24.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pycalor-1.0.17-py3-none-any.whl
  • Upload date:
  • Size: 24.2 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.17-py3-none-any.whl
Algorithm Hash digest
SHA256 817266c53fc818b24ac5d446355505ea595a1ec3351a5070ac969b5be0ea515c
MD5 a3bb7d70d2abb2f137d942d210be955d
BLAKE2b-256 996799c53cd847673169ca3b861cfc98870f5d00a7857c187c80f757d7106fc3

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