NCEPLIBS-ip 5.2.0
Loading...
Searching...
No Matches
sptrund.f
Go to the documentation of this file.
1C> @file
2C>
3C> Spectrally truncate to gradients
4C> @author IREDELL @date 96-02-29
5
6C> THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS
7C> ON A GLOBAL CYLINDRICAL GRID, RETURNING THEIR MEANS AND
8C> GRADIENTS TO A POSSIBLY DIFFERENT GLOBAL CYLINDRICAL GRID.
9C> THE WAVE-SPACE CAN BE EITHER TRIANGULAR OR RHOMBOIDAL.
10C> EITHER GRID-SPACE CAN BE EITHER AN EQUALLY-SPACED GRID
11C> (WITH OR WITHOUT POLE POINTS) OR A GAUSSIAN GRID.
12C> THE GRID FIELDS MAY HAVE GENERAL INDEXING.
13C> THE TRANSFORMS ARE ALL MULTIPROCESSED.
14C> OVER ZONAL WAVENUMBER TO ENSURE REPRODUCIBILITY.
15C> TRANSFORM SEVERAL FIELDS AT A TIME TO IMPROVE VECTORIZATION.
16C> SUBPROGRAM CAN BE CALLED FROM A MULTIPROCESSING ENVIRONMENT.
17C>
18C> @param IROMB - INTEGER SPECTRAL DOMAIN SHAPE
19C> (0 FOR TRIANGULAR, 1 FOR RHOMBOIDAL)
20C> @param MAXWV - INTEGER SPECTRAL TRUNCATION
21C> @param IDRTI - INTEGER INPUT GRID IDENTIFIER
22C> (IDRTI=4 FOR GAUSSIAN GRID,
23C> IDRTI=0 FOR EQUALLY-SPACED GRID INCLUDING POLES,
24C> IDRTI=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES)
25C> @param IMAXI - INTEGER EVEN NUMBER OF INPUT LONGITUDES.
26C> @param JMAXI - INTEGER NUMBER OF INPUT LATITUDES.
27C> @param IDRTO - INTEGER OUTPUT GRID IDENTIFIER
28C> (IDRTO=4 FOR GAUSSIAN GRID,
29C> IDRTO=0 FOR EQUALLY-SPACED GRID INCLUDING POLES,
30C> IDRTO=256 FOR EQUALLY-SPACED GRID EXCLUDING POLES)
31C> @param IMAXO - INTEGER EVEN NUMBER OF OUTPUT LONGITUDES.
32C> @param JMAXO - INTEGER NUMBER OF OUTPUT LATITUDES.
33C> @param KMAX - INTEGER NUMBER OF FIELDS TO TRANSFORM.
34C> @param IPRIME - INTEGER INPUT LONGITUDE INDEX FOR THE PRIME MERIDIAN.
35C> (DEFAULTS TO 1 IF IPRIME=0)
36C> (OUTPUT LONGITUDE INDEX FOR PRIME MERIDIAN ASSUMED 1.)
37C> @param ISKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LONGITUDES
38C> (DEFAULTS TO 1 IF ISKIPI=0)
39C> @param JSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT LATITUDES FROM SOUTH
40C> (DEFAULTS TO -IMAXI IF JSKIPI=0)
41C> @param KSKIPI - INTEGER SKIP NUMBER BETWEEN INPUT GRID FIELDS
42C> (DEFAULTS TO IMAXI*JMAXI IF KSKIPI=0)
43C> @param ISKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LONGITUDES
44C> (DEFAULTS TO 1 IF ISKIPO=0)
45C> @param JSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT LATITUDES FROM SOUTH
46C> (DEFAULTS TO -IMAXO IF JSKIPO=0)
47C> @param KSKIPO - INTEGER SKIP NUMBER BETWEEN OUTPUT GRID FIELDS
48C> (DEFAULTS TO IMAXO*JMAXO IF KSKIPO=0)
49C> @param JCPU - INTEGER NUMBER OF CPUS OVER WHICH TO MULTIPROCESS
50C> (DEFAULTS TO ENVIRONMENT NCPUS IF JCPU=0)
51C> @param GRID - REAL (*) INPUT GRID FIELDS
52C> @param GRIDMN - REAL (KMAX) OUTPUT GLOBAL MEANS
53C> @param GRIDX - REAL (*) OUTPUT X-GRADIENTS
54C> @param GRIDY - REAL (*) OUTPUT Y-GRADIENTS
55C>
56C> SUBPROGRAMS CALLED:
57C> - SPTRAN PERFORM A SCALAR SPHERICAL TRANSFORM
58C> - SPTRAND PERFORM A GRADIENT SPHERICAL TRANSFORM
59C> - NCPUS GETS ENVIRONMENT NUMBER OF CPUS
60C>
61C> REMARKS: MINIMUM GRID DIMENSIONS FOR UNALIASED TRANSFORMS TO SPECTRAL:
62C> DIMENSION |LINEAR |QUADRATIC
63C> ----------------------- |--------- |-------------
64C> IMAX |2*MAXWV+2 |3*MAXWV/2*2+2
65C> JMAX (IDRT=4,IROMB=0) |1*MAXWV+1 |3*MAXWV/2+1
66C> JMAX (IDRT=4,IROMB=1) |2*MAXWV+1 |5*MAXWV/2+1
67C> JMAX (IDRT=0,IROMB=0) |2*MAXWV+3 |3*MAXWV/2*2+3
68C> JMAX (IDRT=0,IROMB=1) |4*MAXWV+3 |5*MAXWV/2*2+3
69C> JMAX (IDRT=256,IROMB=0) |2*MAXWV+1 |3*MAXWV/2*2+1
70C> JMAX (IDRT=256,IROMB=1) |4*MAXWV+1 |5*MAXWV/2*2+1
71 SUBROUTINE sptrund(IROMB,MAXWV,IDRTI,IMAXI,JMAXI,
72 & IDRTO,IMAXO,JMAXO,KMAX,
73 & IPRIME,ISKIPI,JSKIPI,KSKIPI,
74 & ISKIPO,JSKIPO,KSKIPO,JCPU,GRID,
75 & GRIDMN,GRIDX,GRIDY)
76
77 REAL GRID(*),GRIDX(*),GRIDY(*),GRIDMN(*)
78 REAL W((MAXWV+1)*((IROMB+1)*MAXWV+2)/2*2+1,KMAX)
79C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
80C TRANSFORM INPUT GRID TO WAVE
81 jc=jcpu
82 IF(jc.EQ.0) jc=ncpus()
83 mx=(maxwv+1)*((iromb+1)*maxwv+2)/2
84 mdim=2*mx+1
85 jn=-jskipi
86 IF(jn.EQ.0) jn=imaxi
87 js=-jn
88 inp=(jmaxi-1)*max(0,-jn)+1
89 isp=(jmaxi-1)*max(0,-js)+1
90 CALL sptran(iromb,maxwv,idrti,imaxi,jmaxi,kmax,
91 & iprime,iskipi,jn,js,mdim,kskipi,0,0,jc,
92 & w,grid(inp),grid(isp),-1)
93C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
94C TRANSFORM WAVE TO OUTPUT GRADIENTS
95 jn=-jskipo
96 IF(jn.EQ.0) jn=imaxo
97 js=-jn
98 inp=(jmaxo-1)*max(0,-jn)+1
99 isp=(jmaxo-1)*max(0,-js)+1
100 CALL sptrand(iromb,maxwv,idrto,imaxo,jmaxo,kmax,
101 & 0,iskipo,jn,js,mdim,kskipo,0,0,jc,
102 & w,gridmn,
103 & gridx(inp),gridx(isp),gridy(inp),gridy(isp),1)
104C - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
105 END
function ncpus()
Set number of CPUs - the number of processors over which to parallelize.
Definition ncpus.F:22
subroutine sptran(iromb, maxwv, idrt, imax, jmax, kmax, iprime, iskip, jnskip, jsskip, kwskip, kgskip, jbeg, jend, jcpu, wave, gridn, grids, idir)
This subprogram performs a spherical transform between spectral coefficients of scalar quantities and...
Definition sptran.f:88
subroutine sptrand(iromb, maxwv, idrt, imax, jmax, kmax, iprime, iskip, jnskip, jsskip, kwskip, kgskip, jbeg, jend, jcpu, wave, gridmn, gridxn, gridxs, gridyn, gridys, idir)
This subprogram performs a spherical transform between spectral coefficients of scalar fields and the...
Definition sptrand.f:92
subroutine sptrund(iromb, maxwv, idrti, imaxi, jmaxi, idrto, imaxo, jmaxo, kmax, iprime, iskipi, jskipi, kskipi, iskipo, jskipo, kskipo, jcpu, grid, gridmn, gridx, gridy)
THIS SUBPROGRAM SPECTRALLY TRUNCATES SCALAR FIELDS ON A GLOBAL CYLINDRICAL GRID, RETURNING THEIR MEAN...
Definition sptrund.f:76