11.1.12. Unit¶
This module implements units.
Shortcuts are defined to build unit values easily :
for each unit prefix, e.g.
pico(),nano(),micro(),milli(),kilo(),mega(),tera(). These shortcuts return unit less values.for each unit and prefix as the concatenation of u_, the unit prefix and the unit suffix, e.g.
u_pV(),u_nV(),u_uV()u_mV(),u_V(),u_kV(),u_MV(),u_TV().
Theses unit value constructors accept int, float, object that can be converted to float,
UnitValue instance and an iterable on these types.
A shortcut is defined to check an unit value match a particular unit, e.g. as_V(). Theses
shortcuts return the value if the unit match else it raises the exception UnitError.
A shortcut is defined to access each unit, e.g. U_V(), U_A(), U_s(), U_Hz(),
U_Ω(), U_F(), U_H.(), as well as for prefixes e.g. U_mV().
Some shortcuts have Unicode and ASCII variants:
For micro, we have the prefix μ and u.
For Ohm, we have
u_Ω()andu_Ohm().
Some examples of usage:
foo = kilo(1) # unit less
resistance_unit = U_Ω
resistance1 = u_kΩ(1)
resistance1 = u_kOhm(1) # ASCII variant
resistance1 = 1@u_kΩ # using Python 3.5 syntax
resistance1 = 1 @u_kΩ # space doesn't matter
resistance1 = 1 @ u_kΩ #
resistance2 = as_Ω(resistance1) # check unit
resistances = u_kΩ(range(1, 11)) # same as [u_kΩ(x) for x in range(1, 11)]
resistances = range(1, 11)@u_kΩ # using Python 3.5 syntax
capacitance = u_uF(200)
inductance = u_mH(1)
temperature = u_Degree(25)
voltage = resistance1 * u_mA(1) # compute unit
frequency = u_ms(20).frequency
period = u_Hz(50).period
pulsation = frequency.pulsation
pulsation = period.pulsation
Warning
According to the Python `operator precedence
<https://docs.python.org/3/reference/expressions.html#operator-precedence>`_, division operators
have a higher priority than the matrix multiplication operator. In consequence you must had
parenthesis to perform something like (10@u_s) / (2@_us).
-
class
PySpice.Unit.FrequencyValue(prefixed_unit, value)[source]¶ Bases:
PySpice.Unit.Unit.UnitValue,PySpice.Unit.Unit.FrequencyMixin
-
class
PySpice.Unit.FrequencyValues[source]¶ Bases:
PySpice.Unit.Unit.UnitValues
-
class
PySpice.Unit.PeriodValue(prefixed_unit, value)[source]¶ Bases:
PySpice.Unit.Unit.UnitValue,PySpice.Unit.Unit.PeriodMixin
-
class
PySpice.Unit.PeriodValues[source]¶ Bases:
PySpice.Unit.Unit.UnitValues