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

org.lsmp.djep.matrixJep.MatrixPartialDerivative Maven / Gradle / Ivy

Go to download

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

The newest version!
/* @author rich
 * Created on 29-Oct-2003
 */
package org.lsmp.djep.matrixJep;
import org.nfunk.jep.*;
import org.lsmp.djep.djep.*;
import org.lsmp.djep.vectorJep.*;
import org.lsmp.djep.vectorJep.values.*;
/**
 * Contains information about a PartialDerivative of a variable.
 * 
 * @author Rich Morris
 * Created on 29-Oct-2003
 * TODO Should setValue be overwritten?
 */
public class MatrixPartialDerivative extends PartialDerivative implements MatrixVariableI {

	private MatrixValueI mvalue = null;

	/**
	 * Protected constructor, should only be constructed
	 * through the findDerivative method in {@link MatrixVariable}.
	**/ 
	protected MatrixPartialDerivative(MatrixVariable var, String derivnames[],Node deriv)
	{
		super(var,derivnames);
		/*TODO could be a little cleverer just have a 
		 * partial derivative which is a constant dy/dx = 1
		 * don't use an equation, instead use a value.
		 * 
		if(deriv instanceof ASTMConstant) {
			MatrixValueI val = ((ASTMConstant) deriv).getMValue();
			System.out.println("Warning constant derivative "+getName()+"="+val);
			mvalue = (Scaler) Scaler.getInstance(val);
		}
		else {
		*/
			setEquation(deriv);
			setValidValue(false);
			mvalue=Tensor.getInstance(var.getDimensions());
	}
	
	public Dimensions getDimensions()
	{
		MatrixVariableI root = (MatrixVariableI) getRoot();
		return root.getDimensions();
	}
	public void setDimensions(Dimensions dims)	{}
	public MatrixValueI getMValue() { return mvalue; }

	public void setMValue(MatrixValueI val) {
		if(this.isConstant()) return;
		mvalue.setEles(val);
		setValidValue(true);
		setChanged();
		notifyObservers();
	}
//	public void setMValue(VectorMatrixTensorI value) 
//	{ this.mvalue = value; setValidValue(true); }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy