Source code for sas.sascalc.fit.pluginmodel
from sas.sascalc.calculator.BaseComponent import BaseComponent
import math
[docs]class Model1DPlugin(BaseComponent):
is_multiplicity_model = False
## Name of the model
def __init__(self , name="Plugin Model" ):
""" Initialization """
BaseComponent.__init__(self)
self.name = name
self.details = {}
self.params = {}
self.description = 'plugin model'
[docs] def function(self, x):
"""
Function to be implemented by the plug-in writer
"""
return x
[docs] def run(self, x = 0.0):
"""
Evaluate the model
:param x: input x, or [x, phi] [radian]
:return: function value
"""
if x.__class__.__name__ == 'list':
x_val = x[0]*math.cos(x[1])
y_val = x[0]*math.sin(x[1])
return self.function(x_val)*self.function(y_val)
elif x.__class__.__name__ == 'tuple':
raise ValueError("Tuples are not allowed as input to BaseComponent models")
else:
return self.function(x)
[docs] def runXY(self, x = 0.0):
"""
Evaluate the model
:param x: input x, or [x, y]
:return: function value
"""
if x.__class__.__name__ == 'list':
return self.function(x[0])*self.function(x[1])
elif x.__class__.__name__ == 'tuple':
raise ValueError("Tuples are not allowed as input to BaseComponent models")
else:
return self.function(x)
[docs] def set_details(self):
"""
Set default details
"""
if not self.params:
return {}
for key in self.params.keys():
self.details[key] = ['', None, None]