:orphan:
# DMLocalToGlobal
updates global vectors from local vectors
## Synopsis
```
#include "petscdm.h"
#include "petscdmlabel.h"
#include "petscds.h"
PetscErrorCode DMLocalToGlobal(DM dm, Vec l, InsertMode mode, Vec g)
```
Neighbor-wise Collective
## Input Parameters
- ***dm -*** the `DM` object
- ***l -*** the local vector
- ***mode -*** if `INSERT_VALUES` then no parallel communication is used, if `ADD_VALUES` then all ghost points from the same base point accumulate into that base point.
- ***g -*** the global vector
## Notes
The communication involved in this update can be overlapped with computation by using
`DMLocalToGlobalBegin()` and `DMLocalToGlobalEnd()`.
In the `ADD_VALUES` case you normally would zero the receiving vector before beginning this operation.
`INSERT_VALUES` is not supported for `DMDA`; in that case simply compute the values directly into a global vector instead of a local one.
Use `DMLocalToGlobalHookAdd()` to add additional operations that are performed on the data during the update process
## See Also
[](ch_dmbase), `DM`, `DMLocalToGlobalBegin()`, `DMLocalToGlobalEnd()`, `DMCoarsen()`, `DMDestroy()`, `DMView()`, `DMCreateGlobalVector()`, `DMCreateInterpolation()`, `DMGlobalToLocal()`, `DMGlobalToLocalEnd()`, `DMGlobalToLocalBegin()`, `DMLocalToGlobalHookAdd()`, `DMGlobaToLocallHookAdd()`
## Level
beginner
## Location
src/dm/interface/dm.c
## Examples
src/dm/impls/stag/tutorials/ex1.c
src/dm/impls/stag/tutorials/ex2.c
src/dm/impls/stag/tutorials/ex3.c
src/dm/impls/stag/tutorials/ex4.c
src/dm/impls/stag/tutorials/ex6.c
src/dm/tutorials/ex2.c
---
[Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/src/dm/interface/dm.c)
[Index of all DM routines](index.md)
[Table of Contents for all manual pages](/manualpages/index.md)
[Index of all manual pages](/manualpages/singleindex.md)