!******************************************************************************* SUBROUTINE RRTM_TAUMOL10 (KLEV,TAU,& &TAUAERL,FAC00,FAC01,FAC10,FAC11,JP,JT,JT1,& &COLH2O,LAYTROP,PFRAC) ! BAND 10: 1390-1480 cm-1 (low - H2O; high - H2O) ! Modifications ! ! D Salmond 2000-05-15 speed-up ! JJMorcrette 2000-05-17 speed-up #include "tsmbkind.h" USE PARRRTM , ONLY : JPLAY ,JPBAND ,JPGPT ,JPXSEC , NGS9 USE YOERRTWN , ONLY : NG ,NSPA ,NSPB USE YOERRTA10, ONLY : NG10 ,ABSA ,ABSB ,FRACREFA, FRACREFB, KA , KB ! Input !#include "yoeratm.h" ! REAL TAUAER(JPLAY) IMPLICIT NONE ! Output REAL_B :: TAU (JPGPT,JPLAY) ! DUMMY INTEGER SCALARS INTEGER_M :: KLEV !- from AER REAL_B :: TAUAERL(JPLAY,JPBAND) !- from INTFAC REAL_B :: FAC00(JPLAY) REAL_B :: FAC01(JPLAY) REAL_B :: FAC10(JPLAY) REAL_B :: FAC11(JPLAY) !- from INTIND INTEGER_M :: JP(JPLAY) INTEGER_M :: JT(JPLAY) INTEGER_M :: JT1(JPLAY) !- from PROFDATA REAL_B :: COLH2O(JPLAY) INTEGER_M :: LAYTROP !- from SP REAL_B :: PFRAC(JPGPT,JPLAY) INTEGER_M :: IND0(JPLAY),IND1(JPLAY) ! LOCAL INTEGER SCALARS INTEGER_M :: IG, LAY ! EQUIVALENCE (TAUAERL(1,10),TAUAER) ! Compute the optical depth by interpolating in ln(pressure) and ! temperature. DO LAY = 1, LAYTROP IND0(LAY) = ((JP(LAY)-1)*5+(JT(LAY)-1))*NSPA(10) + 1 IND1(LAY) = (JP(LAY)*5+(JT1(LAY)-1))*NSPA(10) + 1 ENDDO !-- DS_000515 DO IG = 1, NG10 DO LAY = 1, LAYTROP !-- DS_000515 TAU (NGS9+IG,LAY) = COLH2O(LAY) *& &(FAC00(LAY) * ABSA(IND0(LAY) ,IG) +& & FAC10(LAY) * ABSA(IND0(LAY)+1,IG) +& & FAC01(LAY) * ABSA(IND1(LAY) ,IG) +& & FAC11(LAY) * ABSA(IND1(LAY)+1,IG)) & &+ TAUAERL(LAY,10) PFRAC(NGS9+IG,LAY) = FRACREFA(IG) ENDDO ENDDO DO LAY = LAYTROP+1, KLEV IND0(LAY) = ((JP(LAY)-13)*5+(JT(LAY)-1))*NSPB(10) + 1 IND1(LAY) = ((JP(LAY)-12)*5+(JT1(LAY)-1))*NSPB(10) + 1 ENDDO !-- JJM_000517 DO IG = 1, NG10 DO LAY = LAYTROP+1, KLEV !-- JJM_000517 TAU (NGS9+IG,LAY) = COLH2O(LAY) *& &(FAC00(LAY) * ABSB(IND0(LAY) ,IG) +& & FAC10(LAY) * ABSB(IND0(LAY)+1,IG) +& & FAC01(LAY) * ABSB(IND1(LAY) ,IG) +& & FAC11(LAY) * ABSB(IND1(LAY)+1,IG)) & &+ TAUAERL(LAY,10) PFRAC(NGS9+IG,LAY) = FRACREFB(IG) ENDDO ENDDO RETURN END SUBROUTINE RRTM_TAUMOL10