ASCOT5
Loading...
Searching...
No Matches
Data Structures | Functions
B_GS.h File Reference

Header file for B_GS.c. More...

#include "../offload_acc_omp.h"
#include "../ascot5.h"
#include "../error.h"

Go to the source code of this file.

Data Structures

struct  B_GS_offload_data
 Analytic magnetic field parameters that will be offloaded to target. More...
 
struct  B_GS_data
 Analytic magnetic field parameters on the target. More...
 

Functions

int B_GS_init_offload (B_GS_offload_data *offload_data, real **offload_array)
 Initialize magnetic field offload data.
 
void B_GS_free_offload (B_GS_offload_data *offload_data, real **offload_array)
 Free offload array.
 
void B_GS_init (B_GS_data *Bdata, B_GS_offload_data *offload_data, real *offload_array)
 Initialize magnetic field data struct on target.
 
a5err B_GS_eval_B (real B[3], real r, real phi, real z, B_GS_data *Bdata)
 Evaluate magnetic field.
 
DECLARE_TARGET_END a5err B_GS_eval_psi (real *psi, real r, real phi, real z, B_GS_data *Bdata)
 Evaluate poloidal flux psi.
 
DECLARE_TARGET_END a5err B_GS_eval_psi_dpsi (real psi_dpsi[4], real r, real phi, real z, B_GS_data *Bdata)
 Evaluate poloidal flux psi and its derivatives.
 
DECLARE_TARGET_END a5err B_GS_eval_rho_drho (real rho_drho[4], real r, real phi, real z, B_GS_data *Bdata)
 Evaluate normalized poloidal flux rho and its derivatives.
 
DECLARE_TARGET_END a5err B_GS_eval_B_dB (real B_dB[12], real r, real phi, real z, B_GS_data *Bdata)
 Evaluate magnetic field and its derivatives.
 
DECLARE_TARGET_END a5err B_GS_get_axis_rz (real rz[2], B_GS_data *Bdata)
 Return magnetic axis R-coordinate.
 

Detailed Description

Header file for B_GS.c.

Definition in file B_GS.h.

Function Documentation

◆ B_GS_init_offload()

int B_GS_init_offload ( B_GS_offload_data * offload_data,
real ** offload_array )

Initialize magnetic field offload data.

The offload data struct is very simple and contains only the necessary fields which are all initialized when the data is read (except B_GS.offload_array_length). The offload array is not required at all. Therefore, this function only sets the offload_array_length to zero, assigns a NULL pointer to offload_array, and prints sanity checks so that user may verify that data was initialized succesfully.

Parameters
offload_datapointer to offload data struct
offload_arraypointer to offload array
Returns
zero to indicate success

Definition at line 91 of file B_GS.c.

◆ B_GS_free_offload()

void B_GS_free_offload ( B_GS_offload_data * offload_data,
real ** offload_array )

Free offload array.

Parameters
offload_datapointer to offload data struct
offload_arraypointer to pointer to offload array

Definition at line 131 of file B_GS.c.

◆ B_GS_init()

void B_GS_init ( B_GS_data * Bdata,
B_GS_offload_data * offload_data,
real * offload_array )

Initialize magnetic field data struct on target.

Parameters
Bdatapointer to data struct on target
offload_datapointer to offload data struct
offload_arrayoffload array

Definition at line 144 of file B_GS.c.

◆ B_GS_eval_B()

a5err B_GS_eval_B ( real B[3],
real r,
real phi,
real z,
B_GS_data * Bdata )

Evaluate magnetic field.

Parameters
Bpointer to array where magnetic field values are stored
rR coordinate [m]
phiphi coordinate [deg]
zz coordinate [m]
Bdatapointer to magnetic field data struct
Returns
zero to indicate success

Definition at line 327 of file B_GS.c.

◆ B_GS_eval_psi()

DECLARE_TARGET_END a5err B_GS_eval_psi ( real * psi,
real r,
real phi,
real z,
B_GS_data * Bdata )

Evaluate poloidal flux psi.

Parameters
psipointer where psi [V*s*m^-1] value will be stored
rR coordinate [m]
phiphi coordinate [rad]
zz coordinate [m]
Bdatapointer to magnetic field data struct
Returns
zero to indicate success

Definition at line 174 of file B_GS.c.

◆ B_GS_eval_psi_dpsi()

DECLARE_TARGET_END a5err B_GS_eval_psi_dpsi ( real psi_dpsi[4],
real r,
real phi,
real z,
B_GS_data * Bdata )

Evaluate poloidal flux psi and its derivatives.

Parameters
psi_dpsipointer for storing psi [V*s*m^-1] and its derivatives
rR coordinate [m]
phiphi coordinate [rad]
zz coordinate [m]
Bdatapointer to magnetic field data struct
Returns
zero to indicate success

Definition at line 227 of file B_GS.c.

◆ B_GS_eval_rho_drho()

DECLARE_TARGET_END a5err B_GS_eval_rho_drho ( real rho_drho[4],
real r,
real phi,
real z,
B_GS_data * Bdata )

Evaluate normalized poloidal flux rho and its derivatives.

Parameters
rho_drhopointer where rho and its derivatives will be stored
rR coordinate [m]
phiphi coordinate [rad]
zz coordinate [m]
Bdatapointer to magnetic field data struct
Returns
zero to indicate success

Definition at line 296 of file B_GS.c.

◆ B_GS_eval_B_dB()

DECLARE_TARGET_END a5err B_GS_eval_B_dB ( real B_dB[12],
real r,
real phi,
real z,
B_GS_data * Bdata )

Evaluate magnetic field and its derivatives.

Parameters
B_dBpointer to array where the field and its derivatives are stored
rR coordinate [m]
phiphi coordinate [deg]
zz coordinate [m]
Bdatapointer to magnetic field data struct
Returns
zero to indicate success

Definition at line 406 of file B_GS.c.

◆ B_GS_get_axis_rz()

DECLARE_TARGET_END a5err B_GS_get_axis_rz ( real rz[2],
B_GS_data * Bdata )

Return magnetic axis R-coordinate.

Parameters
rzpointer where axis R and z [m] values will be stored
Bdatapointer to magnetic field data struct
Returns
Zero a5err value as this function can't fail.

Definition at line 557 of file B_GS.c.