# PetscDeviceInitType
Initialization strategy for `PetscDevice` 
## Synopsis
```
#include <petscdevicetypes.h> 
typedef enum {
  PETSC_DEVICE_INIT_NONE,
  PETSC_DEVICE_INIT_LAZY,
  PETSC_DEVICE_INIT_EAGER
} PetscDeviceInitType;
```
```none
PETSC_DEVICE_INIT_NONE  - PetscDevice is never initialized
```
```none
PETSC_DEVICE_INIT_LAZY  - PetscDevice is initialized on demand
```
```none
PETSC_DEVICE_INIT_EAGER - PetscDevice is initialized as soon as possible
```


## Notes
`PETSC_DEVICE_INIT_NONE` implies that any initialization of `PetscDevice` is disallowed and
doing so results in an error. Useful to ensure that no accelerator is used in a program.




## See Also
 `PetscDevice`, `PetscDeviceType`, `PetscDeviceInitialize()`,
`PetscDeviceInitialized()`, `PetscDeviceCreate()`

## Level
beginner

## Location
<A HREF="PETSC_DOC_OUT_ROOT_PLACEHOLDER/include/petscdevicetypes.h.html#PetscDeviceInitType">include/petscdevicetypes.h</A>


---
[Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/include/petscdevicetypes.h)


[Index of all Sys routines](index.md)  
[Table of Contents for all manual pages](/docs/manualpages/index.md)  
[Index of all manual pages](/docs/manualpages/singleindex.md)  
