python迭代法_如何绘制迭代法?

在下面的代码中,我在Python中实现了对分方法。正如一般概述,我的代码执行以下操作:我的函数能够找到任意连续标量值函数f的根,作为lambda函数的一个给定的函数容差。在

我的例程在区间[0,1]上查找函数f(x)=cos x-sin x的根,容差为10^{14}

记录达到此公差所需的迭代次数。在

但是现在我想在同一区间绘制收敛图。这将是迭代次数的绝对误差。

为了做到这一点,我必须在一个列表中收集一系列错误数字,并将其与一系列整数1到iter的最终值进行比较。在

我正在寻找一些帮助,因为我被困了。我已经用不同的迭代方法做了另外两个代码,所以一旦我能看到它如何在这一个我应该能够实现它在其他人也!非常感谢所有的帮助import math

def root(x):

return(math.cos(x)-math.sin(x))

def bisection_method(f, a, b, tol):

if f(a)*f(b) > 0:

#end function, no root.

print("No root found.")

else:

iter = 0

while (b - a)/2.0 > tol:

midpoint = (a + b)/2.0

if f(a)*f(midpoint) < 0: # Increasing but below 0 case

b = midpoint

else:

a = midpoint

iter += 1

return(midpoint, iter)

answer, iterations = bisection_method(root, 0, 1, 10**(-14))

print("Answer:", answer, "\nfound in", iterations, "iterations")

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值