ASCOT5
|
Module for evaluating MHD parameters. More...
#include <stdlib.h>
#include "../ascot5.h"
#include "../print.h"
#include "../error.h"
#include "../boozer.h"
#include "../spline/interp.h"
#include "../B_field.h"
#include "../math.h"
#include "../mhd.h"
#include "mhd_nonstat.h"
Go to the source code of this file.
Functions | |
int | mhd_nonstat_init_offload (mhd_nonstat_offload_data *offload_data, real **offload_array) |
Load MHD data and prepare parameters for offload. | |
void | mhd_nonstat_free_offload (mhd_nonstat_offload_data *offload_data, real **offload_array) |
Free offload array. | |
void | mhd_nonstat_init (mhd_nonstat_data *mhddata, mhd_nonstat_offload_data *offload_data, real *offload_array) |
Initialize MHD data struct on target. | |
a5err | mhd_nonstat_eval (real mhd_dmhd[10], real r, real phi, real z, real t, int includemode, boozer_data *boozerdata, mhd_nonstat_data *mhddata, B_field_data *Bdata) |
Evaluate the needed quantities from MHD mode for orbit following. | |
a5err | mhd_nonstat_perturbations (real pert_field[7], real r, real phi, real z, real t, int pertonly, int includemode, boozer_data *boozerdata, mhd_nonstat_data *mhddata, B_field_data *Bdata) |
Evaluate mhd perturbed fields Btilde, Etilde and potential Phi for full orbit. | |
Module for evaluating MHD parameters.
Definition in file mhd_nonstat.c.
int mhd_nonstat_init_offload | ( | mhd_nonstat_offload_data * | offload_data, |
real ** | offload_array ) |
Load MHD data and prepare parameters for offload.
This function fills the MHD offload struct with parameters and allocates and fills the offload array. Sets offload array length in the offload struct.
It is assumed that the offload_data struct is completely filled before calling this function (except for the offload_array_length and rhogrid). Furthermore, offload array should contain following data:
1D splines are constructed here and stored to offload array which is reallocated.
offload_data | pointer to offload data struct |
offload_array | pointer to pointer to offload array |
Definition at line 37 of file mhd_nonstat.c.
void mhd_nonstat_free_offload | ( | mhd_nonstat_offload_data * | offload_data, |
real ** | offload_array ) |
Free offload array.
offload_data | pointer to offload data struct |
offload_array | pointer to pointer to offload array |
Definition at line 109 of file mhd_nonstat.c.
void mhd_nonstat_init | ( | mhd_nonstat_data * | mhddata, |
mhd_nonstat_offload_data * | offload_data, | ||
real * | offload_array ) |
Initialize MHD data struct on target.
mhddata | pointer to data struct on target |
offload_data | pointer to offload data struct |
offload_array | pointer to offload array |
Definition at line 121 of file mhd_nonstat.c.
a5err mhd_nonstat_eval | ( | real | mhd_dmhd[10], |
real | r, | ||
real | phi, | ||
real | z, | ||
real | t, | ||
int | includemode, | ||
boozer_data * | boozerdata, | ||
mhd_nonstat_data * | mhddata, | ||
B_field_data * | Bdata ) |
Evaluate the needed quantities from MHD mode for orbit following.
The quantities to be evaluated are alpha, phi, grad alpha, grad phi, partial t alpha, partial t phi
The values are stored in the given array as:
mhd_dmhd | |
r | R coordinate [m] |
phi | phi coordinate [rad] |
z | z coordinate [m] |
t | time coordinate [s] |
includemode | mode number to include or MHD_INCLUDE_ALL |
boozerdata | pointer to boozer data |
mhddata | pointer to mhd data |
Bdata | pointer to magnetic field data |
Definition at line 184 of file mhd_nonstat.c.
a5err mhd_nonstat_perturbations | ( | real | pert_field[7], |
real | r, | ||
real | phi, | ||
real | z, | ||
real | t, | ||
int | pertonly, | ||
int | includemode, | ||
boozer_data * | boozerdata, | ||
mhd_nonstat_data * | mhddata, | ||
B_field_data * | Bdata ) |
Evaluate mhd perturbed fields Btilde, Etilde and potential Phi for full orbit.
The values are stored in the given array as
Only the perturbation values for the magnetic field are returned if pertonly=1, otherwise, the total perturbed field is returned. This is done to avoid double evaluation of the magnetic field e.g. in field line tracing. For electric field only the perturbation component is returned always.
pert_field | perturbation field components |
r | R coordinate [m] |
phi | phi coordinate [rad] |
z | z coordinate [m] |
t | time coordinate [s] |
pertonly | flag whether to return the whole field or only perturbation |
includemode | mode number to include or MHD_INCLUDE_ALL |
boozerdata | pointer to boozer data |
mhddata | pointer to mhd data |
Bdata | pointer to magnetic field data |
Definition at line 315 of file mhd_nonstat.c.