source: CPL/oasis3-mct_5.0/pyoasis/examples/1-serial/fortran/sender-serial.F90 @ 6328

Last change on this file since 6328 was 6328, checked in by aclsce, 17 months ago

First import of oasis3-mct_5.0 (from oasis git server, branch OASIS3-MCT_5.0)

File size: 1.7 KB
Line 
1program sender_serial
2   use mod_oasis
3   implicit none
4   integer :: i, kinfo, date
5   integer :: comp_id, part_id, var_id
6   integer, parameter :: n_points = 1600
7   integer :: part_params(OASIS_Serial_Params)
8   integer :: var_nodims(2)
9   character(len=13) :: comp_name = "sender-serial"
10   character(len=8) :: var_name = "FSENDOCN"
11   real(kind=8) :: field(n_points)
12
13   print '(2A)', "Component name: ", comp_name
14
15   call oasis_init_comp(comp_id, comp_name, kinfo)
16   if(kinfo<0) call oasis_abort(comp_id, comp_name, &
17      & "Error in oasis_init_comp: ", rcode=kinfo)
18   print '(A,I0)', "Sender: Component ID: ", comp_id
19
20   part_params(OASIS_Strategy) = OASIS_Serial
21   part_params(OASIS_Length)   = n_points
22   call oasis_def_partition(part_id, part_params, kinfo)
23   if(kinfo<0) call oasis_abort(comp_id, comp_name, &
24      & "Error in oasis_def_partition: ", rcode=kinfo)
25   print '(A,I0)', "Sender: part_id: ", part_id
26
27   var_nodims=[1, 1]
28   print '(2A)', "Sender: var_name: ", var_name
29   call oasis_def_var(var_id, var_name, part_id, var_nodims, OASIS_OUT, &
30      &               [1], OASIS_REAL, kinfo)
31   if(kinfo<0 .or. var_id<0) call oasis_abort(comp_id, comp_name, &
32      & "Error in oasis_def_var: ", rcode=kinfo)
33   print '(A,I0)', "Sender: var_id: ", var_id
34
35   call oasis_enddef(kinfo)
36   if(kinfo<0) call oasis_abort(comp_id, comp_name, &
37      & "Error in oasis_enddef: ", rcode=kinfo)
38
39   field(:) = [(i, i=1, n_points)]
40
41   date=0
42
43   call oasis_put(var_id, date, field, kinfo)
44   if(kinfo<0) call oasis_abort(comp_id, comp_name, &
45      & "Error in oasis_put: ", rcode=kinfo)
46
47   call oasis_terminate(kinfo)
48   if(kinfo<0) call oasis_abort(comp_id, comp_name, &
49      & "Error in oasis_terminate: ", rcode=kinfo)
50
51end program sender_serial
Note: See TracBrowser for help on using the repository browser.