使用gfortran将数据写成Grads格式的代码示例:

!-----'Fortran4Grads.f90'
program Fortran4Grads
implicit none
integer,parameter::xn=32 !-----经度(Longitude)网格数
integer,parameter::yn=18 !-----纬度(Latitude)网格数
integer,parameter::zn=7 !-----高度层数
integer,parameter::tn=5 !-----时间跨度20010101-20010105
integer,parameter::fileunit=8 !-----文件设备号
integer::x,y,z,v,t,irec !-----定义整型变量 !-----定义多维数组,保存变量
real(kind=4) :: u(xn,yn,zn,tn) !-----水平风速u
real(kind=4) :: w(xn,yn,zn,tn) !-----垂直风速w
real(kind=4) :: h(xn,yn,zn,tn) !-----相对湿度h
real(kind=4):: var !-----辅助变量
!-----数组赋值
do t=1,tn
do z=1,zn
do y=1,yn
do x=1,xn
u(x,y,z,t) = 10.0*sin(1.0*x+1.0*y)+1.0*z !-----水平风速u
w(x,y,z,t) = 10.0*cos(1.0*x+1.0*y)+1.0*z !-----垂直风速w
h(x,y,z,t) = 1.0/real(t)+1.0/real(x)+1.0/real(y) !-----相对湿度h
enddo
enddo
enddo
enddo
!-----将数据写入文件
open(fileunit,file='m.dat',form='unformatted',access='direct',recl=4)
!---在open语句中,gfortran编译real(kind=4)时,recl=4
irec = 1
do t=1,tn
!-----保存水平风速u
do z=1,zn
do y=1,yn
do x=1,xn
write(fileunit,rec=irec) u(x,y,z,t)
irec = irec + 1
enddo
enddo
enddo
!-----保存垂直风速w
do z=1,zn
do y=1,yn
do x=1,xn
write(fileunit,rec=irec) w(x,y,z,t)
irec = irec + 1
enddo
enddo
enddo
!-----保存相对湿度h
do z=1,zn
do y=1,yn
do x=1,xn
write(fileunit,rec=irec) h(x,y,z,t)
irec = irec + 1
enddo
enddo
enddo
enddo
close(fileunit)
write(*,*)'irec=xn*yn*zn*3*tn=',irec
end program Fortran4Grads

在grads中描述文件为:

dset ^m.dat
title "Write Data for GrADS Using Fortran"
undef 1e+40
xdef 32 linear -160.000000 10.000000
ydef 18 linear -90.000000 10.000000
zdef 7 levels 1000 850 700 500 300 200 100
tdef 5 linear 0Z2jan2001 1dy
vars 3
u 7 99 Eastward wind [m/s]
w 7 99 vertical wind [m/s]
h 7 99 relative humidity [%]
endvars

上面的Fortran语句保存数据时如果采用隐式Do循环,效率会高很多:

!-----'Fortran4Grads1.f90'
program Fortran4Grads1
implicit none
integer,parameter::xn=32 !-----经度(Longitude)网格数
integer,parameter::yn=18 !-----纬度(Latitude)网格数
integer,parameter::zn=7 !-----高度层数
integer,parameter::tn=5 !-----时间跨度20010101-20010105
integer,parameter::fileunit=8 !-----文件设备号
integer::x,y,z,v,t,irec !-----定义整型变量 !-----定义多维数组,保存变量
real(kind=4) :: u(xn,yn,zn,tn) !-----水平风速u
real(kind=4) :: w(xn,yn,zn,tn) !-----垂直风速w
real(kind=4) :: h(xn,yn,zn,tn) !-----相对湿度h
real(kind=4):: var !-----辅助变量
!-----数组赋值
do t=1,tn
do z=1,zn
do y=1,yn
do x=1,xn
u(x,y,z,t) = 10.0*sin(1.0*x+1.0*y)+1.0*z !-----水平风速u
w(x,y,z,t) = real(x+y+z) !-----垂直风速w
h(x,y,z,t) = 1.0/real(t)+1.0/real(x)+1.0/real(y) !-----相对湿度h
enddo
enddo
enddo
enddo
!-----将数据写入文件Grads
open(fileunit,file='m.dat',form='unformatted',access='direct',recl=xn*yn*zn*4)
!---在open语句中,gfortran编译real(kind=4)时,recl=4
irec = 1
do t=1,tn
!-----采用Do循环,保存水平风速u
write(fileunit,rec=irec) (((u(x,y,z,t),x=1,xn),y=1,yn),z=1,zn)
irec = irec + 1
!-----采用Do循环,保存垂直风速w
write(fileunit,rec=irec) (((w(x,y,z,t),x=1,xn),y=1,yn),z=1,zn)
irec = irec + 1
!-----采用Do循环,保存相对湿度h
write(fileunit,rec=irec) (((h(x,y,z,t),x=1,xn),y=1,yn),z=1,zn)
irec = irec + 1
enddo
close(fileunit)
write(*,*)'irec=3*tn=',irec
end program Fortran4Grads1

测试环境为centos X86-64,gcc 4.4.7

使用gfortran将数据写成Grads格式的代码示例的更多相关文章

  1. CAFFE学习笔记(四)将自己的jpg数据转成lmdb格式

    1 引言 1-1 以example_mnist为例,如何加载属于自己的测试集? 首先抛出一个问题:在example_mnist这个例子中,测试集是人家给好了的.那么如果我们想自己试着手写几个数字然后验 ...

  2. python2/3中 将base64数据写成图片,并将图片数据转为16进制数据的方法、bytes/string的区别

    1.python2将base64数据写成图片,并将数据转为16进制字符串的方法 import binascii img = u'R0lGODlhagAeAIcAAAAAAAAARAAAiAAAzABE ...

  3. 利用python将excel数据解析成json格式

    利用python将excel数据解析成json格式 转成json方便项目中用post请求推送数据自定义数据,也方便测试: import xlrdimport jsonimport requests d ...

  4. MFC编辑框接收数据动态更新与刷新方法代码示例-如何让编辑框内容实时更新

    MFC编辑框接收数据动态更新与刷新方法代码示例-如何让编辑框内容实时更新 关键代码: //发送数据通知 //from txwtech@163.com LRESULT CCommSampleDlg::O ...

  5. C++读写图片数据转成Base64格式

    转载:http://www.cnblogs.com/jeray/p/8746976.html 转载:https://www.cnblogs.com/lujin49/p/4957742.html 转载: ...

  6. 利用Ajax把前端的数据封装成JSON格式发送到服务器端并写成XML格式在服务器的硬盘上

    1.首先要在前端把要发送的东西(这里是一个实例化的car对象)都准备好,利用Ajax发送到服务器端,代码如下: <html xmlns="http://www.w3.org/1999/ ...

  7. flask框架下读取mysql数据 转换成json格式API

    研究了一天 因为需要从数据库拿数据然后转换成json的格式 expose出去为 API 发现一条数据是容易,两条以上我居然搞了这么久 好歹出来了 先贴一下 后面更新 mysql的操作 比较容易了htt ...

  8. C++读写图片数据转成Base64格式的一种方法

    最近在一个项目中要实现在客户端和服务端之间传送图片文件的功能,采用了C++语言读写图片转化成Base64格式进行传输.具体代码如下: //++Base64.h #pragma once class C ...

  9. C#中任意类型数据转成JSON格式

    /// <summary>    /// List转成json     /// </summary>    /// <typeparam name="T&quo ...

随机推荐

  1. hexo博客的优化与配置——加入统计代码

    今天看着csdn博客的訪客数,就想给hexo博客也加入统计訪客的插件,上次折腾了个pacman主题,中间自带的是goole的统计,easy被墙,所以就想换一个统计工具,看了好多人用的都是cnzz的站长 ...

  2. C++沉思录之三——设计容器类

    一.对容器的基本认识 总的来说,容器应该包含放在其中的对象的副本,而不是对象本身. 二.复制容器意味着什么? 通常将容器成为模板,而容器内的对象的类型就是模板参数.Container<T> ...

  3. Java基础知识强化39:StringBuffer类之StringBuffer的删除功能

    1. StringBuffer的删除功能: public StringBuffer  deleteCharAt(int index):删除指定位置的字符,并返回字符串缓冲区本身. public Str ...

  4. 设计模式2----建造者模式(builder pattern)

    定义:将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 类型:创建类模式 类图: UML图 四个要素 Builder: 抽象建造者ConcreteBuilder: 具体建造者 ...

  5. spark-sql

    本文用到的测试数据person.txt lijing 29 guodegang 45 heyunwei 30 yueyunpeng 100 rdd的分区数量,读取hdfs文件,默认是文件个数 rdd生 ...

  6. myEclipse笔记(1):优化配置

    一.设置字体 Window->Preferences->General->Appearance->Colors and Fonts 在右侧找到”Aa Test Font”双击或 ...

  7. php时间戳与时间转换

    PHP时间大的来分有两种,一是时间戳类型(1228348800),二是正常日期格式(2008-12-4) 所以存到数据库也有两种形式了(真正不止,我的应用就两种),时间戳类型我是保存为字符串的,这个是 ...

  8. js ||与&&

    ||:找到结果为true的分项就停止,并返回该分项的值,否则继续执行,如果都没有为true的分项则返回最后分项的值(注意每个分项先转成bool与true进行比较). //例如下面的例子: // &qu ...

  9. Python 一路走来 HTML CSS Javascript

    前端三把利器 HTML          -标签 (成对写不容易忘记闭合)                     自闭和标签           标签里写个 xx=xx, 表示标签的属性       ...

  10. CSAPP--虚拟存储器

    虚拟存储器 虚拟存储器(VM)是对主存的一种抽象概念.是硬件一场,硬件地址翻译,贮存,磁盘文件和内核软件的完美交互.他为每个进程提供了一个大的,一致的和私有的地址空间. 它将贮存堪称一个存储在磁盘上的 ...