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