Skip to main content

calculations with physical quantities

Project description

https://pepy.tech/badge/quantiphy_eval/month https://github.com/KenKundert/quantiphy_eval/actions/workflows/build.yaml/badge.svg https://coveralls.io/repos/github/KenKundert/quantiphy_eval/badge.svg?branch=master https://img.shields.io/pypi/v/quantiphy_eval.svg https://img.shields.io/pypi/pyversions/quantiphy_eval.svg
Author:

Ken Kundert

Version:

0.5.0

Released:

2022-09-02

A companion to QuantiPhy, quantiphy_eval evaluates strings containing simple algebraic expressions that involve quantities. It returns a quantity. For example:

>>> from quantiphy_eval import evaluate

>>> avg_price = evaluate('($1.2M + $1.3M)/2', '$')
>>> print(avg_price)
$1.25M

>>> avg_freq = evaluate('(122.317MHz + 129.349MHz)/2', 'Hz')
>>> print(avg_freq)
125.83 MHz

QuantiPhy Eval is used in networth to allow you to give your estimated values using expressions that include numbers that have units, SI scale factors, and commas. That allows you the convenience of copy-and-pasting your numbers from websites without being forced to reformat them.

With QuantiPhy the units do not survive operations, so you can specify the resolved units using the second argument. In fact, the second argument is passed to QuantiPhy as the model, which allows you to give the return value a name and description along with units, as demonstrated in the next example.

By default QuantiPhy Eval provides no built-in constants. However, you can add your own constants:

>>> from quantiphy import Quantity
>>> from quantiphy_eval import evaluate, initialize
>>> import math

>>> my_constants = dict(
...     k = Quantity('k'),
...     q = Quantity('q'),
...     T = Quantity('25°C', scale='K'),
...     π = Quantity(math.pi),
...     τ = Quantity(math.tau),
... )
>>> initialize(variables=my_constants)

>>> Vt = evaluate('k*T/q', 'Vt V thermal voltage')
>>> print(Vt.render(show_label='f'))
Vt = 25.693 mV — thermal voltage

Alternatively, you can specify the model directly in the text passed to evaluate. Simply append it in the form of a double-quoted string:

>>> Vt = evaluate('k*T/q "Vt V thermal voltage"')
>>> print(Vt.render(show_label='f'))
Vt = 25.693 mV — thermal voltage

You can also use evaluate to assign values to names directly, QuantiPhy Eval remembers these values between calls to evaluate:

>>> f_0 = evaluate('f₀ = 1MHz')
>>> omega_0 = evaluate('ω₀ = τ*f₀ "rads/s"')
>>> print(omega_0.render(show_label=True))
ω₀ = 6.2832 Mrads/s

Similarly, QuantiPhy Eval provides no built-in functions by default, but you can add any you need:

>>> def median(*args):
...    args = sorted(args)
...    l = len(args)
...    m = l//2
...    if l % 2:
...        return args[m]
...    return (args[m] + args[m-1])/2

>>> initialize(functions = dict(median=median))
>>> median_price = evaluate('median($636122, $749151, $706781)', '$')
>>> print(median_price.fixed(show_commas=True))
$706,781

initialize takes three arguments, variables, functions and quantity. Both arguments and functions take dictionaries that overwrite any previously saved values. quantity takes a quantiphy Quantity class. The return value of evaluate will be an object of this class.

rm_commas is a function for removing commas from an expression. This is used if your number contain commas. Simply stripping the commas it would prevent you from using multi-argument functions. However after removing the commas rm_commas also converts semicolons to commas. So the previous example could be rewritten as:

>>> from quantiphy_eval import evaluate, rm_commas

>>> median_price = evaluate(
...     rm_commas('median($636,122; $749,151; $706,781)'),
...     '$',
... )
>>> print(median_price.fixed(show_commas=True))
$706,781

QuantiPhy Eval supports comments. A # and anything that follows it to the end of the line is ignored:

>>> average_price = evaluate(
...     rm_commas('''
...         median(
...             $636,122 +   # Zillow
...             $749,151 +   # Redfin
...             $706,781     # Trulia
...         )/3
...     '''),
...     '$'
... )
>>> print(average_price.fixed(show_commas=True, prec=2, strip_zeros=False))
$697,351.33

Finally, QuantiPhy Eval uses inform.Error for error reporting:

>>> from inform import Error

>>> try:
...     Vt = evaluate('kT/q', 'V')
...     print(Vt)
... except Error as e:
...     print(str(e))
kT: variable unknown.

Releases

Latest development release:
Version: 0.5.0
Released: 2022-09-02
0.5 (2022-09-02):
  • refactor the project structure

  • provide qe example, a simple calculator

0.4 (2021-01-27):
  • Add ability to explicitly specify units (or model) in evaluated string.

0.3 (2020-08-12):
  • complete re-write, parser now implemented with ply rather than pyparsing.

  • all built-in constants and functions have been removed.

  • split evaluate into two: evaluate and initialize.

0.2 (2020-03-06):
  • rm_commas now converts semicolons to commas

  • support comments

0.1 (2020-03-05):
  • Add support for user-defined constants and functions.

  • add rm_commas function.

0.0 (2020-02-14):

Initial version.

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

quantiphy_eval-0.5.0.tar.gz (7.4 kB view details)

Uploaded Source

Built Distribution

quantiphy_eval-0.5.0-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file quantiphy_eval-0.5.0.tar.gz.

File metadata

  • Download URL: quantiphy_eval-0.5.0.tar.gz
  • Upload date:
  • Size: 7.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for quantiphy_eval-0.5.0.tar.gz
Algorithm Hash digest
SHA256 cff2d7c2666ff4292ee3bb15b920932f79053d95f536ae11f512d6810e32cb0a
MD5 f8468f5f9a15b4a08d7d381fb395a4b0
BLAKE2b-256 b4a7446e382f0984f25e09c2a3b3611927791d78add80d79ff6a43926f5d5c32

See more details on using hashes here.

File details

Details for the file quantiphy_eval-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for quantiphy_eval-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b1a7d0151196dea6bde316741273b57eac42c7beaf0148a60209791d55de9519
MD5 b6a7fe2fd3cb7a2f7450417d701c3c69
BLAKE2b-256 82f358d89ab1a145cdb95d7dfd9e535b3e57a33bec2c9f1c698d8ef20d1ec137

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