xref: /petsc/src/dm/tutorials/ex9.c (revision 48a46eb9bd028bec07ec0f396b1a3abb43f14558) !
1c4762a1bSJed Brown static char help[] = "Demonstrates HDF5 vector input/ouput\n\n";
2c4762a1bSJed Brown 
3c4762a1bSJed Brown #include <petscsys.h>
4c4762a1bSJed Brown #include <petscdm.h>
5c4762a1bSJed Brown #include <petscdmda.h>
6c4762a1bSJed Brown #include <petscviewerhdf5.h>
7c4762a1bSJed Brown 
89371c9d4SSatish Balay int main(int argc, char **argv) {
9c4762a1bSJed Brown   PetscViewer viewer;
10c4762a1bSJed Brown   DM          da;
11c4762a1bSJed Brown   Vec         global, local, global2;
12c4762a1bSJed Brown   PetscMPIInt rank;
13c4762a1bSJed Brown   PetscBool   flg;
14c4762a1bSJed Brown   PetscInt    ndof;
15c4762a1bSJed Brown 
16c4762a1bSJed Brown   /*
17c4762a1bSJed Brown     Every PETSc routine should begin with the PetscInitialize() routine.
18c4762a1bSJed Brown     argc, argv - These command line arguments are taken to extract the options
19c4762a1bSJed Brown                  supplied to PETSc and options supplied to MPI.
20c4762a1bSJed Brown     help       - When PETSc executable is invoked with the option -help,
21c4762a1bSJed Brown                  it prints the various options that can be applied at
22c4762a1bSJed Brown                  runtime.  The user can use the "help" variable place
23c4762a1bSJed Brown                  additional help messages in this printout.
24c4762a1bSJed Brown   */
25327415f7SBarry Smith   PetscFunctionBeginUser;
269566063dSJacob Faibussowitsch   PetscCall(PetscInitialize(&argc, &argv, (char *)0, help));
27c4762a1bSJed Brown   /* Get number of DOF's from command line */
28d0609cedSBarry Smith   PetscOptionsBegin(PETSC_COMM_WORLD, NULL, "DMDA VecView/VecLoad example", "");
29c4762a1bSJed Brown   {
30c4762a1bSJed Brown     ndof = 1;
31c4762a1bSJed Brown     PetscOptionsBoundedInt("-ndof", "Number of DOF's in DMDA", "", ndof, &ndof, NULL, 1);
32c4762a1bSJed Brown   }
33d0609cedSBarry Smith   PetscOptionsEnd();
34c4762a1bSJed Brown 
35c4762a1bSJed Brown   /* Create a DMDA and an associated vector */
369566063dSJacob Faibussowitsch   PetscCall(DMDACreate2d(PETSC_COMM_WORLD, DM_BOUNDARY_NONE, DM_BOUNDARY_NONE, DMDA_STENCIL_BOX, 100, 90, PETSC_DECIDE, PETSC_DECIDE, ndof, 1, NULL, NULL, &da));
379566063dSJacob Faibussowitsch   PetscCall(DMSetFromOptions(da));
389566063dSJacob Faibussowitsch   PetscCall(DMSetUp(da));
399566063dSJacob Faibussowitsch   PetscCall(DMCreateGlobalVector(da, &global));
409566063dSJacob Faibussowitsch   PetscCall(DMCreateLocalVector(da, &local));
419566063dSJacob Faibussowitsch   PetscCall(VecSet(global, -1.0));
429566063dSJacob Faibussowitsch   PetscCall(DMGlobalToLocalBegin(da, global, INSERT_VALUES, local));
439566063dSJacob Faibussowitsch   PetscCall(DMGlobalToLocalEnd(da, global, INSERT_VALUES, local));
449566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Comm_rank(PETSC_COMM_WORLD, &rank));
459566063dSJacob Faibussowitsch   PetscCall(VecScale(local, rank + 1));
469566063dSJacob Faibussowitsch   PetscCall(DMLocalToGlobalBegin(da, local, ADD_VALUES, global));
479566063dSJacob Faibussowitsch   PetscCall(DMLocalToGlobalEnd(da, local, ADD_VALUES, global));
48c4762a1bSJed Brown 
49c4762a1bSJed Brown   /* Create the HDF5 viewer for writing */
509566063dSJacob Faibussowitsch   PetscCall(PetscViewerHDF5Open(PETSC_COMM_WORLD, "hdf5output.h5", FILE_MODE_WRITE, &viewer));
519566063dSJacob Faibussowitsch   PetscCall(PetscViewerSetFromOptions(viewer));
52c4762a1bSJed Brown 
53c4762a1bSJed Brown   /* Write the Vec without one extra dimension for BS */
549566063dSJacob Faibussowitsch   PetscCall(PetscViewerHDF5SetBaseDimension2(viewer, PETSC_FALSE));
559566063dSJacob Faibussowitsch   PetscCall(PetscObjectSetName((PetscObject)global, "noBsDim"));
569566063dSJacob Faibussowitsch   PetscCall(VecView(global, viewer));
57c4762a1bSJed Brown 
58c4762a1bSJed Brown   /* Write the Vec with one extra, 1-sized, dimension for BS */
599566063dSJacob Faibussowitsch   PetscCall(PetscViewerHDF5SetBaseDimension2(viewer, PETSC_TRUE));
609566063dSJacob Faibussowitsch   PetscCall(PetscObjectSetName((PetscObject)global, "bsDim"));
619566063dSJacob Faibussowitsch   PetscCall(VecView(global, viewer));
62c4762a1bSJed Brown 
639566063dSJacob Faibussowitsch   PetscCall(PetscViewerDestroy(&viewer));
649566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Barrier(PETSC_COMM_WORLD));
659566063dSJacob Faibussowitsch   PetscCall(VecDuplicate(global, &global2));
66c4762a1bSJed Brown 
67c4762a1bSJed Brown   /* Create the HDF5 viewer for reading */
689566063dSJacob Faibussowitsch   PetscCall(PetscViewerHDF5Open(PETSC_COMM_WORLD, "hdf5output.h5", FILE_MODE_READ, &viewer));
699566063dSJacob Faibussowitsch   PetscCall(PetscViewerSetFromOptions(viewer));
70c4762a1bSJed Brown 
71c4762a1bSJed Brown   /* Load the Vec without the BS dim and compare */
729566063dSJacob Faibussowitsch   PetscCall(PetscObjectSetName((PetscObject)global2, "noBsDim"));
739566063dSJacob Faibussowitsch   PetscCall(VecLoad(global2, viewer));
74c4762a1bSJed Brown 
759566063dSJacob Faibussowitsch   PetscCall(VecEqual(global, global2, &flg));
76*48a46eb9SPierre Jolivet   if (!flg) PetscCall(PetscPrintf(PETSC_COMM_WORLD, "Error: Vectors are not equal\n"));
77c4762a1bSJed Brown 
78c4762a1bSJed Brown   /* Load the Vec with one extra, 1-sized, BS dim and compare */
799566063dSJacob Faibussowitsch   PetscCall(PetscObjectSetName((PetscObject)global2, "bsDim"));
809566063dSJacob Faibussowitsch   PetscCall(VecLoad(global2, viewer));
819566063dSJacob Faibussowitsch   PetscCall(PetscViewerDestroy(&viewer));
82c4762a1bSJed Brown 
839566063dSJacob Faibussowitsch   PetscCall(VecEqual(global, global2, &flg));
84*48a46eb9SPierre Jolivet   if (!flg) PetscCall(PetscPrintf(PETSC_COMM_WORLD, "Error: Vectors are not equal\n"));
85c4762a1bSJed Brown 
86c4762a1bSJed Brown   /* clean up and exit */
879566063dSJacob Faibussowitsch   PetscCall(VecDestroy(&local));
889566063dSJacob Faibussowitsch   PetscCall(VecDestroy(&global));
899566063dSJacob Faibussowitsch   PetscCall(VecDestroy(&global2));
909566063dSJacob Faibussowitsch   PetscCall(DMDestroy(&da));
91c4762a1bSJed Brown 
929566063dSJacob Faibussowitsch   PetscCall(PetscFinalize());
93b122ec5aSJacob Faibussowitsch   return 0;
94c4762a1bSJed Brown }
95c4762a1bSJed Brown 
96c4762a1bSJed Brown /*TEST
97c4762a1bSJed Brown 
98c4762a1bSJed Brown       build:
99c4762a1bSJed Brown          requires: hdf5
100c4762a1bSJed Brown 
101c4762a1bSJed Brown       test:
102c4762a1bSJed Brown          nsize: 4
103c4762a1bSJed Brown 
104c4762a1bSJed Brown       test:
105c4762a1bSJed Brown          nsize: 4
106c4762a1bSJed Brown          suffix: 2
107c4762a1bSJed Brown          args: -ndof 2
108c4762a1bSJed Brown          output_file: output/ex9_1.out
109c4762a1bSJed Brown 
110c4762a1bSJed Brown TEST*/
111