vtk_fortran_vtk_file_xml_writer_binary_local.f90 Source File


This file depends on

sourcefile~~vtk_fortran_vtk_file_xml_writer_binary_local.f90~~EfferentGraph sourcefile~vtk_fortran_vtk_file_xml_writer_binary_local.f90 vtk_fortran_vtk_file_xml_writer_binary_local.f90 sourcefile~penf.f90 penf.F90 sourcefile~vtk_fortran_vtk_file_xml_writer_binary_local.f90->sourcefile~penf.f90 sourcefile~stringifor.f90 stringifor.F90 sourcefile~vtk_fortran_vtk_file_xml_writer_binary_local.f90->sourcefile~stringifor.f90 sourcefile~vtk_fortran_vtk_file_xml_writer_abstract.f90 vtk_fortran_vtk_file_xml_writer_abstract.f90 sourcefile~vtk_fortran_vtk_file_xml_writer_binary_local.f90->sourcefile~vtk_fortran_vtk_file_xml_writer_abstract.f90 sourcefile~vtk_fortran_dataarray_encoder.f90 vtk_fortran_dataarray_encoder.f90 sourcefile~vtk_fortran_vtk_file_xml_writer_binary_local.f90->sourcefile~vtk_fortran_dataarray_encoder.f90 sourcefile~penf_global_parameters_variables.f90 penf_global_parameters_variables.F90 sourcefile~penf.f90->sourcefile~penf_global_parameters_variables.f90 sourcefile~penf_b_size.f90 penf_b_size.F90 sourcefile~penf.f90->sourcefile~penf_b_size.f90 sourcefile~penf_stringify.f90 penf_stringify.F90 sourcefile~penf.f90->sourcefile~penf_stringify.f90 sourcefile~stringifor.f90->sourcefile~penf.f90 sourcefile~stringifor_string_t.f90 stringifor_string_t.F90 sourcefile~stringifor.f90->sourcefile~stringifor_string_t.f90 sourcefile~vtk_fortran_vtk_file_xml_writer_abstract.f90->sourcefile~penf.f90 sourcefile~vtk_fortran_vtk_file_xml_writer_abstract.f90->sourcefile~stringifor.f90 sourcefile~vtk_fortran_parameters.f90 vtk_fortran_parameters.f90 sourcefile~vtk_fortran_vtk_file_xml_writer_abstract.f90->sourcefile~vtk_fortran_parameters.f90 sourcefile~foxy.f90 foxy.f90 sourcefile~vtk_fortran_vtk_file_xml_writer_abstract.f90->sourcefile~foxy.f90 sourcefile~vtk_fortran_dataarray_encoder.f90->sourcefile~penf.f90 sourcefile~befor64.f90 befor64.F90 sourcefile~vtk_fortran_dataarray_encoder.f90->sourcefile~befor64.f90 sourcefile~stringifor_string_t.f90->sourcefile~penf.f90 sourcefile~stringifor_string_t.f90->sourcefile~befor64.f90 sourcefile~face.f90 face.F90 sourcefile~stringifor_string_t.f90->sourcefile~face.f90 sourcefile~penf_b_size.f90->sourcefile~penf_global_parameters_variables.f90 sourcefile~vtk_fortran_parameters.f90->sourcefile~penf.f90 sourcefile~foxy.f90->sourcefile~penf.f90 sourcefile~foxy_xml_file.f90 foxy_xml_file.f90 sourcefile~foxy.f90->sourcefile~foxy_xml_file.f90 sourcefile~foxy_xml_tag.f90 foxy_xml_tag.F90 sourcefile~foxy.f90->sourcefile~foxy_xml_tag.f90 sourcefile~penf_stringify.f90->sourcefile~penf_global_parameters_variables.f90 sourcefile~penf_stringify.f90->sourcefile~penf_b_size.f90 sourcefile~befor64.f90->sourcefile~penf.f90 sourcefile~befor64_pack_data_m.f90 befor64_pack_data_m.F90 sourcefile~befor64.f90->sourcefile~befor64_pack_data_m.f90 sourcefile~foxy_xml_file.f90->sourcefile~penf.f90 sourcefile~foxy_xml_file.f90->sourcefile~foxy_xml_tag.f90 sourcefile~foxy_xml_tag.f90->sourcefile~penf.f90 sourcefile~foxy_xml_tag.f90->sourcefile~stringifor.f90 sourcefile~befor64_pack_data_m.f90->sourcefile~penf.f90

Files dependent on this one

sourcefile~~vtk_fortran_vtk_file_xml_writer_binary_local.f90~~AfferentGraph sourcefile~vtk_fortran_vtk_file_xml_writer_binary_local.f90 vtk_fortran_vtk_file_xml_writer_binary_local.f90 sourcefile~vtk_fortran_vtk_file.f90 vtk_fortran_vtk_file.f90 sourcefile~vtk_fortran_vtk_file.f90->sourcefile~vtk_fortran_vtk_file_xml_writer_binary_local.f90 sourcefile~vtk_fortran.f90 vtk_fortran.f90 sourcefile~vtk_fortran.f90->sourcefile~vtk_fortran_vtk_file.f90 sourcefile~vtk_fortran_write_vtr.f90 vtk_fortran_write_vtr.f90 sourcefile~vtk_fortran_write_vtr.f90->sourcefile~vtk_fortran.f90 sourcefile~vtk_fortran_write_vts.f90 vtk_fortran_write_vts.f90 sourcefile~vtk_fortran_write_vts.f90->sourcefile~vtk_fortran.f90 sourcefile~vtk_fortran_write_vtu_tensor.f90 vtk_fortran_write_vtu_tensor.f90 sourcefile~vtk_fortran_write_vtu_tensor.f90->sourcefile~vtk_fortran.f90 sourcefile~vtk_fortran_write_vtm.f90 vtk_fortran_write_vtm.f90 sourcefile~vtk_fortran_write_vtm.f90->sourcefile~vtk_fortran.f90 sourcefile~vtk_fortran_write_vtu.f90 vtk_fortran_write_vtu.f90 sourcefile~vtk_fortran_write_vtu.f90->sourcefile~vtk_fortran.f90 sourcefile~vtk_fortran_write_volatile.f90 vtk_fortran_write_volatile.f90 sourcefile~vtk_fortran_write_volatile.f90->sourcefile~vtk_fortran.f90 sourcefile~vtk_fortran_use_module_basic.f90 vtk_fortran_use_module_basic.f90 sourcefile~vtk_fortran_use_module_basic.f90->sourcefile~vtk_fortran.f90 sourcefile~vtk_fortran_write_pvts.f90 vtk_fortran_write_pvts.f90 sourcefile~vtk_fortran_write_pvts.f90->sourcefile~vtk_fortran.f90

Contents


Source Code

!< VTK file XMl writer, binary local.
module vtk_fortran_vtk_file_xml_writer_binary_local
!< VTK file XMl writer, binary local.
!<
!< This writer is (currently) the only one able also to create a *volatile* file (enabling volatile option).
!< Instead of saving data into a real file on the system, this writer can save data into a (volatile) characters string that can be
!< used also on (slave) processes that have not access to filesystem: the volatile string can be easily sent to other (master)
!< processes having access to filesytem. The volatile writer mode is designed to facilitate the use of the library in parallel
!< envinroments wehere not all processes/threads have access to filesystem.
use penf
use stringifor
use vtk_fortran_dataarray_encoder
use vtk_fortran_vtk_file_xml_writer_abstract

implicit none
private
public :: xml_writer_binary_local

type, extends(xml_writer_abstract) :: xml_writer_binary_local
   !< VTK file XML writer, binary local.
   contains
      ! deferred methods
      procedure, pass(self) :: initialize                 !< Initialize writer.
      procedure, pass(self) :: finalize                   !< Finalize writer.
      procedure, pass(self) :: write_dataarray1_rank1_R8P !< Write dataarray 1, rank 1, R8P.
      procedure, pass(self) :: write_dataarray1_rank1_R4P !< Write dataarray 1, rank 1, R4P.
      procedure, pass(self) :: write_dataarray1_rank1_I8P !< Write dataarray 1, rank 1, I8P.
      procedure, pass(self) :: write_dataarray1_rank1_I4P !< Write dataarray 1, rank 1, I4P.
      procedure, pass(self) :: write_dataarray1_rank1_I2P !< Write dataarray 1, rank 1, I2P.
      procedure, pass(self) :: write_dataarray1_rank1_I1P !< Write dataarray 1, rank 1, I1P.
      procedure, pass(self) :: write_dataarray1_rank2_R8P !< Write dataarray 1, rank 2, R8P.
      procedure, pass(self) :: write_dataarray1_rank2_R4P !< Write dataarray 1, rank 2, R4P.
      procedure, pass(self) :: write_dataarray1_rank2_I8P !< Write dataarray 1, rank 2, I8P.
      procedure, pass(self) :: write_dataarray1_rank2_I4P !< Write dataarray 1, rank 2, I4P.
      procedure, pass(self) :: write_dataarray1_rank2_I2P !< Write dataarray 1, rank 2, I2P.
      procedure, pass(self) :: write_dataarray1_rank2_I1P !< Write dataarray 1, rank 2, I1P.
      procedure, pass(self) :: write_dataarray1_rank3_R8P !< Write dataarray 1, rank 3, R8P.
      procedure, pass(self) :: write_dataarray1_rank3_R4P !< Write dataarray 1, rank 3, R4P.
      procedure, pass(self) :: write_dataarray1_rank3_I8P !< Write dataarray 1, rank 3, I8P.
      procedure, pass(self) :: write_dataarray1_rank3_I4P !< Write dataarray 1, rank 3, I4P.
      procedure, pass(self) :: write_dataarray1_rank3_I2P !< Write dataarray 1, rank 3, I2P.
      procedure, pass(self) :: write_dataarray1_rank3_I1P !< Write dataarray 1, rank 3, I1P.
      procedure, pass(self) :: write_dataarray1_rank4_R8P !< Write dataarray 1, rank 4, R8P.
      procedure, pass(self) :: write_dataarray1_rank4_R4P !< Write dataarray 1, rank 4, R4P.
      procedure, pass(self) :: write_dataarray1_rank4_I8P !< Write dataarray 1, rank 4, I8P.
      procedure, pass(self) :: write_dataarray1_rank4_I4P !< Write dataarray 1, rank 4, I4P.
      procedure, pass(self) :: write_dataarray1_rank4_I2P !< Write dataarray 1, rank 4, I2P.
      procedure, pass(self) :: write_dataarray1_rank4_I1P !< Write dataarray 1, rank 4, I1P.
      procedure, pass(self) :: write_dataarray3_rank1_R8P !< Write dataarray 3, rank 1, R8P.
      procedure, pass(self) :: write_dataarray3_rank1_R4P !< Write dataarray 3, rank 1, R4P.
      procedure, pass(self) :: write_dataarray3_rank1_I8P !< Write dataarray 3, rank 1, I8P.
      procedure, pass(self) :: write_dataarray3_rank1_I4P !< Write dataarray 3, rank 1, I4P.
      procedure, pass(self) :: write_dataarray3_rank1_I2P !< Write dataarray 3, rank 1, I2P.
      procedure, pass(self) :: write_dataarray3_rank1_I1P !< Write dataarray 3, rank 1, I1P.
      procedure, pass(self) :: write_dataarray3_rank3_R8P !< Write dataarray 3, rank 3, R8P.
      procedure, pass(self) :: write_dataarray3_rank3_R4P !< Write dataarray 3, rank 3, R4P.
      procedure, pass(self) :: write_dataarray3_rank3_I8P !< Write dataarray 3, rank 3, I8P.
      procedure, pass(self) :: write_dataarray3_rank3_I4P !< Write dataarray 3, rank 3, I4P.
      procedure, pass(self) :: write_dataarray3_rank3_I2P !< Write dataarray 3, rank 3, I2P.
      procedure, pass(self) :: write_dataarray3_rank3_I1P !< Write dataarray 3, rank 3, I1P.
      procedure, pass(self) :: write_dataarray6_rank1_R8P !< Write dataarray 6, rank 1, R8P.
      procedure, pass(self) :: write_dataarray6_rank1_R4P !< Write dataarray 6, rank 1, R4P.
      procedure, pass(self) :: write_dataarray6_rank1_I8P !< Write dataarray 6, rank 1, I8P.
      procedure, pass(self) :: write_dataarray6_rank1_I4P !< Write dataarray 6, rank 1, I4P.
      procedure, pass(self) :: write_dataarray6_rank1_I2P !< Write dataarray 6, rank 1, I2P.
      procedure, pass(self) :: write_dataarray6_rank1_I1P !< Write dataarray 6, rank 1, I1P.
      procedure, pass(self) :: write_dataarray6_rank3_R8P !< Write dataarray 6, rank 3, R8P.
      procedure, pass(self) :: write_dataarray6_rank3_R4P !< Write dataarray 6, rank 3, R4P.
      procedure, pass(self) :: write_dataarray6_rank3_I8P !< Write dataarray 6, rank 3, I8P.
      procedure, pass(self) :: write_dataarray6_rank3_I4P !< Write dataarray 6, rank 3, I4P.
      procedure, pass(self) :: write_dataarray6_rank3_I2P !< Write dataarray 6, rank 3, I2P.
      procedure, pass(self) :: write_dataarray6_rank3_I1P !< Write dataarray 6, rank 3, I1P.
      procedure, pass(self) :: write_dataarray_appended   !< Write appended.
endtype xml_writer_binary_local
contains
   function initialize(self, format, filename, mesh_topology, nx1, nx2, ny1, ny2, nz1, nz2, &
                       is_volatile, mesh_kind) result(error)
   !< Initialize writer.
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: format        !< File format: binary.
   character(*),                   intent(in)           :: filename      !< File name.
   character(*),                   intent(in)           :: mesh_topology !< Mesh topology.
   integer(I4P),                   intent(in), optional :: nx1           !< Initial node of x axis.
   integer(I4P),                   intent(in), optional :: nx2           !< Final node of x axis.
   integer(I4P),                   intent(in), optional :: ny1           !< Initial node of y axis.
   integer(I4P),                   intent(in), optional :: ny2           !< Final node of y axis.
   integer(I4P),                   intent(in), optional :: nz1           !< Initial node of z axis.
   integer(I4P),                   intent(in), optional :: nz2           !< Final node of z axis.
   character(*),                   intent(in), optional :: mesh_kind     !< Kind of mesh data: Float64, Float32, ecc.
   logical,                        intent(in), optional :: is_volatile   !< Flag to check volatile writer.
   integer(I4P)                                         :: error         !< Error status.

   self%is_volatile = .false. ; if (present(is_volatile)) self%is_volatile = is_volatile
   self%topology = trim(adjustl(mesh_topology))
   self%format_ch = format
   self%format_ch = self%format_ch%lower()
   call self%open_xml_file(filename=filename)
   call self%write_header_tag
   call self%write_topology_tag(nx1=nx1, nx2=nx2, ny1=ny1, ny2=ny2, nz1=nz1, nz2=nz2, mesh_kind=mesh_kind)
   error = self%error
   endfunction initialize

   function finalize(self) result(error)
   !< Finalize writer.
   class(xml_writer_binary_local), intent(inout) :: self  !< Writer.
   integer(I4P)                                  :: error !< Error status.

   call self%write_end_tag(name=self%topology%chars())
   call self%write_end_tag(name='VTKFile')
   call self%close_xml_file
   error = self%error
   endfunction finalize

   ! write_dataarray methods
   function write_dataarray1_rank1_R8P(self, data_name, x, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="1"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R8P),                      intent(in)           :: x(1:)        !< Data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = 1
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank1_R8P

   function write_dataarray1_rank1_R4P(self, data_name, x, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="1"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R4P),                      intent(in)           :: x(1:)        !< Data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = 1
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank1_R4P

   function write_dataarray1_rank1_I8P(self, data_name, x, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="1"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I8P),                   intent(in)           :: x(1:)        !< Data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = 1
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank1_I8P

   function write_dataarray1_rank1_I4P(self, data_name, x, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="1"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I4P),                   intent(in)           :: x(1:)        !< Data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = 1
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank1_I4P

   function write_dataarray1_rank1_I2P(self, data_name, x, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="1"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I2P),                   intent(in)           :: x(1:)        !< Data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = 1
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank1_I2P

   function write_dataarray1_rank1_I1P(self, data_name, x, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="1"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I1P),                   intent(in)           :: x(1:)        !< Data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = 1
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank1_I1P

   function write_dataarray1_rank2_R8P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   real(R8P),                      intent(in)           :: x(1:,1:)      !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank2_R8P

   function write_dataarray1_rank2_R4P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   real(R4P),                      intent(in)           :: x(1:,1:)      !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank2_R4P

   function write_dataarray1_rank2_I8P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   integer(I8P),                   intent(in)           :: x(1:,1:)      !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank2_I8P

   function write_dataarray1_rank2_I4P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   integer(I4P),                   intent(in)           :: x(1:,1:)      !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank2_I4P

   function write_dataarray1_rank2_I2P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   integer(I2P),                   intent(in)           :: x(1:,1:)      !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank2_I2P

   function write_dataarray1_rank2_I1P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   integer(I1P),                   intent(in)           :: x(1:,1:)      !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank2_I1P

   function write_dataarray1_rank3_R8P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   real(R8P),                      intent(in)           :: x(1:,1:,1:)   !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank3_R8P

   function write_dataarray1_rank3_R4P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   real(R4P),                      intent(in)           :: x(1:,1:,1:)   !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank3_R4P

   function write_dataarray1_rank3_I8P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   integer(I8P),                   intent(in)           :: x(1:,1:,1:)   !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank3_I8P

   function write_dataarray1_rank3_I4P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   integer(I4P),                   intent(in)           :: x(1:,1:,1:)   !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank3_I4P

   function write_dataarray1_rank3_I2P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                  intent(in)           :: data_name     !< Data name.
   integer(I2P),                  intent(in)           :: x(1:,1:,1:)   !< Data variable.
   logical,                       intent(in), optional :: one_component !< Force one component.
   logical,                       intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                        :: error         !< Error status.
   character(len=:), allocatable                       :: data_type     !< Data type.
   integer(I4P)                                        :: n_components  !< Number of components.
   character(len=:), allocatable                       :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank3_I2P

   function write_dataarray1_rank3_I1P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self          !< Writer.
   character(*),                   intent(in)           :: data_name     !< Data name.
   integer(I1P),                   intent(in)           :: x(1:,1:,1:)   !< Data variable.
   logical,                        intent(in), optional :: one_component !< Force one component.
   logical,                        intent(in), optional :: is_tuples     !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error         !< Error status.
   character(len=:), allocatable                        :: data_type     !< Data type.
   integer(I4P)                                         :: n_components  !< Number of components.
   character(len=:), allocatable                        :: code          !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank3_I1P

   function write_dataarray1_rank4_R8P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self           !< Writer.
   character(*),                   intent(in)           :: data_name      !< Data name.
   real(R8P),                      intent(in)           :: x(1:,1:,1:,1:) !< Data variable.
   logical,                        intent(in), optional :: one_component  !< Force one component.
   logical,                        intent(in), optional :: is_tuples      !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error          !< Error status.
   character(len=:), allocatable                        :: data_type      !< Data type.
   integer(I4P)                                         :: n_components   !< Number of components.
   character(len=:), allocatable                        :: code           !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank4_R8P

   function write_dataarray1_rank4_R4P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self           !< Writer.
   character(*),                   intent(in)           :: data_name      !< Data name.
   real(R4P),                      intent(in)           :: x(1:,1:,1:,1:) !< Data variable.
   logical,                        intent(in), optional :: one_component  !< Force one component.
   logical,                        intent(in), optional :: is_tuples      !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error          !< Error status.
   character(len=:), allocatable                        :: data_type      !< Data type.
   integer(I4P)                                         :: n_components   !< Number of components.
   character(len=:), allocatable                        :: code           !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank4_R4P

   function write_dataarray1_rank4_I8P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self           !< Writer.
   character(*),                   intent(in)           :: data_name      !< Data name.
   integer(I8P),                   intent(in)           :: x(1:,1:,1:,1:) !< Data variable.
   logical,                        intent(in), optional :: one_component  !< Force one component.
   logical,                        intent(in), optional :: is_tuples      !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error          !< Error status.
   character(len=:), allocatable                        :: data_type      !< Data type.
   integer(I4P)                                         :: n_components   !< Number of components.
   character(len=:), allocatable                        :: code           !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank4_I8P

   function write_dataarray1_rank4_I4P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self           !< Writer.
   character(*),                   intent(in)           :: data_name      !< Data name.
   integer(I4P),                   intent(in)           :: x(1:,1:,1:,1:) !< Data variable.
   logical,                        intent(in), optional :: one_component  !< Force one component.
   logical,                        intent(in), optional :: is_tuples      !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error          !< Error status.
   character(len=:), allocatable                        :: data_type      !< Data type.
   integer(I4P)                                         :: n_components   !< Number of components.
   character(len=:), allocatable                        :: code           !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank4_I4P

   function write_dataarray1_rank4_I2P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self           !< Writer.
   character(*),                   intent(in)           :: data_name      !< Data name.
   integer(I2P),                   intent(in)           :: x(1:,1:,1:,1:) !< Data variable.
   logical,                        intent(in), optional :: one_component  !< Force one component.
   logical,                        intent(in), optional :: is_tuples      !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error          !< Error status.
   character(len=:), allocatable                        :: data_type      !< Data type.
   integer(I4P)                                         :: n_components   !< Number of components.
   character(len=:), allocatable                        :: code           !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank4_I2P

   function write_dataarray1_rank4_I1P(self, data_name, x, one_component, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="n"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self           !< Writer.
   character(*),                   intent(in)           :: data_name      !< Data name.
   integer(I1P),                   intent(in)           :: x(1:,1:,1:,1:) !< Data variable.
   logical,                        intent(in), optional :: one_component  !< Force one component.
   logical,                        intent(in), optional :: is_tuples      !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error          !< Error status.
   character(len=:), allocatable                        :: data_type      !< Data type.
   integer(I4P)                                         :: n_components   !< Number of components.
   character(len=:), allocatable                        :: code           !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = size(x, dim=1)
   if (present(one_component)) then
     if (one_component) n_components = 1
   endif
   code = encode_binary_dataarray(x=x)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray1_rank4_I1P

   function write_dataarray3_rank1_R8P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R8P),                      intent(in)           :: x(1:)        !< X component of data variable.
   real(R8P),                      intent(in)           :: y(1:)        !< Y component of data variable.
   real(R8P),                      intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank1_R8P

   function write_dataarray3_rank1_R4P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R4P),                      intent(in)           :: x(1:)        !< X component of data variable.
   real(R4P),                      intent(in)           :: y(1:)        !< Y component of data variable.
   real(R4P),                      intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank1_R4P

   function write_dataarray3_rank1_I8P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I8P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I8P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I8P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank1_I8P

   function write_dataarray3_rank1_I4P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I4P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I4P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I4P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank1_I4P

   function write_dataarray3_rank1_I2P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I2P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I2P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I2P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank1_I2P

   function write_dataarray3_rank1_I1P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I1P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I1P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I1P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank1_I1P

   function write_dataarray3_rank3_R8P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R8P),                      intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   real(R8P),                      intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   real(R8P),                      intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank3_R8P

   function write_dataarray3_rank3_R4P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R4P),                      intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   real(R4P),                      intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   real(R4P),                      intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank3_R4P

   function write_dataarray3_rank3_I8P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I8P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I8P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I8P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank3_I8P

   function write_dataarray3_rank3_I4P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I4P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I4P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I4P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank3_I4P

   function write_dataarray3_rank3_I2P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I2P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I2P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I2P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank3_I2P

   function write_dataarray3_rank3_I1P(self, data_name, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I1P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I1P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I1P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = 3
   code = encode_binary_dataarray(x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray3_rank3_I1P
   
   function write_dataarray6_rank1_R8P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="6"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R8P),                      intent(in)           :: u(1:)        !< U component of data variable.
   real(R8P),                      intent(in)           :: v(1:)        !< V component of data variable.
   real(R8P),                      intent(in)           :: w(1:)        !< W component of data variable.
   real(R8P),                      intent(in)           :: x(1:)        !< X component of data variable.
   real(R8P),                      intent(in)           :: y(1:)        !< Y component of data variable.
   real(R8P),                      intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank1_R8P

   function write_dataarray6_rank1_R4P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R4P),                      intent(in)           :: u(1:)        !< U component of data variable.
   real(R4P),                      intent(in)           :: v(1:)        !< V component of data variable.
   real(R4P),                      intent(in)           :: w(1:)        !< W component of data variable.
   real(R4P),                      intent(in)           :: x(1:)        !< X component of data variable.
   real(R4P),                      intent(in)           :: y(1:)        !< Y component of data variable.
   real(R4P),                      intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank1_R4P

   function write_dataarray6_rank1_I8P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I8P),                   intent(in)           :: u(1:)        !< U component of data variable.
   integer(I8P),                   intent(in)           :: v(1:)        !< V component of data variable.
   integer(I8P),                   intent(in)           :: w(1:)        !< W component of data variable.
   integer(I8P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I8P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I8P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank1_I8P

   function write_dataarray6_rank1_I4P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I4P),                   intent(in)           :: u(1:)        !< U component of data variable.
   integer(I4P),                   intent(in)           :: v(1:)        !< V component of data variable.
   integer(I4P),                   intent(in)           :: w(1:)        !< W component of data variable.
   integer(I4P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I4P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I4P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank1_I4P

   function write_dataarray6_rank1_I2P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I2P),                   intent(in)           :: u(1:)        !< U component of data variable.
   integer(I2P),                   intent(in)           :: v(1:)        !< V component of data variable.
   integer(I2P),                   intent(in)           :: w(1:)        !< W component of data variable.
   integer(I2P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I2P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I2P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank1_I2P

   function write_dataarray6_rank1_I1P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I1P),                   intent(in)           :: u(1:)        !< U component of data variable.
   integer(I1P),                   intent(in)           :: v(1:)        !< V component of data variable.
   integer(I1P),                   intent(in)           :: w(1:)        !< W component of data variable.
   integer(I1P),                   intent(in)           :: x(1:)        !< X component of data variable.
   integer(I1P),                   intent(in)           :: y(1:)        !< Y component of data variable.
   integer(I1P),                   intent(in)           :: z(1:)        !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank1_I1P

   function write_dataarray6_rank3_R8P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (R8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R8P),                      intent(in)           :: u(1:,1:,1:)  !< U component of data variable.
   real(R8P),                      intent(in)           :: v(1:,1:,1:)  !< V component of data variable.
   real(R8P),                      intent(in)           :: w(1:,1:,1:)  !< W component of data variable.
   real(R8P),                      intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   real(R8P),                      intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   real(R8P),                      intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float64'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank3_R8P

   function write_dataarray6_rank3_R4P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (R4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   real(R4P),                      intent(in)           :: u(1:,1:,1:)  !< U component of data variable.
   real(R4P),                      intent(in)           :: v(1:,1:,1:)  !< V component of data variable.
   real(R4P),                      intent(in)           :: w(1:,1:,1:)  !< W component of data variable.
   real(R4P),                      intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   real(R4P),                      intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   real(R4P),                      intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Float32'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank3_R4P

   function write_dataarray6_rank3_I8P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I8P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I8P),                   intent(in)           :: u(1:,1:,1:)  !< U component of data variable.
   integer(I8P),                   intent(in)           :: v(1:,1:,1:)  !< V component of data variable.
   integer(I8P),                   intent(in)           :: w(1:,1:,1:)  !< W component of data variable.
   integer(I8P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I8P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I8P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int64'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank3_I8P

   function write_dataarray6_rank3_I4P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I4P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I4P),                   intent(in)           :: u(1:,1:,1:)  !< U component of data variable.
   integer(I4P),                   intent(in)           :: v(1:,1:,1:)  !< V component of data variable.
   integer(I4P),                   intent(in)           :: w(1:,1:,1:)  !< W component of data variable.
   integer(I4P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I4P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I4P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int32'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank3_I4P

   function write_dataarray6_rank3_I2P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I2P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I2P),                   intent(in)           :: u(1:,1:,1:)  !< U component of data variable.
   integer(I2P),                   intent(in)           :: v(1:,1:,1:)  !< V component of data variable.
   integer(I2P),                   intent(in)           :: w(1:,1:,1:)  !< W component of data variable.
   integer(I2P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I2P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I2P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int16'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank3_I2P

   function write_dataarray6_rank3_I1P(self, data_name, u, v, w, x, y, z, is_tuples) result(error)
   !< Write `<DataArray... NumberOfComponents="3"...>...</DataArray>` tag (I1P).
   class(xml_writer_binary_local), intent(inout)        :: self         !< Writer.
   character(*),                   intent(in)           :: data_name    !< Data name.
   integer(I1P),                   intent(in)           :: u(1:,1:,1:)  !< U component of data variable.
   integer(I1P),                   intent(in)           :: v(1:,1:,1:)  !< V component of data variable.
   integer(I1P),                   intent(in)           :: w(1:,1:,1:)  !< W component of data variable.
   integer(I1P),                   intent(in)           :: x(1:,1:,1:)  !< X component of data variable.
   integer(I1P),                   intent(in)           :: y(1:,1:,1:)  !< Y component of data variable.
   integer(I1P),                   intent(in)           :: z(1:,1:,1:)  !< Z component of data variable.
   logical,                        intent(in), optional :: is_tuples    !< Use "NumberOfTuples" instead of "NumberOfComponents".
   integer(I4P)                                         :: error        !< Error status.
   character(len=:), allocatable                        :: data_type    !< Data type.
   integer(I4P)                                         :: n_components !< Number of components.
   character(len=:), allocatable                        :: code         !< Data variable encoded, binary or Base64 codec.

   data_type = 'Int8'
   n_components = 6
   code = encode_binary_dataarray(u=u, v=v, w=w, x=x, y=y, z=z)
   call self%write_dataarray_tag(data_type=data_type, number_of_components=n_components, data_name=data_name, data_content=code, &
                                 is_tuples=is_tuples)
   error = self%error
   endfunction write_dataarray6_rank3_I1P

   subroutine write_dataarray_appended(self)
   !< Do nothing, binary local is not appended.
   class(xml_writer_binary_local), intent(inout) :: self !< Writer.
   endsubroutine write_dataarray_appended
endmodule vtk_fortran_vtk_file_xml_writer_binary_local