2003-04-16 06:28:05 +08:00
|
|
|
! * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
! Copyright by the Board of Trustees of the University of Illinois. *
|
|
|
|
! All rights reserved. *
|
|
|
|
! *
|
|
|
|
! This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
! terms governing use, modification, and redistribution, is contained in *
|
|
|
|
! the files COPYING and Copyright.html. COPYING can be found at the root *
|
|
|
|
! of the source code distribution tree; Copyright.html can be found at the *
|
|
|
|
! root level of an installed copy of the electronic HDF5 document set and *
|
|
|
|
! is linked from the top-level documents page. It can also be found at *
|
|
|
|
! http://hdf.ncsa.uiuc.edu/HDF5/doc/Copyright.html. If you do not have *
|
|
|
|
! access to either file, you may request a copy from hdfhelp@ncsa.uiuc.edu. *
|
|
|
|
! * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
!
|
2000-09-20 04:06:49 +08:00
|
|
|
!
|
|
|
|
! The following example shows how to write and read to/from an existing dataset.
|
|
|
|
! It opens the file created in the previous example, obtains the dataset
|
|
|
|
! identifier, writes the data to the dataset in the file,
|
|
|
|
! then reads the dataset to memory.
|
|
|
|
!
|
|
|
|
|
|
|
|
|
|
|
|
PROGRAM RWDSETEXAMPLE
|
|
|
|
|
|
|
|
USE HDF5 ! This module contains all necessary modules
|
|
|
|
|
|
|
|
IMPLICIT NONE
|
|
|
|
|
|
|
|
CHARACTER(LEN=8), PARAMETER :: filename = "dsetf.h5" ! File name
|
|
|
|
CHARACTER(LEN=4), PARAMETER :: dsetname = "dset" ! Dataset name
|
|
|
|
|
|
|
|
INTEGER(HID_T) :: file_id ! File identifier
|
|
|
|
INTEGER(HID_T) :: dset_id ! Dataset identifier
|
|
|
|
|
|
|
|
INTEGER :: error ! Error flag
|
|
|
|
INTEGER :: i, j
|
|
|
|
|
|
|
|
INTEGER, DIMENSION(4,6) :: dset_data, data_out ! Data buffers
|
2004-04-23 01:18:46 +08:00
|
|
|
INTEGER(HSIZE_T), DIMENSION(2) :: data_dims
|
2000-09-20 04:06:49 +08:00
|
|
|
|
|
|
|
!
|
|
|
|
! Initialize the dset_data array.
|
|
|
|
!
|
|
|
|
do i = 1, 4
|
|
|
|
do j = 1, 6
|
|
|
|
dset_data(i,j) = (i-1)*6 + j;
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
|
|
|
|
!
|
2000-11-04 03:49:59 +08:00
|
|
|
! Initialize FORTRAN interface.
|
2000-09-20 04:06:49 +08:00
|
|
|
!
|
2000-11-18 06:45:34 +08:00
|
|
|
CALL h5open_f(error)
|
2000-09-20 04:06:49 +08:00
|
|
|
|
|
|
|
!
|
|
|
|
! Open an existing file.
|
|
|
|
!
|
|
|
|
CALL h5fopen_f (filename, H5F_ACC_RDWR_F, file_id, error)
|
|
|
|
|
|
|
|
!
|
|
|
|
! Open an existing dataset.
|
|
|
|
!
|
|
|
|
CALL h5dopen_f(file_id, dsetname, dset_id, error)
|
|
|
|
|
|
|
|
!
|
|
|
|
! Write the dataset.
|
|
|
|
!
|
2001-04-27 11:52:24 +08:00
|
|
|
data_dims(1) = 4
|
|
|
|
data_dims(2) = 6
|
|
|
|
CALL h5dwrite_f(dset_id, H5T_NATIVE_INTEGER, dset_data, data_dims, error)
|
2000-09-20 04:06:49 +08:00
|
|
|
|
|
|
|
!
|
|
|
|
! Read the dataset.
|
|
|
|
!
|
2001-04-27 11:52:24 +08:00
|
|
|
CALL h5dread_f(dset_id, H5T_NATIVE_INTEGER, data_out, data_dims, error)
|
2000-09-20 04:06:49 +08:00
|
|
|
|
|
|
|
!
|
|
|
|
! Close the dataset.
|
|
|
|
!
|
|
|
|
CALL h5dclose_f(dset_id, error)
|
|
|
|
|
|
|
|
!
|
|
|
|
! Close the file.
|
|
|
|
!
|
|
|
|
CALL h5fclose_f(file_id, error)
|
|
|
|
|
|
|
|
!
|
2000-11-04 03:49:59 +08:00
|
|
|
! Close FORTRAN interface.
|
2000-09-20 04:06:49 +08:00
|
|
|
!
|
2000-11-18 06:45:34 +08:00
|
|
|
CALL h5close_f(error)
|
2000-09-20 04:06:49 +08:00
|
|
|
|
|
|
|
END PROGRAM RWDSETEXAMPLE
|
|
|
|
|
|
|
|
|
|
|
|
|