请选择 进入手机版 | 继续访问电脑版
爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 28374|回复: 6

[分享资料] Grads求偏导数问题

[复制链接]

新浪微博达人勋

发表于 2021-1-13 11:11:23 | 显示全部楼层 |阅读模式
20金钱
'define pi=3.1415926/180'      *pi即π,取值3.14
'define r=6.371e6'                 *r是地球半径
'define deqt=cdiff(eqt,y)'        *deqt是对eqt是指假相当位温,求cidff中央差分
'define dy=cdiff(lat,y)*pi*r'     *dy是对lat纬度,求cidff中央差分
'define eqt=-deqt/dy'             *求偏导数:-偏eqt/偏y


上述脚本中,计算结果,量级比实际大了10倍,有大神指导问题出在哪里吗?

密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2021-1-13 11:53:24 | 显示全部楼层
我觉得好像没有问题,大了10倍怎么判断的?
密码修改失败请联系微信:mofangbao
回复

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2021-1-13 16:05:26 | 显示全部楼层
river 发表于 2021-1-13 11:53
我觉得好像没有问题,大了10倍怎么判断的?

跟别人发表的文献对比发现的
密码修改失败请联系微信:mofangbao
回复

使用道具 举报

新浪微博达人勋

发表于 2021-1-13 17:39:55 | 显示全部楼层
额,以下两段复制自GrADS官网,
算相对涡度:
define dv = cdiff(v,x)
define dx = cdiff(lon,x)*3.1416/180
define du = cdiff(u*cos(lat*3.1416/180),y)
define dy = cdiff(lat,y)*3.1416/180
display (dv/dx-du/dy)/(6.37e6*cos(lat*3.1416/180))
算水平平流:
define dtx = cdiff(t,x)
define dty = cdiff(t,y)
define dx = cdiff(lon,x)*3.1416/180
define dy = cdiff(lat,y)*3.1416/180
display -1*( (u*dtx)/(cos(lat*3.1416/180)*dx) + v*dty/dy )/6.37e6
照着他们的写法,试试看?
密码修改失败请联系微信:mofangbao
回复

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2021-1-14 08:52:41 | 显示全部楼层
伽蓝鸟 发表于 2021-1-13 17:39
额,以下两段复制自GrADS官网,
算相对涡度:
define dv = cdiff(v,x)

是照着上面的写法来写的,反复确认了好多次,高值区分布都没问题,就是量级大了10倍左右
密码修改失败请联系微信:mofangbao
回复

使用道具 举报

新浪微博达人勋

发表于 2021-1-14 15:06:55 | 显示全部楼层
伽蓝鸟 发表于 2021-1-13 17:39
额,以下两段复制自GrADS官网,
算相对涡度:
define dv = cdiff(v,x)

官网上的这2种算法,试过,下边那个没问题。上边算相对涡度的这个,define du = cdiff(u*cos(lat*3.1416/180),y),这句换成define du = cdiff(u,y)*cos(lat*3.1416/180)就跟下边这种结果一样了,不知道为何?
密码修改失败请联系微信:mofangbao
回复

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2021-1-14 17:08:39 | 显示全部楼层
问题已经解决了,是最后乘数错了
密码修改失败请联系微信:mofangbao
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表