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

Uploaded Python 3

File details

Details for the file mo-math-7.579.24081.tar.gz.

File metadata

  • Download URL: mo-math-7.579.24081.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.579.24081.tar.gz
Algorithm Hash digest
SHA256 12d77ea72cc9516b0638df2f331f4226275aa9927efd3283a4dcc6f93a5bbe70
MD5 337d2b5464ca81e7da86cdd175308fbb
BLAKE2b-256 58f8e57768ceabc8897ce229ef89b19cd50e05f2ff38253211b93678b5b94378

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mo_math-7.579.24081-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.579.24081-py3-none-any.whl
Algorithm Hash digest
SHA256 0987288fa731af78977ab3fb0e1cff84222a3118c0e9693f347700f9bdc8eeeb
MD5 929c3262bfc4564c8b0da236c9fde9fb
BLAKE2b-256 081fba2f2178c87ef00b602fb8d05749ac6ab405611a281d3ca4f677c2861580

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