3D surface plot from imported 2D excel array
이 질문을 팔로우합니다.
- 팔로우하는 게시물 피드에서 업데이트를 확인할 수 있습니다.
- 정보 수신 기본 설정에 따라 이메일을 받을 수 있습니다.
오류 발생
페이지가 변경되었기 때문에 동작을 완료할 수 없습니다. 업데이트된 상태를 보려면 페이지를 다시 불러오십시오.
이전 댓글 표시
0 개 추천
New to Matlab. Im sure this is answered somewhere already, but I can't manage to find it; I have a 2D array of experimental data tabulated in excel. 1st row and column are varied parameters, and I measure the corresponding amplitudes in the matrix. Importing the table to Matlab is simple. I would then like to plot a 3D surface of the 1st row (x) vs. 1st column (y), for the amplitudes in the matrix. This is very straightforward in excel, but the plots look terrible. Thanks in advance for the help.
채택된 답변
Star Strider
2018년 3월 2일
Try this:
[D,S,R] = xlsread('ExampleArray.xls');
figure(1)
ribbon(D(:,1), D(:,2:end))
grid on
[X,Y] = meshgrid((1:size(D,2)-1), D(:,1));
Z = D(:,2:end);
figure(2)
surf(X, Y, Z)
grid on
댓글 수: 8
Hi Star Strider, Thanks for the help! This is pretty close to what I am after. However, I still have a couple issues with the result. The x axis looks correct (first column of the table), but the y axis is from 1 to 5, and not the values in the first row of the table. Also the colormap is not correct. I tried this, but the colormap scaling is apparently not being automatically adjusted;
[D,S,R] = xlsread('ExampleArray.xls');
[X,Y] = meshgrid((1:size(D,2)-1), D(:,1));
Z = D(:,2:end);
figure(2)
C=X.*Y;
surf(X,Y,Z)
colormap parula
shading interp
colorbar
As always, my pleasure.
The first value in the first row is NaN, and that will cause problems. That is the reason I chose [1:5] to test the code. The first column is also significantly different from the others, and since I have no idea what the data are, I used it for the independent variable.
You can get some color definition by adding:
caxis([0.001 0.025])
after the surf call. (No magickal knowledge to that — I experimented until I found something that worked!)
The caxis function worked nicely. It seems the amplitude of the Z data was too low for the colormap to rescale properly by default. I still haven't come up with a good way to rescale the x axis. It is actually the y axis that is being set correctly already (The 1st column of the data table). You are right they are the independent variable. The second independent variable, x, is the 1st row (wavelengths in this case). The Z amplitudes are the measured values in the rest of the table for the corresponding x,y settings. It seems like there should be a very straightforward way to deal with this, but I haven't managed to figured it out yet. Any help would be greatly appreciated.
The first element in the first row is NaN.
What should that wavelength be?
Yes, the way the data is generated in the excel file it is not supposed to be a number. The 1st row basically contains the column headings for the z data below, and the 1st column is the row headings. The y-axis looks correct (4000 to 6000 increments), but the 1-5 on the x axis should instead be the wavelengths 825-945 in the table.

I’m glad caxis works!
So perhaps:
Row_1 = linspace(825, 945, 5);
Would that do what you want?
joe pearson
2018년 3월 3일
편집: joe pearson
2018년 3월 3일
That's almost what I wanted. I finally figured out how it works. Thanks again for all the help!! This is the code I am using, in case the next person to come along finds it useful;
[D,S,R] = xlsread('ExampleArray.xls');
Z = D(2:end,2:end);
M = max(max(Z));
figure(1)
X = D(1,2:end);
Y = D(2:end,1);
x1 = min(X);
x2 = max(X);
y1 = min(Y);
y2 = max(Y);
surf(X,Y,Z)
axis manual
xlim([x1 x2])
ylim([y1 y2])
colormap parula
shading interp
colorbar
caxis([0 M])
%view(2)

uncommenting the view(2) makes a nice psuedo 3D view
As always, my pleasure!
추가 답변 (0개)
카테고리
도움말 센터 및 File Exchange에서 Color and Styling에 대해 자세히 알아보기
참고 항목
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!웹사이트 선택
번역된 콘텐츠를 보고 지역별 이벤트와 혜택을 살펴보려면 웹사이트를 선택하십시오. 현재 계신 지역에 따라 다음 웹사이트를 권장합니다:
또한 다음 목록에서 웹사이트를 선택하실 수도 있습니다.
사이트 성능 최적화 방법
최고의 사이트 성능을 위해 중국 사이트(중국어 또는 영어)를 선택하십시오. 현재 계신 지역에서는 다른 국가의 MathWorks 사이트 방문이 최적화되지 않았습니다.
미주
- América Latina (Español)
- Canada (English)
- United States (English)
유럽
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
