4 #define v_get_val(x,i) ((x)->ve[(i)]) 5 #define m_get_val(A,i,j) ((A)->me[(i)][(j)]) 6 #define SPECIES_ABSENT -1 105 void *(*task)(
void*);
140 void ics_dg_adi_x(
ICS_Grid_node*
g,
int,
int,
int,
double,
double*,
double*,
double*,
double*,
double*,
double*);
141 void ics_dg_adi_y(
ICS_Grid_node*
g,
int,
int,
int,
double,
double*,
double*,
double*,
double*,
double*,
double*);
142 void ics_dg_adi_z(
ICS_Grid_node*
g,
int,
int,
int,
double,
double*,
double*,
double*,
double*,
double*,
double*);
143 void ics_dg_adi_x_inhom(
ICS_Grid_node*
g,
int,
int,
int,
double,
double*,
double*,
double*,
double*,
double*,
double*);
144 void ics_dg_adi_y_inhom(
ICS_Grid_node*
g,
int,
int,
int,
double,
double*,
double*,
double*,
double*,
double*,
double*);
145 void ics_dg_adi_z_inhom(
ICS_Grid_node*
g,
int,
int,
int,
double,
double*,
double*,
double*,
double*,
double*,
double*);
157 int find(
const int,
const int,
const int,
const int,
const int);
void current_reaction(double *states)
void * TaskQueue_exe_tasks(void *)
void set_num_threads(const int)
double * states_for_reaction_dx
void ics_dg_adi_y(ICS_Grid_node *g, int, int, int, double, double *, double *, double *, double *, double *, double *)
void TaskQueue_sync(TaskQueue *)
void _ecs_ode_reinit(double *)
struct ICSReactions * next
void(* scatter)(double *, int)
ECS_Grid_node ** ecs_grid
void ics_dg_adi_x_inhom(ICS_Grid_node *g, int, int, int, double, double *, double *, double *, double *, double *, double *)
void ecs_set_adi_homogeneous(ECS_Grid_node *)
void run_threaded_ics_dg_adi(ICS_Grid_node *g, ICSAdiDirection *ics_adi_dir)
void dg_transfer_data(AdiLineData *const, double *const, int const, int const, int const)
struct SpeciesIndexList * next
struct SpeciesIndexList SpeciesIndexList
void _ics_variable_hybrid_helper(ICS_Grid_node *, const double *, double *const, const double *, double *const)
void _ics_rhs_variable_step_helper(ICS_Grid_node *, double const *const, double *)
void ecs_atolscale(double *)
void do_currents(Grid_node *, double *, double, int)
void(* ptr_update_cmd)(void *)
struct TaskQueue TaskQueue
void(* gather)(double *, int)
pthread_cond_t * task_cond
void _ics_hybrid_helper(ICS_Grid_node *)
void _rhs_variable_step_ecs(const double *, double *)
PyObject_HEAD struct OcPtrVector_(* newOcPtrVector)()
int const size_t const size_t n
void * do_reactions(void *)
void(* setval)(int, double)
int get_num_threads(void)
void ecs_set_adi_tort(ECS_Grid_node *)
pthread_mutex_t * task_mutex
void TaskQueue_add_task(TaskQueue *, void *(*task)(void *args), void *, void *)
void scatter_concentrations(void)
void ics_dg_adi_x(ICS_Grid_node *g, int, int, int, double, double *, double *, double *, double *, double *, double *)
void start_threads(const int)
void ecs_run_threaded_dg_adi(const int, const int, ECS_Grid_node *, ECSAdiDirection *, const int)
void _ode_reinit(double *)
double * ecs_states_for_reaction_dx
void _fadvance_fixed_step_3D(void)
ReactGridData * create_threaded_reactions(const int)
void _rhs_variable_step(const double *, double *)
void ics_dg_adi_z(ICS_Grid_node *g, int, int, int, double, double *, double *, double *, double *, double *, double *)
void _rhs_variable_step_helper(Grid_node *, double const *const, double *)
struct OcPtrVector_ OcPtrVector
void ecs_set_adi_vol(ECS_Grid_node *)
pthread_mutex_t * waiting_mutex
void ics_dg_adi_z_inhom(ICS_Grid_node *g, int, int, int, double, double *, double *, double *, double *, double *, double *)
void _rhs_variable_step_helper_vol(Grid_node *, double const *const, double *)
double * states_for_reaction
pthread_cond_t * waiting_cond
void do_ics_reactions(double *, double *, double *, double *)
void ics_ode_solve_helper(ICS_Grid_node *, double, double *)
void run_threaded_deltas(ICS_Grid_node *g, ICSAdiDirection *ics_adi_dir)
void _rhs_variable_step_helper_tort(Grid_node *, double const *const, double *)
void(* deleteOcPtrVector)()
void(* pset)(int, double *)
void apply_node_flux3D(Grid_node *, double, double *)
int find(const int, const int, const int, const int, const int)
void set_num_threads_3D(int n)
struct ICSReactions ICSReactions
double * ecs_states_for_reaction
void ics_ode_solve(double, double *, const double *)
void(* ReactionRate)(double **, double **, double **, double *, double *, double *, double *, double **, double)
void get_all_reaction_rates(double *, double *, double *)
void ics_dg_adi_y_inhom(ICS_Grid_node *g, int, int, int, double, double *, double *, double *, double *, double *, double *)