Source code for onetick.py.math

from onetick.py.core.column_operations.base import _Operation


class _MaxOperator(_Operation):

    def __init__(self, objs):
        from onetick.py.types import get_type_by_objects

        super().__init__(dtype=get_type_by_objects(objs))

        def _str_max(l_val, r_val):
            if type(r_val) is list:
                if len(r_val) > 1:
                    r_val = _str_max(r_val[0], r_val[1:])
                else:
                    r_val = r_val[0]
            return f'case({l_val} > {r_val}, 1, {l_val}, {r_val})'

        self._repr = _str_max(objs[0], objs[1:])

    def __str__(self):
        return self._repr


[docs]def max(*objs): """ Returns maximum value from list of ``objs``. Parameters ---------- objs: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['MAX'] = otp.math.max(5, data['A']) >>> otp.run(data) Time A MAX 0 2003-12-01 1 5 """ return _MaxOperator(list(objs))
class _MinOperator(_Operation): def __init__(self, objs): from onetick.py.types import get_type_by_objects super().__init__(dtype=get_type_by_objects(objs)) def _str_min(l_val, r_val): if type(r_val) is list: if len(r_val) > 1: r_val = _str_min(r_val[0], r_val[1:]) else: r_val = r_val[0] return f'case({l_val} < {r_val}, 1, {l_val}, {r_val})' self._repr = _str_min(objs[0], objs[1:]) def __str__(self): return self._repr
[docs]def min(*objs): """ Returns minimum value from list of ``objs``. Parameters ---------- objs: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['MIN'] = otp.math.min(-5, data['A']) >>> otp.run(data) Time A MIN 0 2003-12-01 1 -5 """ return _MinOperator(list(objs))
class _RandomFunc(_Operation): """ It implements the `rand` built-in function. """ def __init__(self, min_value: int, max_value: int, seed: int = None): super().__init__(dtype=int) def _repr(min_value, max_value, seed): result = f'rand({min_value}, {max_value}' if seed is not None: result += f',{seed})' else: result += ')' return result self._repr = _repr(min_value, max_value, seed) def __str__(self): return self._repr
[docs]def rand(min_value: int, max_value: int, seed: int = None): """ Returns a pseudo-random value in the range between ``min_value`` and ``max_value``. If ``seed`` is not specified, the function produces different values each time a query is invoked. If ``seed`` is specified, for this seed the function produces the same sequence of values each time a query is invoked. Parameters ---------- min_value: int, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` max_value: int, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` seed: int, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['RAND'] = otp.math.rand(1, 1000) """ if isinstance(min_value, int) and min_value < 0: raise Exception("It is not possible to use negative values for the `min_value`") if isinstance(min_value, int) and isinstance(max_value, int) and min_value >= max_value: raise Exception("The `max_value` parameter should be more than `min_value`") return _RandomFunc(min_value, max_value, seed)
class _Now(_Operation): def __init__(self): from onetick.py.types import nsectime super().__init__(dtype=nsectime) def _repr(): return 'now()' self._repr = _repr() def __str__(self): return self._repr # TODO: this is not math, let's move it somewhere else
[docs]def now(): """ Returns the current time expressed as the number of milliseconds since the UNIX epoch. Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['NOW'] = otp.now() """ return _Now()
class _Ln(_Operation): """ Compute the natural logarithm. """ def __init__(self, value): super().__init__(dtype=float) def _repr(value): return f'LOG({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def ln(value): """ Compute the natural logarithm of the ``value``. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['LN'] = otp.math.ln(2.718282) >>> otp.run(data) Time A LN 0 2003-12-01 1 1.0 See Also -------- onetick.py.math.exp """ return _Ln(value)
class _Log10(_Operation): """ Compute the base-10 logarithm. """ def __init__(self, value): super().__init__(dtype=float) def _repr(value): return f'LOG10({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def log10(value): """ Compute the base-10 logarithm of the ``value``. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['LOG10'] = otp.math.log10(100) >>> otp.run(data) Time A LOG10 0 2003-12-01 1 2.0 """ return _Log10(value)
class _Exp(_Operation): """ Compute the natural exponent. """ def __init__(self, value): super().__init__(dtype=float) def _repr(value): return f'EXP({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def exp(value): """ Compute the natural exponent of the ``value``. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['E'] = otp.math.exp(1) >>> otp.run(data) Time A E 0 2003-12-01 1 2.718282 See Also -------- onetick.py.math.ln """ return _Exp(value)
class _Sqrt(_Operation): """ Compute the square root. """ def __init__(self, value): super().__init__(dtype=float) def _repr(value): return f'SQRT({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def sqrt(value): """ Compute the square root of the ``value``. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['SQRT'] = otp.math.sqrt(4) >>> otp.run(data) Time A SQRT 0 2003-12-01 1 2.0 """ return _Sqrt(value)
class _Sign(_Operation): """ Get the sign of value. """ def __init__(self, value): super().__init__(dtype=int) def _repr(value): return f'SIGN({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def sign(value): """ Compute the sign of the ``value``. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['SIGN_POS'] = otp.math.sign(123) >>> data['SIGN_ZERO'] = otp.math.sign(0) >>> data['SIGN_NEG'] = otp.math.sign(-123) >>> otp.run(data) Time A SIGN_POS SIGN_ZERO SIGN_NEG 0 2003-12-01 1 1 0 -1 """ return _Sign(value)
class _Power(_Operation): """ Compute the ``base`` to the power of the ``exponent``. """ def __init__(self, base, exponent): super().__init__(dtype=float) def _repr(base, exponent): return f'POWER({base}, {exponent})' self._repr = _repr(base, exponent) def __str__(self): return self._repr
[docs]def pow(base, exponent): """ Compute the ``base`` to the power of the ``exponent``. Parameters ---------- base: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` exponent: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=2) >>> data['RES'] = otp.math.pow(data['A'], 10) >>> otp.run(data) Time A RES 0 2003-12-01 2 1024.0 """ return _Power(base, exponent)
class _Pi(_Operation): def __init__(self): super().__init__(dtype=float) def _repr(): return 'PI()' self._repr = _repr() def __str__(self): return self._repr
[docs]def pi(): """ Returns the value of Pi number. Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['PI'] = otp.math.pi() >>> otp.run(data) Time A PI 0 2003-12-01 1 3.141593 """ return _Pi()
class _Sin(_Operation): """ Returns the value of trigonometric function `sin` for the given angle number expressed in radians. """ def __init__(self, value): super().__init__(dtype=float) def _repr(value): return f'SIN({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def sin(value): """ Returns the value of trigonometric function `sin` for the given ``value`` number expressed in radians. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['SIN'] = otp.math.sin(otp.math.pi() / 6) >>> otp.run(data) Time A SIN 0 2003-12-01 1 0.5 See Also -------- onetick.py.math.pi """ return _Sin(value)
class _Cos(_Operation): """ Returns the value of trigonometric function `cos` for the given angle number expressed in radians. """ def __init__(self, value): super().__init__(dtype=float) def _repr(value): return f'COS({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def cos(value): """ Returns the value of trigonometric function `cos` for the given ``value`` number expressed in radians. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['COS'] = otp.math.cos(otp.math.pi() / 3) >>> otp.run(data) Time A COS 0 2003-12-01 1 0.5 See Also -------- onetick.py.math.pi """ return _Cos(value)
class _Tan(_Operation): """ Returns the value of trigonometric function `tan` for the given angle number expressed in radians. """ def __init__(self, value): super().__init__(dtype=float) def _repr(value): return f'TAN({value})' self._repr = _repr(value) def __str__(self): return self._repr
[docs]def tan(value): """ Returns the value of trigonometric function `tan` for the given ``value`` number expressed in radians. Parameters ---------- value: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=1) >>> data['TAN'] = otp.math.tan(otp.math.pi() / 4) >>> otp.run(data) Time A TAN 0 2003-12-01 1 1.0 See Also -------- onetick.py.math.pi """ return _Tan(value)
class _Mod(_Operation): """ Implements the remainder from dividing ``value1`` by ``value2`` """ def __init__(self, value1, value2): super().__init__(dtype=int) def _repr(value1, value2): return f'MOD({value1}, {value2})' self._repr = _repr(value1, value2) def __str__(self): return self._repr
[docs]def mod(value1, value2): """ Computes the remainder from dividing ``value1`` by ``value2`` Parameters ---------- value1: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` value2: int, float, :py:class:`~onetick.py.Operation`, :py:class:`~onetick.py.Column` Return ------ :py:class:`~onetick.py.Operation` Examples -------- >>> data = otp.Tick(A=100) >>> data['MOD'] = otp.math.mod(data['A'], 72) >>> otp.run(data) Time A MOD 0 2003-12-01 100 28 """ return _Mod(value1, value2)