!----------------------------------------------------------------------
!     Copyright (c) 2024 Shin-ichi Takehiro. All rights reserved.
!----------------------------------------------------------------------
!
!表題  wt_zonal_module テストプログラム
!
!      微分のテスト
!  
!履歴  2024/02/19  竹広真一  wt_wave_module_derivative_test1.f90 から改造
!
program wt_zonal_module_derivative_test1

  use dc_message, only : MessageNotify
  use dc_test, only : AssertEqual
  use wt_zonal_module
  implicit none

  integer,parameter  :: im=1,  jm=16, km=16  ! 格子点の設定(経度, 緯度, 動径)
  integer,parameter  :: nm=10, lm=16         ! 切断波数の設定(水平, 動径)
  real(8),parameter  :: ri=0.5, ro=1.5       ! 内外半径

  real(8), dimension(0:im-1,1:jm,0:km)     :: xyz_Data
  real(8), dimension(0:im-1,1:jm,0:km)     :: xyz_DData

  real(8), dimension(0:im-1,1:jm,0:km)     :: xyz_VLon
  real(8), dimension(0:im-1,1:jm,0:km)     :: xyz_VLat
  real(8), dimension(0:im-1,1:jm,0:km)     :: xyz_VRad
  real(8), dimension(0:im-1,1:jm,0:km)     :: xyz_Div
  real(8), dimension(0:im-1,1:jm,0:km)     :: xyz_Psi


  ! 判定誤差設定
  integer, parameter :: check_digits = 10
  integer, parameter :: ignore = -11

  integer, parameter :: nmin=1, nmax=9

  integer :: n, j

  call MessageNotify('M','wt_zonal_module_derivative_test1', &
       'wt_zonal_module derivative function test #1')

  call wt_Initial(im,jm,km,nm,lm,ri,ro)

  !==================== wt_DivRad_wt ====================
  do n=nmin,nmax
     write(6,*) 'n=',n
     xyz_Data = xyz_Rad**n * sin(xyz_Lat)
     xyz_DData = (n+2)*xyz_Rad**(n-1) * sin(xyz_Lat)

     call AssertEqual(&
       message='wt_DivRad_wt with r^n',                            &
       answer = xyz_DData,                                         &
       check = xyz_wt(wt_DivRad_wt(wt_xyz(xyz_Data))),             &
       significant_digits = check_digits, ignore_digits = ignore   &
       )
  enddo

  !========== xyz_GradLon_wt, xyz_GradLat_wt, wt_Div_xyz_xyz_xyz ==========

  ! ------ r^2 P_1^0 Toloidal field -----
  n = 2
  write(6,*) 'n=',n
  xyz_Psi = xyz_Rad**n * sin(xyz_Lat)   ! r^2 P_1^0
  xyz_VRad = 0

  xyz_VLon = 0.0D0
  call AssertEqual(&
       message='xyz_GradLon_wt with r^2 P_1^0',                      &
       answer = xyz_VLon,                                            &
       check = xyz_GradLon_wt(wt_xyz(xyz_Psi)),                      &
       significant_digits = check_digits, ignore_digits = ignore     &
       )

  xyz_VLat = xyz_Rad**(n-1)*cos(xyz_Lat)
  call AssertEqual(&
       message='xyz_GradLat_wt with r^2 P_1^0',                     &
       answer = xyz_VLat,                                           &
       check = xyz_GradLat_wt(wt_xyz(xyz_Psi)),                     &
       significant_digits = check_digits, ignore_digits = ignore    &
       )

  xyz_Div = - 2 * xyz_Psi/xyz_Rad**2
  call AssertEqual(&
       message='wt_Div_xyz_xyz_xyz with Toroiral r^2 P_1^0',         &
       answer = xyz_Div,                                             &
       check = xyz_wt(wt_Div_xyz_xyz_xyz(xyz_VLon,xyz_VLat,xyz_VRad)),&
       significant_digits = check_digits, ignore_digits = ignore     &
       )

  ! ------ r^2 P_2^0 Toloidal field -----
  n = 2
  xyz_VRad = 0
  xyz_Psi = xyz_Rad**n * sqrt(5.0D0)*(3.0D0*sin(xyz_Lat)**2-1.0D0)/2.0D0 ! r^2 P_2^0

  xyz_VLon = 0.0D0
  call AssertEqual(&
       message='xyz_GradLon_wt with r^2 P_2^0',                     &
       answer = xyz_VLon,                                           &
       check =  xyz_GradLon_wt(wt_xyz(xyz_Psi)),                    &
       significant_digits = check_digits, ignore_digits = ignore    &
       )

  xyz_VLat = xyz_Rad**(n-1)*sqrt(5.0D0)*3.0D0*sin(xyz_Lat)*cos(xyz_Lat)
  call AssertEqual(&
       message='xyz_GradLat_wt with r^2 P_2^0',                     &
       answer = xyz_VLat,                                           &
       check = xyz_GradLat_wt(wt_xyz(xyz_Psi)),                     &
       significant_digits = check_digits, ignore_digits = ignore    &
       )

  xyz_Div = - 6* xyz_Psi/xyz_Rad**2
  call AssertEqual(&
       message='wt_Div_xyz_xyz_xyz with Toroiral r2 P_2^0',           &
       answer = xyz_Div,                                              &
       check = xyz_wt(wt_Div_xyz_xyz_xyz(xyz_VLon,xyz_VLat,xyz_VRad)),&
       significant_digits = check_digits, ignore_digits = ignore      &
       )

  !==================== wt_DivLon_xyz, wt_DivLat_xyz ====================
  n=2
  write(6,*)'n =',n

  xyz_VLon  = xyz_rad**n * sqrt(3.0D0)*sin(xyz_Lat)*cos(xyz_Lat)
  xyz_DData = 0.0D0
  call AssertEqual(&
       message='wt_DivLon_xyz with r^n P_1^0 cos φ',               &
       answer = xyz_DData,                                          &
       check = xyz_wt(wt_DivLon_xyz(xyz_VLon)),                     &
       significant_digits = check_digits, ignore_digits = ignore    &
       )

  xyz_VLat  = xyz_rad**n * sqrt(3.0D0)*sin(xyz_Lat)*cos(xyz_Lat)
  xyz_DData = xyz_rad**(n-1)*sqrt(3.0D0)*(1.0D0-3.0D0*sin(xyz_Lat)**2) 
  call AssertEqual(&
       message='wt_DivLat_xyz with r^n P_1^1cosφ',                 &
       answer = xyz_DData,                                          &
       check = xyz_wt(wt_DivLat_xyz(xyz_VLat)),                     &
       significant_digits = check_digits, ignore_digits = ignore    &
       )

  call MessageNotify('M','wt_zonal_module_derivative_test1', &
       'wt_zonal_module derivative function test #1 succeeded!')

end program wt_zonal_module_derivative_test1


