Page 1 Source Listing TTBLEX 2014-12-17 20:48 TTBLEX.f 1 SUBROUTINE TTBLEX(TREF,TTBL,ITB,JTB,KARR,PDSL,AETAL,HTML 2 1, PT,PL,QQ,PP,RDP,THE0,STHE,RDTHE,THESP 3 2, IPTB,ITHTB) 4 CFPP$ NOCONCUR R 5 C$$$ SUBPROGRAM DOCUMENTATION BLOCK 6 C . . . 7 C SUBPROGRAM: TTBLEX COMPUTES T ALONG A MOIST ADIABAT 8 C PRGRMMR: BLACK ORG: W/NP2 DATE: ??-??-?? 9 C 10 C ABSTRACT: 11 C THIS ROUTINE COMPUTES THE TEMPERATURE ALONG A MOIST 12 C ADIABAT GIVEN THE SATURATION POTENTIAL TEMPERATURE 13 C AND THE PRESSURE 14 C . 15 C 16 C PROGRAM HISTORY LOG: 17 C ??-??-?? T BLACK - ORIGINATOR 18 C 98-06-12 T BLACK - CONVERSION FROM 1-D TO 2-D 19 C 00-01-04 JIM TUCCILLO - MPI VERSION 20 C 21 C OUTPUT FILES: 22 C NONE 23 C 24 C SUBPROGRAMS CALLED: 25 C UTILITIES: 26 C NONE 27 C 28 C ATTRIBUTES: 29 C LANGUAGE: FORTRAN 30 C---------------------------------------------------------------------- 31 INCLUDE "parmeta" 49 INCLUDE "CTLBLK.comm" 50 C---------------------------------------------------------------------- 65 D I M E N S I O N 66 1 TREF(IM,JM),TTBL(JTB,ITB),KARR(IM,JM),PDSL(IM,JM),HTML(IM,JM) 67 2,QQ(IM,JM),PP(IM,JM),THE0(ITB),STHE(ITB),THESP(IM,JM) 68 3,IPTB(IM,JM),ITHTB(IM,JM) 69 C----------------------------------------------------------------------- 70 !$omp parallel do 71 !$omp& private(bthe00k,bthe10k,bthk,ip,iptbk,ith,pk,sthe00k,sthe10k, 72 !$omp& sthk,t00k,t01k,t10k,t11k,tpk,tthk) 73 DO 500 J=JSTA_M,JEND_M 74 DO 500 I=2,IM-1 75 IF(KARR(I,J).GT.0)THEN 76 C--------------SCALING PRESSURE & TT TABLE INDEX------------------------ 77 PK=PDSL(I,J)*AETAL+PT 78 TPK=(PK-PL)*RDP 79 QQ(I,J)=TPK-AINT(TPK) 80 IPTB(I,J)=INT(TPK)+1 81 C--------------KEEPING INDICES WITHIN THE TABLE------------------------- 82 IF(IPTB(I,J).LT.1)THEN 83 IPTB(I,J)=1 84 QQ(I,J)=0. 85 ENDIF 86 C 87 IF(IPTB(I,J).GE.ITB)THEN 88 IPTB(I,J)=ITB-1 Page 2 Source Listing TTBLEX 2014-12-17 20:48 TTBLEX.f 89 QQ(I,J)=0. 90 ENDIF 91 C--------------BASE AND SCALING FACTOR FOR THE-------------------------- 92 IPTBK=IPTB(I,J) 93 BTHE00K=THE0(IPTBK) 94 STHE00K=STHE(IPTBK) 95 BTHE10K=THE0(IPTBK+1) 96 STHE10K=STHE(IPTBK+1) 97 C--------------SCALING THE & TT TABLE INDEX----------------------------- 98 BTHK=(BTHE10K-BTHE00K)*QQ(I,J)+BTHE00K 99 STHK=(STHE10K-STHE00K)*QQ(I,J)+STHE00K 100 TTHK=(THESP(I,J)-BTHK)/STHK*RDTHE 101 PP(I,J)=TTHK-AINT(TTHK) 102 ITHTB(I,J)=INT(TTHK)+1 103 C--------------KEEPING INDICES WITHIN THE TABLE------------------------- 104 IF(ITHTB(I,J).LT.1)THEN 105 ITHTB(I,J)=1 106 PP(I,J)=0. 107 ENDIF 108 C 109 IF(ITHTB(I,J).GE.JTB)THEN 110 ITHTB(I,J)=JTB-1 111 PP(I,J)=0. 112 ENDIF 113 C--------------TEMPERATURE AT FOUR SURROUNDING TT TABLE PTS.------------ 114 ITH=ITHTB(I,J) 115 IP=IPTB(I,J) 116 T00K=TTBL(ITH ,IP ) 117 T10K=TTBL(ITH+1,IP ) 118 T01K=TTBL(ITH ,IP+1) 119 T11K=TTBL(ITH+1,IP+1) 120 C--------------PARCEL TEMPERATURE------------------------------------- 121 TREF(I,J)=(T00K+(T10K-T00K)*PP(I,J)+(T01K-T00K)*QQ(I,J) 122 1 +(T00K-T10K-T01K+T11K)*PP(I,J)*QQ(I,J))*HTML(I,J) 123 ENDIF 124 500 CONTINUE 125 C 126 RETURN 127 END Page 3 Source Listing TTBLEX 2014-12-17 20:48 Entry Points TTBLEX.f ENTRY POINTS Name ttblex_ SYMBOL CROSS REFERENCE Name Object Declared Type Bytes Dimen Elements Attributes References 500 Label 93 42,43 AETAL Dummy 1 R(4) 4 scalar ARG,INOUT 46 AINT Func 48 scalar 48,70 BTHE00K Local 62 R(4) 4 scalar 62,67 BTHE10K Local 64 R(4) 4 scalar 64,67 BTHK Local 67 R(4) 4 scalar 67,69 CTLBLK Common 2 96 DT Scalar 4 R(4) 4 scalar COM FIRST Scalar 3 R(4) 4 scalar COM HTML Dummy 1 R(4) 4 2 91719 ARG,INOUT 91 I Local 43 I(4) 4 scalar 43,44,46,48,49,51,52,53,56,57,58,6 1,67,68,69,70,71,73,74,75,78,79,80 ,83,84,90,91 ICNT Scalar 7 I(4) 4 1 1024 COM IDAT Scalar 3 I(4) 4 1 3 COM IDIM1 Param 14 I(4) 4 scalar IDIM2 Param 14 I(4) 4 scalar IDN Scalar 7 I(4) 4 scalar COM IDSP Scalar 7 I(4) 4 1 1024 COM IDTAD Scalar 4 I(4) 4 scalar COM IGSTL Param 9 I(4) 4 scalar 14 IGSTR Param 9 I(4) 4 scalar 14 IHRST Scalar 3 I(4) 4 scalar COM IM Param 3 I(4) 4 scalar 11,14,35,36,37,43 INPES Param 6 I(4) 4 scalar 11,14 INT Func 49 scalar 49,71 IOUT Scalar 3 I(4) 4 scalar COM IP Local 84 I(4) 4 scalar 84,85,86,87,88 IPTB Dummy 3 I(4) 4 2 91719 ARG,INOUT 49,51,52,56,57,61,84 IPTBK Local 61 I(4) 4 scalar 61,62,63,64,65 ITAIL Param 11 I(4) 4 scalar ITB Dummy 1 I(4) 4 scalar ARG,INOUT 35,36,56,57 ITH Local 83 I(4) 4 scalar 83,85,86,87,88 ITHTB Dummy 3 I(4) 4 2 91719 ARG,INOUT 71,73,74,78,79,83 IUP Scalar 7 I(4) 4 scalar COM J Local 42 I(4) 4 scalar 42,44,46,48,49,51,52,53,56,57,58,6 1,67,68,69,70,71,73,74,75,78,79,80 ,83,84,90,91 JDIM1 Param 15 I(4) 4 scalar JDIM2 Param 15 I(4) 4 scalar JEND Scalar 6 I(4) 4 scalar COM JEND_2U Scalar 8 I(4) 4 scalar COM JEND_M Scalar 7 I(4) 4 scalar COM 42 JEND_M2 Scalar 7 I(4) 4 scalar COM Page 4 Source Listing TTBLEX 2014-12-17 20:48 Symbol Table TTBLEX.f Name Object Declared Type Bytes Dimen Elements Attributes References JGSTL Param 10 I(4) 4 scalar 15 JGSTR Param 10 I(4) 4 scalar 15 JM Param 3 I(4) 4 scalar 12,15,35,36,37 JNPES Param 6 I(4) 4 scalar 12,15 JSTA Scalar 6 I(4) 4 scalar COM JSTA_2L Scalar 8 I(4) 4 scalar COM JSTA_M Scalar 7 I(4) 4 scalar COM 42 JSTA_M2 Scalar 7 I(4) 4 scalar COM JTAIL Param 12 I(4) 4 scalar JTB Dummy 1 I(4) 4 scalar ARG,INOUT 35,78,79 KARR Dummy 1 I(4) 4 2 91719 ARG,INOUT 44 LIST Scalar 3 I(4) 4 scalar COM LM Param 3 I(4) 4 scalar LSM Param 3 I(4) 4 scalar ME Scalar 6 I(4) 4 scalar COM NBC Scalar 3 I(4) 4 scalar COM NBOCO Scalar 4 I(4) 4 scalar COM NCP Scalar 4 I(4) 4 scalar COM NDDAMP Scalar 4 I(4) 4 scalar COM NFCST Scalar 3 I(4) 4 scalar COM NPHS Scalar 5 I(4) 4 scalar COM NPREC Scalar 4 I(4) 4 scalar COM NRADL Scalar 5 I(4) 4 scalar COM NRADS Scalar 5 I(4) 4 scalar COM NSHDE Scalar 4 I(4) 4 scalar COM NTSD Scalar 4 I(4) 4 scalar COM NTSTM Scalar 4 I(4) 4 scalar COM NUM_PROCS Scalar 6 I(4) 4 scalar COM PARALLEL Common 9 8240 PDSL Dummy 1 R(4) 4 2 91719 ARG,INOUT 46 PK Local 46 R(4) 4 scalar 46,47 PL Dummy 2 R(4) 4 scalar ARG,INOUT 47 PP Dummy 2 R(4) 4 2 91719 ARG,INOUT 70,75,80,90,91 PT Dummy 2 R(4) 4 scalar ARG,INOUT 46 QQ Dummy 2 R(4) 4 2 91719 ARG,INOUT 48,53,58,67,68,90,91 RDP Dummy 2 R(4) 4 scalar ARG,INOUT 47 RDTHE Dummy 2 R(4) 4 scalar ARG,INOUT 69 RESTRT Scalar 3 R(4) 4 scalar COM RUN Scalar 3 R(4) 4 scalar COM SIGMA Scalar 3 R(4) 4 scalar COM STHE Dummy 2 R(4) 4 1 0 ARG,INOUT 63,65 STHE00K Local 63 R(4) 4 scalar 63,68 STHE10K Local 65 R(4) 4 scalar 65,68 STHK Local 68 R(4) 4 scalar 68,69 T00K Local 85 R(4) 4 scalar 85,90,91 T01K Local 87 R(4) 4 scalar 87,90,91 T10K Local 86 R(4) 4 scalar 86,90,91 T11K Local 88 R(4) 4 scalar 88,91 THE0 Dummy 2 R(4) 4 1 0 ARG,INOUT 62,64 THESP Dummy 2 R(4) 4 2 91719 ARG,INOUT 69 TPK Local 47 R(4) 4 scalar 47,48,49 TREF Dummy 1 R(4) 4 2 91719 ARG,INOUT 90 TTBL Dummy 1 R(4) 4 2 0 ARG,INOUT 85,86,87,88 TTBLEX Subr 1 TTHK Local 69 R(4) 4 scalar 69,70,71 Page 5 Source Listing TTBLEX 2014-12-17 20:48 TTBLEX.f 128 C&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& Page 6 Source Listing TTBLEX 2014-12-17 20:48 Subprograms/Common Blocks TTBLEX.f SUBPROGRAMS/COMMON BLOCKS Name Object Declared Type Bytes Dimen Elements Attributes References CTLBLK Common 2 96 PARALLEL Common 9 8240 TTBLEX Subr 1 COMPILER OPTIONS BEING USED -align nocommons -align nodcommons -align noqcommons -align records -align nosequence -align norec1byte -align norec2byte -align norec4byte -align norec8byte -align norec16byte -altparam -assume accuracy_sensitive -assume nobscc -assume nobuffered_io -assume byterecl -assume nocc_omp -assume nocstring -assume nodummy_aliases -assume nofpe_summary -assume noieee_fpe_flags -assume nominus0 -assume noold_boz -assume old_unit_star -assume old_ldout_format -assume noold_logical_ldio -assume old_maxminloc -assume old_xor -assume protect_constants -assume noprotect_parens -assume split_common -assume source_include -assume nostd_intent_in -assume nostd_mod_proc_name -assume norealloc_lhs -assume underscore -assume no2underscores no -auto -auto_scalar no -bintext -ccdefault default -check noargs -check noarg_temp_created -check nobounds -check noformat -check nooutput_conversion -check nooverflow -check nopointers -check power -check noshape -check nounderflow -check nouninitialized -coarray-num-procs 0 no -coarray-config-file -convert big_endian -cross_reference -D __INTEL_COMPILER=1210 -D __unix__ -D __unix -D __linux__ -D __linux -D __gnu_linux__ -D unix -D linux -D __ELF__ -D __x86_64 -D __x86_64__ -D _MT -D __INTEL_COMPILER_BUILD_DATE=20120612 -D __i686 -D __i686__ -D __pentiumpro -D __pentiumpro__ -D __pentium4 -D __pentium4__ -D __tune_pentium4__ -D __SSE2__ -D __SSE__ -D __MMX__ -double_size 64 no -d_lines no -Qdyncom -error_limit 30 no -f66 no -f77rtl no -fast -fpscomp nofilesfromcmd -fpscomp nogeneral -fpscomp noioformat -fpscomp noldio_spacing -fpscomp nologicals Page 7 Source Listing TTBLEX 2014-12-17 20:48 TTBLEX.f -fixed no -fpconstant -fpe3 -fprm nearest no -ftz -fp_model noprecise -fp_model fast -fp_model nostrict -fp_model nosource -fp_model nodouble -fp_model noextended -fp_model novery_fast -fp_model noexcept -fp_model nono_except -heap_arrays 0 no -threadprivate_compat -g2 -iface nomixed_str_len_arg -iface nono_mixed_str_len_arg no -intconstant -integer_size 32 no -mixed_str_len_arg no -module -names lowercase no -noinclude -O2 no -pad_source -real_size 32 no -recursive -reentrancy none no -sharable_localsaves -vec=simd -show noinclude -show map -show options no -syntax_only no -threadcom no -U no -vms -w noall -w nonone -w alignments -w noargument_checking -w nodeclarations -w general -w noignore_bounds -w noignore_loc -w nointerfaces -w notruncated_source -w uncalled -w uninitialized -w nounused -w usage -includepath : /gpfs/tp1/usrx/local/intel/composer_xe_2011_sp1.11.339/compiler/include/,.f,./.f,/usrx/local/intel/composerxe/mkl/include/.f, /usrx/local/intel/composerxe/tbb/include/.f,/gpfs/tp1/usrx/local/intel/composer_xe_2011_sp1.11.339/compiler/include/intel64/.f, /gpfs/tp1/usrx/local/intel/composer_xe_2011_sp1.11.339/compiler/include/.f,/usr/local/include/.f,/usr/lib/gcc/x86_64-redhat-linux/4.4.7/include/.f, /usr/include/.f,/usr/include/.f -list filename : TTBLEX.lst -o filename : none COMPILER: Intel(R) Fortran 12.1-2100