attach_field_attributes.c 1.62 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
/*
  Copyright (c) 2006-2015, The Regents of the University of California,
  through Lawrence Berkeley National Laboratory (subject to receipt of any
  required approvals from the U.S. Dept. of Energy) and the Paul Scherrer
  Institut (Switzerland).  All rights reserved.

  License: see file COPYING in top level of source distribution.
*/

#include "H5hut.h"

// name of output file
const char* fname = "example_field.h5";

// H5hut verbosity level
const h5_int64_t h5_verbosity = H5_VERBOSE_DEFAULT;

int
main (
        int argc,
        char* argv[]
        ){

        // initialize MPI & H5hut
        MPI_Init (&argc, &argv);
        MPI_Comm comm = MPI_COMM_WORLD;
        int comm_size = 1;
        MPI_Comm_size (comm, &comm_size);
	int comm_rank = 0;
        MPI_Comm_rank (comm, &comm_rank);
        H5AbortOnError ();
        H5SetVerbosityLevel (h5_verbosity);
	//H5SetDebugMask (-1);

        // open file and create first step
        h5_file_t file = H5OpenFile (fname, H5_O_RDWR, H5_PROP_DEFAULT);
        H5SetStep (file, 0); 

	if (!H5BlockHasField (file, "data")) {
		printf ("Doesn't have field data with name 'data' in step#0\n");
		goto done;
	}

	h5_int32_t attrib[1] = { 42 };
	H5BlockWriteFieldAttribInt32 (
		file,
		"data",
		"The answer",
		attrib,
		sizeof (attrib) / sizeof (*attrib));
	h5_float64_t origin[3] = { 0.0, 0.0, 1.0 };
	H5Block3dSetFieldOrigin (
		file,
		"data",
		origin[0], origin[1], origin[2]);
	h5_float64_t spacing[3] = { 1.0, 2.0, 3.0 };
	H5Block3dSetFieldSpacing (
		file,
		"data",
		spacing[0], spacing[1], spacing[2]);
done:
        // done
        H5CloseFile(file);
	MPI_Finalize ();
        return 0;
}