- 积分
- 6974
- 贡献
-
- 精华
- 在线时间
- 小时
- 注册时间
- 2013-1-1
- 最后登录
- 1970-1-1
|
登录后查看更多精彩内容~
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
本帖最后由 言深深 于 2014-9-12 10:47 编辑
众所周知,清风大侠各种编程,软件设计能力都很出色,为气象家园的建设发展做出了不可磨灭的贡献。每一次看清风的帖子,我都能学到不少东西。再次,真诚致谢!!!
因为项目研究需要,必须将中国范围以外的数据设置成undef,然后才能进行下一步工作。于是乎,本人遍历了家园中fortran和grads下的大部分帖子,找到了清风的帖子:fortran提取任意区域内的点,可用来生成GrADS的mask文件。http://bbs.06climate.com/forum.p ... 18693&fromuid=21651
清风的程序中用到了一个子程序,很牛的,用来判断某个站点是否属于多边形区域内。看到这里,我觉得需要有更简单的方法作为替代。由于地形数据需要用MeteInfo生成,然后就拜读了传说中的谁的帖子:maskout方法的使用以及maskout文件制作
http://bbs.06climate.com/forum.php?mod=viewthread&tid=893&fromuid=21651
(出处: 气象家园),学会了生成地形文件。和传说中的谁一样,我将地形文件保存成为二进制格式。这样,保存的二进制文件中的所有为1的元素表示中国范围内,为-1的元素为中国范围外的。
接下来,我用fortran读入该地形文件以及所研究的数据,分别存放在数组china和array中。然后仅用一条语句就把中国范围以外的数据给屏蔽掉了:
WHERE ( china .EQ. -1 )
array = undef
ENDWHERE
看看俺的图吧
很简单吧!!!如果您也按照我的方法试成功了,请您点个赞 PS :: 我的mask文件china.dat的数据范围是从70-136,15-55°,分辨率为0.25°。如果您的数据分辨率为0.25°的整数倍,不想学习MeteInfo生成地形文件也可以。只要在fortran中度取数据后,每个几个数进行设置为undef就可以了。下面上传我的地形文件。
|
-
pcp
-
-
china.dat
166.66 KB, 下载次数: 52, 下载积分: 金钱 -5
mask
评分
-
查看全部评分
|