Package ffx.numerics.switching
Class PowerSwitch
java.lang.Object
ffx.numerics.switching.PowerSwitch
- All Implemented Interfaces:
- UnivariateDiffFunction,- UnivariateSwitchingFunction
A PowerSwitch interpolates between 0 and 1 vi f(x) = (ax)^beta, where x must be between 0 and
 1/a.
- Author:
- Jacob M. Litman, Michael J. Schnieders
- 
Constructor SummaryConstructorsConstructorDescriptionDefault Constructor of the PowerSwitch: constructs a linear switch.PowerSwitch(double a, double beta) Constructor of the PowerSwitch.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanRemains 0 below the lower bound, and 1 above the upper bound (i.e. a multiplicative switch).doublefirstDerivative(double x) First derivative at a point.doubleGets the value of beta in f(x) = (a*x)^betaintThe highest-order derivative that is zero at the bounds.doubleGets the value of a in f(x) = (a*x)^beta.doubleGets the one bound, where f(x) becomes one.doubleGets the zero bound, where f(x) becomes zero.intPower switch derivatives can be zero at the zero bound if the exponent is greater than the derivative order.doublenthDerivative(double x, int order) N'th order derivative at a point.doublesecondDerivative(double x) Second derivative at a point.booleanTrue if f(lb + delta) + f(ub - delta) = 1 for all delta between 0 and (ub - lb).toString()booleanRemains in the range 0-1 outside the bounds.doublevalueAt(double x) Value at a point
- 
Constructor Details- 
PowerSwitchpublic PowerSwitch()Default Constructor of the PowerSwitch: constructs a linear switch.
- 
PowerSwitchpublic PowerSwitch(double a, double beta) Constructor of the PowerSwitch.- Parameters:
- a- The upper bound of the switch is 1.0 / a.
- beta- The power of the function f(x) = (ax)^beta,
 
 
- 
- 
Method Details- 
constantOutsideBoundspublic boolean constantOutsideBounds()Remains 0 below the lower bound, and 1 above the upper bound (i.e. a multiplicative switch).- Specified by:
- constantOutsideBoundsin interface- UnivariateSwitchingFunction
- Returns:
- df(x)/dx is zero outside range lb-ub.
 
- 
firstDerivativeFirst derivative at a point.- Specified by:
- firstDerivativein interface- UnivariateDiffFunction
- Parameters:
- x- a double.
- Returns:
- f'(x)
- Throws:
- IllegalArgumentException- If f'(x) is undefined at x.
 
- 
getExponentpublic double getExponent()Gets the value of beta in f(x) = (a*x)^beta- Returns:
- Exponent of input
 
- 
getHighestOrderZeroDerivativepublic int getHighestOrderZeroDerivative()The highest-order derivative that is zero at the bounds.- Specified by:
- getHighestOrderZeroDerivativein interface- UnivariateSwitchingFunction
- Returns:
- Maximum order zero derivative at bounds.
 
- 
getMultiplierpublic double getMultiplier()Gets the value of a in f(x) = (a*x)^beta.- Returns:
- Multiplier of input
 
- 
getOneBoundpublic double getOneBound()Gets the one bound, where f(x) becomes one.- Specified by:
- getOneBoundin interface- UnivariateSwitchingFunction
- Returns:
- One bound
 
- 
getZeroBoundpublic double getZeroBound()Gets the zero bound, where f(x) becomes zero.- Specified by:
- getZeroBoundin interface- UnivariateSwitchingFunction
- Returns:
- Zero bound
 
- 
highestOrderZeroDerivativeAtZeroBoundpublic int highestOrderZeroDerivativeAtZeroBound()Power switch derivatives can be zero at the zero bound if the exponent is greater than the derivative order.- Specified by:
- highestOrderZeroDerivativeAtZeroBoundin interface- UnivariateSwitchingFunction
- Returns:
- the highest order zero derivative at zero bound
 
- 
nthDerivativeN'th order derivative at a point. Should be relatively optional for any order above 2.- Specified by:
- nthDerivativein interface- UnivariateDiffFunction
- Parameters:
- x- a double.
- order- Derivative order (>= 1)
- Returns:
- d^nf(x)/dx^n
- Throws:
- IllegalArgumentException- If derivative undefined at x.
 
- 
secondDerivativeSecond derivative at a point.- Specified by:
- secondDerivativein interface- UnivariateDiffFunction
- Parameters:
- x- a double.
- Returns:
- f''(x)
- Throws:
- IllegalArgumentException- If f''(x) is undefined at x.
 
- 
symmetricToUnitypublic boolean symmetricToUnity()True if f(lb + delta) + f(ub - delta) = 1 for all delta between 0 and (ub - lb). For example, a power switch with beta 1 is symmetric to unity, as f(l) + f(1-l) = 1, but beta 2 produces a non-unity result, where f(0.5) + f(0.5) = 0.5.- Specified by:
- symmetricToUnityin interface- UnivariateSwitchingFunction
- Returns:
- If symmetry produces unity result.
 
- 
toString
- 
validOutsideBoundspublic boolean validOutsideBounds()Remains in the range 0-1 outside the bounds. Implied to be true if constantOutsideBounds is true.- Specified by:
- validOutsideBoundsin interface- UnivariateSwitchingFunction
- Returns:
- min(f ( x)) = 0 and max(f(x)) = 1.
 
- 
valueAtValue at a point- Specified by:
- valueAtin interface- UnivariateDiffFunction
- Parameters:
- x- a double.
- Returns:
- f(x)
- Throws:
- IllegalArgumentException- If f(x) is undefined at x.
 
 
-