利用Argo数据分别计算温度、盐度和温盐所造成的比容海平面变化

本文所用到的温盐数据集:IPRC(美国夏威夷大学国际太平洋研究中心)

Argo data products | Argo (ucsd.edu)icon-default.png?t=N7T8https://argo.ucsd.edu/data/argo-data-products/

理论知识(相关计算公式):

代码和工具包准备

参照论文 Kuo, Y.-N., Lo, M.-H., Liang, Y.-C.,Tseng, Y.-H., & Hsu, C.-W. (2021). Terrestrial water storage anomalies emphasize interannual variations in global mean sea level during 1997–1998 and 2015–2016 El Niño events. Geophysical Research Letters, 48, e2021GL094104. https://doi.org/10.1029/2021GL094104和下面博文 计算由于海洋温度和盐度变化产生的比容海平面变化-CSDN博客中的详细描述,需下载计算海底压力、海水密度以及其他有关海水信息的“seawater”代码包,还需下载Yan-Ning Kuo编写的用于计算比容海平面变化的代码包(“steric_height_calculation.m”)

①Seawater: https://github.com/ashao/matlab/tree/master/external/seawatericon-default.png?t=N7T8https://github.com/ashao/matlab/tree/master/external/seawater

②  steric_height_calculation: ynkuo/TWS_emphysize_GMSL_difference_in_9798_1516_ElNino_paper_codes: v1.0.0 (zenodo.org)icon-default.png?t=N7T8https://zenodo.org/records/5144491

下面重点以IPRC数据集为例,分别计算由温度、盐度和温盐度造成的比热容变化

1、首先展示steric_height_calculation.m计算比容海平面变化的核心代码:

按照上述盐容和热容海平面变化的计算公式,计算热容时,保持盐度为平均盐度不变;同理,计算盐容时,保持温度为平均温度不变;故得到如下热容和盐容的求解代码:

%% ii 取值为 1:热容  2:盐容  3:比容
rho = zeros(length(lon),length(lat),length(depth),time_step);
salinity_0(:,:,:,1)=mean(salinity,4,'omitnan');temperature_0(:,:,:,1)=mean(temperature,4,'omitnan');
for t = 1:time_stepfor k = 1:length(depth)for j=1:length(lat)if ii==1rho(:,j,k,t)=sw_dens(salinity_0(:,j,k,1),temperature(:,j,k,t)-273.15,pressure(j,k));elseif ii==2rho(:,j,k,t)=sw_dens(salinity(:,j,k,t),temperature_0(:,j,k,1)-273.15,pressure(j,k));elserho(:,j,k,t)=sw_dens(salinity(:,j,k,t),temperature(:,j,k,t)-273.15,pressure(j,k)); %[kg/m^3]endendend
end

2、值得注意的是

① IPRC和SIO的温度单位均为摄氏度,EN4为开尔文;所以在计算前两者比容变化时,不需要再对温度进行单位转换。即下面三项不需要减去273.15。

② 虽然SIO 给出变量名为“压强/压力”的变量信息,但建议还是利用sw_pres函数将其转换为某深度处的压力大小。

 3、读取IPRC温盐数据,并绘制比容海平面变化全球趋势图与盐容、热容以及比容在太平洋某处的时间序列图

% read data
clear;
addpath E:\Data\Temp_sal\Argo;
addpath E:\Data\Temp_sal\Argo\function;
full_path = 'E:\Data\Temp_sal\Argo\IPRC\argo_2005-2020_grd.nc\argo_2005-2020_grd.nc';
info_IPRC = ncinfo(full_path);
TEMP=ncread(full_path,'TEMP');
SLAT=ncread(full_path,'SALT');
dep=ncread(full_path,'LEVEL'); 
lat=ncread(full_path,'LATITUDE');
lon=ncread(full_path,'LONGITUDE');%  cal sterictime_step = length(squeeze(TEMP(1,1,1,:)));type = {'_T';'_S';'_'};%%最后一位数字 1:热容  2:盐容  3:比容ticfor i=1:3[steric_height] = steric_height_calculation(TEMP,SLAT,dep,lat,lon,time_step,i);steric_height_avg=mean(steric_height,3);for ii=1:time_steptemp(:,:)=steric_height(:,:,ii);SH(:,:,ii)=flipud((temp-steric_height_avg)');endeval(['SH' type{i,1} '=SH;']);endtocFileNameTime05={'2005-01','2005-02','2005-03','2005-04','2005-05','2005-06','2005-07','2005-08','2005-09','2005-10','2005-11','2005-12'};
FileNameTime06={'2006-01','2006-02','2006-03','2006-04','2006-05','2006-06','2006-07','2006-08','2006-09','2006-10','2006-11','2006-12'};
FileNameTime07={'2007-01','2007-02','2007-03','2007-04','2007-05','2007-06','2007-07','2007-08','2007-09','2007-10','2007-11','2007-12'};
FileNameTime08={'2008-01','2008-02','2008-03','2008-04','2008-05','2008-06','2008-07','2008-08','2008-09','2008-10','2008-11','2008-12'};
FileNameTime09={'2009-01','2009-02','2009-03','2009-04','2009-05','2009-06','2009-07','2009-08','2009-09','2009-10','2009-11','2009-12'};
FileNameTime10={'2010-01','2010-02','2010-03','2010-04','2010-05','2010-06','2010-07','2010-08','2010-09','2010-10','2010-11','2010-12'};
FileNameTime11={'2011-01','2011-02','2011-03','2011-04','2011-05','2011-06','2011-07','2011-08','2011-09','2011-10','2011-11','2011-12'};
FileNameTime12={'2012-01','2012-02','2012-03','2012-04','2012-05','2012-06','2012-07','2012-08','2012-09','2012-10','2012-11','2012-12'};
FileNameTime13={'2013-01','2013-02','2013-03','2013-04','2013-05','2013-06','2013-07','2013-08','2013-09','2013-10','2013-11','2013-12'};
FileNameTime14={'2014-01','2014-02','2014-03','2014-04','2014-05','2014-06','2014-07','2014-08','2014-09','2014-10','2014-11','2014-12'};
FileNameTime15={'2015-01','2015-02','2015-03','2015-04','2015-05','2015-06','2015-07','2015-08','2015-09','2015-10','2015-11','2015-12'};
FileNameTime16={'2016-01','2016-02','2016-03','2016-04','2016-05','2016-06','2016-07','2016-08','2016-09','2016-10','2016-11','2016-12'};
FileNameTime17={'2017-01','2017-02','2017-03','2017-04','2017-05','2017-06','2017-07','2017-08','2017-09','2017-10','2017-11','2017-12'};
FileNameTime18={'2018-01','2018-02','2018-03','2018-04','2018-05','2018-06','2018-07','2018-08','2018-09','2018-10','2018-11','2018-12'};
FileNameTime19={'2019-01','2019-02','2019-03','2019-04','2019-05','2019-06','2019-07','2019-08','2019-09','2019-10','2019-11','2019-12'};
FileNameTime20={'2020-01','2020-02','2020-03','2020-04'};FileNameTime=[FileNameTime05,FileNameTime06,FileNameTime07,FileNameTime08,FileNameTime09,FileNameTime10,...FileNameTime11,FileNameTime12,FileNameTime13,FileNameTime14,FileNameTime15,FileNameTime16,FileNameTime17,...FileNameTime18,FileNameTime19,FileNameTime20];num_file=size(FileNameTime,2);
FileNameTimeChar=char(FileNameTime);
int_year=zeros(num_file,1);int_month=zeros(num_file,1);
for i=1:num_fileint_year(i)=str2double(FileNameTimeChar(i,1:4));int_month(i)=str2double(FileNameTimeChar(i,6:7));
end
time=int_year+(int_month-0.5)/12;[ Amp_T, ~, ~, ~,  ~,  ~,  ~,  ~, Trend_T] = gmt_harmonic(time,[],SH_T);
[ Amp_S, ~, ~, ~,  ~,  ~,  ~,  ~, Trend_S] = gmt_harmonic(time,[],SH_S);
[ Amp_, ~, ~, ~,  ~,  ~,  ~,  ~, Trend_] = gmt_harmonic(time,[],SH_);% time series
mask='E:\Data\Basin\Pacific_rectangle.vec';  rows=5;
Amp_T_serie=gmt_grid2serie(Amp_T,mask,'line',rows);
Amp_S_serie=gmt_grid2serie(Amp_S,mask,'line',rows);
Amp_serie=gmt_grid2serie(Amp_,mask,'line',rows);Tre_T_serie=gmt_grid2serie(Trend_T,mask,'line',rows);
Tre_S_serie=gmt_grid2serie(Trend_S,mask,'line',rows);
Tre_serie=gmt_grid2serie(Trend_,mask,'line',rows);SH_T_serie=gmt_grid2serie(SH_T,mask,'line',rows);
SH_S_serie=gmt_grid2serie(SH_S,mask,'line',rows);
SH_serie=gmt_grid2serie(SH_,mask,'line',rows);close all;
grid_1=SH(:,:,10);
gmt_grid2map(Trend_.*1000,-10,10,1,0,'mm/year',['Trend IPRC'],20);close all;plot(time,SH_T_serie,'r','Linewidth',1);hold on; %% mmplot(time,SH_S_serie,'g','Linewidth',1);plot(time,SH_serie,'--','color',[0 0 1],'Linewidth',1);
l1=legend('热容','盐容','比热容');
set(l1,'box','off',"FontSize",10);
function [steric_height] = steric_height_calculation(temperature,salinity,depth,lat,lon,time_step,ii)
%--------------------------------------------------------------
%% ii 1:热容、2:盐容、3:比容% This function is used to calculate the steric height.
% Note that the SEAWATER linrary version 3.2 by Lindsay Pender is 
% used in the code. 
%--------------------------------------------------------------
% input:
%  temperature(lon,lat,depth,time): temperature, unit: degree C
%  salinity(lon,lat,depth,time): salinity, unit: psu (PSS-78)
%  depth: depth of the ocean layer, unit: m
%  lat: latitude
%  lon: longitude
%  time_step: the number of time step of temperature/salinity 
%             ***  time_step = length(squeeze(temperature(1,1,1,:)))
%--------------------------------------------------------------
% output:
%  steric_height(lon,lat,time): steric height
%--------------------------------------------------------------
addpath E:\Data\Temp_sal\matlab-master\matlab-master\external\seawater;
% calculate pressure from depth
pressure = zeros(length(depth),length(lat));
for k=1:length(depth)for j=1:length(lat)pressure(k,j)=sw_pres(depth(k),lat(j));%[db]end
end
pressure=pressure';
clear k j
rho = zeros(length(lon),length(lat),length(depth),time_step);
salinity_0(:,:,:,1)=mean(salinity,4,'omitnan');temperature_0(:,:,:,1)=mean(temperature,4,'omitnan');
for t = 1:time_stepfor k = 1:length(depth)for j=1:length(lat)if ii==1rho(:,j,k,t)=sw_dens(salinity_0(:,j,k,1),temperature(:,j,k,t),pressure(j,k));elseif ii==2rho(:,j,k,t)=sw_dens(salinity(:,j,k,t),temperature_0(:,j,k,1),pressure(j,k));elserho(:,j,k,t)=sw_dens(salinity(:,j,k,t),temperature(:,j,k,t),pressure(j,k)); %[kg/m^3]endendend
end
DEPTH = repmat(depth',length(lat),1);
steric_height = NaN(length(lon),length(lat),time_step);rhobar = mean(rho,4,'omitnan'); % time-meaned rho%%时间域均值
rho0_dep = squeeze(mean(mean(rhobar,1,'omitnan'),2,'omitnan')); % rho0 of each depth%%求全球所有格网点的均值海水密度
dz =NaN(length(depth),1); 
dz(1) = abs(DEPTH(1,1)-0); 
dz(2:length(depth)) = abs(DEPTH(1,2:length(depth))-DEPTH(1,1:length(depth)-1));
DZ = NaN(length(lon),length(lat),length(depth)); rho0 = DZ;
for i = 1:length(lon)for j = 1:length(lat)DZ(i,j,:) = dz; %create DZ(lon,lat,depth) from dz(depth) %为全球格网赋值一样的深度rho0(i,j,:) = rho0_dep; % create rho0(lon,lat,depth) from rho0_dep(depth) %为全球格网赋值同样的海水密度end
endfor t = 1:time_stepsteric_height(:,:,t) = -sum(DZ.*((squeeze(rho(:,:,1:length(depth),t))-rhobar)./rho0),3,'omitnan');
%     disp(t)
end

如有任何问题,尽情批评指正!

PS:感谢“我是水怪的哥”博文的启发,还有引领我进入GRACE海洋研究的贵人,再次一并致谢!

参考文献:

① 2021 杨元元(博) 基于卫星重力、卫星测高和海洋温盐数据的海平面收支及深海冷暖研究

② 2021 Kuo Yan-Ning Terrestrial Water Storage Anomalies Emphasize Interannual Variations in Global Mean Sea Level During 1997–1998 and 2015–2016 El Niño Events

③ 2021 王奉伟(博) 基于卫星重力的质量海平面变化及其闭合度研究

④ 2022 李杨(硕) 联合时变重力数据和卫星测高数据反演地表质量迁移及全球海平面变化

⑤ 2013 江敏(博) 重海平面变化及其成因的空间大地测量监测与分析

⑥ 2012 文江汉 联合Argo浮标、卫星测高和GRACE数据研究海平面变化

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/660221.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

芒果超媒财报解读:科技加持下,如何蜕变为内容“全科生”?

在降本增效和内容为王的基调下,国内头部长视频平台正在拥抱增长。 爱奇艺率先公布2023年财务数据,实现归母净利润19.25亿元,与2022年亏损1.36亿元相比,扭亏为盈且增幅显著。 而近日,随着新一季《浪姐》播出&#xff…

git 的迁移

现象是gitlab经常会挂掉,linux会显示磁盘空间不足,实际上,我们linux某个目录的空间是4T。这个空间应该是足够的。猜测是gitlab的安装目录不对导致的空间不足。 1、查找原因 用rpm 安装gitlab会有自己的目录,很多安装文件会在opt…

如何更好的使用cpm

nvidia发布了RAFT库,支持向量数据库的底层计算优化,RAFT 也使用CMake Package Manager( CPM )和rapids-cmake管理项目,可以方便快捷的下载到需要的对应版本的thirdparty的依赖库,但是,一般情况下,项目是直接…

nacos(docker部署)+springboot集成

文章目录 说明零nacos容器部署初始化配置高级配置部分访问权限控制命名空间设置新建配置文件 springboot配置nacos添加依赖编写测试controller 说明 nacos容器部署采用1Panel运维面板,进行部署操作,简化操作注意提前安装好1Panel和配置完成docker镜像加…

(三十二)第 5 章 数组和广义表(稀疏矩阵的十字链表存储表示实现)

1. 背景说明 2. 示例代码 1) errorRecord.h // 记录错误宏定义头文件#ifndef ERROR_RECORD_H #define ERROR_RECORD_H#include <stdio.h> #include <string.h> #include <stdint.h>// 从文件路径中提取文件名 #define FILE_NAME(X) strrchr(X, \\) ? strrch…

Linux - nohup 后台启动命令

目录 1. nohup启动 2. nohup与&&#xff0c;后台运行 3. nohup与>&#xff0c;日志重定向 4. nohup后台启动-综合使用(推荐) 5. 文件描述符-0 1 2 6. 知识扩展 6.1 不停止服务&#xff0c;直接清空nohup.out 6.2 只记录警告级别比较高的日志 6.3 不想输出日志 …

C#调用skiasharp操作并绘制图片

之前学习ViewFaceCore时采用Panel控件和GDI将图片及识别出的人脸方框和关键点绘制出来&#xff0c;本文将其修改为基于SKControl和SKCanvas实现相同的显示效果并支持保存为本地图片。   新建Winform项目&#xff0c;在Nuget包管理器中搜索并安装一下SkiaSharp和ViewFaceCore…

Centos 7 安装 Redis

Centos 7 安装 Redis 安装步骤1、安装软件源2、安装redis3、创建符号链接4、修改配置文件5、启动 redis6、停止redis 安装步骤 1、安装软件源 如果是Centos 8 直接yum install 就可以了 yum install -y redis但是如果是Centos 7&#xff0c;redis 默认的是 redis 3 系列&…

大数据技术就业和发展前景怎么样

大数据技术的就业和发展前景极为乐观&#xff0c;具有行业需求旺盛、就业多样性、可持续发展潜力等特点&#xff0c; 上大学网 &#xff08;www.sdaxue.com&#xff09;整理出了大数据技术的就业和发展前景以下几个关键趋势&#xff0c;供大家参考&#xff01; 行业需求旺盛&…

数据驱动,敏捷前行|MongoDB线下技术沙龙-杭州站活动

扫描海报中二维码或点击阅读原文&#xff0c;报名参加阿里云MongoDB在5月11日杭州举办的【数据驱动&#xff0c;敏捷前行——MongoDB企业开发加速器】线下沙龙活动&#xff0c;与MongoDB专家以及其他游戏行业同行一起探讨轻松获得游戏数据库高可用性和弹性的方法&#xff01; 在…

Eclipse MAT工具分析内存溢出

1、通过dominator_tree可以查看哪些对象大 可以看到com.codex.terry.entity.User对象有57万个 2、打开thread_overview查看内存溢出的代码

微服务之SpringCloud AlibabaSeata处理分布式事务

一、概述 1.1背景 一次业务操作需要跨多个数据源或需要跨多个系统进行远程调用&#xff0c;就会产生分布式事务问题 but 关系型数据库提供的能力是基于单机事务的&#xff0c;一旦遇到分布式事务场景&#xff0c;就需要通过更多其他技术手段来解决问题。 全局事务&#xff1a;…