矩阵维度必须一致。 出错 Untitled2 (line 13) z_shifted = repmat(z, length(y), 1) + repmat(y', 1, length(x));
时间: 2024-02-27 12:54:50 浏览: 36
这个错误提示表明矩阵的维度不一致,导致无法进行加法运算。可能是因为 `z` 矩阵的维度与 `y` 矩阵的维度不一致导致的。
你可以在 `z` 矩阵的定义中添加一行代码 `z = zeros(size(t1));`,用来初始化 `z` 矩阵的大小,使其与 `t1` 矩阵的大小一致。同时,你还需要将 `z_shifted` 矩阵的 `length(y)` 改为 `length(y)*10`,因为 `z` 矩阵的大小也变化了。
修改后的代码如下:
```matlab
% 定义x的范围
x = 0:0.1:110;
% 定义分段函数z,将x改为t1
z = zeros(size(t1));
z(t1>=0 & t1<17) = 0;
z(t1>=17 & t1<45) = 4/7*t1(t1>=17 & t1<45) - 9.7;
z(t1>=45 & t1<65) = 16;
z(t1>=65 & t1<93) = -4/7*t1(t1>=65 & t1<93) + 53.1;
z(t1>=93 & t1<=110) = 0;
% 在y方向上平移这条线
y = 0:5:39;
z_shifted = repmat(z, length(y)*10, 1) + repmat(y', 1, length(x));
% 定义颜色映射参数c
Nr = 39;
Ny = 22000;
t = linspace(0,39,Nr)';
t1 = linspace(0,110,Ny)';
x = zeros(Ny,Nr);
z = zeros(Ny,Nr);
y = zeros(Ny,Nr);
for i=1:Ny
y(i,:) = t;
if i>0 && i<=17200
z(i,:) = 0;
elseif i>17200 && i<=45200
z(i,:) = (4/7*t - 9.7);
elseif i>45200 && i<=65200
z(i,:) = 16;
elseif i>65200 && i<=93200
z(i,:) = (-4/7*t + 53.1);
elseif i>93200 && i<=110200
z(i,:) = 0;
end
end
for j=1:Nr
x(:,j)=t1;
end
V=d2;
c=zeros(Nr,Ny);
for j = 1:Nr
for i = 1:Ny
c(j,i) = V((j-1)*(length(x))+i);
end
end
c=c';
% 绘制图像
h = surf(x, y, z_shifted, c);
set(h, 'edgecolor', 'none');
xlabel('x/mm');
ylabel('y/mm');
zlabel('z/mm');
title('分段函数z的图像');
```
这样修改后,再运行代码,就可以成功绘制出三维图像了。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)