74 int nprt_generated = 0;
82 nprt_inj = nprt - nprt_generated;
90 nprt_generated += nprt_inj;
92 "Generated %d markers for injector %d.\n", nprt_inj, i+1);
98 for(
int i = 0; i < nprt; i++) {
105 for(
int i = 0; i < nprt; i++) {
106 pq.
p[pq.
next++] = &((*p)[i]);
139 + (1.0/3) * inj->
efrac[2];
144 #pragma omp parallel for
145 for(
int i = 0; i < nprt; i++) {
149 real xyz[3], vxyz[3], rpz[3], vhat[3];
160 xyz[0] += ds * vhat[0];
161 xyz[1] += ds * vhat[1];
162 xyz[2] += ds * vhat[2];
176 p[i].
p_r = vrpz[0] * gamma * inj->
mass;
177 p[i].
p_phi = vrpz[1] * gamma * inj->
mass;
178 p[i].
p_z = vrpz[2] * gamma * inj->
mass;
187 p[i].
id = ngenerated + i + 1;
219 for(
int i=0; i<
NSIMD; i++) {
230 while(n_running > 0) {
233 for(
int i=0; i<
NSIMD; i++) {
251 real posrpz[3] = {p.
r[i], p.
phi[i], p.
z[i]};
252 real posxyz[3], fposxyz[3];
254 fposxyz[0] = posxyz[0] + pxyz[0] * hin[i] / (gamma * p.
mass[i]);
255 fposxyz[1] = posxyz[1] + pxyz[1] * hin[i] / (gamma * p.
mass[i]);
256 fposxyz[2] = posxyz[2] + pxyz[2] * hin[i] / (gamma * p.
mass[i]);
259 p.
r[i] = sqrt(fposxyz[0]*fposxyz[0] + fposxyz[1]*fposxyz[1]);
261 posxyz[0] * fposxyz[1] - posxyz[1] * fposxyz[0],
262 posxyz[0] * fposxyz[0] + posxyz[1] * fposxyz[1] );
267 p.
p_r[i] = pxyz[0] * cosp + pxyz[1] * sinp;
268 p.
p_phi[i] = -pxyz[0] * sinp + pxyz[1] * cosp;
281 if(!err && p.
rho[i] <= 1.0 && rho[0] > 1.0) {
290 p.
theta[i] = atan2(p.
z[i]-axisrz[1], p.
r[i]-axisrz[0]);
294 pls_dens, pls_temp, rho[0], p.
r[i], p.
phi[i], p.
z[i],
304 n_species-1, pls_znum, pls_anum, pls_temp[0],
308 rate = pls_dens[0] * sigmav;
310 remaining[i] *= exp(-rate * ds);
316 if(shinethrough[i]) {
318 p0.
r[i], p0.
phi[i], p0.
z[i],
324 p.
r[i] = p0.
r[i] + w*(p.
r[i] - p0.
r[i]);
326 p.
z[i] = p0.
z[i] + w*(p.
z[i] - p0.
z[i]);
336 if(remaining[i] < threshold[i]) {
350 for(
int i=0; i<
NSIMD; i++) {
371 p.
B_phi[i] = B_dB[4];
389 pdiag.
time[i] += hin[i];
390 pdiag.
weight[i] /= hin[i];
a5err B_field_eval_rho(real rho[2], real psi, B_field_data *Bdata)
Evaluate normalized poloidal flux rho and its psi derivative.
a5err B_field_eval_psi(real *psi, real r, real phi, real z, real t, B_field_data *Bdata)
Evaluate poloidal flux psi.
a5err B_field_eval_B_dB(real B_dB[15], real r, real phi, real z, real t, B_field_data *Bdata)
Evaluate magnetic field and its derivatives.
a5err B_field_get_axis_rz(real rz[2], B_field_data *Bdata, real phi)
Return magnetic axis Rz-coordinates.
Header file for B_field.c.
Main header file for ASCOT5.
#define NBI_MAX_DISTANCE
Maximum distance BBNBI traces markers in seconds.
#define NSIMD
Number of particles simulated simultaneously in a particle group operations.
#define MAX_SPECIES
Maximum number of plasma species.
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.
Header file for asigma.c.
void bbnbi_inject_markers(particle_state *p, int nprt, int ngenerated, real t0, real t1, nbi_injector *inj, sim_data *sim)
Inject neutrals from an injector.
void bbnbi_simulate(sim_data *sim, int nprt, real t1, real t2, particle_state **p)
Simulate NBI injection.
void bbnbi_trace_markers(particle_queue *pq, sim_data *sim)
Trace a neutral marker until it has ionized or hit wall.
Functions to execute bbnbi externally.
Header file containing physical and mathematical constants.
#define CONST_E
Elementary charge [C]
void diag_update_fo(diag_data *data, B_field_data *Bdata, particle_simd_fo *p_f, particle_simd_fo *p_i)
Collects diagnostics when marker represents a particle.
Header file for endcond.c.
unsigned long int a5err
Simulation error flag.
#define math_vec_xyz2rpz(vxyz, vrpz, phi)
Transform vector from cartesian to cylindrical basis: vxyz -> vrpz, phi is the toroidal angle in radi...
#define math_unit(a, b)
Calculate unit vector b from a 3D vector a.
#define math_xyz2rpz(xyz, rpz)
Convert cartesian coordinates xyz to cylindrical coordinates rpz.
#define math_vec_rpz2xyz(vrpz, vxyz, phi)
Transform vector from cylindrical to cartesian basis: vrpz -> vxyz, phi is the toroidal angle in radi...
#define math_rpz2xyz(rpz, xyz)
Convert cylindrical coordinates rpz to cartesian coordinates xyz.
#define math_normc(a1, a2, a3)
Calculate norm of 3D vector from its components a1, a2, a3.
#define math_norm(a)
Calculate norm of 3D vector a.
void nbi_inject(real *xyz, real *vxyz, nbi_injector *inj, random_data *rng)
Sample injected marker's coordinates.
Header file for neutral.c.
void particle_allocate_fo(particle_simd_fo *p_fo, int nmrk)
Allocates struct representing particle markers.
int particle_cycle_fo(particle_queue *q, particle_simd_fo *p, B_field_data *Bdata, int *cycle)
Replace finished FO markers with new ones or dummies.
void particle_copy_fo(particle_simd_fo *p1, int i, particle_simd_fo *p2, int j)
Copy FO struct.
Header file for particle.c.
Methods to evaluate elementary physical quantities.
#define physlib_gamma_pnorm(m, p)
Evaluate Lorentz factor from momentum norm.
#define physlib_Ekin_pnorm(m, p)
Evaluate kinetic energy [J] from momentum norm.
#define physlib_gamma_vnorm(v)
Evaluate Lorentz factor from velocity norm.
const int * plasma_get_species_znum(plasma_data *pls_data)
Get charge number of ion species.
int plasma_get_n_species(plasma_data *pls_data)
Get the number of plasma species.
a5err plasma_eval_densandtemp(real *dens, real *temp, real rho, real r, real phi, real z, real t, plasma_data *pls_data)
Evaluate plasma density and temperature for all species.
const int * plasma_get_species_anum(plasma_data *pls_data)
Get atomic mass number of ion species.
Header file for plasma.c.
Macros for printing console output.
#define print_out0(v, rank, root,...)
Print to standard output only for root process.
Header file for random.c.
#define random_uniform(data)
#define random_init(data, seed)
void simulate_init(sim_data *sim)
Initialize simulation data struct.
Header file for simulate.c.
Structure for describing an NBI injector.
Struct representing NSIMD particle markers.
General representation of a marker.
Header file for suzuki.c.
int wall_hit_wall(real r1, real phi1, real z1, real r2, real phi2, real z2, wall_data *w, real *w_coll)
Check if a given directed line segment intersects the wall.