Skip to main content

More Math! Many of the aggregates you are familiar with, but null-safe

Project description

More Math!

Basic math functions that have been stabilized to act well over Null/None/NaN

Branch Status
master Build Status
dev Build Status

Overview

Many of the basic math functions you know and love, with the additional benefit that they do not throw exceptions and do not return NaN.

These functions are all module methods. Be sure you call the functions with mo_math. prefix, like

import mo_math
mo_math.abs(-42)

or rename the functions

from mo_math import abs as mo_abs
mo_abs(-42)

This prevents confusion with the __builtin__ functions by the same name

Functions

Functions are generally conservative in the face of nulls: Specifically, they return Null if any of their operands are not a number.

Most functions need no introduction, but some are interesting:

  • round(value, decimal=7, digits=None) - Rounds to 7 decimal points, unless specified differently. Rounding to decimal=0 will return an int. The useful parameter here is digits, which rounds to a specified number of significant digits.
  • floor(value, mod=1) - The modulo parameter is used to specify the granularity of the floor function.
  • ceiling(value, mod=1) - Return the smallest value, that's equal or larger than value, with suitable granularity.
  • mod(value, mod=1) - Works on floats
  • approx_str(value) - Round values, and return text (unicode in py2, str in py3)
  • sign(v) - Missing from the Python library

The all-caps aggregate functions accept only one parameter; an iterable. They are decisive operators: Non-numbers are ignored, if no values are numbers then the aggregate will return Null.

  • COUNT(values)
  • SUM(values)
  • PRODUCT(values)
  • MIN(values)
  • MAX(values)

Crypto

The AES and RSA crypto functions provide structured input/output on top of cryptography library. The intent is to reveal the signed/encrypted structures so third parties can decode the data.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

mo_math-7.606.24115.tar.gz (48.2 kB view details)

Uploaded Source

Built Distribution

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

mo_math-7.606.24115-py3-none-any.whl (55.1 kB view details)

Uploaded Python 3

File details

Details for the file mo_math-7.606.24115.tar.gz.

File metadata

  • Download URL: mo_math-7.606.24115.tar.gz
  • Upload date:
  • Size: 48.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.6

File hashes

Hashes for mo_math-7.606.24115.tar.gz
Algorithm Hash digest
SHA256 d1261cc39785810fdac5e6cb63a5a6ef9b209cc24b9c31ab3850c8b8d9f3fe3f
MD5 0676b3f98c3474020e7178ee17210339
BLAKE2b-256 944bfdf6217c7286648e1fdf50a088485a08b34ae421adea2cf06967fdf56e77

See more details on using hashes here.

File details

Details for the file mo_math-7.606.24115-py3-none-any.whl.

File metadata

  • Download URL: mo_math-7.606.24115-py3-none-any.whl
  • Upload date:
  • Size: 55.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.6

File hashes

Hashes for mo_math-7.606.24115-py3-none-any.whl
Algorithm Hash digest
SHA256 485f99a1b03600e1800e418b83a5453277b09fc5a2d9f1a39e71930682312c5c
MD5 9d84eb4f44e47d44a4f4846ee3691e19
BLAKE2b-256 bd2f5486eec65ce2977658099bd88837ec667c404826f72f153963fc04f9f371

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