xref: /petsc/src/dm/tutorials/ex9.c (revision 5f80ce2ab25dff0f4601e710601cbbcecf323266)
1c4762a1bSJed Brown static char help[] = "Demonstrates HDF5 vector input/ouput\n\n";
2c4762a1bSJed Brown 
3c4762a1bSJed Brown /*T
4c4762a1bSJed Brown    Concepts: viewers
5c4762a1bSJed Brown    Concepts: HDF5
6c4762a1bSJed Brown    Processors: n
7c4762a1bSJed Brown T*/
8c4762a1bSJed Brown #include <petscsys.h>
9c4762a1bSJed Brown #include <petscdm.h>
10c4762a1bSJed Brown #include <petscdmda.h>
11c4762a1bSJed Brown #include <petscviewerhdf5.h>
12c4762a1bSJed Brown 
13c4762a1bSJed Brown int main(int argc,char **argv)
14c4762a1bSJed Brown {
15c4762a1bSJed Brown   PetscErrorCode ierr;
16c4762a1bSJed Brown   PetscViewer    viewer;
17c4762a1bSJed Brown   DM             da;
18c4762a1bSJed Brown   Vec            global,local,global2;
19c4762a1bSJed Brown   PetscMPIInt    rank;
20c4762a1bSJed Brown   PetscBool      flg;
21c4762a1bSJed Brown   PetscInt       ndof;
22c4762a1bSJed Brown 
23c4762a1bSJed Brown   /*
24c4762a1bSJed Brown     Every PETSc routine should begin with the PetscInitialize() routine.
25c4762a1bSJed Brown     argc, argv - These command line arguments are taken to extract the options
26c4762a1bSJed Brown                  supplied to PETSc and options supplied to MPI.
27c4762a1bSJed Brown     help       - When PETSc executable is invoked with the option -help,
28c4762a1bSJed Brown                  it prints the various options that can be applied at
29c4762a1bSJed Brown                  runtime.  The user can use the "help" variable place
30c4762a1bSJed Brown                  additional help messages in this printout.
31c4762a1bSJed Brown   */
32c4762a1bSJed Brown   ierr = PetscInitialize(&argc,&argv,(char*)0,help);if (ierr) return ierr;
33c4762a1bSJed Brown   /* Get number of DOF's from command line */
34c4762a1bSJed Brown   ierr = PetscOptionsBegin(PETSC_COMM_WORLD,NULL,"DMDA VecView/VecLoad example","");CHKERRQ(ierr);
35c4762a1bSJed Brown   {
36c4762a1bSJed Brown     ndof = 1;
37c4762a1bSJed Brown     PetscOptionsBoundedInt("-ndof","Number of DOF's in DMDA","",ndof,&ndof,NULL,1);
38c4762a1bSJed Brown   }
39c4762a1bSJed Brown   ierr = PetscOptionsEnd();CHKERRQ(ierr);
40c4762a1bSJed Brown 
41c4762a1bSJed Brown   /* Create a DMDA and an associated vector */
42*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMDACreate2d(PETSC_COMM_WORLD, DM_BOUNDARY_NONE, DM_BOUNDARY_NONE,DMDA_STENCIL_BOX,100,90,PETSC_DECIDE,PETSC_DECIDE,ndof,1,NULL,NULL,&da));
43*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMSetFromOptions(da));
44*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMSetUp(da));
45*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMCreateGlobalVector(da,&global));
46*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMCreateLocalVector(da,&local));
47*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecSet(global,-1.0));
48*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMGlobalToLocalBegin(da,global,INSERT_VALUES,local));
49*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMGlobalToLocalEnd(da,global,INSERT_VALUES,local));
50*5f80ce2aSJacob Faibussowitsch   CHKERRMPI(MPI_Comm_rank(PETSC_COMM_WORLD,&rank));
51*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecScale(local,rank+1));
52*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMLocalToGlobalBegin(da,local,ADD_VALUES,global));
53*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMLocalToGlobalEnd(da,local,ADD_VALUES,global));
54c4762a1bSJed Brown 
55c4762a1bSJed Brown   /* Create the HDF5 viewer for writing */
56*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerHDF5Open(PETSC_COMM_WORLD,"hdf5output.h5",FILE_MODE_WRITE,&viewer));
57*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerSetFromOptions(viewer));
58c4762a1bSJed Brown 
59c4762a1bSJed Brown   /* Write the Vec without one extra dimension for BS */
60*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerHDF5SetBaseDimension2(viewer, PETSC_FALSE));
61*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscObjectSetName((PetscObject) global, "noBsDim"));
62*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecView(global,viewer));
63c4762a1bSJed Brown 
64c4762a1bSJed Brown   /* Write the Vec with one extra, 1-sized, dimension for BS */
65*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerHDF5SetBaseDimension2(viewer, PETSC_TRUE));
66*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscObjectSetName((PetscObject) global, "bsDim"));
67*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecView(global,viewer));
68c4762a1bSJed Brown 
69*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerDestroy(&viewer));
70*5f80ce2aSJacob Faibussowitsch   CHKERRMPI(MPI_Barrier(PETSC_COMM_WORLD));
71*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecDuplicate(global,&global2));
72c4762a1bSJed Brown 
73c4762a1bSJed Brown   /* Create the HDF5 viewer for reading */
74*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerHDF5Open(PETSC_COMM_WORLD,"hdf5output.h5",FILE_MODE_READ,&viewer));
75*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerSetFromOptions(viewer));
76c4762a1bSJed Brown 
77c4762a1bSJed Brown   /* Load the Vec without the BS dim and compare */
78*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscObjectSetName((PetscObject) global2, "noBsDim"));
79*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecLoad(global2,viewer));
80c4762a1bSJed Brown 
81*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecEqual(global,global2,&flg));
82c4762a1bSJed Brown   if (!flg) {
83*5f80ce2aSJacob Faibussowitsch     CHKERRQ(PetscPrintf(PETSC_COMM_WORLD,"Error: Vectors are not equal\n"));
84c4762a1bSJed Brown   }
85c4762a1bSJed Brown 
86c4762a1bSJed Brown   /* Load the Vec with one extra, 1-sized, BS dim and compare */
87*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscObjectSetName((PetscObject) global2, "bsDim"));
88*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecLoad(global2,viewer));
89*5f80ce2aSJacob Faibussowitsch   CHKERRQ(PetscViewerDestroy(&viewer));
90c4762a1bSJed Brown 
91*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecEqual(global,global2,&flg));
92c4762a1bSJed Brown   if (!flg) {
93*5f80ce2aSJacob Faibussowitsch     CHKERRQ(PetscPrintf(PETSC_COMM_WORLD,"Error: Vectors are not equal\n"));
94c4762a1bSJed Brown   }
95c4762a1bSJed Brown 
96c4762a1bSJed Brown   /* clean up and exit */
97*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecDestroy(&local));
98*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecDestroy(&global));
99*5f80ce2aSJacob Faibussowitsch   CHKERRQ(VecDestroy(&global2));
100*5f80ce2aSJacob Faibussowitsch   CHKERRQ(DMDestroy(&da));
101c4762a1bSJed Brown 
102c4762a1bSJed Brown   ierr = PetscFinalize();
103c4762a1bSJed Brown   return ierr;
104c4762a1bSJed Brown }
105c4762a1bSJed Brown 
106c4762a1bSJed Brown /*TEST
107c4762a1bSJed Brown 
108c4762a1bSJed Brown       build:
109c4762a1bSJed Brown          requires: hdf5
110c4762a1bSJed Brown 
111c4762a1bSJed Brown       test:
112c4762a1bSJed Brown          nsize: 4
113c4762a1bSJed Brown 
114c4762a1bSJed Brown       test:
115c4762a1bSJed Brown          nsize: 4
116c4762a1bSJed Brown          suffix: 2
117c4762a1bSJed Brown          args: -ndof 2
118c4762a1bSJed Brown          output_file: output/ex9_1.out
119c4762a1bSJed Brown 
120c4762a1bSJed Brown TEST*/
121