All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.lsmp.djep.xjep.MacroFunction Maven / Gradle / Ivy

Go to download

JEP is a Java library for parsing and evaluating mathematical expressions.

There is a newer version: 2.4.2
Show newest version
/* @author rich
 * Created on 18-Jun-2003
 */
package org.lsmp.djep.xjep;

import org.nfunk.jep.function.PostfixMathCommand;
import org.nfunk.jep.*;
import java.util.*;
/**
 * A function specified by a string.
 * For example
 * 
 * XJepI jep = new XJep();
 * j.addFunction("zap",new MacroFunction("zap",1,"x*(x-1)/2",j));
 * Node node = j.parse("zap(10)");
 * System.out.println(j.evaluate(node)); // print 45
 * 
* The names of the variables used inside the function depends on the number of arguments: *
    *
  • One argument variable must be x: new MacroFunction("sec",1,"1/cos(x)",j)
  • *
  • Two arguments variables must be x or y: new MacroFunction("myPower",2,"x^y",j)
  • *
  • Three or more arguments variables must be x1, x2, x3,...: new MacroFunction("add3",3,"x1+x2+x3",j)
  • *
* @author R Morris. * Created on 18-Jun-2003 */ public class MacroFunction extends PostfixMathCommand { private String name; private Node topNode; private EvaluatorVisitor ev = new EvaluatorVisitor(); // private XJep localJep; private XSymbolTable mySymTab; private Variable vars[]; public String getName() { return name; } public Node getTopNode() { return topNode; } /** * Create a function specified by a string. * For example new MacroFunction("sec",1,"1/cos(x)",tu) creates the function for sec. * Variable names must be x,y for 1 or 2 variables or x1,x2,x3,.. for 3 or more variables. * @param inName name of function * @param nargs number of arguments * @param expression a string representing the expression. * @param jep a reference to main XJep object. */ public MacroFunction(String inName,int nargs,String expression,XJep jep) throws IllegalArgumentException,ParseException { super(); name = inName; XSymbolTable jepSymTab = (XSymbolTable) jep.getSymbolTable(); mySymTab = (XSymbolTable) jepSymTab.newInstance(); mySymTab.copyConstants(jepSymTab); XJep localJep = jep.newInstance(mySymTab); numberOfParameters = nargs; if(numberOfParameters == 0) {} else if(numberOfParameters == 1) vars = new Variable[]{mySymTab.addVariable("x",null)}; else if(numberOfParameters == 2) { vars = new Variable[]{ mySymTab.addVariable("x",null), mySymTab.addVariable("y",null)}; } else { vars = new Variable[numberOfParameters]; for(int i=numberOfParameters-1;i>0;) vars[i] = mySymTab.addVariable("x"+String.valueOf(i),null); } topNode = localJep.parse(expression); } /** * Calculates the value of the expression. * @throws ParseException if run. */ public void run(Stack stack) throws ParseException { if(numberOfParameters == 0) {} else if(numberOfParameters == 1) vars[0].setValue(stack.pop()); else if(numberOfParameters == 2) { vars[1].setValue(stack.pop()); vars[0].setValue(stack.pop()); } else { for(int i=numberOfParameters-1;i>0;) vars[i].setValue(stack.pop()); } try { Object res = ev.getValue(topNode,mySymTab); stack.push(res); } catch(Exception e1) { throw new ParseException("MacroFunction eval: "+e1.getMessage()); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy