代码修正,求出插值曲线和原图的对比:x0=zeros(100,1)'; z0=zeros(100,1)'; x0= linspace(-4, 4, 100); for i = 1:100 z0(i) = sin(pix0(i)/2) + cos(pix0(i)/3); end figure(1); plot(x0,z0,'k-'); k=1 %RBF sigma=0.2; x_g=zeros(100,1)'; for j=1:100 dist=sqrt((x0(j))^2); x_g(j)=exp(-(dist)/2sigma^2);%gauss %x_g(j,k)=((dist)^2+1)^0.5; end w=x_g\z0'; x_hat = linspace(-2, 2, 100); z_g=zeros(length(x_hat),1); for p=1:length(x_hat) for m=1:100 dist2=sqrt((x0(m)-x_hat(p))^2); f=w(m)exp(-(dist2)/2sigma^2);%gauss %f=w(m)((dist2)^2+1)^0.5; z_g(p)=z_g(p)+f; end z_real=sin(pix_hat(p)/2) + cos(pix_hat(p)/3); end figure(2) plot(x_hat,z_g'); %set(gcf, 'Renderer', 'ZBuffer'); axis([-4 4 -2 2]); E_max=max(max(abs(z_g-z_real))); E_avg=mean(mean(abs(z_g-z_real))); fprintf('均方根误差最大值为 %.4f\n', E_max) fprintf('均方根误差平均值为 %.4f\n', E_avg) x = [1]; y1 = E_max; y2 =E_avg; % 绘制第一组数据的图形,使用红色实线 figure(3) plot(x, y2, '*'); hold on;
时间: 2023-08-12 17:04:32 浏览: 48
好的,您可以使用以下代码来画出插值曲线和原图的对比:
```
% 绘制原图
figure(1);
plot(x0, z0, 'k-');
title('原图');
xlabel('x');
ylabel('y');
% 绘制插值曲线
figure(2);
plot(x_hat, z_g, 'r-', x_hat, z_real, 'b-');
title('插值曲线和原图对比');
xlabel('x');
ylabel('y');
legend('插值曲线', '原图');
```
以上代码会生成两张图,第一张图是原图,第二张图是插值曲线和原图的对比。希望能够帮助到您。
相关问题
将代码转化为画二维图形的代码:x0=zeros(100,1)'; y0=zeros(100,1)'; z0=zeros(100,1)'; k=1 x1= linspace(-2, 2, 10); y1= linspace(-2, 2, 10); for i = 1:length(x1) for j = 1:length(y1) M(k,:) = [x1(i) y1(j)]; % M中是均匀采样点的坐标 k = k+1; end end x0 = M(:, 1); % 提取 M 的第一列,即 x1 列 y0 = M(:, 2); % 提取 M 的第二列,即 y1 列 for i = 1:100 z0(i) = sin(pix0(i)/2) + cos(pix0(i)/3); end figure(1); plot3(x0,y0,z0,''); %RBF sigma=0.2; x_g=zeros(100,100); for j=1:100 for k=1:100 dist=sqrt((x0(j)-x0(k))^2+(y0(j)-y0(k))^2); x_g(j,k)=exp(-(dist)/2sigma^2);%gauss %x_g(j,k)=((dist)^2+1)^0.5; end end w=x_g\z0'; x_hat = linspace(-2, 2, 100); y_hat = linspace(-2, 2, 100); z_g=zeros(length(x_hat),length(x_hat)); for p=1:length(x_hat) for n=1:length(x_hat) for m=1:100 dist2=sqrt((x0(m)-x_hat(p))^2+(y0(m)-y_hat(n))^2); f=w(m)exp(-(dist2)/2sigma^2);%gauss %f=w(m)*((dist2)^2+1)^0.5; z_g(p,n)=z_g(p,n)+f; end z_real=x_hat(p)exp(-x_hat(p)^2+y_hat(n)); end end figure(2) mesh(x_hat,y_hat,z_g'); %set(gcf, 'Renderer', 'ZBuffer'); axis([-2 2 -2 2 -2 2]); E_max=max(max(abs(z_g-z_real))); E_avg=mean(mean(abs(z_g-z_real))); fprintf('均方根误差最大值为 %.4f\n', E_max) fprintf('均方根误差平均值为 %.4f\n', E_avg) x = [1]; y1 = E_max; y2 =E_avg; % 绘制第一组数据的图形,使用红色实线 figure(3) plot(x, y2, ''); hold on;
好的,以下是将代码转化为画二维图形的代码:
```matlab
% 均匀采样点
x0 = zeros(100, 1)';
y0 = zeros(100, 1)';
z0 = zeros(100, 1)';
k = 1;
x1 = linspace(-2, 2, 10);
y1 = linspace(-2, 2, 10);
for i = 1:length(x1)
for j = 1:length(y1)
M(k,:) = [x1(i) y1(j)]; % M中是均匀采样点的坐标
k = k + 1;
end
end
x0 = M(:, 1); % 提取 M 的第一列,即 x1 列
y0 = M(:, 2); % 提取 M 的第二列,即 y1 列
% 真实函数
for i = 1:100
z0(i) = sin(pi*x0(i)/2) + cos(pi*x0(i)/3);
end
% 绘制均匀采样点和真实函数的图像
figure(1);
plot3(x0, y0, z0, '');
% RBF插值
sigma = 0.2;
x_g = zeros(100, 100);
for j = 1:100
for k = 1:100
dist = sqrt((x0(j)-x0(k))^2 + (y0(j)-y0(k))^2);
x_g(j, k) = exp(-dist/2/sigma^2); % 高斯核函数
%x_g(j, k) = ((dist)^2 + 1)^0.5; % 多项式核函数
end
end
w = x_g \ z0';
x_hat = linspace(-2, 2, 100);
y_hat = linspace(-2, 2, 100);
z_g = zeros(length(x_hat), length(x_hat));
for p = 1:length(x_hat)
for n = 1:length(x_hat)
for m = 1:100
dist2 = sqrt((x0(m)-x_hat(p))^2 + (y0(m)-y_hat(n))^2);
f = w(m) * exp(-dist2/2/sigma^2); % 高斯核函数
%f = w(m) * ((dist2)^2 + 1)^0.5; % 多项式核函数
z_g(p, n) = z_g(p, n) + f;
end
z_real = x_hat(p) * exp(-x_hat(p)^2 + y_hat(n));
end
end
% 绘制插值结果的图像
figure(2)
mesh(x_hat, y_hat, z_g');
%set(gcf, 'Renderer', 'ZBuffer');
axis([-2 2 -2 2 -2 2]);
% 计算误差并输出
E_max = max(max(abs(z_g-z_real)));
E_avg = mean(mean(abs(z_g-z_real)));
fprintf('均方根误差最大值为 %.4f\n', E_max)
fprintf('均方根误差平均值为 %.4f\n', E_avg)
% 绘制误差图像
x = [1];
y1 = E_max;
y2 = E_avg;
figure(3)
plot(x, y2, '');
hold on;
```
f = zeros(n, n); f(:, 1) = y'; for j = 2:n
这段代码的作用是什么呢?
这段代码用于计算出差商表。首先,我们创建一个 n 行 n 列的矩阵 f,用于存储差商表。然后,将 y 转置后赋值给 f 的第一列,即 f(:, 1) = y'。接下来,使用双重循环计算出差商表的其他元素。其中,j 表示列数,i 表示行数。具体地,对于第 j 列的第 i 个元素,根据差商的定义,它的值为:
f(i, j) = (f(i, j-1) - f(i-1, j-1)) / (x(i) - x(i-j+1));
其中,f(i, j-1) 表示前一列的第 i 个元素,f(i-1, j-1) 表示前一列的第 i-1 个元素,x(i) 表示第 i 个数据点的 x 坐标,x(i-j+1) 表示第 i-j+1 个数据点的 x 坐标。通过这个公式,我们可以逐步计算出差商表的所有元素。最终,f 中的第 j 列就是以 x0, x1, ..., xj-1 为节点的插值多项式在 x0 处的 j 阶导数的值,而 f(1, j) 就是插值多项式在 x0 处的值。