- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 python 进行根查找迭代。
我首先定义了 F(x)。
def F(x):
return 0.01-0.4*x+x**2/(1+x**2)
我还定义了 dFdx。
def dFdx(x):
return -0.4+2*x/((1+x**2)**2)
下面是我的寻根代码
def Testing_Root(x, F, dFdx):
# store the values of x_n in a list, xstore
# first, make an initial list with an initial guess x_0
xstore = [x]
# calculate differences in each iteration and store in a list, difference
# first, make an empty list
difference = []
print('n=0, x[0] =', x)
for i in range(50):
x = x - F(x)/dFdx(x)
xstore.append(x)
for j in range(50):
d = xstore[j+1] - xstore[j]
difference.append(d)
for k in range(50):
print('n=', k+1, 'x[', k+1, ']=', xstore[k+1], 'difference is', difference[k])
for j in range(k, 50):
if all(abs(difference[j]) < 0.000000000001):
break
break
return print('so the root is', round(x, 4), 'to 4dp')
当我使用 x=-0.1 的求根函数时
In [38]: Testing_Root(-0.1, F, dFdx)
n=0, x[0] = -0.1
n= 1 x[ 1 ]= 0.0004950332214986031 difference is 0.10049503322149861
so the root is 0.0268 to 4dp
在我的函数中,我想检查它是否收敛到根。另外,我不想打印所有迭代。如果所有 k>= 点的差异小于 0.000000000001,我希望它在某个点停止打印迭代。所以我在 for 循环中使用了 if 循环('for k in range(50) : if all(abs(difference[j])<0.0000001): break' 部分)。然而,它并没有像我预期的那样工作。它在 n=1 后停止打印,但 n=2 时的差异是 0.02306141...这显然大于 0.000000000001。为什么它不起作用?我应该在代码中更改什么?
最佳答案
需要解决的三个简单问题:
all
旨在处理可迭代的对象(想想:“在列表上”)。通过将 for
循环放在 all
调用之外,您就欺骗了 all
的功能。相反,将整个感兴趣的列表传递给 all
并且根本不循环。abs
和
<
不适用于可迭代对象!相反,使用 Python 强大的
列表理解通过逐个元素操作生成列表。语法
difference[k:]
表示
difference
中从索引
k
到末尾的所有元素。
break
循环中有一个杂散 k
,它每次都会在第一次迭代后中断循环。因此您的 k
循环应如下所示:
for k in range(50):
print('n=', k+1, 'x[', k+1, ']=', xstore[k+1], 'difference is', difference[k])
if all([abs(n)<0.000000000001 for n in difference[k:]]):
break
输出是:
n=0, x[0] = -0.1
n= 1 x[ 1 ]= 0.0004950332214986031 difference is 0.10049503322149861
n= 2 x[ 2 ]= 0.025061418498996398 difference is 0.024566385277497795
n= 3 x[ 3 ]= 0.0267848938218123 difference is 0.001723475322815901
n= 4 x[ 4 ]= 0.02679343238175541 difference is 8.538559943111618e-06
n= 5 x[ 5 ]= 0.026793432591266996 difference is 2.0951158516413493e-10
n= 6 x[ 6 ]= 0.026793432591266996 difference is 0.0
so the root is 0.0268 to 4dp
关于python - 使用 for 循环和 if 语句求根迭代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55553615/
for (i = 0; i <= 1000; i++) { if ( i % 3 === 0){ console.log(i); } if ( i % 5 ==
对于一项作业,我需要解决一个数学问题。我将其缩小为以下内容: 令 A[1, ... ,n] 为 n 整数数组。 令y 为整数常量。 现在,我必须编写一个算法,在 O(n) 时间内找到 M(y) 的最小
我可以使用 iOS MediaPlayer 并通过这种方式播放电影。但我需要,寻找一秒钟的电影。我该怎么做,我像这样通过 MediaPlayer 播放电影: NSURL *videoURL =
我听说过 eCos看起来作为一个爱好项目来玩会很有趣。 任何人都可以推荐一个价格合理的开发板。如果它不会增加太多成本,我想要几个按钮来按下(并以编程方式检测按下)和一些调试输出的 LCD。以太网会很好
给定 a 到 b 的范围和数字 k ,找到 a 到 b [包括两者]之间的所有 k-素数。 k-素数的定义:如果一个数恰好有 k 个不同的素数因子,则该数是 k-素数。 即 a=4 , b=10 k=
这是对 my previous question 的重新措辞尝试作为它收到的反馈的结果。 我想要一个简单的网络通信,我可以将其用作底层框架,而无需再次查看。我只想将一个字符串从一台 PC 推送到另一台
我有许多节点通过其他类型的中间节点连接。如图所示,中间节点可以有多个。我需要找到给定数量的节点的所有中间节点,并按初始节点之间的链接数量对其进行排序。在我的示例中,给定 A、B、C、D,它应该返回节点
我的代码遇到问题。我试图找到这个 5x5 数组的总和,但它总是给我总计 0。当我使用 2x2 数组时,它可以工作,但对于 5x5 数组则不起作用。有人可以帮忙吗? import java.util.*
我们有一个给定的数组,我们想要打印 BST 中每个节点的级别。 例如,如果给定数组为:{15, 6, 2, 10, 9, 7, 13} 那么答案是: 1 2 3 3 4 5 4 (表示存储15的节点级
我对 R 和编程非常陌生,所以请留在我身边:) 我正在尝试使用迭代来查找无限迭代到小数点后第四位的值。 IE。其中小数点后第四位不变。所以 1.4223,其中 3 不再改变,所以小数点后 3 位的结果
我的问题与 Fastest way of computing the power that a "power of 2" number used? 非常相似: 将 x=2^y 作为输入,我想输出 y。
如何找到三个非零数字中最小的一个。 我尝试引入一个非常小的数字eps = 1e-6(我的数字为零或明显大于eps)并在min(x,eps)、min(y,eps)之间进行测试)等我什么也没得到。有没有办
我有一个类(class),他们计算矩阵中最大的“1”岛,但他的岛概念是“如果两个单元在水平、垂直或对角线上彼此相邻,则称它们是相连的。 “ 我需要帮助来删除对角台阶。 class GFG {
我开始使用 IDE Jupyter && Python 3.6 并出现了一个问题。我必须通过IDE绘制Petersen子图中的哈密顿路径,但我不知道该怎么做。 我显示有关该图的信息: Petersen
public static void main(String[] args) { int sum = 2; int isPrime; for(int x = 3; x Mat
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: How much time should it take to find the sum of all prime
我想找到给定节点到链表二叉搜索树中根的距离。我有下面的代码来计算树的高度(root.getHeightN()),从根到叶子,但我现在需要的是从叶子到根。 public int getHeightN()
是否有一种优雅的方法使用预先计算的 KDTree 来查找连接组件的数量?现在使用呼吸优先搜索算法以及 k 最近邻的 KDTree 给出的邻接矩阵来查找连接的组件,但是是否有更好的可能性? import
我有一个要求,我需要找到具有相同名称的不同对象中 amt 值的总和。下面是代码片段 traveler = [ { description: 'Senior', Amount: 50}, {
我正在尝试使用 pandas 对某些列进行求和,同时保留其他列。例如: member_no, data_1, data_2, data_3, dat_1, dat_2, other_1, other_
我是一名优秀的程序员,十分优秀!