Class | xyz_deriv_module |
In: |
../src/utils/xyz_deriv_module.f90
|
xyz_deriv_module は, 3 次元 (xyz 方向) 不等間隔交互格子を用いた有限差分 法に基づく数値モデルのための, 微分演算を行う Fortran90 関数を提供する. 微分演算は 2 次精度中心差分を用いて行う.
このモジュールは下請けモジュールとして xyz_base_module, data_type モジュールを用いている.
モジュール内の変数と手続きの命名方法については xyz_module を参照のこと.
xyz_dx_pyz, pyz_dx_xyz : | x 方向 1 階微分を計算する |
xyz_dy_xqz, xqz_dy_xyz : | y 方向 1 階微分を計算する |
xyz_dz_xyr, xyr_dz_xyz : | z 方向 1 階微分を計算する |
Function : | |
paa_dx_xaa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
xaa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function paa_dx_xaa(xaa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: xaa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: paa_dx_xaa(imin:imax,jmin:jmax,kmin:kmax) integer :: ix ! 1 階微分の計算 ! do ix = imin, imax-1 paa_dx_xaa(ix,:,:) = (xaa_Var(ix+1,:,:)-xaa_Var(ix,:,:))/p_dx(ix) end do ! imax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! paa_dx_xaa(imax,:,:) = 1.0d10 end function paa_dx_xaa
Function : | |
aqa_dy_aya(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aya_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aqa_dy_aya(aya_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aya_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aqa_dy_aya(imin:imax,jmin:jmax,kmin:kmax) integer :: jy ! y 方向一様な場合は微分はゼロ. if (jmin == jmax) then aqa_dy_aya = 0.0d0 return end if ! 1 階微分の計算 ! do jy = jmin, jmax-1 aqa_dy_aya(:,jy,:) = (aya_Var(:,jy+1,:)-aya_Var(:,jy,:))/q_dy(jy) end do ! jmax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aqa_dy_aya(:,jmax,:) = 1.0d10 end function aqa_dy_aya
Function : | |
paa_dx_xaa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
xaa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function paa_dx_xaa(xaa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: xaa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: paa_dx_xaa(imin:imax,jmin:jmax,kmin:kmax) integer :: ix ! 1 階微分の計算 ! do ix = imin, imax-1 paa_dx_xaa(ix,:,:) = (xaa_Var(ix+1,:,:)-xaa_Var(ix,:,:))/p_dx(ix) end do ! imax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! paa_dx_xaa(imax,:,:) = 1.0d10 end function paa_dx_xaa
Function : | |
aar_dz_aaz(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aaz_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aar_dz_aaz(aaz_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aaz_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aar_dz_aaz(imin:imax,jmin:jmax,kmin:kmax) integer :: kz ! 1 階微分の計算 ! do kz = kmin, kmax-1 aar_dz_aaz(:,:,kz) = (aaz_Var(:,:,kz+1)-aaz_Var(:,:,kz))/r_dz(kz) end do ! kmax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aar_dz_aaz(:,:,kmax) = 1.0d10 end function aar_dz_aaz
Function : | |
paa_dx_xaa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
xaa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function paa_dx_xaa(xaa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: xaa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: paa_dx_xaa(imin:imax,jmin:jmax,kmin:kmax) integer :: ix ! 1 階微分の計算 ! do ix = imin, imax-1 paa_dx_xaa(ix,:,:) = (xaa_Var(ix+1,:,:)-xaa_Var(ix,:,:))/p_dx(ix) end do ! imax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! paa_dx_xaa(imax,:,:) = 1.0d10 end function paa_dx_xaa
Function : | |
aya_dy_aqa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aqa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aya_dy_aqa(aqa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aqa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aya_dy_aqa(imin:imax,jmin:jmax,kmin:kmax) integer :: jy ! y 方向一様な場合は微分はゼロ. if (jmin == jmax) then aya_dy_aqa = 0.0d0 return end if ! 1 階微分の計算 ! do jy = jmin+1, jmax aya_dy_aqa(:,jy,:) = (aqa_Var(:,jy,:)-aqa_Var(:,jy-1,:))/y_dy(jy) end do ! jmin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aya_dy_aqa(:,jmin,:) = 1.0d10 end function aya_dy_aqa
Function : | |
aaz_dz_aar(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aar_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aaz_dz_aar(aar_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aar_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aaz_dz_aar(imin:imax,jmin:jmax,kmin:kmax) integer :: kz ! 1 階微分の計算 ! do kz = kmin+1, kmax aaz_dz_aar(:,:,kz) = (aar_Var(:,:,kz)-aar_Var(:,:,kz-1))/z_dz(kz) end do ! kmin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aaz_dz_aar(:,:,kmin) = 1.0d10 end function aaz_dz_aar
Function : | |
aqa_dy_aya(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aya_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aqa_dy_aya(aya_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aya_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aqa_dy_aya(imin:imax,jmin:jmax,kmin:kmax) integer :: jy ! y 方向一様な場合は微分はゼロ. if (jmin == jmax) then aqa_dy_aya = 0.0d0 return end if ! 1 階微分の計算 ! do jy = jmin, jmax-1 aqa_dy_aya(:,jy,:) = (aya_Var(:,jy+1,:)-aya_Var(:,jy,:))/q_dy(jy) end do ! jmax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aqa_dy_aya(:,jmax,:) = 1.0d10 end function aqa_dy_aya
Function : | |
aar_dz_aaz(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aaz_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aar_dz_aaz(aaz_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aaz_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aar_dz_aaz(imin:imax,jmin:jmax,kmin:kmax) integer :: kz ! 1 階微分の計算 ! do kz = kmin, kmax-1 aar_dz_aaz(:,:,kz) = (aaz_Var(:,:,kz+1)-aaz_Var(:,:,kz))/r_dz(kz) end do ! kmax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aar_dz_aaz(:,:,kmax) = 1.0d10 end function aar_dz_aaz
Function : | |
xaa_dx_paa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
paa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function xaa_dx_paa(paa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: paa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: xaa_dx_paa(imin:imax,jmin:jmax,kmin:kmax) integer :: ix ! 1 階微分の計算 ! do ix = imin+1, imax xaa_dx_paa(ix,:,:) = (paa_Var(ix,:,:)-paa_Var(ix-1,:,:))/x_dx(ix) end do ! imin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! xaa_dx_paa(imin,:,:) = 1.0d10 end function xaa_dx_paa
Function : | |
aqa_dy_aya(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aya_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aqa_dy_aya(aya_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aya_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aqa_dy_aya(imin:imax,jmin:jmax,kmin:kmax) integer :: jy ! y 方向一様な場合は微分はゼロ. if (jmin == jmax) then aqa_dy_aya = 0.0d0 return end if ! 1 階微分の計算 ! do jy = jmin, jmax-1 aqa_dy_aya(:,jy,:) = (aya_Var(:,jy+1,:)-aya_Var(:,jy,:))/q_dy(jy) end do ! jmax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aqa_dy_aya(:,jmax,:) = 1.0d10 end function aqa_dy_aya
Function : | |
aaz_dz_aar(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aar_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aaz_dz_aar(aar_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aar_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aaz_dz_aar(imin:imax,jmin:jmax,kmin:kmax) integer :: kz ! 1 階微分の計算 ! do kz = kmin+1, kmax aaz_dz_aar(:,:,kz) = (aar_Var(:,:,kz)-aar_Var(:,:,kz-1))/z_dz(kz) end do ! kmin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aaz_dz_aar(:,:,kmin) = 1.0d10 end function aaz_dz_aar
Function : | |
xaa_dx_paa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
paa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function xaa_dx_paa(paa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: paa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: xaa_dx_paa(imin:imax,jmin:jmax,kmin:kmax) integer :: ix ! 1 階微分の計算 ! do ix = imin+1, imax xaa_dx_paa(ix,:,:) = (paa_Var(ix,:,:)-paa_Var(ix-1,:,:))/x_dx(ix) end do ! imin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! xaa_dx_paa(imin,:,:) = 1.0d10 end function xaa_dx_paa
Function : | |
aya_dy_aqa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aqa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aya_dy_aqa(aqa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aqa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aya_dy_aqa(imin:imax,jmin:jmax,kmin:kmax) integer :: jy ! y 方向一様な場合は微分はゼロ. if (jmin == jmax) then aya_dy_aqa = 0.0d0 return end if ! 1 階微分の計算 ! do jy = jmin+1, jmax aya_dy_aqa(:,jy,:) = (aqa_Var(:,jy,:)-aqa_Var(:,jy-1,:))/y_dy(jy) end do ! jmin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aya_dy_aqa(:,jmin,:) = 1.0d10 end function aya_dy_aqa
Function : | |
aar_dz_aaz(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aaz_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aar_dz_aaz(aaz_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aaz_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aar_dz_aaz(imin:imax,jmin:jmax,kmin:kmax) integer :: kz ! 1 階微分の計算 ! do kz = kmin, kmax-1 aar_dz_aaz(:,:,kz) = (aaz_Var(:,:,kz+1)-aaz_Var(:,:,kz))/r_dz(kz) end do ! kmax での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aar_dz_aaz(:,:,kmax) = 1.0d10 end function aar_dz_aaz
Function : | |
xaa_dx_paa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
paa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function xaa_dx_paa(paa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: paa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: xaa_dx_paa(imin:imax,jmin:jmax,kmin:kmax) integer :: ix ! 1 階微分の計算 ! do ix = imin+1, imax xaa_dx_paa(ix,:,:) = (paa_Var(ix,:,:)-paa_Var(ix-1,:,:))/x_dx(ix) end do ! imin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! xaa_dx_paa(imin,:,:) = 1.0d10 end function xaa_dx_paa
Function : | |
aya_dy_aqa(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aqa_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aya_dy_aqa(aqa_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aqa_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aya_dy_aqa(imin:imax,jmin:jmax,kmin:kmax) integer :: jy ! y 方向一様な場合は微分はゼロ. if (jmin == jmax) then aya_dy_aqa = 0.0d0 return end if ! 1 階微分の計算 ! do jy = jmin+1, jmax aya_dy_aqa(:,jy,:) = (aqa_Var(:,jy,:)-aqa_Var(:,jy-1,:))/y_dy(jy) end do ! jmin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aya_dy_aqa(:,jmin,:) = 1.0d10 end function aya_dy_aqa
Function : | |
aaz_dz_aar(imin:imax,jmin:jmax,kmin:kmax) : | real(DP) |
aar_Var(imin:imax,jmin:jmax,kmin:kmax) : | real(DP),intent(in) |
半整数格子点上の 1 階微分を計算する
function aaz_dz_aar(aar_Var) ! 半整数格子点上の 1 階微分を計算する real(DP),intent(in) :: aar_Var(imin:imax,jmin:jmax,kmin:kmax) real(DP) :: aaz_dz_aar(imin:imax,jmin:jmax,kmin:kmax) integer :: kz ! 1 階微分の計算 ! do kz = kmin+1, kmax aaz_dz_aar(:,:,kz) = (aar_Var(:,:,kz)-aar_Var(:,:,kz-1))/z_dz(kz) end do ! kmin での値は決まらないので, 値を入れておく. ! 計算領域に滲み出した時にわかるように, 大きな値を入れておく ! aaz_dz_aar(:,:,kmin) = 1.0d10 end function aaz_dz_aar