Class BrentSolver
- java.lang.Object
- 
- org.apache.commons.numbers.rootfinder.BrentSolver
 
- 
 public class BrentSolver extends Object This class implements the Brent algorithm for finding zeros of real univariate functions. The function should be continuous but not necessarily smooth. Thesolvemethod returns a zeroxof the functionfin the given interval[a, b]to within a tolerance2 eps abs(x) + twhereepsis the relative accuracy andtis the absolute accuracy.The given interval must bracket the root. The reference implementation is given in chapter 4 of Algorithms for Minimization Without Derivatives, Richard P. Brent, Dover, 2002 
- 
- 
Constructor SummaryConstructors Constructor Description BrentSolver(double relativeAccuracy, double absoluteAccuracy, double functionValueAccuracy)Construct a solver.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description doublefindRoot(DoubleUnaryOperator func, double min, double max)Search the function's zero within the given interval.doublefindRoot(DoubleUnaryOperator func, double min, double initial, double max)Search the function's zero within the given interval, starting from the given estimate.
 
- 
- 
- 
Constructor Detail- 
BrentSolverpublic BrentSolver(double relativeAccuracy, double absoluteAccuracy, double functionValueAccuracy) Construct a solver.- Parameters:
- relativeAccuracy- Relative accuracy.
- absoluteAccuracy- Absolute accuracy.
- functionValueAccuracy- Function value accuracy.
 
 
- 
 - 
Method Detail- 
findRootpublic double findRoot(DoubleUnaryOperator func, double min, double max) Search the function's zero within the given interval.- Parameters:
- func- Function to solve.
- min- Lower bound.
- max- Upper bound.
- Returns:
- the root.
- Throws:
- IllegalArgumentException- if- min > max.
- IllegalArgumentException- if the given interval does not bracket the root.
 
 - 
findRootpublic double findRoot(DoubleUnaryOperator func, double min, double initial, double max) Search the function's zero within the given interval, starting from the given estimate.- Parameters:
- func- Function to solve.
- min- Lower bound.
- initial- Initial guess.
- max- Upper bound.
- Returns:
- the root.
- Throws:
- IllegalArgumentException- if- min > maxor- initialis not in the- [min, max]interval.
- IllegalArgumentException- if the given interval does not bracket the root.
 
 
- 
 
-