data_readA3_R Subroutine

subroutine data_readA3_R(pname, Y1, order, wspace)

Arguments

Type IntentOptional Attributes Name
character(len=*) :: pname
real(kind=8), dimension(:,:,:) :: Y1
character(len=*), optional :: order
logical, optional :: wspace

Calls

proc~~data_reada3_r~2~~CallsGraph proc~data_reada3_r~2 data_readA3_R file_gunzip file_gunzip proc~data_reada3_r~2->file_gunzip file_gzip file_gzip proc~data_reada3_r~2->file_gzip free_unit free_unit proc~data_reada3_r~2->free_unit ioread_control ioread_control proc~data_reada3_r~2->ioread_control reg reg proc~data_reada3_r~2->reg

Source Code

subroutine data_readA3_R(pname,Y1,order,wspace)
  integer                   :: Ny1,Ny2,Ny3
  integer                   :: i1,i2,i3
  character(len=*)          :: pname
  real(8),dimension(:,:,:)  :: Y1
  character(len=*),optional :: order
  logical,optional          :: wspace
  character(len=1)          :: order_
  logical                   :: wspace_
  order_ = "R"   ; if(present(order))order_=trim(order(1:1))
  wspace_= .true.; if(present(wspace))wspace_=wspace
  !
  call file_gunzip(reg(pname))
  call ioread_control(pname,control)
  !
  open(free_unit(unit),file=reg(pname))
  !
  Ny1=size(Y1,1)
  Ny2=size(Y1,2)
  Ny3=size(Y1,3)
  !
  select case(order_)
  case default
     stop "read_array: order != Row-major, Col-major"
  case ("R")
     do i1=1,Ny1
        do i2=1,Ny2
           do i3=1,Ny3
              read(unit,*)Y1(i1,i2,i3)
           enddo
        enddo
     enddo
  case ("C")
     do i3=1,Ny3
        do i2=1,Ny2
           do i1=1,Ny1
              read(unit,*)Y1(i1,i2,i3)
           enddo
        enddo
     enddo
  end select
  close(unit)
  call file_gzip(reg(pname))
end subroutine data_readA3_R