%include "cpointer.i" %include "carrays.i" %include "cdata.i" %include "cstring.i" %pointer_functions(int, int_p); %pointer_functions(int, int64_p); %pointer_functions(double, double_p); %array_functions(char, char_1d); %array_functions(int, int_1d); %array_functions(double, double_1d); %pointer_cast(void *, int *, void_p_to_int_p); %pointer_cast(void *, int **, void_p_to_int2d_p); %pointer_cast(void *, int *, void_p_to_int64_p); %pointer_cast(void *, int **, void_p_to_int64_2d_p); %pointer_cast(void *, double *, void_p_to_double_p); %pointer_cast(void *, double **, void_p_to_double_2d_p); #if !defined(SWIGLUA) %cstring_output_maxsize(char *buffer, int buf_size); #endif %{ /** Data type constants for extracting data from atoms, computes and fixes * * Must be kept in sync with the equivalent constants in ``src/library.h``, * ``python/lammps/constants.py``, ``examples/COUPLE/plugin/liblammpsplugin.h``, * ``src/lmptype.h``, and ``fortran/lammps.f90`` */ enum _LMP_DATATYPE_CONST { LAMMPS_NONE =-1, /*!< no data type assigned (yet) */ LAMMPS_INT = 0, /*!< 32-bit integer (array) */ LAMMPS_INT_2D = 1, /*!< two-dimensional 32-bit integer array */ LAMMPS_DOUBLE = 2, /*!< 64-bit double (array) */ LAMMPS_DOUBLE_2D = 3, /*!< two-dimensional 64-bit double array */ LAMMPS_INT64 = 4, /*!< 64-bit integer (array) */ LAMMPS_INT64_2D = 5, /*!< two-dimensional 64-bit integer array */ LAMMPS_STRING = 6 /*!< C-String */ }; /** Style constants for extracting data from computes and fixes. * * Must be kept in sync with the equivalent constants in ``src/library.h``, * ``python/lammps/constants.py``, ``examples/COUPLE/plugin/liblammpsplugin.h``, * and ``fortran/lammps.f90`` */ enum _LMP_STYLE_CONST { LMP_STYLE_GLOBAL = 0, /*!< return global data */ LMP_STYLE_ATOM = 1, /*!< return per-atom data */ LMP_STYLE_LOCAL = 2 /*!< return local data */ }; /** Type and size constants for extracting data from computes and fixes. * * Must be kept in sync with the equivalent constants in ``src/library.h``, * ``python/lammps/constants.py``, ``examples/COUPLE/plugin/liblammpsplugin.h``, * and ``fortran/lammps.f90`` */ enum _LMP_TYPE_CONST { LMP_TYPE_SCALAR = 0, /*!< return scalar */ LMP_TYPE_VECTOR = 1, /*!< return vector */ LMP_TYPE_ARRAY = 2, /*!< return array */ LMP_SIZE_VECTOR = 3, /*!< return length of vector */ LMP_SIZE_ROWS = 4, /*!< return number of rows */ LMP_SIZE_COLS = 5 /*!< return number of columns */ }; /** Error codes to select the suitable function in the Error class * * Must be kept in sync with the equivalent constants in ``src/library.h``, * ``python/lammps/constants.py``, ``examples/COUPLE/plugin/liblammpsplugin.h``, * and ``fortran/lammps.f90`` */ enum _LMP_ERROR_CONST { LMP_ERROR_WARNING = 0, /*!< call Error::warning() */ LMP_ERROR_ONE = 1, /*!< called from one MPI rank */ LMP_ERROR_ALL = 2, /*!< called from all MPI ranks */ LMP_ERROR_WORLD = 4, /*!< error on Comm::world */ LMP_ERROR_UNIVERSE = 8 /*!< error on Comm::universe */ }; /** Variable style constants for extracting data from variables. * * Must be kept in sync with the equivalent constants in ``src/library.h``, * ``python/lammps/constants.py``, ``examples/COUPLE/plugin/liblammpsplugin.h``, * and ``fortran/lammps.f90`` */ enum _LMP_VAR_CONST { LMP_VAR_EQUAL = 0, /*!< compatible with equal-style variables */ LMP_VAR_ATOM = 1, /*!< compatible with atom-style variables */ LMP_VAR_VECTOR = 2, /*!< compatible with vector-style variables */ LMP_VAR_STRING = 3 /*!< return value will be a string (catch-all) */ }; /** Neighbor list settings constants * * Must be kept in sync with the equivalent constants in ``python/lammps/constants.py``, * ``fortran/lammps.f90``, ``tools/swig/lammps.i``, and * ``examples/COUPLE/plugin/liblammpsplugin.h`` */ enum _LMP_NEIGH_CONST { LMP_NEIGH_HALF = 0, /*!< request (default) half neighbor list */ LMP_NEIGH_FULL = 1, /*!< request full neighbor list */ }; /* extern void *lammps_open(int argc, char **argv, MPI_Comm comm, void **ptr); */ extern void *lammps_open_no_mpi(int argc, char **argv, void **ptr); extern void *lammps_open_fortran(int argc, char **argv, int f_comm); extern void lammps_close(void *handle); extern void lammps_mpi_init(); extern void lammps_mpi_finalize(); extern void lammps_kokkos_finalize(); extern void lammps_python_finalize(); extern void lammps_plugin_finalize(); extern void lammps_error(void *handle, int error_type, const char *error_text); extern char *lammps_expand(void *handle, const char *line); extern void lammps_file(void *handle, const char *file); extern char *lammps_command(void *handle, const char *cmd); extern void lammps_commands_list(void *handle, int ncmd, const char **cmds); extern void lammps_commands_string(void *handle, const char *str); extern double lammps_get_natoms(void *handle); extern double lammps_get_thermo(void *handle, const char *keyword); extern void *lammps_last_thermo(void *handle, const char *what, int index); extern void lammps_extract_box(void *handle, double *boxlo, double *boxhi, double *xy, double *yz, double *xz, int *pflags, int *boxflag); extern void lammps_reset_box(void *handle, double *boxlo, double *boxhi, double xy, double yz, double xz); extern void lammps_memory_usage(void *handle, double *meminfo); extern int lammps_get_mpi_comm(void *handle); extern int lammps_extract_setting(void *handle, const char *keyword); extern int lammps_extract_global_datatype(void *handle, const char *name); extern void *lammps_extract_global(void *handle, const char *name); extern int lammps_extract_pair_dimension(void *handle, const char *name); extern void *lammps_extract_pair(void *handle, const char *name); extern int lammps_map_atom(void *handle, const void *id); extern int lammps_extract_atom_datatype(void *handle, const char *name); extern int lammps_extract_atom_size(void *handle, const char *name, int type); extern void *lammps_extract_atom(void *handle, const char *name); extern void *lammps_extract_compute(void *handle, const char *id, int, int); extern void *lammps_extract_fix(void *handle, const char *, int, int, int, int); extern void *lammps_extract_variable(void *handle, const char *, const char *); extern int lammps_extract_variable_datatype(void *handle, const char *name); extern int lammps_set_variable(void *, const char *, const char *); extern int lammps_set_string_variable(void *, const char *, const char *); extern int lammps_set_internal_variable(void *, const char *, double); extern int lammps_variable_info(void *handle, int idx, char *buf, int bufsize); extern double lammps_eval(void *handle, const char *expr); extern void lammps_clearstep_compute(void *handle); extern void lammps_addstep_compute(void *handle, void *nstep); extern void lammps_addstep_compute_all(void *handle, void *nstep); extern void lammps_gather_atoms(void *, const char *, int, int, void *); extern void lammps_gather_atoms_concat(void *, const char *, int, int, void *); extern void lammps_gather_atoms_subset(void *, const char *, int, int, int, int *, void *); extern void lammps_scatter_atoms(void *, const char *, int, int, void *); extern void lammps_scatter_atoms_subset(void *, const char *, int, int, int, int *, void *); extern void lammps_gather_bonds(void *handle, void *data); extern void lammps_gather_angles(void *handle, void *data); extern void lammps_gather_dihedrals(void *handle, void *data); extern void lammps_gather_impropers(void *handle, void *data); extern void lammps_gather(void *, const char *, int, int, void *); extern void lammps_gather_concat(void *, const char *, int, int, void *); extern void lammps_gather_subset(void *, const char *, int, int, int, int *, void *); extern void lammps_scatter(void *, const char *, int, int, void *); extern void lammps_scatter_subset(void *, const char *, int, int, int, int *, void *); extern int lammps_create_atoms(void *handle, int n, const int *id, const int *type, const double *x, const double *v, const int *image, int bexpand); /* extern int lammps_create_atoms(void *handle, int n, int64_t *id, int *type, */ extern int lammps_find_pair_neighlist(void *, const char *, int, int, int); extern int lammps_find_fix_neighlist(void *, const char *, int); extern int lammps_find_compute_neighlist(void *, const char *, int); extern int lammps_request_single_neighlist(void *, const char *, int, double); extern int lammps_neighlist_num_elements(void *, int); extern void lammps_neighlist_element_neighbors(void *, int, int, int *, int *, int ** ); extern int lammps_version(void *handle); extern void lammps_get_os_info(char *buffer, int buf_size); extern int lammps_config_has_mpi_support(); extern int lammps_config_has_gzip_support(); extern int lammps_config_has_png_support(); extern int lammps_config_has_jpeg_support(); extern int lammps_config_has_ffmpeg_support(); extern int lammps_config_has_curl_support(); extern int lammps_config_has_exceptions(); extern int lammps_config_has_package(const char *); extern int lammps_config_package_count(); extern int lammps_config_package_name(int, char *, int); extern int lammps_config_accelerator(const char *, const char *, const char *); extern int lammps_has_gpu_device(); extern void lammps_get_gpu_device_info(char *buffer, int buf_size); extern int lammps_has_style(void *, const char *, const char *); extern int lammps_style_count(void *, const char *); extern int lammps_style_name(void *, const char *, int, char *buffer, int buf_size); extern int lammps_has_id(void *, const char *, const char *); extern int lammps_id_count(void *, const char *); extern int lammps_id_name(void *, const char *, int, char *buffer, int buf_size); extern int lammps_plugin_count(); extern int lammps_plugin_name(int, char *, char *, int); /* * Have not found a good way to map these functions in a general way. * So some individual customization for the specific use case and compilation is needed. * extern int lammps_encode_image_flags(int ix, int iy, int iz); extern void lammps_decode_image_flags(int image, int *flags); extern int64_t lammps_encode_image_flags(int ix, int iy, int iz); extern void lammps_decode_image_flags(int64_t image, int *flags); * Supporting the fix external callback mechanism will require extra code specific to the application. typedef void (*FixExternalFnPtr)(void *, int64_t, int, int64_t *, double **, double **); extern void lammps_set_fix_external_callback(void *handle, const char *id, FixExternalFnPtr funcptr, void *ptr); * these two functions can only be used from the callback, so we don't support them either extern void lammps_fix_external_set_energy_peratom(void *handle, const char *id, double *eng); extern void lammps_fix_external_set_virial_peratom(void *handle, const char *id, double **virial); */ extern double **lammps_fix_external_get_force(void *handle, const char *id); extern void lammps_fix_external_set_energy_global(void *handle, const char *id, double eng); extern void lammps_fix_external_set_virial_global(void *handle, const char *id, double *virial); extern void lammps_fix_external_set_vector_length(void *handle, const char *id, int len); extern void lammps_fix_external_set_vector(void *handle, const char *id, int idx, double val); extern void lammps_flush_buffers(void *ptr); extern void lammps_free(void *ptr); extern int lammps_is_running(void *handle); extern void lammps_force_timeout(void *handle); extern int lammps_has_error(void *handle); extern int lammps_get_last_error_message(void *handle, char *buffer, int buf_size); extern int lammps_set_show_error(void *handle, const int flag); extern int lammps_python_api_version(); %} /** Data type constants for extracting data from atoms, computes and fixes * * Must be kept in sync with the equivalent constants in src/library.h, * python/lammps/constants.py, and fortran/lammps.f90 */ enum _LMP_DATATYPE_CONST { LAMMPS_INT = 0, /*!< 32-bit integer (array) */ LAMMPS_INT_2D = 1, /*!< two-dimensional 32-bit integer array */ LAMMPS_DOUBLE = 2, /*!< 64-bit double (array) */ LAMMPS_DOUBLE_2D = 3, /*!< two-dimensional 64-bit double array */ LAMMPS_INT64 = 4, /*!< 64-bit integer (array) */ LAMMPS_INT64_2D = 5, /*!< two-dimensional 64-bit integer array */ LAMMPS_STRING = 6 /*!< C-String */ }; /** Style constants for extracting data from computes and fixes. * * Must be kept in sync with the equivalent constants in src/library.h, * python/lammps/constants.py, and fortran/lammps.f90 */ enum _LMP_STYLE_CONST { LMP_STYLE_GLOBAL = 0, /*!< return global data */ LMP_STYLE_ATOM = 1, /*!< return per-atom data */ LMP_STYLE_LOCAL = 2 /*!< return local data */ }; /** Type and size constants for extracting data from computes and fixes. * * Must be kept in sync with the equivalent constants in src/library.h, * python/lammps/constants.py, and fortran/lammps.f90 */ enum _LMP_TYPE_CONST { LMP_TYPE_SCALAR = 0, /*!< return scalar */ LMP_TYPE_VECTOR = 1, /*!< return vector */ LMP_TYPE_ARRAY = 2, /*!< return array */ LMP_SIZE_VECTOR = 3, /*!< return length of vector */ LMP_SIZE_ROWS = 4, /*!< return number of rows */ LMP_SIZE_COLS = 5 /*!< return number of columns */ }; /** Error codes to select the suitable function in the Error class * * Must be kept in sync with the equivalent constants in src/library.h, * python/lammps/constants.py, and fortran/lammps.f90 */ enum _LMP_ERROR_CONST { LMP_ERROR_WARNING = 0, /*!< call Error::warning() */ LMP_ERROR_ONE = 1, /*!< called from one MPI rank */ LMP_ERROR_ALL = 2, /*!< called from all MPI ranks */ LMP_ERROR_WORLD = 4, /*!< error on Comm::world */ LMP_ERROR_UNIVERSE = 8 /*!< error on Comm::universe */ }; /** Variable style constants for extracting data from variables. * * Must be kept in sync with the equivalent constants in src/library.h, * python/lammps/constants.py, and fortran/lammps.f90 */ enum _LMP_VAR_CONST { LMP_VAR_EQUAL = 0, /*!< compatible with equal-style variables */ LMP_VAR_ATOM = 1, /*!< compatible with atom-style variables */ LMP_VAR_VECTOR = 2, /*!< compatible with vector-style variables */ LMP_VAR_STRING = 3 /*!< return value will be a string (catch-all) */ }; /* extern void *lammps_open(int argc, char **argv, MPI_Comm comm, void **ptr); */ extern void *lammps_open_no_mpi(int argc, char **argv, void **ptr); extern void *lammps_open_fortran(int argc, char **argv, int f_comm); extern void lammps_close(void *handle); extern void lammps_mpi_init(); extern void lammps_mpi_finalize(); extern void lammps_kokkos_finalize(); extern void lammps_python_finalize(); extern void lammps_plugin_finalize(); extern void lammps_error(void *handle, int error_type, const char *error_text); extern char *lammps_expand(void *handle, const char *line); extern void lammps_file(void *handle, const char *file); extern char *lammps_command(void *handle, const char *cmd); extern void lammps_commands_list(void *handle, int ncmd, const char **cmds); extern void lammps_commands_string(void *handle, const char *str); extern double lammps_get_natoms(void *handle); extern double lammps_get_thermo(void *handle, const char *keyword); extern void *lammps_last_thermo(void *handle, const char *what, int index); extern void lammps_extract_box(void *handle, double *boxlo, double *boxhi, double *xy, double *yz, double *xz, int *pflags, int *boxflag); extern void lammps_reset_box(void *handle, double *boxlo, double *boxhi, double xy, double yz, double xz); extern void lammps_memory_usage(void *handle, double *meminfo); extern int lammps_get_mpi_comm(void *handle); extern int lammps_extract_setting(void *handle, const char *keyword); extern int lammps_extract_global_datatype(void *handle, const char *name); extern void *lammps_extract_global(void *handle, const char *name); extern int lammps_extract_pair_dimension(void *handle, const char *name); extern void *lammps_extract_pair(void *handle, const char *name); extern int lammps_map_atom(void *handle, const void *id); extern int lammps_extract_atom_datatype(void *handle, const char *name); extern int lammps_extract_atom_size(void *handle, const char *name, int type); extern void *lammps_extract_atom(void *handle, const char *name); extern void *lammps_extract_compute(void *handle, const char *id, int, int); extern void *lammps_extract_fix(void *handle, const char *, int, int, int, int); extern void *lammps_extract_variable(void *handle, const char *, const char *); extern int lammps_extract_variable_datatype(void *handle, const char *name); extern int lammps_set_variable(void *, const char *, const char *); extern int lammps_set_string_variable(void *, const char *, const char *); extern int lammps_set_internal_variable(void *, const char *, double); extern int lammps_variable_info(void *handle, int idx, char *buf, int bufsize); extern double lammps_eval(void *handle, const char *expr); extern void lammps_clearstep_compute(void *handle); extern void lammps_addstep_compute(void *handle, void *nstep); extern void lammps_addstep_compute_all(void *handle, void *nstep); extern void lammps_gather_atoms(void *, const char *, int, int, void *); extern void lammps_gather_atoms_concat(void *, const char *, int, int, void *); extern void lammps_gather_atoms_subset(void *, const char *, int, int, int, int *, void *); extern void lammps_scatter_atoms(void *, const char *, int, int, void *); extern void lammps_scatter_atoms_subset(void *, const char *, int, int, int, int *, void *); extern void lammps_gather_bonds(void *handle, void *data); extern void lammps_gather_angles(void *handle, void *data); extern void lammps_gather_dihedrals(void *handle, void *data); extern void lammps_gather_impropers(void *handle, void *data); extern void lammps_gather(void *, const char *, int, int, void *); extern void lammps_gather_concat(void *, const char *, int, int, void *); extern void lammps_gather_subset(void *, const char *, int, int, int, int *, void *); extern void lammps_scatter(void *, const char *, int, int, void *); extern void lammps_scatter_subset(void *, const char *, int, int, int, int *, void *); extern int lammps_create_atoms(void *handle, int n, const int *id, const int *type, const double *x, const double *v, const int *image, int bexpand); /* extern int lammps_create_atoms(void *handle, int n, int64_t *id, int *type, */ extern int lammps_find_pair_neighlist(void*, const char *, int, int, int); extern int lammps_find_fix_neighlist(void*, const char *, int); extern int lammps_find_compute_neighlist(void*, const char *, int); extern int lammps_request_single_neighlist(void *, const char *, int, double); extern int lammps_neighlist_num_elements(void*, int); extern void lammps_neighlist_element_neighbors(void *, int, int, int *, int *, int ** ); extern int lammps_version(void *handle); extern void lammps_get_os_info(char *buffer, int buf_size); extern int lammps_config_has_mpi_support(); extern int lammps_config_has_gzip_support(); extern int lammps_config_has_png_support(); extern int lammps_config_has_jpeg_support(); extern int lammps_config_has_ffmpeg_support(); extern int lammps_config_has_curl_support(); extern int lammps_config_has_exceptions(); extern int lammps_config_has_package(const char *); extern int lammps_config_package_count(); extern int lammps_config_package_name(int, char *, int); extern int lammps_config_accelerator(const char *, const char *, const char *); extern int lammps_has_gpu_device(); extern void lammps_get_gpu_device_info(char *buffer, int buf_size); extern int lammps_has_style(void *, const char *, const char *); extern int lammps_style_count(void *, const char *); extern int lammps_style_name(void *, const char *, int, char *buffer, int buf_size); extern int lammps_has_id(void *, const char *, const char *); extern int lammps_id_count(void *, const char *); extern int lammps_id_name(void *, const char *, int, char *buffer, int buf_size); extern int lammps_plugin_count(); extern int lammps_plugin_name(int, char *, char *, int); /* * Have not found a good way to map these functions in a general way. * So some individual customization for the specific use case and compilation is needed. * extern int lammps_encode_image_flags(int ix, int iy, int iz); extern void lammps_decode_image_flags(int image, int *flags); extern int64_t lammps_encode_image_flags(int ix, int iy, int iz); extern void lammps_decode_image_flags(int64_t image, int *flags); * Supporting the fix external callback mechanism will require extra code specific to the application. typedef void (*FixExternalFnPtr)(void *, int64_t, int, int64_t *, double **, double **); extern void lammps_set_fix_external_callback(void *handle, const char *id, FixExternalFnPtr funcptr, void *ptr); * these two functions can only be used from the callback, so we don't support them either extern void lammps_fix_external_set_energy_peratom(void *handle, const char *id, double *eng); extern void lammps_fix_external_set_virial_peratom(void *handle, const char *id, double **virial); */ extern double **lammps_fix_external_get_force(void *handle, const char *id); extern void lammps_fix_external_set_energy_global(void *handle, const char *id, double eng); extern void lammps_fix_external_set_virial_global(void *handle, const char *id, double *virial); extern void lammps_fix_external_set_vector_length(void *handle, const char *id, int len); extern void lammps_fix_external_set_vector(void *handle, const char *id, int idx, double val); extern void lammps_flush_buffers(void *ptr); extern void lammps_free(void *ptr); extern int lammps_is_running(void *handle); extern void lammps_force_timeout(void *handle); extern int lammps_has_error(void *handle); extern int lammps_get_last_error_message(void *handle, char *buffer, int buf_size); extern int lammps_set_show_error(void *handle, const int flag); extern int lammps_python_api_version(); /* last revised on 3 October 2022 */