布伦特法

更新时间:2024-05-21 16:29

布伦特方法(the method of Brent)是在二分法或试位法的基础上,借助二次插值方法进行加速,有利用反插值方法来简化计算而形成的一种方法。

布伦特(Brent)方法初步感觉有些小题大做,仔细分析又不无道理。

假如知道f(x)的零点x’在一个不太大的区间 内,而且已知 在区间的端点处的函数值 ,以及 在(x0,x1)内的近似解x=x2和f(x2),接下来利用这已知的三个点以及它们所对应的函数值作插值抛物线。与Muller方法不同的是,把

x0 ,x1 ,x2 与f(x0), f(x1), f(x2)的对应关系反过来用,相当于用y0 ,y1 ,y2 替代方程组

f(x0)= a(x0-x2) ^2+b(x0-x2)+c **************** (1)

f(x1)= a(x1-x2) ^2+b(x1-x2)+c **************** (2)

f(x2)= a(x2-x2) ^2+b(x2-x2)+c **************** (3)

中的x0 ,x1 ,x2 ,而方程组的常数项f(x0), f(x1), f(x2) 则用这里的x0 ,x1 ,x2替换。所以对应的插值抛物线的一般形式为

x= a(y-y2) ^2+b(y-y2)+c **************** (4)

x0= a(y0-y2) ^2+b(y0-y2)+c **************** (5)

x1= a(y1-y2) ^2+b(y1-y2)+c **************** (6)

x2= a(y2-y2) ^2+b(y2-y2)+c **************** (7)

由(5)(6)(7)式可以得c=x2,利用Muller方法,可以写成a,b 的表达式。

在(4)中令y=0,可以得到下一个近似点为

X=x2+(ay2 ^2+by2) **************** (8)

其中ay2 ^2+by2相当于校正项。

Brent方法的下一个规则是,如果得到的x仍然在区间[x0,x1]内,则用x2根据f(x2)

的符号替换x0或x1 ,用x替换x2;如果所得到的x不在区间[x0,x1]内,则暂时放弃反抛物线插值法,继续用二分法或试位法。

实际上,我们可以利用二分法所得到函数顺便采用反插值方法试探一下,看能否捡到一些便宜。

在这种平常心态下,我们也可以得到类似的效果,而且方法还简单得多。

免责声明
隐私政策
用户协议
目录 22
0{{catalogNumber[index]}}. {{item.title}}
{{item.title}}