- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是 matlab 的新手,我需要创建一个函数,以起始近似值 x = a 执行 Newton-Raphson 方法的 n 次迭代。此起始近似值不算作交互,另一个要求是需要 for 循环。我查看了发布的其他类似问题,但就我而言,我不想使用 while 循环。
我的输入应该是这样的:
mynewton(f,a,n) which takes three inputs:
f: A function handle for a function of x.
a: A real number.
n: A positive integer.
到目前为止,这是我的代码。
function r=mynewton(f,a,n)
syms x;
z=f(x);
y=a;
for i=1:n
y(i+1)=y(i)-(z(i)/diff(z(i)));
end
r=y
end
当我尝试调用该函数时,我收到一条错误消息:
Error in MuPAD command: DOUBLE cannot convert the input expression into a double array.
If the input expression contains a symbolic variable, use the VPA function instead.
Error in mynewton (line 6)
y(i+1)=y(i)-(z(i)/diff(z(i)));
问题是我该如何使用这个VPA功能?当然,我的代码的其余部分可能也不是 100% 正确,但是如果能解决 vpa 问题或修复我的代码的其他部分,我们将不胜感激。
谢谢!
最佳答案
您的 Newton-Raphson 技术有两点不太正确……但肯定可以解决!在我们修复此问题后,您所说的 VPA
错误就不再存在了。
第一个是迭代本身。记忆一下 Newton-Raphson 技术的定义:
(来源:mit.edu)
对于下一次迭代,您使用上一次迭代的值。您所做的是使用循环计数器并将其代入您的f(x)
,这是不正确的。它必须是前一次迭代的值。
如果您看一下您是如何编写函数代码的,您会以符号方式定义您的函数,但您正在尝试将数字 值替换到您的函数中。不幸的是,这不适用于 MATLAB。如果你真的想替换值,你必须使用 subs
.这将为您替换一个实际值作为 x
的函数或您的函数使用的任何自变量。执行此操作后,您的值仍然是 sym
类型。您需要将其转换为 double 才能以数字方式使用它。
同样为了效率,没必要把y
做成数组。只需将其设为在每次迭代时更新自身的单个值即可。综上所述,您的代码已更新为如下所示。请注意,我在循环之前采用了函数的导数来减少您需要进行的计算量。我还拆分了 Newton-Raphson 迭代的分子和分母项,以使事情变得清晰,并使 subs
更容易接受。事不宜迟:
function r = mynewton(f,a,n)
syms x;
z = f(x);
diffZ = diff(z); %// Edit - Include derivative
y = a; %// Initial root
for idx = 1 : n
numZ = subs(z,x,y); %// Numerator - Substitute f(x) for f(y)
denZ = subs(diffZ,x,y); %// Denominator - Substitute for f'(x) for f'(y)
y = y - double(numZ)/double(denZ); %// Update - Cast to double to get the numerical value
end
r = y; %// Send to output
end
请注意,我在循环中将 i
替换为 idx
。原因是因为实际上不建议使用 i
或 j
作为循环索引,因为这些字母被保留来表示复数。如果你看看 Shai 发表的这篇文章,你会发现使用这些变量作为循环索引实际上更慢:Using i and j as variables in Matlab
无论如何,为了测试这一点,假设我们的函数是 y = sin(x)
,我的初始根是 x0 = 2
,有 5 次迭代,我们这样做:
f = @(x) sin(x);
r = mynewton(f, 2, 5)
r =
3.1416
这与我们对 sin(x)
的了解一致,因为 sin(x)
的截距位于 pi
的整数倍处. x0 = 2
位于 pi
附近,因此这确实按我们预期的那样工作。
您的原始代码在每次迭代时将根的值存储在 y
中。如果您真的想这样做,则必须修改您的代码,使其看起来像这样。请记住,我预先分配了 y
以提高效率:
function r = mynewton(f,a,n)
syms x;
z = f(x);
diffZ = diff(z);
y = zeros(1,n+1); %// Pre-allocate output array
y(1) = a; %// First entry is the initial root
for idx = 1 : n
numZ = subs(z,x,y(idx)); %// Remember to use PREVIOUS guess for next guess
denZ = subs(diffZ,x,y(idx));
y(idx+1) = y(idx) - double(numZ)/double(denZ); %// Place next guess in right spot
end
r = y; %// Send to output
end
通过使用与上面完全相同的参数运行此代码,我们得到:
f = @(x) sin(x);
r = mynewton(f, 2, 5)
r =
2.0000 4.1850 2.4679 3.2662 3.1409 3.1416
r
中的每个值都会告诉您在该特定迭代中对根的猜测。数组的第一个元素是初始猜测(当然)。下一个值是 Newton-Raphson 根每次迭代时的猜测值。请注意,数组的最后一个元素是我们的最终迭代,大致等于 pi
。
关于matlab - Matlab 中的 Newton-Raphson 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25129233/
在 Matlab 中,您可以选择创建新的“示例”脚本文件以及脚本、函数、类等。创建它们时,它们会获得一个脚本图标。 它们与其他标准脚本文件的处理方式有何不同? 是否有关于这些示例脚本类型的预期用途的文
我正在运行一个不是我自己编写的大 m 文件,它依赖于某些子函数。我想知道是否在所有嵌套函数的任何地方都使用了特定函数(在我的例子中是函数 eig.m(计算特征值))。有没有快速的方法来做到这一点? 亲
Matlab中有一个函数叫 copulafit .我怎样才能看到这个函数背后的代码?许多 Python 的 numpy 和 scipy 函数在 Github 上很容易开源,但由于某种原因我在 Gith
我定义了一个抽象基类measurementHandler < handle它定义了所有继承类的接口(interface)。这个类的两个子类是a < measurementHandler和 b < me
假设有一个矩阵 A = 1 3 2 4 4 2 5 8 6 1 4 9 例如,我有一个 Vector 包含该矩阵每一列的“类”
我有一个在后台运行的 Matlab 脚本。随着计算的进行,它会不断弹出进度栏窗口。这很烦人。 问题是我没有自己写 Matlab 脚本,这是一段很长很复杂的代码,我不想搞砸。那么如何在不修改 Matla
有没有办法从一个 matlab 程序中检测计算机上正在运行多少个 matlab 进程? 我想要恰好有 n 个 matlab 进程在运行。如果我的数量太少,我想创建它们,如果数量太多,我想杀死一些。您当
我正在测试我们在 Matlab 中开发的一个独立应用程序,当时我注意到它的内存使用量(根据 Windows 任务管理器)达到了 16gb 以上的数倍峰值。我决定在编译版本后面的脚本上使用 profil
我面临着一个相当棘手的问题。在 Matlab 中,命令 S = char(1044) 将俄语字母 д 放入变量 S。但是 disp(S) 返回空白符号,尽管内容实际上是正确的: >> S = char
我在这行 MATLAB 代码中遇到内存不足错误: result = (A(1:xmax,1:ymax,1:zmax) .* B(2:xmax+1,2:ymax+1,2:zmax+1) +
我正在寻找一种在 MATLAB 中比较有限顺序数据与非确定性顺序的方法。基本上,我想要的是一个数组,但不对包含的元素强加顺序。如果我有对象 a = [x y z]; 和 b = [x z y]; 我希
我有一个由 1 和 0 组成的二维矩阵。 mat = [0 0 0 0 1 1 1 0 0 1 1 1 1 1 0 0 1 0 0 0 1 0 1 1 0 0 1]; 我需
我可以在 Matlab 中用一组 x,y 点绘制回归线。但是,如果我有一组点(如下图),假设我有四组点,我想为它们绘制四条回归线……我该怎么做?所有的点都保存在 x,y 中。没有办法将它们分开并将它们
我正在尝试使用以下代码在 MATLAB 中绘制圆锥体。但是,当 MATLAB 生成绘图时,曲面中有一个间隙,如下图所示。谁能建议关闭它的方法? clearvars; close all; clc; [
我有一个 map称为 res_Map,包含一组不同大小的数组。我想找到用于存储 res_Map 的总内存。 正如您在下面看到的,看起来 res_Map 几乎不占用内存,而 res_Map 中的各个元素
有没有办法在 MATLAB 中组合 2 个向量,这样: mat = zeros(length(C),length(S)); for j=1:length(C) mat(j,:)=C(j)*S;
已结束。此问题不符合 Stack Overflow guidelines 。它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答它。 关闭 5 年前
我正在尝试将MatLab中的t copula适配到我的数据,并且我的功能是: u = ksdensity(range_1, range_1,'function','cdf'); v = ksdens
大家好,我目前正在尝试使用论文“多尺度形态学图像简化”中的 SMMT 运算符 Dorini .由于没有订阅无法访问该页面,因此我将相关详细信息发布在这里: 请注意,我将相关文章的部分内容作为图片发布。
我在MATLAB中编写代码,需要使用一个名为modwt的函数,该函数同时存在于两个我同时使用的工具箱(Wavelet和WMTSA)中。问题在于,一个版本仅返回一个输出,而另一个版本则返回三个输出。我应
我是一名优秀的程序员,十分优秀!