Source code for biosteam.evaluation._metric

# -*- coding: utf-8 -*-
# BioSTEAM: The Biorefinery Simulation and Techno-Economic Analysis Modules
# Copyright (C) 2020-2023, Yoel Cortes-Pena <yoelcortes@gmail.com>
# 
# This module is under the UIUC open-source license. See 
# github.com/BioSTEAMDevelopmentGroup/biosteam/blob/master/LICENSE.txt
# for license details.
"""
"""
from ._feature import Feature

__all__ = ('Metric', 'metric')

[docs] class Metric(Feature): """ Create a Metric object that serves as an argument for Model objects. Parameters ---------- name : str Name of metric. units : str Metric units of measure. getter : function Should take no arguments and return the metric value. element : str Element corresponding to metric """ __slots__ = ('getter', 'cache') distribution = None def __init__(self, name, getter, units=None, element=None): if name is None and hasattr(getter, '__name__'): name = getter.__name__ super().__init__(name, units, element) self.getter = getter
[docs] def __call__(self): self.cache = self.getter() return self.cache
[docs] def get(self): """Return value of metric. This method used cached values.""" try: return self.cache except: self.cache = self.getter() return self.cache
[docs] def difference(self): """Return the difference between the current metric value and the last one evaluated by calling this object.""" return self.getter() - self.cache
def metric(getter=None, name=None, units=None, element='Biorefinery'): if not getter: return lambda getter: metric(getter, name, units, element) return Metric(name, getter, units, element)