Source code for ansible.plugins.filter.mathstuff

# (c) 2014, Brian Coca <bcoca@ansible.com>
#
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible.  If not, see <http://www.gnu.org/licenses/>.

# Make coding more python3-ish
from __future__ import (absolute_import, division, print_function)
__metaclass__ = type


import math
import collections
from ansible import errors

[docs]def unique(a): if isinstance(a,collections.Hashable): c = set(a) else: c = [] for x in a: if x not in c: c.append(x) return c
[docs]def intersect(a, b): if isinstance(a,collections.Hashable) and isinstance(b,collections.Hashable): c = set(a) & set(b) else: c = unique(filter(lambda x: x in b, a)) return c
[docs]def difference(a, b): if isinstance(a,collections.Hashable) and isinstance(b,collections.Hashable): c = set(a) - set(b) else: c = unique(filter(lambda x: x not in b, a)) return c
[docs]def symmetric_difference(a, b): if isinstance(a,collections.Hashable) and isinstance(b,collections.Hashable): c = set(a) ^ set(b) else: c = unique(filter(lambda x: x not in intersect(a,b), union(a,b))) return c
[docs]def union(a, b): if isinstance(a,collections.Hashable) and isinstance(b,collections.Hashable): c = set(a) | set(b) else: c = unique(a + b) return c
[docs]def min(a): _min = __builtins__.get('min') return _min(a);
[docs]def max(a): _max = __builtins__.get('max') return _max(a);
[docs]def isnotanumber(x): try: return math.isnan(x) except TypeError: return False
[docs]def logarithm(x, base=math.e): try: if base == 10: return math.log10(x) else: return math.log(x, base) except TypeError as e: raise errors.AnsibleFilterError('log() can only be used on numbers: %s' % str(e))
[docs]def power(x, y): try: return math.pow(x, y) except TypeError as e: raise errors.AnsibleFilterError('pow() can only be used on numbers: %s' % str(e))
[docs]def inversepower(x, base=2): try: if base == 2: return math.sqrt(x) else: return math.pow(x, 1.0/float(base)) except TypeError as e: raise errors.AnsibleFilterError('root() can only be used on numbers: %s' % str(e))
[docs]def human_readable(size, isbits=False, unit=None): base = 'bits' if isbits else 'Bytes' suffix = '' ranges = ( (1<<70, 'Z'), (1<<60, 'E'), (1<<50, 'P'), (1<<40, 'T'), (1<<30, 'G'), (1<<20, 'M'), (1<<10, 'K'), (1, base) ) for limit, suffix in ranges: if (unit is None and size >= limit) or \ unit is not None and unit.upper() == suffix: break if limit != 1: suffix += base[0] return '%.2f %s' % (float(size)/ limit, suffix)
[docs]class FilterModule(object): ''' Ansible math jinja2 filters '''
[docs] def filters(self): return { # general math 'isnan': isnotanumber, 'min' : min, 'max' : max, # exponents and logarithms 'log': logarithm, 'pow': power, 'root': inversepower, # set theory 'unique' : unique, 'intersect': intersect, 'difference': difference, 'symmetric_difference': symmetric_difference, 'union': union, # computer theory 'human_readable' : human_readable, }