![]() |
(git:e68414f)
|
#include <stdbool.h>#include "../../offload/offload_buffer.h"#include "../common/grid_basis_set.h"#include "../common/grid_constants.h"Go to the source code of this file.
Data Structures | |
| struct | grid_cpu_task |
| Internal representation of a task. More... | |
| struct | grid_cpu_layout |
| Internal representation of a grid layout. More... | |
| struct | grid_cpu_task_list |
| Internal representation of a task list. More... | |
Functions | |
| void | grid_cpu_create_task_list (const bool orthorhombic, const int ntasks, const int nlevels, const int natoms, const int nkinds, const int nblocks, const int block_offsets[nblocks], const double atom_positions[natoms][3], const int atom_kinds[natoms], const grid_basis_set *basis_sets[nkinds], const int level_list[ntasks], const int iatom_list[ntasks], const int jatom_list[ntasks], const int iset_list[ntasks], const int jset_list[ntasks], const int ipgf_list[ntasks], const int jpgf_list[ntasks], const int border_mask_list[ntasks], const int block_num_list[ntasks], const double radius_list[ntasks], const double rab_list[ntasks][3], const int npts_global[nlevels][3], const int npts_local[nlevels][3], const int shift_local[nlevels][3], const int border_width[nlevels][3], const double dh[nlevels][3][3], const double dh_inv[nlevels][3][3], grid_cpu_task_list **task_list) |
| Allocates a task list for the cpu backend. See grid_task_list.h for details. | |
| void | grid_cpu_free_task_list (grid_cpu_task_list *task_list) |
| Deallocates given task list, basis_sets have to be freed separately. | |
| void | grid_cpu_collocate_task_list (const grid_cpu_task_list *task_list, const enum grid_func func, const int nlevels, const offload_buffer *pab_blocks, offload_buffer *grids[nlevels]) |
| Collocate all tasks of in given list onto given grids. See grid_task_list.h for details. | |
| void | grid_cpu_integrate_task_list (const grid_cpu_task_list *task_list, const bool compute_tau, const int natoms, const int nlevels, const offload_buffer *pab_blocks, const offload_buffer *grids[nlevels], offload_buffer *hab_blocks, double forces[natoms][3], double virial[3][3]) |
| Integrate all tasks of in given list from given grids. See grid_task_list.h for details. | |
| void grid_cpu_create_task_list | ( | const bool | orthorhombic, |
| const int | ntasks, | ||
| const int | nlevels, | ||
| const int | natoms, | ||
| const int | nkinds, | ||
| const int | nblocks, | ||
| const int | block_offsets[nblocks], | ||
| const double | atom_positions[natoms][3], | ||
| const int | atom_kinds[natoms], | ||
| const grid_basis_set * | basis_sets[nkinds], | ||
| const int | level_list[ntasks], | ||
| const int | iatom_list[ntasks], | ||
| const int | jatom_list[ntasks], | ||
| const int | iset_list[ntasks], | ||
| const int | jset_list[ntasks], | ||
| const int | ipgf_list[ntasks], | ||
| const int | jpgf_list[ntasks], | ||
| const int | border_mask_list[ntasks], | ||
| const int | block_num_list[ntasks], | ||
| const double | radius_list[ntasks], | ||
| const double | rab_list[ntasks][3], | ||
| const int | npts_global[nlevels][3], | ||
| const int | npts_local[nlevels][3], | ||
| const int | shift_local[nlevels][3], | ||
| const int | border_width[nlevels][3], | ||
| const double | dh[nlevels][3][3], | ||
| const double | dh_inv[nlevels][3][3], | ||
| grid_cpu_task_list ** | task_list_out | ||
| ) |
Allocates a task list for the cpu backend. See grid_task_list.h for details.
Definition at line 42 of file grid_cpu_task_list.c.
| void grid_cpu_free_task_list | ( | grid_cpu_task_list * | task_list | ) |
Deallocates given task list, basis_sets have to be freed separately.
Definition at line 182 of file grid_cpu_task_list.c.
| void grid_cpu_collocate_task_list | ( | const grid_cpu_task_list * | task_list, |
| const enum grid_func | func, | ||
| const int | nlevels, | ||
| const offload_buffer * | pab_blocks, | ||
| offload_buffer * | grids[nlevels] | ||
| ) |
Collocate all tasks of in given list onto given grids. See grid_task_list.h for details.
Definition at line 417 of file grid_cpu_task_list.c.
| void grid_cpu_integrate_task_list | ( | const grid_cpu_task_list * | task_list, |
| const bool | compute_tau, | ||
| const int | natoms, | ||
| const int | nlevels, | ||
| const offload_buffer * | pab_blocks, | ||
| const offload_buffer * | grids[nlevels], | ||
| offload_buffer * | hab_blocks, | ||
| double | forces[natoms][3], | ||
| double | virial[3][3] | ||
| ) |
Integrate all tasks of in given list from given grids. See grid_task_list.h for details.
Definition at line 632 of file grid_cpu_task_list.c.