:orphan:
# PETSC_COMM_WORLD
the equivalent of the `MPI_COMM_WORLD` communicator which represents all the processes that PETSc knows about.
## Notes
By default `PETSC_COMM_WORLD` and `MPI_COMM_WORLD` are identical unless you wish to
run PETSc on ONLY a subset of `MPI_COMM_WORLD`. In that case create your new (smaller)
communicator, call it, say comm, and set `PETSC_COMM_WORLD` = comm BEFORE calling
PetscInitialize(), but after `MPI_Init()` has been called.
The value of `PETSC_COMM_WORLD` should never be USED/accessed before `PetscInitialize()`
is called because it may not have a valid value yet.
## See Also
`PETSC_COMM_SELF`
## Level
beginner
## Location
include/petscsys.h
## Examples
src/dm/dt/dualspace/impls/lagrange/tutorials/ex1.c
src/dm/dt/dualspace/impls/lagrange/tutorials/ex2.c
src/dm/field/tutorials/ex1.c
src/dm/impls/forest/tutorials/ex1.c
src/dm/impls/plex/tutorials/ex1.c
src/dm/impls/plex/tutorials/ex10.c
src/dm/impls/plex/tutorials/ex11.c
src/dm/impls/plex/tutorials/ex13.c
src/dm/impls/plex/tutorials/ex14.c
src/dm/impls/plex/tutorials/ex1f90.F90
src/dm/impls/plex/tutorials/ex3f90.F90
---
[Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/include/petscsys.h)
[Index of all Sys routines](index.md)
[Table of Contents for all manual pages](/manualpages/index.md)
[Index of all manual pages](/manualpages/singleindex.md)