ASCOT5
Loading...
Searching...
No Matches
asigma.c File Reference

Atomic reaction data interface. More...

#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#include "ascot5.h"
#include "print.h"
#include "error.h"
#include "asigma.h"
#include "asigma/asigma_loc.h"
#include "consts.h"

Go to the source code of this file.

Functions

void asigma_extrapolate (int extrapolate)
 Toggle extrapolation when evaluating cross sections.
 
void asigma_free (asigma_data *data)
 Free allocated resources.
 
void asigma_offload (asigma_data *data)
 Offload data to the accelerator.
 
a5err asigma_eval_sigma (real *sigma, int z_1, int a_1, int z_2, int a_2, real E_coll_per_amu, asigma_reac_type reac_type, asigma_data *asigma_data)
 Evaluate atomic reaction cross-section.
 
a5err asigma_eval_sigmav (real *sigmav, int z_1, int a_1, real m_1, int z_2, int a_2, real E, real T_e, real T_0, real n_i, asigma_reac_type reac_type, asigma_data *asigma_data)
 Evaluate atomic reaction rate coefficient.
 
a5err asigma_eval_cx (real *ratecoeff, int z_1, int a_1, real E, real mass, int nspec, const int *znum, const int *anum, real T_0, real *n_0, asigma_data *asigma_data)
 Evaluate charge exchange rate coefficient.
 
a5err asigma_eval_bms (real *ratecoeff, int z_1, int a_1, real E, real mass, int nion, const int *znum, const int *anum, real T_e, real *n_i, asigma_data *asigma_data)
 Evaluate beam stopping rate coefficient.
 

Variables

static int ASIGMA_EXTRAPOLATE = 0
 

Detailed Description

Atomic reaction data interface.

This is an interface through which atomic reaction data is initialized and accessed. Reading, for example from local files, is done elsewhere.

The name asigma is short for atomicsigma. The word sigma refers to cross-section, a fundamental type of reaction probability data. Note that the data is not necessarily in the form of pure cross-sections. It might be in some derivative form, such as rate coefficients.

To add a new atomic reaction data instance, make sure the functions are implemented and called from this interface, and that asigma.h contains enum type for the new instance.

The interface checks which instance given data corresponds to from the "type"-field in asigma_offload_data or asigma_data that is given as an argument, and calls the relevant function for that instance.

Definition in file asigma.c.

Function Documentation

◆ asigma_extrapolate()

void asigma_extrapolate ( int extrapolate)

Toggle extrapolation when evaluating cross sections.

In this context the extrapolation means values outside the abscissae are set to zero instead of raising an error.

Parameters
extrapolateflag whether to extrapolate

Definition at line 45 of file asigma.c.

◆ asigma_free()

void asigma_free ( asigma_data * data)

Free allocated resources.

Parameters
datapointer to the data struct

Definition at line 54 of file asigma.c.

◆ asigma_offload()

void asigma_offload ( asigma_data * data)

Offload data to the accelerator.

Parameters
datapointer to the data struct

Definition at line 67 of file asigma.c.

◆ asigma_eval_sigma()

a5err asigma_eval_sigma ( real * sigma,
int z_1,
int a_1,
int z_2,
int a_2,
real E_coll_per_amu,
asigma_reac_type reac_type,
asigma_data * asigma_data )

Evaluate atomic reaction cross-section.

This function evaluates the cross-section (sigma) for the atomic reaction corresponding to the reaction identifiers given as parameters at the given mass-normalized collision energy.

This is a SIMD function.

Parameters
sigmapointer to evaluated cross-section
z_1atomic number of fast particle
a_1atomic mass number of fast particle
z_2atomic number of bulk particle
a_2atomic mass number of bulk particle
E_coll_per_amuenergy per amu corresponding to collision speed
reac_typereaction type
asigma_datapointer to atomic data struct
Returns
Non-zero a5err value if evaluation failed, zero otherwise

Definition at line 95 of file asigma.c.

◆ asigma_eval_sigmav()

a5err asigma_eval_sigmav ( real * sigmav,
int z_1,
int a_1,
real m_1,
int z_2,
int a_2,
real E,
real T_e,
real T_0,
real n_i,
asigma_reac_type reac_type,
asigma_data * asigma_data )

Evaluate atomic reaction rate coefficient.

This function evaluates the rate coefficient (<sigma*v>) for the atomic reaction corresponding to the reaction identifiers given as parameters at the given fast particle energy and bulk plasma conditions.

This is a SIMD function.

Parameters
sigmavpointer to evaluated rate coefficient
z_1atomic number of fast particle
a_1atomic mass number of fast particle
m_1mass of fast particle
z_2atomic number of bulk particle
a_2atomic mass number of bulk particle
Eenergy of fast particle
T_eelectron temperature of bulk plasma
T_0temperature of bulk neutrals
n_iion density of bulk plasma
reac_typereaction type
asigma_datapointer to atomic data struct
Returns
Non-zero a5err value if evaluation failed, zero otherwise

Definition at line 145 of file asigma.c.

◆ asigma_eval_cx()

a5err asigma_eval_cx ( real * ratecoeff,
int z_1,
int a_1,
real E,
real mass,
int nspec,
const int * znum,
const int * anum,
real T_0,
real * n_0,
asigma_data * asigma_data )

Evaluate charge exchange rate coefficient.

This is a SIMD function.

Parameters
ratecoeffpointer to evaluated rate coefficient
z_1atomic number of fast particle
a_1atomic mass number of fast particle
Eenergy of fast particle
massmass of fast particle
nspecnumber of bulk neutral species
znumatomic numbers of bulk particles
anumatomic mass numbers of bulk particles
T_0temperature of bulk neutrals
n_0densities of bulk neutrals
asigma_datapointer to atomic data struct
Returns
Non-zero a5err value if evaluation failed, zero otherwise

Definition at line 191 of file asigma.c.

◆ asigma_eval_bms()

a5err asigma_eval_bms ( real * ratecoeff,
int z_1,
int a_1,
real E,
real mass,
int nion,
const int * znum,
const int * anum,
real T_e,
real * n_i,
asigma_data * asigma_data )

Evaluate beam stopping rate coefficient.

This is a SIMD function.

Parameters
ratecoeffpointer to evaluated rate coefficient
z_1atomic number of fast particle
a_1atomic mass number of fast particle
Eenergy of fast particle
massmass of fast particle
nionnumber of bulk ion species
znumatomic numbers of bulk particles
anumatomic mass numbers of bulk particles
T_eelectron temperature of bulk plasma
n_idensities of bulk ions
asigma_datapointer to atomic data struct
Returns
Non-zero a5err value if evaluation failed, zero otherwise

Definition at line 237 of file asigma.c.

Variable Documentation

◆ ASIGMA_EXTRAPOLATE

int ASIGMA_EXTRAPOLATE = 0
static

Set values outside abscissae to zero instead of raising an error.

Definition at line 34 of file asigma.c.