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

org.cogchar.animoid.calc.curve.ConstAccelCurve Maven / Gradle / Ivy

/*
 *  Copyright 2011 by The Cogchar Project (www.cogchar.org).
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *       http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */

package org.cogchar.animoid.calc.curve;

import org.appdapter.bind.math.jscience.number.NumberFactory;
import static org.cogchar.animoid.calc.curve.ConstAccelCurveStateVarSymbol.*;
import org.jscience.mathematics.function.Polynomial;
import org.jscience.mathematics.function.Term;
import org.jscience.mathematics.function.Variable;
import org.jscience.mathematics.number.Number;

/**
 * This second-order (parabolic + linear) curve is parametrized by and differentiable in 4 variables:
 * TimeOffset
 * ConstAccel
 * InitPos
 * InitVel
 * 
 * "Init" values are at timeOffset=0.
 *

 * @param 
 * @author Stu B. 
 */
public class ConstAccelCurve>
	extends PolynomialMotionCurve {

	private NumberFactory		myNumberFactory;
	private	Polynomial			myAccelCurve;
	// private	Variable					myTimeOffsetVar;

	/**
	 * In this form, the timeOffset variable is supplied externally so that it may
	 * easily be shared among other curves.   This sharing is important when
	 * polynomials over this curve are combined with polynomials over curves on
	 * the same time segment, as it allows like terms to be combined symbolically.
	 *
	 *
	 * @param symbolSuffix
	 * @param offsetTimeVar
	 */

	public ConstAccelCurve(String symbolSuffix, Variable offsetTimeVar,
				NumberFactory numFact) {
		super(symbolSuffix);
		// myTimeOffsetVar = offsetTimeVar;
		mySymbolSuffix = symbolSuffix;
		if (offsetTimeVar != null) {
			useExistingPolyVar(TIME_OFFSET, offsetTimeVar);
		}
		myNumberFactory = numFact;
		Polynomial curvePoly = makeCurvePoly();
		setCurvePoly(curvePoly);
	}
	public ConstAccelCurve(String symbolSuffix, NumberFactory numFact) {
		this(symbolSuffix, null, numFact);
	}
	private Polynomial makeCurvePoly() {
		RN one = myNumberFactory.getOne();
		RN oneHalf = myNumberFactory.getOneHalf();

		Variable	timeVar = getPolyVar(TIME_OFFSET);
		Variable	accVar = getPolyVar(CONST_ACCEL);
		Variable	initPosVar = getPolyVar(INIT_POS);
		Variable	initVelVar = getPolyVar(INIT_VEL);

		Term  timeSquaredTerm = Term.valueOf(timeVar, 2);
		Term  accelTerm = Term.valueOf(accVar, 1);
		Term  accelTimeSqTerm = timeSquaredTerm.times(accelTerm);

		Polynomial parabPoly = Polynomial.valueOf(oneHalf, accelTimeSqTerm);

		Term timeTerm = Term.valueOf(timeVar, 1);
		Term velTerm = Term.valueOf(initVelVar, 1);
		Term velTimeTerm = timeTerm.times(velTerm);
		Polynomial linearPoly = Polynomial.valueOf(one, velTimeTerm);

		Polynomial constPoly = Polynomial.valueOf(one, initPosVar);

		Polynomial constPlusLinear = constPoly.plus(linearPoly);

		Polynomial fullPoly = constPlusLinear.plus(parabPoly);

		return fullPoly;		
	}
	
	public Polynomial getVelocityCurve() {
		return getDerivPolyForStateVarSymbol(TIME_OFFSET);
	}
	public Polynomial getAccelCurve() {
		if (myAccelCurve == null) {
			Polynomial velCurve = getVelocityCurve();
			Variable	timeVar = getPolyVar(TIME_OFFSET);
			myAccelCurve = velCurve.differentiate(timeVar);
		}
		return myAccelCurve;
	}
	public RN getVelocityAtCurrentState() {
		return evalDerivPolyAtCurrentState(TIME_OFFSET);
	}
	public RN getPositionAtCurrentState() {
		return evalCurvePolyAtCurrentState();
	}
	public RN getAccelAtCurrentState() {
		return getStateVarVal(CONST_ACCEL);
	}
	public RN getTimeOffsetAtCurrentState() {
		return getStateVarVal(TIME_OFFSET);
	}

	public void setInitPosition(RN initPos) {
		setStateVarVal(INIT_POS, initPos);
	}
	public void setInitVelocity(RN initVel) {
		setStateVarVal(INIT_VEL, initVel);
	}
	public void setConstAccel(RN constAccel) {
		setStateVarVal(CONST_ACCEL, constAccel);
	}
	public void setTimeOffset(RN timeOffset) {
		setStateVarVal(TIME_OFFSET, timeOffset);
	}
	public RN makeNumber(double dval) {
		return myNumberFactory.makeNumberFromDouble(dval);
	}
	public void configureWithDoubles(double timeOffset, double constAccel, double initPos, 
				double initVel) {
		setTimeOffset(makeNumber(timeOffset));
		setConstAccel(makeNumber(constAccel));
		setInitPosition(makeNumber(initPos));
		setInitVelocity(makeNumber(initVel));
	}


/*
	public String getInitPosSymbol() {
		return getFullSymbolStringForStateVar(INIT_POS);
	}
	public String getInitVelSymbol() {
		return getFullSymbolStringForStateVar(INIT_VEL);
	}
	public String getConstAccSymbol() {
		return getFullSymbolStringForStateVar(CONST_ACCEL);
	}
	public String getTimeOffsetSymbol() {
		return getFullSymbolStringForStateVar(TIME_OFFSET);
	}
	public Polynomial getDerivPolyWRT_TimeOffset() {
		return getDerivPolyForStateVarSymbol(TIME_OFFSET);
	}
	public Polynomial getDerivPolyWRT_ConstAccel() {
		return getDerivPolyForStateVarSymbol(CONST_ACCEL);
	}
	public Polynomial getDerivPolyWRT_InitPos()  {
		return getDerivPolyForStateVarSymbol(INIT_POS);
	}
	public Polynomial getDerivPolyWRT_InitVel()  {
		return getDerivPolyForStateVarSymbol(INIT_VEL);
	}

	public double getTimeOffsetValue() {
		return RealFuncs.getVariableValue(myTimeOffsetVar);
	}
	public double getInitPosValue() {
		return RealFuncs.getInputVarValue(getPositionPolynomial(), getInitPosSymbol());
	}
	public double getInitVelValue() {
		return RealFuncs.getInputVarValue(getPositionPolynomial(), getInitVelSymbol());
	}
	public double getConstAccValue() {
		return RealFuncs.getInputVarValue(getPositionPolynomial(), getConstAccSymbol());
	}

	public void setTimeOffsetValue(double timeOffset) {
		RealFuncs.setVariableValue(myTimeOffsetVar, timeOffset);
	}
	void setInitPosValue(double x0val) {
		RealFuncs.setInputVarValue(getPositionPolynomial(), getInitPosSymbol(), x0val);
	}
	void setInitVelValue(double v0val) {
		RealFuncs.setInputVarValue(getPositionPolynomial(), getInitVelSymbol(), v0val);
	}
	void setConstAccValue(double aval) {
		RealFuncs.setInputVarValue(getPositionPolynomial(), getConstAccSymbol(), aval);
	}
	double getVelValueAtCurrentTimeOffset() {
		double timeOffset = getTimeOffsetValue();
		return getInitVelValue() + timeOffset * getConstAccValue();
	}
	double getPosValueAtCurrentTimeOffset() {
		// TimeOffset, AccelValue, InitVel, InitPos must all be set for this to work!
		return evalPositionPolynomial();
	}
	*/

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy