!--
!----------------------------------------------------------------------
!     Copyright (c) 2019-2020 Shin-ichi Takehiro. All rights reserved.
!----------------------------------------------------------------------
!表題  ua_mpi_module_mint
!
!   spml/ua_mpi_module モジュールは球面上での 2 次元流体運動を
!   球面調和函数を用いたスペクトル法によって数値計算するための
!   Fortran90 関数を提供する.
!
!   球面上の 1 層モデル用 w_module モジュールを多層モデル用に
!   拡張したものであり, 同時に複数個のスペクトルデータ, 格子点データに
!   対する変換が行える.
!
!   ua_module は実際には基本変換, 微分計算, 積分・平均計算,
!   スペクトル解析をそれぞれ担っている下部モジュール ua_base_module_sjpack,
!   ua_deriv_module, wa_integral_module,
!   wa_spectrum_module および 1 層用のモジュール w_module からなっている.
!
!   内部で ISPACK3 の SYPACK の Fortran77 サブルーチンを呼んでいる.
!   スペクトルデータおよび格子点データの格納方法や変換の詳しい計算法に
!   ついては ISPACK3/SYPACK のマニュアルを参照されたい.
!
!   関数, サブルーチンの名前と機能は wa_module のものと同じである.
!   したがって use 文を wa_module から wa_module に
!   変更するだけで SYPACK の機能が使えるようになる.
!
!   ただし l_nm, nm_l の使い方には注意されたい. wa_module の l_nm, nm_l は
!   wa_Initial で初期化しなくとも用いることができる(結果が切断波数に依らない)が,
!   wa_module のものは初期化したのちにしか使うことができない.
!
!履歴  2019/05/03  竹広真一
!      2020/01/25  竹広真一  u_xv, xv_u を ut_mpi_module から移動
!      2020/08/04  竹広真一  xvb <=> pva と wb 関数を追加
!      2020/11/10  竹広真一  セクター計算オプション導入
!
!++
module ua_mpi_module_mint
  !
  != ua_mpi_module
  !
  ! Authors:: Shin-ichi Takehiro, Youhei SASAKI
  ! Version:: $Id$
  ! Copyright&License:: See COPYRIGHT[link:../COPYRIGHT]
  !
  !== 概要
  !
  !   spml/ua_mpi_module モジュールは球面上での 2 次元流体運動を
  !   球面調和函数を用いたスペクトル法によって数値計算するための
  !   Fortran90 関数を提供する.
  !
  !   球面上の 1 層モデル用 w_module モジュールを多層モデル用に
  !   拡張したものであり, 同時に複数個のスペクトルデータ, 格子点データに
  !   対する変換が行える.
  !
  !   ua_module は実際には基本変換, 微分計算, 積分・平均計算,
  !   スペクトル解析をそれぞれ担っている下部モジュール wa_base_module_sjpack,
  !   wa_deriv_module, wa_integral_module,
  !   wa_spectrum_module および 1 層用のモジュール w_module からなっている.
  !
  !   内部で ISPACK3 の SYPACK の Fortran77 サブルーチンを呼んでいる.
  !   スペクトルデータおよび格子点データの格納方法や変換の詳しい計算法に
  !   ついては ISPACK3/SYPACK のマニュアルを参照されたい.
  !
  !   関数, サブルーチンの名前と機能は wa_module のものと同じである.
  !   したがって use 文を wa_module から wa_module に
  !   変更するだけで SYPACK の機能が使えるようになる.
  !
  !   ただし l_nm, nm_l の使い方には注意されたい. wa_module の l_nm, nm_l は
  !   wa_Initial で初期化しなくとも用いることができる(結果が切断波数に依らない)が,
  !   wa_module のものは初期化したのちにしか使うことができない.
  !
  !=== 命名法
  !
  ! * 関数名の先頭 (ua_, nma_, na_, xyb_, xa_, ya_, w_, xy_, x_, y_, a_) は,
  !   返す値の形を示している.
  !   wa_  :: 水平スペクトルデータの並んだ 2 次元配列(スペクトルデータの
  !           並びは SNPACK/ISPACK に従ったもの)
  !   nma_ :: スペクトルデータの並んだ 3 次元配列 (スペクトルデータの並びは
  !           全波数 n, 帯状波数 m で指定される 2 次元配列)
  !   na_  :: スペクトルデータの並んだ 2 次元配列 (スペクトルデータの並びは
  !           全波数 n で指定される 1 次元配列)
  !   xya_ :: 2 次元格子点データの並んだ 3 次元配列
  !   xa_  :: 経度方向 1 次元格子点データの並んだ 2 次元配列
  !   ya_  :: 緯度方向 1 次元格子点データの並んだ 2 次元配列
  !
  ! * 関数名の間の文字列(DLon, GradLat, GradLat, DivLon, DivLat, Lapla,
  !   LaplaInv, Jacobian)は, その関数の作用を表している.
  !
  ! * 関数名の最後 (_wa_wa, _wa, _xya, _xa, _ya, _w_w, _w, _xy, _x, _y) は,
  !   入力変数の形スペクトルデータおよび格子点データであることを示している.
  !   _wa    :: スペクトルデータの並んだ 2 次元配列
  !   _wa_wa :: 2 つのスペクトルデータの並んだ 2 次元配列
  !   _xya   :: 2 次元格子点データの並んだ 3 次元配列
  !   _xa    :: 経度方向 1 次元格子点データの並んだ 2 次元配列
  !   _ya    :: 緯度方向 1 次元格子点データの並んだ 2 次元配列
  !
  !=== 各データの種類の説明
  !
  ! * xya : 2 次元格子点データの並んだ 3 次元配列.
  !   * 変数の種類と次元は real(8), dimension(0:im-1,1:jm,:).
  !   * im, jm はそれぞれ経度, 緯度座標の格子点数であり, サブルーチン
  !     wa_Initial にてあらかじめ設定しておく.
  !   * 扱う第 3 次元の大きさの最大値を wa_Initial で設定しておく.
  !
  ! * wa : スペクトルデータの並んだ 2 次元配列.
  !   * 変数の種類と次元は real(8), dimension((nm+1)*(nm+1),:).
  !   * nm は球面調和函数の最大全波数であり, サブルーチン wa_Initial にて
  !     あらかじめ設定しておく.
  !   * スペクトルデータの格納のされ方は関数
  !     l_nm, nm_l によって調べることができる.
  !   * 扱う第 3 次元の大きさの最大値を wa_Initial で設定しておく.
  !
  ! * xa, ya : 経度, 緯度方向 1 次元格子点データ.
  !   * 変数の種類と次元はそれぞれ real(8), dimension(0:im-1,:)
  !     および real(8), dimension(1:jm,:).
  !
  ! * nma : スペクトルデータの並んだ 3 次元配列.
  !   * 変数の種類と次元は real(8), dimension(0:nm,-nm:nm,:).
  !   * 第 1 次元が水平全波数, 第 2 次元が帯状波数を表す.
  !   * nm は球面調和函数の最大全波数であり,
  !     サブルーチン wa_Initial にてあらかじめ設定しておく.
  !
  ! * na : スペクトルデータの並んだ 2 次元配列.
  !   * 変数の種類と次元は real(8), dimension(0:nm,:).
  !   *  第 1 次元が水平全波数を表す.nm は球面調和函数の最大全波数であり,
  !      サブルーチン wa_Initial にてあらかじめ設定しておく.
  !
  ! * wa_ で始まる関数が返す値はスペクトルデータの並んだ 2 次元配列に同じ.
  !
  ! * nma_ で始まる関数が返す値はスペクトルデータの並んだ 3 次元配列に同じ.
  !
  ! * na_ で始まる関数が返す値はスペクトルデータの並んだ 2 次元配列に同じ.
  !
  ! * xya_ で始まる関数が返す値は 2 次元格子点データの並んだ 3 次元配列に
  !   同じ.
  !
  ! * xa_, ya_ で始まる関数が返す値は 1 次元格子点データの並んだ 2 次元
  !   配列に同じ.
  !
  ! * スペクトルデータに対する微分等の作用とは, 対応する格子点データに
  !   微分などを作用させたデータをスペクトル変換したものことである.
  !
  !
  !== 変数・手続き群の要約
  !
  !==== 初期化
  !
  ! wa_Initial :: スペクトル変換の格子点数, 波数, 領域の大きさ,
  !            :: および同時に計算するデータの個数の最大値設定
  !
  !==== 終了処理
  !
  ! wa_Finalize :: モジュールの終了処理(割り付け配列の解放)をおこなう.
  !
  !==== 座標変数
  !
  ! x_Lon, y_Lat     ::  格子点座標(緯度, 経度座標)を格納した 1 次元配列
  ! x_Lon_Weight, y_Lat_Weight ::  重み座標を格納した 1 次元配列
  ! xy_Lon, xy_Lat   :: 格子点データの経度・緯度座標(X,Y)
  !                     (格子点データ型 2 次元配列)
  !
  !==== 基本変換
  !
  ! xya_wa, xy_w :: スペクトルデータから格子データへの変換(多層, 1 層用)
  ! wa_xya, w_xy :: 格子データからスペクトルデータへの変換(多層, 1 層用)
  ! l_nm, nm_l :: スペクトルデータの格納位置と全波数・帯状波数の変換
  ! w_StreamPotential2Vector :: 流線ポテンシャルから速度場計算
  ! w_Vector2VorDiv   :: 速度場から渦度発散を計算
  ! w_VectorCosLat2VorDiv   :: 速度場から渦度発散を計算
  ! wa_StreamPotential2Vector :: 流線ポテンシャルから速度場計算
  ! wa_Vector2VorDiv   :: 速度場から渦度発散を計算
  ! wa_VectorCosLat2VorDiv   :: 速度場から渦度発散を計算
  !
  !==== 微分
  !
  ! wa_Lapla_wa, w_Lapla_w        :: スペクトルデータにラプラシアンを
  !                                  作用させる(多層, 1 層用)
  ! rn                            :: スペクトルデータのラプラシアンを
  !                                  計算するための係数
  ! irm                           :: 経度微分演算用配列(未定義)
  ! wa_LaplaInv_wa, w_LaplaInv_w  :: スペクトルデータにラプラシアンの逆変換を
  !                                  作用させる(多層, 1 層用)
  ! wa_DLon_wa, w_DLon_w          :: スペクトルデータに
  !                                  経度微分∂/∂λを作用させる(多層, 1 層用)
  ! xya_GradLon_wa, xy_GradLon_w  :: スペクトルデータに
  !                                  勾配型経度微分 1/cosφ・∂/∂λ を
  !                                  作用させる(多層, 1 層用)
  ! xya_GradLat_wa, xy_GradLat_w  :: スペクトルデータに
  !                                  勾配型緯度微分 ∂/∂φ を
  !                                  作用させる(多層, 1 層用)
  ! wa_DivLon_xya, w_DivLon_xy    :: 格子データに
  !                                  発散型経度微分 1/cosφ・∂/∂λを
  !                                  作用させる(多層, 1 層用)
  ! wa_DivLat_xya, w_DivLat_xy    :: 格子データに
  !                                  発散型緯度微分 1/cosφ・∂(g cosφ)/∂φを
  !                                  作用させる (多層, 1 層用)
  ! wa_Div_xya_xya, w_Div_xy_xy   :: ベクトル成分である 2 つの格子データに
  !                                  発散を作用させる(多層, 1 層用)
  ! wa_Jacobian_wa_wa,w_Jacobian_w_w :: 2つのスペクトルデータからヤコビアンを
  !                                     計算する(多層, 1 層用)
  !
  !==== 微分(λ,μ=sinφ 座標)
  !
  ! xya_GradLambda_wa, xy_GradLambda_w  :: スペクトルデータに
  !                                        勾配型経度微分∂/∂λを作用させる
  !                                        (多層, 1 層用)
  ! xya_GradMu_wa, xy_GradMu_w          :: スペクトルデータに
  !                                        勾配型緯度微分(1-μ^2)∂/∂μ
  !                                        を作用させる
  !                                        (多層, 1 層用)
  ! wa_DivLambda_xya,w_DivLambda_xy     :: 格子データに発散型経度微分
  !                                        1 /(1-μ^2)・∂/∂λを作用させる
  !                                        (多層, 1 層用)
  !
  ! wa_DivMu_xya,w_DivMu_xy             :: 格子データに発散型緯度微分
  !                                        ∂/∂μを作用させる(多層, 1 層用)
  !
  !==== 補間計算
  !
  ! a_Interpolate_wa, Interpolate_w :: スペクトルデータから
  !                                    任意の点の関数値を計算する.
  !
  !==== 積分・平均
  !
  ! a_IntLonLat_xya, a_AvrLonLat_xya :: 2 次元格子点データの
  !                                     全領域積分および平均(多層用)
  ! IntLonLat_xy, AvrLonLat_xy       :: 2 次元格子点データの
  !                                     全領域積分および平均(1 層用)
  ! ya_IntLon_xya, ya_AvrLon_xya     :: 2 次元格子点データの
  !                                     経度方向積分および平均(多層用)
  ! y_IntLon_xy, y_AvrLon_xy         :: 2 次元格子点データの
  !                                     経度方向積分および平均(1 層用)
  ! a_IntLon_xa, a_AvrLon_xa         :: 1 次元(X)格子点データの
  !                                     経度方向積分および平均(多層用)
  ! IntLon_x, AvrLon_x               :: 1 次元(X)格子点データの
  !                                     経度方向積分および平均(1 層用)
  ! xa_IntLat_xya, x_AvrLat_xy       :: 2 次元格子点データの
  !                                     緯度方向積分および平均(多層用)
  ! x_IntLat_xy, x_AvrLat_xy         :: 2 次元格子点データの
  !                                     緯度方向積分および平均(1 層用)
  ! a_IntLat_ya, a_AvrLat_ya         :: 1 次元(Y)格子点データの
  !                                     緯度方向積分および平均(多層用)
  ! IntLat_y, AvrLat_y               :: 1 次元(Y)格子点データの
  !                                     緯度方向積分および平均(1 層用)
  !
  !==== スペクトル解析
  !
  ! nma_EnergyFromStreamfunc_wa,nm_EnergyFromStreamfunc_w   ::
  ! 流線関数からエネルギースペクトルを計算する
  ! (水平全波数 n, 帯状波数 m 空間)(多層, 1 層用)
  !
  ! na_EnergyFromStreamfunc_wa,n_EnergyFromStreamfunc_w     ::
  ! 流線関数からエネルギースペクトルを計算する
  ! (水平全波数 n 空間) (多層, 1 層用)
  !
  ! nma_EnstrophyFromStreamfunc_wa,nm_EnstrophyFromStreamfunc_w   ::
  ! 流線関数からエンストロフィースペクトルを計算する
  ! (水平全波数 n, 帯状波数 m 空間)(多層, 1 層用)
  !
  ! na_EnstrophyFromStreamfunc_wa,n_EnstrophyFromStreamfunc_w ::
  ! 流線関数からエンストロフィースペクトルを計算する(水平全波数 n 空間)
  ! (多層, 1 層用)
  !
  ! w_spectrum_VMiss              ::  欠損値
  !
  !
  use dc_message, only : MessageNotify
  use w_mpi_module_integral_mint
  use w_mpi_module_interpolate_mint
  use w_mpi_module_spectrum_mint
  use ua_mpi_module_base_mint
  use ua_mpi_module_deriv_mint
  use ua_mpi_module_integral_mint
  use ua_mpi_module_interpolate_mint
  use ua_mpi_module_spectrum_mint

  implicit none

  private
  public ua_mpi_Initial                       ! 初期化
  public ua_mpi_Finalize                      ! 終了処理

  public nproc_h, nproc_v
  public iproc_h, iproc_v

  public jc, nc
  public is, ie, ic
  public ks, ke, kc
  public nms, nme, nmc

  public l_nm, nm_l
  public lu_nm, nm_lu
  public kp_kl

  public xv_Lon, xv_Lat
  public x_Lon, v_Lat                          ! 格子座標
  public x_Lon_Weight, v_Lat_Weight            ! 格子座標重み
  public pv_Lon, pv_Lat
  public p_Lon                                 ! 格子座標
  public p_Lon_Weight                          ! 格子座標重み

  public ua_pva, pva_ua                        ! 変換関数(ua)
  public xvb_ua, ua_xvb                        ! 変換関数(ua)
  public pv_u, u_pv                            ! 変換関数(ua)
  public xv_u, u_xv                            ! 変換関数(ua)

  public wb_pva, pva_wb                        ! 変換関数(wb)
  public wb_xvb, xvb_wb                        ! 変換関数(wb)
  public pv_w, w_pv                            ! 変換関数(wb)
  public xv_w, w_xv                            ! 変換関数(wb)

  public xvb_pva, pva_xvb                      ! 変換関数
  public wb_ua, ua_wb                          ! 変換関数  
  public wa_ua, ua_wa                          ! 変換関数
  public xa_pa, pa_xa                          ! 変換関数
  public aa_ab, ab_aa                          ! 変換関数
  
  public ua_StreamPotential2VectorMPI          ! 流線ポテンシャルから速度場計算(ua)
  public ua_Vector2VorDivMPI                   ! 速度場から渦度発散を計算(ua)
  public ua_VectorCosLat2VorDivMPI             ! 速度場から渦度発散を計算(ua)
  public wb_StreamPotential2VectorMPI          ! 流線ポテンシャルから速度場計算(wa)
  public wb_Vector2VorDivMPI                   ! 速度場から渦度発散を計算(wa)
  public wb_VectorCosLat2VorDivMPI             ! 速度場から渦度発散を計算(wa)

  public rn, rnu                               ! ラプラシアンの係数配列

  public ua_Lapla_ua, ua_LaplaInv_ua          ! ラプラシアンと逆演算
  public ua_DLon_ua                           ! 経度微分
  public pva_GradLon_ua, pva_GradLat_ua       ! 勾配型微分
  public xvb_GradLon_ua, xvb_GradLat_ua       ! 勾配型微分
  public ua_DivLon_pva, ua_DivLat_pva         ! 発散型微分
  public ua_DivLon_xvb, ua_DivLat_xvb         ! 発散型微分
  public ua_Div_pva_pva                       ! 発散型微分
  public ua_Div_xvb_xvb                       ! 発散型微分
  public ua_JacobianMPI_ua_ua                 ! ヤコビアン
  public pva_GradLambda_ua, pva_GradMu_ua     ! 勾配型微分(λ,μ座標)
  public xvb_GradLambda_ua, xvb_GradMu_ua     ! 勾配型微分(λ,μ座標)
  public ua_DivLambda_pva, ua_DivMu_pva       ! 発散型微分(λ,μ座標)
  public ua_DivLambda_xvb, ua_DivMu_xvb       ! 発散型微分(λ,μ座標)

  public wb_Lapla_wb, wb_LaplaInv_wb          ! ラプラシアンと逆演算
  public wb_DLon_wb                           ! 経度微分
  public pva_GradLon_wb, pva_GradLat_wb       ! 勾配型微分
  public wb_DivLon_pva, wb_DivLat_pva         ! 発散型微分
  public wb_Div_pva_pva                       ! 発散型微分
  public wb_JacobianMPI_wb_wb                 ! ヤコビアン
  public pva_GradLambda_wb, pva_GradMu_wb     ! 勾配型微分(λ,μ座標)
  public wb_DivLambda_pva, wb_DivMu_pva       ! 発散型微分(λ,μ座標)

  public u_Lapla_u, u_LaplaInv_u              ! ラプラシアンと逆演算
  public u_DLon_u                             ! 経度微分
  public pv_GradLon_u, pv_GradLat_u           ! 勾配型微分
  public xv_GradLon_u, xv_GradLat_u           ! 勾配型微分
  public u_DivLon_pv, u_DivLat_pv             ! 発散型微分
  public u_DivLon_xv, u_DivLat_xv             ! 発散型微分
  public u_Div_pv_pv                          ! 発散型微分
  public u_Div_xv_xv                          ! 発散型微分  
  public u_JacobianMPI_u_u                    ! ヤコビアン
  public pv_GradLambda_u, pv_GradMu_u         ! 勾配型微分(λ,μ座標)
  public xv_GradLambda_u, xv_GradMu_u         ! 勾配型微分(λ,μ座標)
  public u_DivLambda_pv, u_DivMu_pv           ! 発散型微分(λ,μ座標)
  public u_DivLambda_xv, u_DivMu_xv           ! 発散型微分(λ,μ座標)

  public w_Lapla_w, w_LaplaInv_w              ! ラプラシアンと逆演算
  public w_DLon_w                             ! 経度微分
  public pv_GradLon_w, pv_GradLat_w           ! 勾配型微分
  public w_DivLon_pv, w_DivLat_pv             ! 発散型微分
  public w_Div_pv_pv                          ! 発散型微分
  public w_JacobianMPI_w_w                    ! ヤコビアン
  public pv_GradLambda_w, pv_GradMu_w         ! 勾配型微分(λ,μ座標)
  public w_DivLambda_pv, w_DivMu_pv           ! 発散型微分(λ,μ座標)

  public a_IntLonLat_pva, IntLonLat_pv        ! 緯度経度積分
  public va_IntLon_pva, a_IntLon_pa, IntLon_p ! 経度積分
  public pa_IntLat_pva, a_IntLat_va           ! 緯度積分
  public a_AvrLonLat_pva, AvrLonLat_pv        ! 緯度経度平均
  public va_AvrLon_pva, a_AvrLon_pa, AvrLon_p ! 経度平均
  public pa_AvrLat_pva, a_AvrLat_va           ! 緯度平均
  
  public b_IntLonLat_xvb                      ! 緯度経度積分
  public vb_IntLon_xvb, b_IntLon_xb           ! 経度積分
  public xb_IntLat_xvb, b_IntLat_vb           ! 緯度積分
  public b_AvrLonLat_xvb                      ! 緯度経度平均
  public vb_AvrLon_xvb, b_AvrLon_xb           ! 経度平均
  public xb_AvrLat_xvb, b_AvrLat_vb           ! 緯度平均

  public IntLonLat_xv                         ! 緯度経度積分
  public v_IntLon_xv, IntLon_x                ! 経度積分
  public x_IntLat_xv, IntLat_v                ! 緯度積分
  public AvrLonLat_xv                         ! 緯度経度平均
  public v_AvrLon_xv, AvrLon_x                ! 経度平均
  public x_AvrLat_xv, AvrLat_v                ! 緯度平均

  public b_Interpolate_ua                     ! 補間関数
  public b_Interpolate_wb                     ! 補間関数

  public nma_EnergyFromStreamfunc_ua          ! エネルギースペクトル
                                              ! (水平全波数 n, 帯状波数 m 空間)
  public na_EnergyFromStreamfunc_ua           ! エネルギースペクトル
                                              ! (水平全波数 n 空間)
  public nma_EnstrophyFromStreamfunc_ua       ! エンストロフィースペクトル
                                              ! (水平全波数 n, 帯状波数 m 空間)
  public na_EnstrophyFromStreamfunc_ua        ! エンストロフィースペクトル
                                              !  (水平全波数 n 空間)

  public nmb_EnergyFromStreamfunc_wb          ! エネルギースペクトル
                                              ! (水平全波数 n, 帯状波数 m 空間)
  public nb_EnergyFromStreamfunc_wb           ! エネルギースペクトル
                                              ! (水平全波数 n 空間)
  public nmb_EnstrophyFromStreamfunc_wb       ! エンストロフィースペクトル
                                              ! (水平全波数 n, 帯状波数 m 空間)
  public nb_EnstrophyFromStreamfunc_wb        ! エンストロフィースペクトル
                                              !  (水平全波数 n 空間)
  public ua_spectrum_VMiss                    ! 欠損値

  public nm_EnergyFromStreamfunc_w            ! エネルギースペクトル
                                              ! (水平全波数 n, 帯状波数 m 空間)
  public n_EnergyFromStreamfunc_w             ! エネルギースペクトル
                                              ! (水平全波数 n 空間)
  public nm_EnstrophyFromStreamfunc_w         ! エンストロフィースペクトル
                                              ! (水平全波数 n, 帯状波数 m 空間)
  public n_EnstrophyFromStreamfunc_w          ! エンストロフィースペクトル
                                              !  (水平全波数 n 空間)
  public w_spectrum_VMiss                     ! 欠損値

contains
  subroutine ua_mpi_Initial(n_in,i_in,j_in,k_in,np,npv,mint)
    !
    ! スペクトル変換の格子点数, 波数, 最大データ数(層数)および
    ! OPENMP 使用時の最大スレッド数を設定する.
    !
    ! 他の関数を呼ぶ前に, 最初にこのサブルーチンを呼んで初期設定を
    ! しなければならない.
    !
    ! SNPACK 用 wa_initial との互換性のために引数 k_in が用意されているが,
    ! このパラメターによって同時に処理できる変数の数(層数)を制限される事はない.
    !
    ! np_in に 1 より大きな値を指定すれば ISPACK の球面調和函数変換
    ! OPENMP 並列計算ルーチンが用いられる. 並列計算を実行するには,
    ! 実行時に環境変数 OMP_NUM_THREADS を np_in 以下の数字に設定する等の
    ! システムに応じた準備が必要となる.
    !
    ! np_in に 1 より大きな値を指定しなければ並列計算ルーチンは呼ばれない.
    !
    integer,intent(in) :: i_in                ! 格子点数(東西)
    integer,intent(in) :: j_in                ! 格子点数(南北)
    integer,intent(in) :: n_in                ! 切断波数
    integer,intent(in) :: k_in                ! 最大データ数(層数)
    integer,intent(in), optional :: np        ! OPENMP での最大スレッド数(dummy)
    integer,intent(in), optional :: npv       ! OPENMP での最大スレッド数
    integer,intent(in), optional :: mint      ! 経度方向対称性

    if ( present(np) ) &
      call MessageNotify('M','ua_mpi_Initial','Optional argument np is dummy')
    if ( present(npv) ) then
       if ( present(mint) ) then
          call ua_base_mpi_Initial(n_in,i_in,j_in,k_in,npv=npv,mint=mint)
       else
          call ua_base_mpi_Initial(n_in,i_in,j_in,k_in,npv=npv)
       endif
    else if ( present(mint) ) then
       call ua_base_mpi_Initial(n_in,i_in,j_in,k_in,mint=mint)
    else
       call ua_base_mpi_Initial(n_in,i_in,j_in,k_in)
    endif
    call ua_deriv_mpi_Initial

    call MessageNotify('M',&
      & 'ua_mpi_initial', &
      & 'ua_mpi_module_mint (2020/11/10) is initialized')

  end subroutine ua_mpi_Initial

  !--------------- 終了処理 -----------------
  subroutine ua_mpi_Finalize
    !
    ! モジュールの終了処理(割り付け配列の解放)をおこなう.
    !
    ! 解像度を変更する際にはこのサブルーチンを呼んで終了処理を
    ! おこなったのちに再度 ua_mpi_Initial で初期設定しなければ
    ! ならない.
    !
    call ua_base_mpi_Finalize
    call ua_deriv_mpi_Finalize

    call MessageNotify('M','ua_mpi_Finalize', &
      'ua_mpi_module_mint (2020/11/10) is finalized')

  end subroutine ua_mpi_Finalize

end module ua_mpi_module_mint
