a = zeros(100,100,100);
distance = [1,21,41,61,81];
for d = 1:5
for i=distance(d): distance(d)+19
for j=distance(d): distance(d)+19
for k=distance(d): distance(d)+19
a(i,j,k) = 1;
end
end
end
end
大小为(100,100,100)的张量a
和所有元素控制对角线。
如何在MATLAB
中可视化它,0是白色,1是黑色。我在MS office中绘图,这就是我想要的Expected image
对于矩阵情况,我们可以如下所示
X = zeros(100,100);
distance = [1,21,41,61,81];
for d = 1:5
for i=distance(d): distance(d)+19
for j=distance(d): distance(d)+19
X(i,j) = 1;
end
end
end
imagesc(a)
im = imagesc(1-X)
colormap(gray(256))
如何对张量进行类似的处理?
如何在有噪声的情况下显示张量?就像矩阵上的噪声
发布于 2018-05-29 06:11:40
您可以使用isosurface
和isocaps
非常接近MS Office中生成的绘图。AFAIK MATLAB没有任何生成倾斜投影的内置方法,但如果你对正交投影没有意见,下面的方法可能对你有用。
color = [0.2,0.2,0.2];
p1 = patch(isosurface(a), 'FaceColor', color, 'EdgeColor', 'none');
p2 = patch(isocaps(a), 'FaceColor', color, 'EdgeColor', 'none');
camlight left
camlight
lighting gouraud
isonormals(a, p1);
grid on;
view(3);
camorbit(-40,0);
发布于 2018-05-29 06:27:01
我用scatter3试了一下:
nonzeros = find(a);
[px,py,pz] = ind2sub(size(a),nonzeros);
scatter3(px,py,pz,'k','.');
https://stackoverflow.com/questions/50573525
复制相似问题