libtrixi
Loading...
Searching...
No Matches
trixi.h
Go to the documentation of this file.
1#ifndef TRIXI_H_
2#define TRIXI_H_
3
9// Setup
10void trixi_initialize(const char * project_directory, const char * depot_path);
11void trixi_finalize();
12
13// Version information
17const char* trixi_version_library();
18const char* trixi_version_julia();
20
21// Simulation control
22int trixi_initialize_simulation(const char * libelixir);
23void trixi_finalize_simulation(int handle);
24int trixi_is_finished(int handle);
25void trixi_step(int handle);
26
27// Simulation data
28int trixi_ndims(int handle);
29int trixi_nelements(int handle);
30int trixi_nelementsglobal(int handle);
31int trixi_ndofs(int handle);
32int trixi_ndofsglobal(int handle);
33int trixi_ndofselement(int handle);
34int trixi_nvariables(int handle);
35int trixi_nnodes(int handle);
36double trixi_calculate_dt(int handle);
37double trixi_get_simulation_time(int handle);
38void trixi_load_node_reference_coordinates(int handle, double* node_coords);
39void trixi_load_node_weights(int handle, double* node_weights);
40void trixi_load_primitive_vars(int handle, int variable_id, double * data);
41void trixi_load_element_averaged_primitive_vars(int handle, int variable_id, double * data);
42void trixi_register_data(int handle, int index, int size, const double * data);
43
44// T8code
45#if !defined(T8_H) && !defined(T8_FOREST_GENERAL_H)
46typedef struct t8_forest *t8_forest_t;
47#endif
49
50// Misc
51void trixi_eval_julia(const char * code);
52
57#endif // ifndef LIBTRIXI_H_
void trixi_finalize()
Finalize Julia runtime environment.
Definition api.c:161
int trixi_version_library_patch()
Return patch version number of libtrixi.
Definition api.c:240
double trixi_calculate_dt(int handle)
Get time step length.
Definition api.c:440
double trixi_get_simulation_time(int handle)
Return current physical time.
Definition api.c:738
int trixi_nvariables(int handle)
Return number of (conservative) variables.
Definition api.c:575
void trixi_load_primitive_vars(int handle, int variable_id, double *data)
Load primitive variable.
Definition api.c:661
void trixi_initialize(const char *project_directory, const char *depot_path)
Initialize Julia runtime environment.
Definition api.c:105
int trixi_ndofs(int handle)
Return number of local degrees of freedom.
Definition api.c:520
void trixi_eval_julia(const char *code)
Execute Julia code.
Definition api.c:790
int trixi_nelementsglobal(int handle)
Return global number of elements.
Definition api.c:499
int trixi_is_finished(int handle)
Check if simulation is finished.
Definition api.c:375
int trixi_initialize_simulation(const char *libelixir)
Set up Trixi simulation.
Definition api.c:353
t8_forest_t trixi_get_t8code_forest(int handle)
Definition api.c:765
int trixi_ndofselement(int handle)
Return number of degrees of freedom per element.
Definition api.c:558
struct t8_forest * t8_forest_t
Definition trixi.h:46
int trixi_ndofsglobal(int handle)
Return global number of degrees of freedom.
Definition api.c:541
void trixi_finalize_simulation(int handle)
Finalize simulation.
Definition api.c:413
int trixi_version_library_major()
Return major version number of libtrixi.
Definition api.c:200
int trixi_nelements(int handle)
Return number of local elements.
Definition api.c:478
void trixi_load_node_weights(int handle, double *node_weights)
Get weights of 1D quadrature nodes.
Definition api.c:636
const char * trixi_version_julia_extended()
Return name and version of all loaded Julia packages.
Definition api.c:321
const char * trixi_version_library()
Return full version string of libtrixi.
Definition api.c:268
void trixi_register_data(int handle, int index, int size, const double *data)
Store data vector in current simulation's registry.
Definition api.c:718
int trixi_version_library_minor()
Return minor version number of libtrixi.
Definition api.c:220
void trixi_step(int handle)
Perform next simulation step.
Definition api.c:394
const char * trixi_version_julia()
Return name and version of loaded Julia packages LibTrixi directly depends on.
Definition api.c:294
void trixi_load_element_averaged_primitive_vars(int handle, int variable_id, double *data)
Load element averages for primitive variable.
Definition api.c:687
int trixi_ndims(int handle)
Return number of spatial dimensions.
Definition api.c:457
int trixi_nnodes(int handle)
Return number of quadrature nodes per dimension.
Definition api.c:592
void trixi_load_node_reference_coordinates(int handle, double *node_coords)
Get reference coordinates of 1D quadrature nodes.
Definition api.c:614