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)