data_readA4_C Subroutine

subroutine data_readA4_C(pname, Y1, order, wspace)

Arguments

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

Calls

proc~~data_reada4_c~2~~CallsGraph proc~data_reada4_c~2 data_readA4_C file_gunzip file_gunzip proc~data_reada4_c~2->file_gunzip file_gzip file_gzip proc~data_reada4_c~2->file_gzip free_unit free_unit proc~data_reada4_c~2->free_unit ioread_control ioread_control proc~data_reada4_c~2->ioread_control reg reg proc~data_reada4_c~2->reg

Source Code

subroutine data_readA4_C(pname,Y1,order,wspace)
  integer                       :: Ny1,Ny2,Ny3,Ny4
  integer                       :: i1,i2,i3,i4
  character(len=*)              :: pname
  complex(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)
  Ny4=size(Y1,4)
  !
  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
              do i4=1,Ny4
                 read(unit,*)Y1(i1,i2,i3,i4)
              enddo
           enddo
        enddo
     enddo
  case ("C")
     do i4=1,Ny4
        do i3=1,Ny3
           do i2=1,Ny2
              do i1=1,Ny1
                 read(unit,*)Y1(i1,i2,i3,i4)
              enddo
           enddo
        enddo
     enddo
  end select
  !
  close(unit)
  call file_gzip(reg(pname))
end subroutine data_readA4_C