<写在前面>
关于台风轨迹图,这次由于作业需要就画了一幅轨迹图,参考原图选自论文:

LIU Zenghong, XU Jianping, SUN Chaohui, WU Xiaofen. An upper ocean response to Typhoon Bolaven analyzed with Argo profiling floats [J]. Acta Oceanol. Sin., 2014, 33(11), 90–101

大家有兴趣可以自行查找论文进行阅读,本文所绘制台风轨迹图选取论文中的Bolaven(1215号)台风,台风数据采自JMA(由于本人还在学习中,论文中Unisys weather information system尚不会使用,望了解unisys weather的伙伴有时间可以指导,在此感谢>-<),argo浮标数据则主要来源于中国Argo实时资料中心的相关数据;
如有错误还望批评指正!


<图像一览>


1 关于台风轨迹绘制

台风轨迹的绘制可以通过m_patch或者m_line等命令进行绘制;

1.1 m_patch

以下是m_patch绘制的简单示范图:

在使用m_patch的时候需要注意lat的最后一个值需要是NaN,不然得到的图像将会是一片阴影覆盖部分

m_proj('mercator','lat',[15,30],'lon',[120,150]);
m_coast('patch',[.7 .7 .7],'edgecolor','none');
m_grid('linestyle',':','box','fancy','tickdir','out','linecolor','w',...
'alpah','0.5','ytick',[15:5:30],'xtick',[120:5:150]);
lat(end)=NaN; %就是这句,一定要设置NaN,否则图像是面,而非线!
m_patch(lontc,lattc,'k');

在patch命令中可以直接设置线条为渐变颜色,但是在m_patch中,可能是由于命令要求不同,在mmap文件m_patch.m中注释要求颜色设置需要是字符或者1x3 RGB数组,因此个人在设置渐变时失败,大家也可以各自尝试一下,共享经验!
命令行输入openExample(‘graphics/CreateMulticoloredLineExample’)就可以调用运行matlab中patch设置渐变线条的示例,以下是示例结果:

1.2 m_line

最后在<图像一览>中呈现的图就是用m_line绘制的了,这里需要注意的是,m_line是绘制线条,两点确定一条直线,本人一开始没有意识到这一点,最后得到的结果不连续。

f1 = figure(1);
m_proj('mercator','lat',[15,30],'lon',[120,150]);
m_coast('patch',[.7 .7 .7],'edgecolor','none');
m_grid('linestyle',':','box','fancy','tickdir','out','linecolor','w',...
'alpah','0.5','ytick',[15:5:30],'xtick',[120:5:150]); colormap(m_colmap('jet',41));
colorbar;
caxis([15,55]);
cmap = colormap(f1); n = length(lontc);
for i = 1:n
if (isnan(ws(i))==1)
ci = cmap(1,:);
else
ci = cmap(ws(i)-14,:);
end hold on
if (i == 1)
m_line(lontc(1:2),lattc(1:2),'Color',ci,'linewidth',4);
else
m_line(lontc(i-1:i),lattc(i-1:i),'Color',ci,'linewidth',4);
end
end
....然后是一些图像注释等代码(此处省略)

这里大致分析一下代码内容:

  1. m_proj,coast,grid进行基本投影海岸等设置
  2. 选取想要应用的colorbar并设置想要的范围并返回得相应的cmap,这里要注意,本人在设置时候colormap(m_colmap(‘jet’,41)),这样得到的cmap恰好是41x3 RGB矩阵,恰好caxis为[15,55],并以1为步长时的数组大小为41,这样从15到55,方便每个整数对应一个1x3 RGB矩阵
  3. ci就是根据具体风速所提取的RGB矩阵,再通过for循环,对m_line进行拼接,这里m_line每两点画一个,颜色ci为相应速度大小在colorbar中对应的RGB,然后画n次
  4. 注意事项:m_line需要是两点才能防止间断,ci是相应最大风速大小根据colorbar返回的颜色

2 关于argo位置的标记

argo位置标记直接使用m_plot即可,此处不作赘述

3 关于colbar颜色返回值

在1.2中有应用到colorbar某特定数值的RGB返回,这里再次进行总结

  1. colormap jet(n),表示设置颜色数为n,类型为jet的colormap,该colormap是由nx3的RGB矩阵构成的,jet可以替换成自己喜欢的colormap类型
  2. cmap = colormap;可以返回该colormap的cmap值,若有多个坐标区域,注意要标明在哪个坐标区域
  3. caxis可以设置colorbar对应的燕娥范围,如<图像一览>中采用的是15~55,那对应1中n的设置最好是(55-15+1)的整倍数
  4. 根据相应的大小提取RGB数组,如要选择风速为20时候colorbar对应的RGB数组,ci=cmap((20-14),:)
  5. 通用公式:已设置colormap颜色数n,caxis范围[a1,a2],当数值为A时的RGB为:ci=cmap((A-a1+1)*(n/(a2-a1+1)),:)

-------**注意上述通用公式只是一个总结,不一定完全适用于所有的情况,在使用过程中要抓住两个要点,① colormap不是完全连续的,colormap(n),是把颜色谱分成n段;②提取colormap后,根据自己的选出的值会落在那个段中决定,然后选择相应的顺序。**[修正于2019/04/29]

matlab画台风轨迹图小tip的更多相关文章

  1. matlab 画二维图与三维图

    二维图 ezplot('sin(x)');%默认范围 ezplot('sin(x)',[-4 4]);%自己设定范围 三维图 ezmesh('x*x+y*y');%默认范围

  2. matlab画甘特图

    近期为发小论文一直在研究作业调度问题,好不easy把数据搞出来了,结果又被画甘特图给难住了,查了各种资料.anygantt,highchart.Jfree chart等都试了,效果都不咋好.无意中留意 ...

  3. 用matlab画两个曲面的图

    求助!!用matlab画两个曲面的图 这是我写的程序,但是运行不出来,麻烦帮我修改一下,谢谢!!clearallcloseall[x,y]=meshgrid(0:.1:60);z1=(25*y-25* ...

  4. 使用Java、Matlab画多边形闭合折线图

    由于写论文要将“哈密顿回路问题(TSP)”的求解中间结果表示出来,查了一下使用程序画多边形图形.现在在总结一下,这个图是“由给定节点首尾相连的”闭合多边形. 1.使用matlab作闭合多边形图 没有找 ...

  5. Matlab plotyy画双纵坐标图实例

    Matlab plotyy画双纵坐标图实例 x = 0:0.01:20;y1 = 200*exp(-0.05*x).*sin(x);y2 = 0.8*exp(-0.5*x).*sin(10*x);[A ...

  6. Matlab——图形绘制——三维立体图形 剔透玲珑球 动态图——彗星状轨迹图

    三维绘图函数 三维绘制工具 函数view 实例:三维螺旋线 >> t=:pi/:*pi; plot3(sin(t),cos(t),t) grid %添加网格  plot3可以画出空间中的曲 ...

  7. matlab画柱状图

    论文中需要画图进行比较,感觉还是matlab画起来比较方便,先把自己画的图及matlab代码放上. y=[300 311;390 425; 312 321; 250 185; 550 535; 420 ...

  8. matlab画图形函数 semilogx

    matlab画图形函数 semilogx loglog 主要是学习semilogx函数,其中常用的是semilogy函数,即后标为x的是在x轴取对数,为y的是y轴坐标取对数.loglog是x y轴都取 ...

  9. 使用python绘制根轨迹图

    最近在学自动控制原理,发现根轨迹这一张全是绘图的,然而书上教的全是使用matlab进行计算机辅助绘图.但国内对于使用python进行这种绘图的资料基本没有,后来发现python-control包已经将 ...

随机推荐

  1. MS SQL 全局临时表的删除

    本来已经搜索到怎么删除了 如下: IF OBJECT_ID( 'tempdb..##TEMP_COPTD') IS NOT NULL Begin DROP TABLE ##TEMP_COPTD End ...

  2. jq常用

    1.文本框.密码框.隐藏域.文本域(id换成对应的,value属性存在,才能利用attr(‘value’) 获取值,否则返回undefined): 1.1 获取—>$(“#text”).val( ...

  3. WEB学习笔记9-添加必要的<meta>标签

    <meta>标签放置在HTML页面的head中,主要用于标示网站.其中主要包含网站的一些描述信息,如简介,作者等.这些信息有助于搜索引擎更准确地识别网页的内容,也有助于第三方工具抓取网站基 ...

  4. 纯粹的python绑定

    目前很多学习资料这样解释赋值与绑定,当是一个简单变量时,是赋值,当是复合变量时,是绑定. 注:赋值是重新复制变量到新变量中,赋值前后两个变量之间无联系.例C语言中: int a=6: int b: b ...

  5. numpy鸢尾花

    import numpy from sklearn.datasets import load_iris #从sklearn包自带的数据集中读出鸢尾花数据集data iris_data = load_i ...

  6. 第四次SCRUM任务

    一.第四次SCRUM任务 继第三次的任务之后,对最终的部署做一定的完善,以及系统的BUG调试,压力测试,会议明确最终的方案. 二.用户故事 1.用户可以进行输入用户名密码登录和注册. 2.用户可以在程 ...

  7. PL/SQL连接远程服务器数据库,出现ORA-12154: TNS: 无法解析指定的连接标识符。

    故障环境:上礼拜新装了一台服务器(win server2008r2),并在服务器上安装了ORACLE 11g database.且已经做好监听配置,开通了1521端口. 我又在局域网内另一台pc端装了 ...

  8. 14. Encryption tools (加密工具 8个)

    SSH(Secure Shell)现在是无处不在的程序,用于在远程机器上登录或执行命令. 它通过不安全的网络在两个不受信任的主机之间提供安全的加密通信,取代了可怕的不安全的telnet / rlogi ...

  9. Python实例之抓取HTML中的数据并保存为TXT

    本实例实现了抓取捧腹网中存储于html中的笑话数据(非JSON数据) 通过浏览器相关工具发现捧腹网笑话页面的数据存储在HTML页面而非json数据中,因此可以直接使用soup.select()方法来抓 ...

  10. ANSYS中的阻尼damper

    详情请见链接: ANSYS中的阻尼 ANSYS动力学分析中的阻尼