数学建模社区-数学中国
标题:
matlab 画等温线
[打印本页]
作者:
2744557306
时间:
2023-11-12 11:13
标题:
matlab 画等温线
解析代码:
clear; close all;
复制代码
这两行清空MATLAB的工作区,并关闭所有图形窗口。
fphn=fopen('hunan.txt','r');
+ h/ c. W3 t# Z. F8 M( i
& T& I$ R5 \( P: X) r" z$ o
hnb=fgetl(fphn);
$ @, I% M. U) ]' Y& K1 {
5 a2 s @3 R; q; |7 _. ~
hnmap=fscanf(fphn,'%f %f',[2,59]);
' Q+ ?6 J s& ^2 [- a
2 ?' G x: S; B2 n8 X0 F1 }
fclose(fphn);
复制代码
这部分打开名为 'hunan.txt' 的文件,读取文件中的湖南省的经纬度数据。fgetl 用于读取文件的第一行,而 fscanf 用于读取文件的剩余部分。hnmap 存储了湖南省59个位置的经纬度,每一列对应一个位置。文件的每一行应包含两个浮点数。
hnmap=hnmap';
2 `1 S) P$ i6 F. L. {4 e( {
" z! }$ O0 x: t2 y& f
xa=hnmap(:,[1]);
4 |. R% k: p a& i9 X! V
( I0 R+ V6 M6 K
ya=hnmap(:,[2]);
3 q/ `7 n! q( C
% D6 W' O( {6 I) j* J$ K
复制代码
这里对 hnmap 进行了转置,然后将经度和纬度分别存储在 xa 和 ya 中。
fp=fopen('LATLON57.txt','r');
( J" {4 w \0 V6 J# @' I& @' W
* R; I I2 k/ C
LL57=fscanf(fp,'%d %f %f',[3,97]);
# P5 S7 y3 J$ j4 W* `. u0 H2 Q
+ d- r' [" X8 X+ _
fclose(fp);
4 \/ V5 u1 ~) Y) y# _! n
0 j, ^/ D, y7 h0 q
复制代码
这部分打开名为 'LATLON57.txt' 的文件,读取文件中的湖南省97个县的编号和经纬度数据。LL57 存储了97个县的相关信息,每一列对应一个县。文件的每一行应包含一个整数和两个浮点数。
LL57=LL57';
5 U1 D4 q6 ]& i, u
l0 k6 `" J1 N; B" @5 v5 |' A
x=LL57(:,[3])/10;
: K, T# ?+ |( m+ E9 s
/ {* j2 J" a k( I; v
y=LL57(:,[2])/10;
复制代码
这里对 LL57 进行了转置,然后将经度和纬度分别存储在 x 和 y 中。在这里,经度和纬度都除以10,可能是由于数据单位不同而进行的缩放。
fpy=fopen('etw00100.txt','r');
/ L% y2 `; }+ L+ Y
7 F+ e+ R; B) R& ^
ymd57=fscanf(fpy,'%d',[3,1]);
# @ D; s1 `- |) t. p2 F, q
& X% b# [! T# J5 q7 Y# z. q
yu97=fscanf(fpy,'%d %f %f',[3,97]);
$ D- P; O3 y5 c# t
/ @4 T8 w- D% @% W3 |9 ~
fclose(fpy);
复制代码
这部分打开名为 'etw00100.txt' 的文件,读取文件中的湖南省97个县的温度数据。yu97 存储了97个县的温度信息,每一列对应一个县。文件的每一行应包含一个整数和两个浮点数。
yu97=yu97';
; b) G; u: [' `
Q# R, ?- M! B# J( Y4 J- y: P0 b
z=yu97(:,[2]);
复制代码
这里对 yu97 进行了转置,然后将温度数据存储在 z 中。
hold on;
% I8 i! ^6 q3 N3 V, t) x8 U# Q
5 K6 x9 H% n4 }/ U
plot(xa,ya,'.','markersize',5,'color','red');
复制代码
这部分开始绘制图形,用红色的小点表示湖南省的边界。
plot(x,y,'.','markersize',6);
复制代码
这部分继续绘制图形,用蓝色的小点表示湖南省97个县的位置。
[xi,yi]=meshgrid(linspace(min(x),max(x),25),linspace(min(y),max(y),25));
" u- U1 V# a0 O
$ z. ]: ~6 Y& P' j) f$ N0 {5 X, Z. N- |
zi=griddata(x,y,z,xi,yi,'cubic');
% w$ ~4 A \0 z
. L, D+ {5 z, Y
复制代码
这里创建了一个网格,然后使用 griddata 进行三维数据插值,得到 zi 表示的湖南省97个县的温度分布。linspace 用于生成指定范围内的等间隔数据。
hold on;
3 C7 s0 ?, ?, x% U4 S1 y
9 ]6 X* b) v2 [; K) g$ C5 ~
[c,h]=contour(xi,yi,zi,'b-');
复制代码
这部分绘制等值线图,表示湖南省97个县的温度等值线。contour 用于画等值线,xi 和 yi 是插值后的网格,zi 是温度数据,'b-' 表示蓝色实线。
clabel(c,h);
2 K7 s! {% Q1 l( ?
7 Q3 l7 c3 g" \0 a
hold off;
复制代码
这里用于在等值线上标注温度值,然后通过 hold off 结束图形的绘制。
; A/ J/ [% E3 G
请注意,代码中有一个拼写错误,i 应该是 ;,即 hold off;i 应该为 hold off;。
6 |3 H/ l" l/ ] |
% P( V# P- e9 v! G
) m4 z0 {) v4 F" | ^/ @
最后结果图如下:
3 E" r+ O2 B2 F
2023-11-12 11:12 上传
下载附件
(182.96 KB)
# F$ s" r& _3 V% Z: H
) F; O) Q- F8 G; V! }2 g
具体附件代码如下:
3 @8 N& k) i5 r& h$ W1 T1 E! C3 J
8 W+ P' M1 Q0 s* n2 {/ l
" e) ~$ Q; N9 m
7 C3 W8 K2 m/ n, A
6 y( w# v5 R, e' |9 j9 y8 X
0 ~3 r, t5 D# l0 p% L2 [
画等温线.rar
2023-11-12 11:13 上传
点击文件名下载附件
下载积分: 体力 -2 点
4.09 KB, 下载次数: 0, 下载积分: 体力 -2 点
售价:
2 点体力
[
记录
] [
购买
]
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5