我有这种类型的数据:
Data = [1:1:9; 1 2 3 4 5 6 7 8 9; 1 2 3 4 5 6 7 8 9 ;1 2 3 4 5 6 7 8 9;1 2 3 4 5 6 7 8 9];
第一个条目是感兴趣的区域(总共9个区域),其余4个数组条目是区域内停留的时间长度(此问题现在只是任意的。
我想在地图图片上将每个区域中的每个东西绘制多长时间作为3d“热图”样式图。地图分为3x3网格,如下所示:
1 2 3
4 5 6
7 8 9
我如何策划这个?我已经尝试了轮廓和冲浪功能,但我不确定如何将它们映射到网格。我想将图表叠加在地图图片上作为我的最后一步,但只需将图表启动并运行就会很棒!
答案 0 :(得分:0)
您可以将imagesc
用于2D版本,或bar3
用于3D版本,在此示例中我创建了一些子图,但当然您可以自由更改此选项。
Data = [1:1:9; 1 2 3 4 5 6 7 8 9; 1 2 3 4 5 6 7 8 9 ;1 2 3 4 5 6 7 8 9;1 2 3 4 5 6 7 8 9];
M = zeros(3,3);
2D
for ii = 2:size(Data,1)
subplot(2,2,ii-1)
M(1:end) = Data(ii,:);
imagesc(M)
colormap jet
shading flat %for an exact result
% shading interp %for a smooth result
end
figure
3D (即使我认为3D视图无用)
for ii = 2:size(Data,1)
subplot(2,2,ii-1)
M(1:end) = Data(ii,:);
h{ii} = bar3(M)
colorbar
for k = 1:length(h{ii})
zdata = h{ii}(k).ZData;
h{ii}(k).CData = zdata;
h{ii}(k).FaceColor = 'interp';
end
end
答案 1 :(得分:0)
我不确定这是否是您想要的那种情节,但您可以使用Delaunay Triangulation将持续时间数据映射为网格点上的曲面。 MatLab文件交换具有很好的功能,可以使用此方法映射内容。