用牛顿法求解数值问题
Solving numerical problems using Newtons method
本文关键字:问题 更新时间:2023-10-16
我正在学习数值分析,也在书中描述的求解算法。我的问题是关于牛顿方法的。一般来说,如果给定某个函数,我们必须求根,我们如何在代码中确定函数的导数?或者极限?因为你们知道牛顿的方法包含导数和这样的迭代。设某函数f(x)
和初始猜想,p0,
则p(n)=p(n-1)+f(p(n-1))/f'(p(n-1))
,这里f'
为f
的导数。
我如何在代码中近似它?非常感谢。
如果你想使用牛顿法,你需要知道函数的导数并将其编码。
否则,你可以用割线法,它不需要知道导数。但它的收敛速度较慢。
根据给出函数的方式,您可以做以下几件事
- 符号区分,如果你有一个函数的符号表示
- 数值区分,如果你只有点值对
- 用多项式插值并微分(当然是象征性的)
所有选项都是可行的。哪一种方法最适合你的问题取决于你的功能,以及你想在编码和/或阅读如何做到这一点上投入的时间。
Edit:如果在执行时间之前已经知道函数,则手动计算微分并将其作为函数实现。您还应该已经将f(x)
实现为如下的函数
float f (float x) {
// ...
}
,因此:
float df_dx (float x) {
// ...
}
相关文章:
- 警告处理为错误这里有什么问题
- 最小硬币更换问题(自上而下方法)
- 为"adjacent"变量赋值时出现问题
- 我的神经网络不起作用 [XOR 问题]
- 在Ubuntu 16.04上安装Cilk时出现问题
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 编译包含字符串的代码时遇到问题
- Project Euler问题4的错误解决方案
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 在进程中对同一管道进行读取和写入时C++管道出现问题
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++ 雷神库 - 使用资源加载器类时出现问题(不命名类型)
- 一个关于在C++中重载布尔运算符的问题
- 首要问题的答案让值班员搞错了
- setlocale的C++土耳其字符串问题
- 如何重构类层次结构以避免菱形问题
- 基于boost的程序的静态链接——zlib问题
- C++格式化输出问题
- 使用mongocxx驱动程序时包含头文件问题