Actual source code: dupl.c
petsc-3.6.4 2016-04-12
2: #include <petsc/private/viewerimpl.h> /*I "petscviewer.h" I*/
6: /*@
7: PetscViewerGetSingleton - Creates a new PetscViewer (same type as the old)
8: that lives on a single processor (with MPI_comm PETSC_COMM_SELF)
10: Collective on PetscViewer
12: Input Parameter:
13: . viewer - the PetscViewer to be duplicated
15: Output Parameter:
16: . outviewer - new PetscViewer
18: Level: advanced
20: Notes: Call PetscViewerRestoreSingleton() to return this PetscViewer, NOT PetscViewerDestroy()
22: This is most commonly used to view a sequential object that is part of a
23: parallel object. For example block Jacobi PC view could use this to obtain a
24: PetscViewer that is used with the sequential KSP on one block of the preconditioner.
26: Concepts: PetscViewer^sequential version
28: .seealso: PetscViewerSocketOpen(), PetscViewerASCIIOpen(), PetscViewerDrawOpen(), PetscViewerRestoreSingleton()
29: @*/
30: PetscErrorCode PetscViewerGetSingleton(PetscViewer viewer,PetscViewer *outviewer)
31: {
33: PetscMPIInt size;
38: MPI_Comm_size(PetscObjectComm((PetscObject)viewer),&size);
39: if (size == 1) {
40: PetscObjectReference((PetscObject)viewer);
41: *outviewer = viewer;
42: } else if (viewer->ops->getsingleton) {
43: (*viewer->ops->getsingleton)(viewer,outviewer);
44: } else SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_SUP,"Cannot get singleton PetscViewer for type %s",((PetscObject)viewer)->type_name);
45: PetscViewerASCIISynchronizedAllow(viewer,PETSC_TRUE);
46: return(0);
47: }
51: /*@
52: PetscViewerRestoreSingleton - Restores a new PetscViewer obtained with PetscViewerGetSingleton().
54: Collective on PetscViewer
56: Input Parameters:
57: + viewer - the PetscViewer to be duplicated
58: - outviewer - new PetscViewer
60: Level: advanced
62: Notes: Call PetscViewerGetSingleton() to get this PetscViewer, NOT PetscViewerCreate()
64: .seealso: PetscViewerSocketOpen(), PetscViewerASCIIOpen(), PetscViewerDrawOpen(), PetscViewerGetSingleton()
65: @*/
66: PetscErrorCode PetscViewerRestoreSingleton(PetscViewer viewer,PetscViewer *outviewer)
67: {
69: PetscMPIInt size;
74: MPI_Comm_size(PetscObjectComm((PetscObject)viewer),&size);
75: if (size == 1) {
76: PetscObjectDereference((PetscObject)viewer);
77: if (outviewer) *outviewer = 0;
78: } else if (viewer->ops->restoresingleton) {
79: (*viewer->ops->restoresingleton)(viewer,outviewer);
80: }
81: PetscViewerASCIISynchronizedAllow(viewer,PETSC_FALSE);
82: return(0);
83: }
87: /*@
88: PetscViewerGetSubcomm - Creates a new PetscViewer (same type as the old)
89: that lives on a subgroup of processors
91: Collective on PetscViewer
93: Input Parameter:
94: + viewer - the PetscViewer to be duplicated
95: - subcomm - MPI communicator
97: Output Parameter:
98: . outviewer - new PetscViewer
100: Level: advanced
102: Notes: Call PetscViewerRestoreSubcomm() to return this PetscViewer, NOT PetscViewerDestroy()
104: This is used to view a sequential or a parallel object that is part of a larger
105: parallel object. For example redundant PC view could use this to obtain a
106: PetscViewer that is used within a subcommunicator on one duplicated preconditioner.
108: Concepts: PetscViewer^sequential version
110: .seealso: PetscViewerSocketOpen(), PetscViewerASCIIOpen(), PetscViewerDrawOpen(), PetscViewerRestoreSubcomm()
111: @*/
112: PetscErrorCode PetscViewerGetSubcomm(PetscViewer viewer,MPI_Comm subcomm,PetscViewer *outviewer)
113: {
115: PetscMPIInt size;
120: MPI_Comm_size(PetscObjectComm((PetscObject)viewer),&size);
121: if (size == 1) {
122: PetscObjectReference((PetscObject)viewer);
123: *outviewer = viewer;
124: } else if (viewer->ops->getsubcomm) {
125: (*viewer->ops->getsubcomm)(viewer,subcomm,outviewer);
126: } else SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_SUP,"Cannot get subcommunicator PetscViewer for type %s",((PetscObject)viewer)->type_name);
127: return(0);
128: }
132: /*@
133: PetscViewerRestoreSubcomm - Restores a new PetscViewer obtained with PetscViewerGetSubcomm().
135: Collective on PetscViewer
137: Input Parameters:
138: + viewer - the PetscViewer to be duplicated
139: . subcomm - MPI communicator
140: - outviewer - new PetscViewer
142: Level: advanced
144: Notes: Call PetscViewerGetSubcomm() to get this PetscViewer, NOT PetscViewerCreate()
146: .seealso: PetscViewerSocketOpen(), PetscViewerASCIIOpen(), PetscViewerDrawOpen(), PetscViewerGetSubcomm()
147: @*/
148: PetscErrorCode PetscViewerRestoreSubcomm(PetscViewer viewer,MPI_Comm subcomm,PetscViewer *outviewer)
149: {
151: PetscMPIInt size;
156: MPI_Comm_size(PetscObjectComm((PetscObject)viewer),&size);
157: if (size == 1 || (outviewer && viewer == *outviewer)) {
158: PetscObjectDereference((PetscObject)viewer);
159: if (outviewer) *outviewer = 0;
160: } else if (viewer->ops->restoresubcomm) {
161: (*viewer->ops->restoresubcomm)(viewer,subcomm,outviewer);
162: }
163: return(0);
164: }