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

3D wall collision checks More...

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include "../ascot5.h"
#include "wall_3d.h"
#include "../list.h"
#include "../octree.h"
#include "../print.h"

Go to the source code of this file.

Functions

void wall_3d_init_octree (wall_3d_data *w)
 Construct wall octree recursively.
 
int wall_3d_init (wall_3d_data *data, int nelements, real *x1x2x3, real *y1y2y3, real *z1z2z3)
 Initialize 3D wall data and check inputs.
 
void wall_3d_free (wall_3d_data *data)
 Free allocated resources.
 
void wall_3d_offload (wall_3d_data *data)
 Offload data to the accelerator.
 
void wall_3d_init_tree (wall_3d_data *w, real *offload_array)
 Construct wall octree iteratively.
 
int wall_3d_hit_wall (real r1, real phi1, real z1, real r2, real phi2, real z2, wall_3d_data *wdata, real *w_coll)
 Check if trajectory from (r1, phi1, z1) to (r2, phi2, z2) intersects the wall using the octree structure.
 
int wall_3d_hit_wall_full (real r1, real phi1, real z1, real r2, real phi2, real z2, wall_3d_data *wdata, real *w_coll)
 Check if trajectory from (r1, phi1, z1) to (r2, phi2, z2) intersects the wall against all triangles.
 
int wall_3d_tri_in_cube (real t1[3], real t2[3], real t3[3], real bb1[3], real bb2[3])
 Check if any part of a triangle is inside a box.
 
double wall_3d_tri_collision (real q1[3], real q2[3], real t1[3], real t2[3], real t3[3])
 Check if a line segment intersects a triangle.
 
int wall_3d_quad_collision (real q1[3], real q2[3], real t1[3], real t2[3], real t3[3], real t4[3])
 Check if a line segment intersects a quad (assumed planar)
 

Detailed Description

3D wall collision checks

3D wall model where wall consists of small triangles that form a surface mesh. A wall collision happens when a marker intersects a wall triangle's plane. During initialization, the computational model is divided into smaller cell using octree, and wall triangles are divided according to which cell(s) they inhabit. Collision checks are only made with respect to triangles that are in the same cell as the marker.

Definition in file wall_3d.c.

Function Documentation

◆ wall_3d_init_octree()

void wall_3d_init_octree ( wall_3d_data * w)

Construct wall octree recursively.

Constructs the octree array by iterating through all wall triangles and placing them into an octree structure

Parameters
wpointer to wall data
offload_arraythe offload array
tree_arraypointer to array storing what octree cells contain which triangles

Definition at line 223 of file wall_3d.c.

◆ wall_3d_init()

int wall_3d_init ( wall_3d_data * data,
int nelements,
real * x1x2x3,
real * y1y2y3,
real * z1z2z3 )

Initialize 3D wall data and check inputs.

Before calling this function, the offload struct is expected to hold triangle positions as

[x1_1, y1_1, z1_1, x2_1, y2_1, z2_1, x3_1, y3_1, z3_1,... ],

where first index is for the triangle vertex and second for the triangle itself.

This function fill rest of the offload struct and constructs the octree, while also printing some values as sanity check.

The default octree depth is defined by macro WALL_OCTREE_DEPTH in wall_3d.h.

Parameters
offload_datapointer to offload data struct
offload_arraypointer to offload array
int_offload_arraypointer to offload array containing integers
Returns
zero if initialization succeeded

Definition at line 46 of file wall_3d.c.

◆ wall_3d_free()

void wall_3d_free ( wall_3d_data * data)

Free allocated resources.

Parameters
datapointer to data struct

Definition at line 115 of file wall_3d.c.

◆ wall_3d_offload()

void wall_3d_offload ( wall_3d_data * data)

Offload data to the accelerator.

Parameters
datapointer to the data struct

Definition at line 125 of file wall_3d.c.

◆ wall_3d_init_tree()

void wall_3d_init_tree ( wall_3d_data * w,
real * offload_array )

Construct wall octree iteratively.

Constructs the octree array by iterating through all wall triangles and octree grid to identify triangles belonging to each grid cell.

Slow, only for testing purposes.

Parameters
wpointer to wall data
offload_arrayoffload array

Definition at line 143 of file wall_3d.c.

◆ wall_3d_hit_wall()

int wall_3d_hit_wall ( real r1,
real phi1,
real z1,
real r2,
real phi2,
real z2,
wall_3d_data * wdata,
real * w_coll )

Check if trajectory from (r1, phi1, z1) to (r2, phi2, z2) intersects the wall using the octree structure.

Parameters
r1start point R coordinate [m]
phi1start point phi coordinate [rad]
z1start point z coordinate [rad]
r2end point R coordinate [m]
phi2end point phi coordinate [rad]
z2end point z coordinate [rad]
wdatapointer to data struct on target
w_collpointer for storing the parameter in P = P1 + w_coll * (P2-P1), where P is the point where the collision occurred.
Returns
id, which is the first element id if hit, zero otherwise

Definition at line 315 of file wall_3d.c.

◆ wall_3d_hit_wall_full()

int wall_3d_hit_wall_full ( real r1,
real phi1,
real z1,
real r2,
real phi2,
real z2,
wall_3d_data * wdata,
real * w_coll )

Check if trajectory from (r1, phi1, z1) to (r2, phi2, z2) intersects the wall against all triangles.

Parameters
r1start point R coordinate [m]
phi1start point phi coordinate [rad]
z1start point z coordinate [rad]
r2end point R coordinate [m]
phi2end point phi coordinate [rad]
z2end point z coordinate [rad]
wdatapointer to data struct on target
w_collpointer for storing the parameter in P = P1 + w_coll * (P2-P1), where P is the point where the collision occurred.
Returns
id is wall element id if hit, zero otherwise*

Definition at line 395 of file wall_3d.c.

◆ wall_3d_tri_in_cube()

int wall_3d_tri_in_cube ( real t1[3],
real t2[3],
real t3[3],
real bb1[3],
real bb2[3] )

Check if any part of a triangle is inside a box.

Parameters
t1xyz coordinates of first triangle vertex [m]
t2xyz coordinates of second triangle vertex [m]
t3xyz coordinates of third triangle vertex [m]
bb1bounding box minimum xyz coordinates [m]
bb2bounding box maximum xyz coordinates [m]
Returns
zero if not any part of the triangle is within the box

Definition at line 440 of file wall_3d.c.

◆ wall_3d_tri_collision()

double wall_3d_tri_collision ( real q1[3],
real q2[3],
real t1[3],
real t2[3],
real t3[3] )

Check if a line segment intersects a triangle.

This routine implements the Möller-Trumbore algorithm.

Parameters
q1line segment start point xyz coordinates [m]
q2line segment end point xyz coordinates [m]
t1xyz coordinates of first triangle vertex [m]
t2xyz coordinates of second triangle vertex [m]
t3xyz coordinates of third triangle vertex [m]
Returns
A positive number w which is defined so that vector q1 + w*(q2-q1) is the intersection point. A negative number is returned if no there is no intersection

Definition at line 520 of file wall_3d.c.

◆ wall_3d_quad_collision()

int wall_3d_quad_collision ( real q1[3],
real q2[3],
real t1[3],
real t2[3],
real t3[3],
real t4[3] )

Check if a line segment intersects a quad (assumed planar)

Parameters
q1line segment start point xyz coordinates [m]
q2line segment end point xyz coordinates [m]
t1xyz coordinates of first quad vertex [m]
t2xyz coordinates of second quad vertex [m]
t3xyz coordinates of third quad vertex [m]
t4xyz coordinates of fourth quad vertex [m]
Returns
Zero if no intersection, positive number otherwise

Definition at line 595 of file wall_3d.c.