2011年10月26日水曜日

change_axcel2.sh

#! /bin/tcsh -f
#####################################
# cloud change  
# chage of axcel
#####################################
#####################################

filename1=change_cloud
filename2=read_data2
filename3=output_data

ffilename1=psea
ffilename2=v # 1000hPa
ffilename3=allcwc
ffilename4=rv #1e+4
ffilename5=rvsrf #1e+4
ffilename6=t #[K]
ffilename7=tsrf #[K]

ofname1=output_axcel
#ofname2=output_axcel_rv
ofname3=output_axcel_ept

####################################
####################################
#model grid size
xgrid=418
ygrid=418
zgrid=16
#include +,=
f_lon=+129.88
f_lat=-45.12

####################################
# set grid for cal


#20km=1grid is 0.18
xgrid_a=56 #10=55.5 grid
ygrid_a=56 #10=55.5 grid
gsize1=20  # 20km or 5km
gsize2=0.18 #grid size 20km=0.18, 5km=0.045

#definition region
lon_l=10.00
lat_l=10.00
#for cal
lon_l2=15.00
lat_l2=15.00

#length from center
ll_km=1000 #[km]
ll_m=`expr $ll_km \* 1000` #[m]

####################################
####################################
#type yyyymmddhhhh start and end time
: ${start:=199201041200}
: ${end:=199201082100}
#: ${end:=199201041500}
year=`echo ${start} | cut -c 1-4`
month=`echo ${start} | cut -c 5-6`
day=`echo ${start} | cut -c 7-8`
hour=`echo ${start} |cut -c 9-10`
h=00

echo start time ${year} ${month} ${day} ${hour} ${h}
echo end   time ${end}

: ${time:=${start}}

#timestep
timestep=1
time_step=0

i=0
while [ ${time} -le ${end} ]
do
time_step=`expr ${timestep} \* ${i}`
echo time_step ${time_step}

##decide m
if [ ${month} -eq 01 ]; then
    m=JAN
elif  [ ${month} -eq 02 ]; then
    m=FEB
elif  [ ${month} -eq 03 ]; then
    m=MAR
elif  [ ${month} -eq 04 ]; then
    m=APR
elif  [ ${month} -eq 05 ]; then
    m=MAY
elif  [ ${month} -eq 06 ]; then
    m=JUN
elif  [ ${month} -eq 07 ]; then
    m=JUL
elif  [ ${month} -eq 08 ]; then
    m=AUG
elif  [ ${month} -eq 09 ]; then
    m=SEP
elif  [ ${month} -eq 10 ]; then
    m=OCT
elif  [ ${month} -eq 11 ]; then
    m=NOV
elif  [ ${month} -eq 12 ]; then
    m=DEC
fi

##decide m

#echo $hour
time=${year}${month}${day}${hour}${h}
#echo yoshiyoshi
echo time $time
echo month $m

    t=`expr ${day} \* 4 - 3`
    t=`expr ${hour} / 6 + ${t}`


##############################################
#read grads data

: ${prefix:=anl_p}    #want data

    cat > ${filename2}.gs <<EOF
'reinit'
'open _NHMMRPPFCSVSTD1_${time}.ctl'

*psea
'set gxout fwrite'
'set undef dfile'
'set fwrite ${ffilename1}.grd'
*'set t ${t}'
'set x 1 418'
'set y 1 418'
'd psea'
'disable fwrite'
'c'

*v (u*u+v*v)**0.5 1000hPa
'set gxout fwrite'
'set undef dfile'
'set fwrite ${ffilename2}.grd'
*'set t ${t}'
'set x 1 418'
'set y 1 418'
'd sqrt(u*u+v*v)'
'disable fwrite'
'c'

*
'set gxout fwrite'
'set undef dfile'
'set fwrite ${ffilename3}.grd'
*'set t ${t}'
'set x 1 418'
'set y 1 418'
'c=vint(lev(z=1), cwc, 100)'
'd c'
'disable fwrite'
'c'

'set gxout fwrite'
'set undef dfile'
'set fwrite ${ffilename4}.grd'
'set x 1 418'
'set y 1 418'
k=1
while (k<=${zgrid})
'set z 'k''
'a=hcurl(u,v)'
'd a*10000'
*say 'yoshiyoshi'
*say k
k=k+1
endwhile
'disable fwrite'
'c'

'set gxout fwrite'
'set undef dfile'
'set fwrite ${ffilename5}.grd'
*'set t ${t}'
'set x 1 418'
'set y 1 418'
'a=hcurl(usrf,vsrf)'
'd a*10000'
'disable fwrite'
'c'

'set gxout fwrite'
'set undef dfile'
'set fwrite ${ffilename6}.grd'
'set x 1 418'
'set y 1 418'
k=1
while (k<=${zgrid})
'set z 'k''
'd t'
*say 'yoshiyoshi'
*say k
k=k+1
endwhile
'disable fwrite'
'c'


'set gxout fwrite'
'set undef dfile'
'set fwrite ${ffilename7}.grd'
*'set t ${t}'
'set x 1 418'
'set y 1 418'
'd tsrf'
'disable fwrite'
'c'

'quit'


EOF
    grads -blc ${filename2}.gs

########################################
####program read_data###################
########################################

if [ ${time} -eq ${start} ]; then
##start : make output file
cat <<EOF > start.f90
program start
 implicit none
open (unit=31, file='${ofname1}.txt', form='FORMATTED')
!open (unit=32, file='${ofname2}.txt', form='FORMATTED')
open (unit=33, file='${ofname3}.txt', form='FORMATTED')

write(31,*) '${ofilename1}'
write(31,*) 'time_step pn plonn platn v1n allarea_avcwc axcel_avcwc'
write(*,*) 'time_step pn plonn platn v1n allarea_avcwc axcel_avcwc'


!#write(32,*) '${ofilename2}'
!#!write(32,*) 'time_step pn plonn platn v1n axcel_avcwc avrvsrf output_rv1000 output_rv800 output_rv600 output_rv400 output_rv200'
!#!write(*,*) 'time_step pn plonn platn v1n axcel_avcwc avrvsrf output_rv1000 output_rv800 output_rv600 output_rv400 output_rv200'

write(33,*) '${ofilename3}'
write(33,*) 'time_step pn plonn platn v1n aveptsrf output_ept1000 output_ept800 output_ept600 output_ept400'
write(*,*) 'time_step pn plonn platn v1n aveptsrf output_ept1000 output_ept800 output_ept600 output_ept400'

close(31)
!#close(32)
close(33)
end program start
EOF

##output data.txt by f90
f90 -o start.out start.f90
./start.out
##start
fi


####find min psea
cat <<EOF > ${filename2}.f90
program  ${filename2}
 implicit none
 integer, parameter :: xgrid=${xgrid}, ygrid=${ygrid}, zgrid=${zgrid}, rgrid=10
 real, parameter ::  gsize1=${gsize1}, gsize2=${gsize2}
 real, parameter :: ll_km=${ll_km}, ll_m=${ll_m}

 integer :: n, i, j, k, step, is, ie, js, je
 integer :: kxn, kyn, pkxn, pkyn
 integer :: ngrid2, ngrid3, size

!ffilename1=psea
!ffilename2=v # 1000hPa
!ffilename3=allcwc
!ffilename4=rv #1e+4
!ffilename5=rvsrf #1e+4
!ffilename6=t #[K]
!ffilename7=tsrf #[K]

 real(kind=4), dimension(xgrid,ygrid) :: ${ffilename1}
 real(kind=4), dimension(xgrid,ygrid) :: ${ffilename2}
 real(kind=4), dimension(xgrid,ygrid) :: ${ffilename3}
 real(kind=4), dimension(xgrid,ygrid,zgrid) :: ${ffilename4}
 real(kind=4), dimension(xgrid,ygrid) :: ${ffilename5}
 real(kind=4), dimension(xgrid,ygrid,zgrid) :: ${ffilename6}
 real(kind=4), dimension(xgrid,ygrid) :: ${ffilename7}

 real(kind=4), dimension(zgrid) :: output_rv
 real(kind=4), dimension(zgrid) :: output_ept
 real(kind=4), dimension(zgrid) :: cal_p

 real(kind=4), dimension(xgrid,ygrid,zgrid) :: pt
 real(kind=4), dimension(xgrid,ygrid,zgrid) :: es
 real(kind=4), dimension(xgrid,ygrid,zgrid) :: ws
 real(kind=4), dimension(xgrid,ygrid,zgrid) :: ept

 real(kind=4), dimension(xgrid,ygrid) :: pts
 real(kind=4), dimension(xgrid,ygrid) :: ess
 real(kind=4), dimension(xgrid,ygrid) :: wss
 real(kind=4), dimension(xgrid,ygrid) :: epts


 real(kind=4) :: pn, ppn, lonn, latn, plonn, platn, v1n, v2n, vlonn, vlatn, vmaxn, x
 real(kind=4) :: cwc_sum, avcwc, allarea_avcwc
 real(kind=4) :: p, axcel_avcwc, l_axcel
 real(kind=4) :: rv_sum, avrv, avrvsrf
 real(kind=4) :: ept_sum, epts_sum, avept, aveptsrf, rde, cpe, le, c1, c2, c3, c4

ngrid2=xgrid*ygrid
ngrid3=xgrid*ygrid*zgrid

open (unit=11,file='${ffilename1}.grd',form='unformatted',access='direct',recl=ngrid2*4)
read (unit=11,rec=1) ${ffilename1}
open (unit=12,file='${ffilename2}.grd',form='unformatted',access='direct',recl=ngrid2*4)
read (unit=12,rec=1)  ${ffilename2}
open (unit=13,file='${ffilename3}.grd',form='unformatted',access='direct',recl=ngrid2*4)
read (unit=13,rec=1)  ${ffilename3}
open (unit=14,file='${ffilename4}.grd',form='unformatted',access='direct',recl=ngrid3*4)
read (unit=14,rec=1)  ${ffilename4}
open (unit=15,file='${ffilename5}.grd',form='unformatted',access='direct',recl=ngrid2*4)
read (unit=15,rec=1)  ${ffilename5}
open (unit=16,file='${ffilename6}.grd',form='unformatted',access='direct',recl=ngrid3*4)
read (unit=16,rec=1)  ${ffilename6}
open (unit=17,file='${ffilename7}.grd',form='unformatted',access='direct',recl=ngrid2*4)
read (unit=17,rec=1)  ${ffilename7}

open (unit=31, file='${ofname1}.txt', position='append', form='FORMATTED')
!open (unit=32, file='${ofname2}.txt', position='append', form='FORMATTED')
open (unit=33, file='${ofname3}.txt', position='append', form='FORMATTED')


!!!!!!!check rv
!do k = 1, ${zgrid}
!write(*,*) 'rv(100,100,k) ', rv(100,100,k)
!enddo
!!!!!!!check t
!do k = 1, ${zgrid}
!write(*,*) 't(100,100,k) ', t(100,100,k)
!enddo

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!find axcel pmin lon,lat
pn=2000
do i = 83, 277 !145~180
   do j = 255, 388 !1~25 @NH
    ppn= psea(i-1,j) + psea(i+1,j) + psea(i,j-1) + psea(i,j-1)
    ppn= ppn / 4
      if (psea(i,j) < ppn) then   
    if (psea(i,j) < pn) then
        pn=psea(i,j)
        kxn=i
        kyn=j
    endif
      endif   
   n=n+1  
   enddo
enddo
pkxn=kxn
pkyn=kyn

!pmin location
plonn=kxn*${gsize2}${f_lon}
platn=kyn*${gsize2}${f_lat}

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!find axcel vmax vlon,vlat
v1n=1

is=kxn-10
js=kyn-10
ie=kxn+10
je=kyn+10

do  i = is, ie
    do j = js, je
    v2n= v(i-1,j) + v(i+1,j) + v(i,j-1) + v(i,j-1)
    v2n= v2n / 4
      if (v(i,j) > v2n) then   
    if (v(i,j) > v1n) then
        kxn=i
        kyn=j
        v1n=v(i,j)   
    endif
      endif   
    enddo
enddo

vlonn=kxn*${gsize2}${f_lon}
vlatn=kyn*${gsize2}${f_lat}


!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
! cal ept
!ept 1~zgrid

!equipment
cal_p(1)=1000
cal_p(2)=975
cal_p(3)=950
cal_p(4)=925
cal_p(5)=900
cal_p(6)=850
cal_p(7)=800
cal_p(8)=700
cal_p(9)=600
cal_p(10)=500
cal_p(11)=400
cal_p(12)=300
cal_p(13)=250
cal_p(14)=200
cal_p(15)=150
cal_p(16)=100

rde=287
cpe=1004
le=2500000

c2=rde/cpe
c3=le/cpe


!ept_sum, avept, aveptsrf, rde, cpe, le, pt, c1, c2, c3, c4
!rde, cpe, le, pt, c1, c2, c3, c4

pt(i,j,k)=1
es(i,j,k)=1
ws(i,j,k)=1
ept(i,j,k)=1


!cal ept z 1~zgrid
do k = 1, ${zgrid}
do i = 1, ${xgrid}
    do j = 1, ${ygrid}
    c1=1000/cal_p(k)
    pt(i,j,k)=c1**c2
    pt(i,j,k)=pt(i,j,k)*t(i,j,k)
        es(i,j,k)=17.27*(t(i,j,k)-273.15)/(t(i,j,k)-35.86) !#tetens
        es(i,j,k)=exp(es(i,j,k))
        ws(i,j,k)=0.622*es(i,j,k)/cal_p(k)
            ept(i,j,k)=le*ws(i,j,k)/cpe
            ept(i,j,k)=ept(i,j,k)/t(i,j,k)
            ept(i,j,k)=pt(i,j,k)*exp(ept(i,j,k))
    enddo
enddo
enddo

!!!!!!!check ept
!do k = 1, ${zgrid}
!write(*,*) 'ept(100,100,k) ', ept(100,100,k)
!enddo


!ept 1~zgrid
step=0
ept_sum=0

do k = 1, ${zgrid}
do i = 1, ${xgrid}
    do j = 1, ${ygrid}
     l_axcel=(i-pkxn)**2+(j-pkyn)**2
        l_axcel=(l_axcel)**0.5
        l_axcel=l_axcel*${gsize1} !between axcel(pmin) and point
        if (l_axcel < ${ll_km}) then!       
        ept_sum = ept_sum + ept(i,j,k)
        step = step + 1
!write(*,*) 'ept_sum ept(i,j,k) step i j k', ept_sum, ept(i,j,k), step, i, j, k
!write(*,*) pkxn, pkyn, 'step', 'ept_sum', step, ept_sum, l_axcel, i, j
        endif   
    l_axcel=0   
    enddo
enddo
output_ept(k) = ept_sum / step
!write(*,*) 'output_ept(k) k', output_ept(k), step, k
step=0
ept_sum=0
enddo


! real(kind=4) :: ept_sum, avept, aveptsrf, rde, cpe, le, c1, c2, c3, c4, avept, aveptsrf
!ept srf
!cal ept srf use kousiki

!cal ept z 1~zgrid
do i = 1, ${xgrid}
    do j = 1, ${ygrid}
    c1=1000/1000
    pts(i,j)=c1**c2
    pts(i,j)=pts(i,j)*tsrf(i,j)
        ess(i,j)=17.27*(tsrf(i,j)-273.15)/(tsrf(i,j)-35.86) !#tetens
        ess(i,j)=exp(ess(i,j))
        wss(i,j)=0.622*ess(i,j)/1000
            epts(i,j)=le*wss(i,j)/cpe
            epts(i,j)=epts(i,j)/tsrf(i,j)
            epts(i,j)=pts(i,j)*exp(epts(i,j))
    enddo
enddo


!do i = 150, 200
!write(*,*) 'pts, ess, wss epts(272,294)', pts(272,294), ess(272,294), wss(272,294), epts(272,294)
!enddo

step=0
epts_sum=0

do i = 1, ${xgrid}
    do j = 1, ${ygrid}
    l_axcel=(i-pkxn)**2+(j-pkyn)**2
        l_axcel=(l_axcel)**0.5
        l_axcel=l_axcel*${gsize1} !between axcel(pmin) and point
        if (l_axcel < ${ll_km}) then
if (epts(i,j)<1000) then
        epts_sum = epts_sum + epts(i,j)
        step = step + 1
!write(*,*) 'epts_sum epts(i,j) step i j', epts_sum, epts(i,j), step, i, j
!write(*,*) pkxn, pkyn, 'step', 'epts_sum', step, ept_sum, l_axcel, i, j
endif
        endif   
    l_axcel=0   
    enddo
enddo
aveptsrf = epts_sum / step
!write(*,*) 'aveptsrf ', aveptsrf, step


!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!! output data
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

write(31,*) ${time_step}, pn, plonn, platn, v1n, allarea_avcwc, axcel_avcwc
write(*,*) ${time_step}, pn, plonn, platn, v1n, allarea_avcwc, axcel_avcwc

!write(32,*) ${time_step}, pn, plonn, platn, v1n, axcel_avcwc, avrvsrf, output_rv(1), output_rv(7), output_rv(9), output_rv(11), output_rv(14)
!write(*,*) ${time_step}, pn, plonn, platn, v1n, axcel_avcwc, avrvsrf, output_rv(1), output_rv(7), output_rv(9), output_rv(11), output_rv(14)

!write(33,*) 'time_step pn plonn platn v1n aveptsrf output_ept1000 output_ept800 output_ept600 output_ept400'
write(33,*) ${time_step}, pn, plonn, platn, v1n, aveptsrf, output_ept(1), output_ept(7), output_ept(9), output_ept(11)
write(*,*) ${time_step}, pn, plonn, platn, v1n, aveptsrf, output_ept(1), output_ept(7), output_ept(9), output_ept(11)

close(11)
close(12)
close(13)
close(14)
close(15)
close(16)
close(17)

close(31)
!close(32)
close(33)

end program 
EOF



##output data.txt by f90
f90 -o ${filename2}.out ${filename2}.f90
./${filename2}.out

#echo ${day}
#echo "yoshiyoshi"
i=`expr $i + 1`
#echo $i

#hour=`expr $hour + 1`
hour=`expr $hour + $timestep`
hour=`echo ${hour} | awk '{printf("%02d",$1)}'`


if [ $hour -eq 24 ]; then
    hour=00
#    day=`expr $day + 1`
        day=`echo ${day} | awk '{printf("%02d",$1+1)}'`
   
    if [ $day -ge 32 ];then
        day=01
#        month=`expr $month + 1`
        month=`echo ${month} | awk '{printf("%02d",$1+1)}'`
   
        if [ $month -ge 13 ];then
            month=01
            year=`expr $year + 1`

        fi   
    fi   
fi
time=${year}${month}${day}${hour}${h}


done

cp ${ofname1}.txt ${ofname1}.dat
cp ${ofname2}.txt ${ofname2}.dat
cp ${ofname3}.txt ${ofname3}.dat

0 件のコメント:

コメントを投稿