NetCDF

✍ dations ◷ 2024-12-23 14:31:11 #NetCDF

网络通用数据格式(英语:Network Common Data Form,NetCDF)是一种自描述、与机器无关、基于数组的科学数据格式,同时也是支持创建、访问和共享这一数据格式的函数库。该项目主页位于美国大气科学研究大学联盟(UCAR)的Unidata规划网站。它也是netCDF软件、标准开发、更新等的主要来源。NetCDF格式是一种开放标准。NetCDF的经典格式和64位偏移量格式是开放地理空间协会采用的国际标准。

该项目开始于1989年,UCAR目前对其积极支持,在新发行版中改进性能、增加功能并修正缺陷,当前版本系列是netCDF-4,在编译时也可以选择只建造netCDF-3库。

1985年美国国家航空航天局(NASA)的国家空间科学数据中心(NSSDC)设计并开发了通用数据格式(CDF),CDF最初是用FORTRAN写成并只能在VAX/VMS环境下获得。Unidata在1987年8月成立了关于CDF的工作组,提议探索与NASA协作扩展CDF的FORTRAN接口,定义C接口,并允许用一个单一调用访问数据聚集,同时要维持与现存NASA接口兼容的可能性。在1988年早些时候,Unidata的Glenn Davis用C开发了原型netCDF包,它位于网络表示层XDR格式的上层。这个原型证明了CDF接口的基于XDR的一个单一文件实现可以在可接受代价下完成,而结果的程序可以在UNIX和VMS系统二者上实现。但这也说明了提供一个小的、可移植的、兼容于NASA CDF的有想要的通用性的FORTRAN接口是不实际的。NASA的CDF和Unidata的netCDF从此独立发展,但新近的CDF版本与netCDF共享了很多特征。

1991年Unidata发布了netCDF版本2.0,1997年发布了版本3.3。2003年7月美国能源部的阿贡国家实验室和西北大学贡献了叫做并行-NetCDF(或称PnetCDF)的一个netCDF并行计算扩展。2004年在NASA的资助下,Unidata与美国国家超级计算应用中心(NCSA)开始合作增进netCDF和HDF5的互操作性。2008年Unidata发布了版本4.0,允许使用HDF5数据文件格式。同时发布了版本3.6.3,它与版本4.0是同样的代码但关掉了netcdf-4特征,目前netCDF-3库仍然在世界各地被广泛使用。2010年Unidata发布了版本4.1.1,增加了对C和Fortran客户端通过OPeNDAP(英语:OPeNDAP)访问远程数据的特定子集的支持,并使用PnetCDF库支持在netCDF经典格式(CDF-1、CDF-2和2012年推出的CDF-5)上的并行I/O。

netCDF库支持netCDF文件的多种不同的二进制格式:

所有格式都是“自描述的”。 这意味其中有一个头部,它描述文件余下部分的格局,特别是数组数据,连同以名称/值特性形式的任意文件元数据。这个格式是跨平台的,涉及的问题如字节序在软件库中解决。数据以允许有效的构造子集的方式来存储。

起始于版本4.0,netCDF API允许使用HDF5数据格式。NetCDF用户可以创建HDF5文件从而获得netCDF格式不具备的利益,比如更大的文件和多重无限制的维度。

完全后向兼容,可访问旧有netCDF文件并支持以前版本的C和Fortran API。

netCDF常用于气候学、气象学和海洋学应用,如天气预报、气候变化;也用于地理信息系统应用,是很多GIS应用的输入/输出格式;并用于通用科学数据交换。从它的站点引述如下:netCDF(网络公用数据格式)是用于面向数组数据访问的一组接口,和针对C、Fortran、C++、Java和其他语言的一套自由发行的数据访问库。netCDF库支持用来表示科学数据的一种机器无关格式。接口、库和格式一起支持创建、访问和共享科学数据。

UCAR发布的软件库提供了对netCDF文件的读写访问,编码和解码所需的数组和元数据。核心库是用C编写的,并为 C、C++应用提供API,为Fortran应用提供两个API,一个给Fortran 77,一个给Fortran 90。Unidata还开发维护一个独立实现,使用100% Java写成,它扩展了核心数据模型并增加了额外的功能。还可获得其他语言的到基于C库的netCDF的接口,包括R(ncdf、ncvar和RNetCDF包)、Perl数据语言(英语:Perl Data Language)、Python、Ruby、Haskell、Mathematica、MATLAB、IDL和Octave。API调用规定在不同语言间非常类似,尽管有着不可避免的不同语法。版本2的API调用与版本3的调用相当不同,但出于后向兼容而被版本3和版本4支持。应用编程者使用受支持语言,在正常情况下不需要关心文件结构自身,即使它是作为开放格式而获得的。

现在已经写出了使用netCDF文件的范围广泛的应用程序。它们的范围从命令行实用程序到图形可视化包。下面列出其中一小部分,而更长的列表可见于UCAR网站列表:

气候和预报(CF)约定是对地球科学数据的元数据约定,意图用于促进处理和共享通过NetCDF应用编程接口(API)创建的文件。CF约定于2003年创建,普遍化并扩展了早期的协作海洋/大气研究数据服务(COARDS)约定和对气候数据的Gregory/Drach/Tett(GDT)约定。CF约定定义了与数据包含在同一个文件中的元数据,从而使得文件“自我描述”,提供对在每个变量中的数据表示的是什么的确切描述,和数据的空间的和时间的属性的确切描述,包括关于网格的信息,比如网格单元边界和单元平均方法。这使得能够使用来自不同来源的数据,确定哪些数据是可比较的,并允许建造有着强力的提取、重新插值和显示能力的应用。Unidata 在2007年至2011年开发了LibCF库。

并行-NetCDF扩展建造在MPI-IO之上,它是对MPI的I/O扩展。使用高层netCDF数据结构,并行-NetCDF库可以进行优化而在多处理器间高效分配文件读和写应用。并行-NetCDF包只可以读/写经典和64-bit偏移量格式。并行-NetCDF不能读或写在netCDF-4.0中可获得的基于HDF5的格式。并行-NetCDF包使用不同但类似的Fortran和C的API。

在Unidata netCDF库中自从版本4.0已经支持对HDF5数据文件的并行I/O。Unidata NetCDF C库自从版本4.1.1使用并行-NetCDF库支持对经典和64-bit偏移量文件的并行 I/O,但使用NetCDF API。

netCDF C库,和基于它的库:Fortran 77和Fortran 90、C++和所有第三方库,自从版本4.1.1开始可以读一些其他数据格式的数据。HDF5格式的数据可以读取,但有一些限制。使用HDF4科学数据(SD)API创建的HDF4格式的数据,可以用netCDF C库读取。

NetCDF-Java库目前已经能够读取很多文件格式和远程访问协议,并且正在开发对一些其他的格式的支持。因为这些都是通过NetCDF API透明的进行访问,NetCDF-Java库被称为实现了科学数据集的“通用数据模型”。

相关

  • 五指山国军示范公墓国军示范公墓(亦称五指山军人公墓或五指山国军示范公墓)位于中华民国新北市汐止区车坪寮山(五指山)山区,为中华民国国军所辖墓区。国军示范公墓之管理机构为“国防部后备指挥部国
  • 郝进礼郝进礼(1916年11月30日-2011年3月9日),圣名安德肋,天主教西湾子教区主教。郝进礼出生于1916年11月30日,1943年晋升司铎。1958年被捕,1981年获释,担任公会镇本堂神父。1984年9月14日
  • 刘仰峤刘仰峤(1913年11月2日-1980年10月16号),山西岢岚人,中国共产党干部,于1958年担任武汉大学党委书记,曾经制造了当时中国最典型的教育浮夸风和大跃进(教育革命时期)。
  • 波里斯·伊沙奎尔波里斯·伊沙奎尔 (西班牙语, Boris Rodolfo Izaguirre Lobo, 加拉加斯, 1965年9月29日-) 是一位委内瑞拉西班牙 男性作家 和 主持人。
  • 正义联盟正义联盟(英语:Justice League),有时则称为美国正义联盟(Justice League of America)或JLA,是DC漫画所推出的虚构超级英雄团体。正义联盟在漫画《勇敢和胆量》第28期首次出场,虽然《
  • 威廉·瓦丁顿威廉·亨利·瓦丁顿(William Henry Waddington,1826年12月11日-1894年1月13日),法国学者、外交家和政治家。他被温和共和派任命为法国总理,主要因为他为人谨慎和无甚政治倾向,这标
  • 2013年墨西哥周末票房冠军下列列表为2013年 墨西哥周末电影票房冠军。
  • 吴觉农吴觉农(1887年-1989年),原名荣堂,男,浙江上虞人,中华人民共和国茶叶专家。早年毕业于浙江省中等农业技术学校,后留学日本。1929年任浙江省建设厅合作事业管理室主任。1936年,担任中国
  • 2021年美国网球公开赛2021年美国网球公开赛(英语:2021 US Open)是由美国网球协会主办的一项在室外硬地球场举办的网球大满贯赛事,它于2021年8月30日到9月12日在美国纽约市美国网球协会比利·简·金网球中心进行。美国网球锦标赛的赛事类型包括单打、双打和混合双打,还包括青少年赛事和轮椅网球项目)。单打比赛有128名球员参加(包括16名资格赛选手),资格赛于8月24日到8月27日进行,这也是第141届美国网球公开赛。多米尼克·蒂姆和大坂直美分别是男单和女单的卫冕冠军,但蒂姆此前已宣布因伤退赛。现男子世界排名第一选手
  • 熊卓为之死熊卓为之死是北京大学的医学教授熊卓为在北京大学第一医院做了一个简单的骨科手术后,因为种种原因,而最终导致她在2006年1月31日死亡的严重医疗事故。在随后的调查中,其丈夫发现,妻子的主治大夫竟然都是没有行医资格的北京大学医学部的在校学生。随后记者在北大医院内发现,没有行医资格的北医在校生坐诊现象很普遍。这次事件是在事发四年后由中央电视台《经济半小时》栏目于2009年11月3日首次披露的。北京大学第一医院心血管研究所教授,澳籍华人熊卓为,于2006年1月23日因腰腿痛,入北大医院治疗,次日进行腰椎部骨科手术