:orphan: # VecSetValuesBlockedLocal Inserts or adds values into certain locations of a vector, using a local ordering of the nodes. ## Synopsis ``` #include "petscvec.h" PetscErrorCode VecSetValuesBlockedLocal(Vec x, PetscInt ni, const PetscInt ix[], const PetscScalar y[], InsertMode iora) ``` Not Collective ## Input Parameters - ***x -*** vector to insert in - ***ni -*** number of blocks to add - ***ix -*** indices where to add in block count, not element count - ***y -*** array of values - ***iora -*** either `INSERT_VALUES` replaces existing entries with new values, `ADD_VALUES` adds values to any existing entries ## Notes `VecSetValuesBlockedLocal()` sets x[bs*ix[i]+j] = y[bs*i+j], for j=0,..bs-1, for i=0,...,ni-1, where bs has been set with `VecSetBlockSize()`. Calls to `VecSetValuesBlockedLocal()` with the `INSERT_VALUES` and `ADD_VALUES` options cannot be mixed without intervening calls to the assembly routines. These values may be cached, so `VecAssemblyBegin()` and `VecAssemblyEnd()` MUST be called after all calls to `VecSetValuesBlockedLocal()` have been completed. `VecSetValuesBlockedLocal()` uses 0-based indices in Fortran as well as in C. ## See Also [](ch_vectors), `Vec`, `VecAssemblyBegin()`, `VecAssemblyEnd()`, `VecSetValues()`, `VecSetValuesBlocked()`, `VecSetLocalToGlobalMapping()` ## Level intermediate ## Location src/vec/vec/interface/rvector.c ## Examples src/ksp/ksp/tutorials/ex71.c
--- [Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/src/vec/vec/interface/rvector.c) [Index of all Vec routines](index.md) [Table of Contents for all manual pages](/manualpages/index.md) [Index of all manual pages](/manualpages/singleindex.md)