source: codes/icosagcm/devel/Python/test/py/test_xios.py @ 622

Last change on this file since 622 was 622, checked in by dubos, 6 years ago

devel/unstructured : XIOS interface + test

File size: 4.9 KB
Line 
1from mpi4py import MPI
2comm = MPI.COMM_WORLD
3mpi_rank, mpi_size = comm.Get_rank(), comm.Get_size()
4print '%d/%d starting'%(mpi_rank,mpi_size)
5
6import sys
7import numpy as np
8#import dynamico.wrap as wrap
9print 'import dynamico.unstructured'
10import dynamico.unstructured as unst
11print 'import dynamico.xios'
12import dynamico.xios as xios
13print 'Done.'
14
15def boundaries(degree,points,lon,lat):
16    n, nvertex = len(degree), degree.max()
17    bnd_lon, bnd_lat = np.zeros((n,nvertex)),np.zeros((n,nvertex))
18    for ij in range(n):
19        nb=degree[ij]
20        for k in range(nb):
21            vertex = points[ij,k]
22            bnd_lon[ij,k]=lon[vertex]
23            bnd_lat[ij,k]=lat[vertex]
24        for k in range(nb,nvertex):   # repeat last vertex if nb<nvertex
25            bnd_lon[ij,k]=bnd_lon[ij,nb-1]
26            bnd_lat[ij,k]=bnd_lat[ij,nb-1]
27    return bnd_lon, bnd_lat
28
29#----------------------------- read MPAS mesh --------------------------------
30
31radian=unst.radian
32grid, llm, nqdyn, nqtot = 10242, 1,1,1 # 2562, 10242, 40962 
33Omega, radius, g, gh0 = 2.*np.pi/86400., 6.4e6, 1., 2.94e4
34N, T, courant = 40, 10800., 1.2 # simulation length = N*T
35print 'Omega, planetary PV', Omega, 2*Omega/gh0
36sys.stdout.flush()
37
38def f(lon,lat): return 2*Omega*np.sin(lat) # Coriolis parameter                                                                                                               
39print 'Reading MPAS mesh ...'
40sys.stdout.flush()
41mesh = unst.MPAS_Mesh('grids/x1.%d.grid.nc'%grid, llm, nqdyn, radius, f)
42print '...Done'
43sys.stdout.flush()
44
45lon_i, lat_i, lon_v, lat_v = [x*radian for x in mesh.lon_i, mesh.lat_i, mesh.lon_v, mesh.lat_v]
46#lon_i, lat_i, lon_v, lat_v = mesh.lon_i, mesh.lat_i, mesh.lon_v, mesh.lat_v
47
48#--------------------------------- initialize XIOS --------------------------
49
50def setup_domain(cat,id, degree,vertex,lon,lat,lon_v,lat_v): # cat in 'domain','domaingroup'
51    bnd_lon, bnd_lat = boundaries(degree, vertex, lon_v, lat_v)
52    ncell_tot, nvertex = bnd_lon.shape
53    mesh = xios.Handle(cat,id)
54    mesh.set_attr(type='unstructured')
55    mesh.set_attr(ni_glo=ncell_tot, ibegin=0, ni=ncell_tot)
56    mesh.set_attr(i_index=np.arange(ncell_tot,dtype=np.int32))
57    mesh.set_attr(lonvalue_1d=lon, latvalue_1d=lat)
58    mesh.set_attr(nvertex=nvertex,bounds_lon_1d=bnd_lon, bounds_lat_1d=bnd_lat)
59
60unst.ker.dynamico_setup_xios()
61
62if True:
63    lev, levp1, nq = [xios.Handle('axis',name) for name in 'lev', 'levp1', 'nq']
64    lev.set_attr(n_glo=llm, value=np.arange(llm))
65    levp1.set_attr(n_glo=llm+1, value=np.arange(llm+1))
66    nq.set_attr(n_glo=nqtot, value=np.arange(nqtot))
67    mesh_i=setup_domain('domaingroup','i', mesh.primal_deg, mesh.primal_vertex-1, lon_i, lat_i, lon_v, lat_v) # primal mesh
68#    mesh_v=setup_domain('domain','v', mesh.dual_deg, mesh.dual_vertex-1, lon_v, lat_v, lon_i, lat_i) # dual mesh
69
70#   CALL xios_set_domain_attr("u",ni_glo=ncell_tot, ibegin=displ, ni=ncell)                                                                             
71#   CALL xios_set_domain_attr("u", data_dim=1, type='unstructured' , nvertex=2, i_index=ind_glo)                                                         
72#   CALL xios_set_domain_attr("u",lonvalue_1d=lon, latvalue_1d=lat, bounds_lon_1d=bounds_lon, bounds_lat_1d=bounds_lat)                                   
73#mesh_e = xios.Handle('domain','u')
74
75# works up to that point !
76
77dtime = xios.Duration(second=3600.)
78
79#   CALL xios_set_timestep(dtime)                                                                                                                       
80if True:
81    calendar=xios.Handle('calendar_wrapper')
82    print (dtime.year, dtime.month, dtime.day, dtime.hour, dtime.second)
83    calendar.set_attr(timestep=dtime)
84    calendar.update_timestep()
85else:
86    unst.ker.dynamico_xios_set_timestep(3600.)
87
88#   CALL xios_set_fieldgroup_attr("standard_output", freq_op=itau_out*xios_timestep, freq_offset=(itau_out-1)*xios_timestep)                             
89if False:
90    std=xios.Handle('fieldgroup','standard_output')
91    std.set_attr(freq_op=dtime)
92    freq_offset = xios.Duration(second=0)
93    std.set_attr(freq_offset=freq_offset)
94
95if True:
96    print 'xios.context_close_definition()'
97    xios.context_close_definition()
98
99no_error=True
100try:
101    for i in range(100):
102        if True:
103            unst.ker.dynamico_xios_update_calendar(i)
104        else:
105            xios.update_calendar(i)
106        print 'send_field', i
107        xios.send_field('ps', lat_i)
108except:
109    print 'An error has occured, trying to close XIOS properly'
110    no_error=False
111# CALL xios_recv_field(name,field)                                                                                                                       
112# CALL xios_send_field(name,field_tmp)                                                                                                                   
113
114print 'xios.context_finalize()'
115xios.context_finalize()
116
117print 'xios.finalize()'
118xios.finalize()
119
120print 'Done'
121
122if not no_error : raise
Note: See TracBrowser for help on using the repository browser.