E
Esmail
Hello all,
I am trying to store a function and some associated information in an
object so that I can later have series of functions in a list that I can
evaluate one at a time.
Right now I am only storing the function itself, the number of
arguments it expects and its string representation. I may add other
information such as the acceptable range for the parameters or other
characteristics such as maximum or minimum.
I wonder if anyone could comment on my implementation and offer
suggestions or constructive criticisms?
The 'loading' of the functions is a bit tedious and of course care
has to be taken to make sure the string representation corresponds to
the actual function computed. It would be nice if there was an
automatic way to convert the function to its string representation.
Comments or problems with the approach I have taken?
Thanks,
Esmail
--
#!/usr/bin/env python
#
# store and represent functions
#
import math
class FunctionException(Exception):
""" custom exception """
def __init__(self, value):
self.parameter = value
def __str__(self):
return repr(self.parameter)
class Function(object):
""" class to represent a function """
def __init__(self, fn, fn_str, num_vars):
"""
the function, its string representation, and the number of variables
"""
self.fn = fn
self.fn_str = fn_str
self.num_vars = num_vars
def eval_fn(self, variables):
""" size of variables should equal num_vars .. else problem """
if len(variables) == self.num_vars:
result = self.fn(*variables)
return result
else:
raise FunctionException('invalid number of args provided - '+
'received %d, expected %d'
%(len(variables), self.num_vars))
def str(self):
""" return string representation of function """
return self.fn_str
def funct1(x):
''' small test function '''
return x * x
def funct2(x, y):
''' small test function '''
return x + y
def funct3(x):
''' small test function '''
return 1000 + (x*x + x) * math.cos(x)
def main():
""" main method """
print 'in main'
fn1 = Function(funct1, 'x * x', 1)
fn2 = Function(funct2, 'x + y', 2)
fn3 = Function(funct3, '1000 + (x*x + x) * cos(x)', 1)
for i in range(-10, 10):
try:
print 'f(', ,') =',
print fn3.str(), ' => ',
print fn3.eval_fn()
except FunctionException, (ex):
print ex.parameter
if __name__ == '__main__':
main()
I am trying to store a function and some associated information in an
object so that I can later have series of functions in a list that I can
evaluate one at a time.
Right now I am only storing the function itself, the number of
arguments it expects and its string representation. I may add other
information such as the acceptable range for the parameters or other
characteristics such as maximum or minimum.
I wonder if anyone could comment on my implementation and offer
suggestions or constructive criticisms?
The 'loading' of the functions is a bit tedious and of course care
has to be taken to make sure the string representation corresponds to
the actual function computed. It would be nice if there was an
automatic way to convert the function to its string representation.
Comments or problems with the approach I have taken?
Thanks,
Esmail
--
#!/usr/bin/env python
#
# store and represent functions
#
import math
class FunctionException(Exception):
""" custom exception """
def __init__(self, value):
self.parameter = value
def __str__(self):
return repr(self.parameter)
class Function(object):
""" class to represent a function """
def __init__(self, fn, fn_str, num_vars):
"""
the function, its string representation, and the number of variables
"""
self.fn = fn
self.fn_str = fn_str
self.num_vars = num_vars
def eval_fn(self, variables):
""" size of variables should equal num_vars .. else problem """
if len(variables) == self.num_vars:
result = self.fn(*variables)
return result
else:
raise FunctionException('invalid number of args provided - '+
'received %d, expected %d'
%(len(variables), self.num_vars))
def str(self):
""" return string representation of function """
return self.fn_str
def funct1(x):
''' small test function '''
return x * x
def funct2(x, y):
''' small test function '''
return x + y
def funct3(x):
''' small test function '''
return 1000 + (x*x + x) * math.cos(x)
def main():
""" main method """
print 'in main'
fn1 = Function(funct1, 'x * x', 1)
fn2 = Function(funct2, 'x + y', 2)
fn3 = Function(funct3, '1000 + (x*x + x) * cos(x)', 1)
for i in range(-10, 10):
try:
print 'f(', ,') =',
print fn3.str(), ' => ',
print fn3.eval_fn()
except FunctionException, (ex):
print ex.parameter
if __name__ == '__main__':
main()