blob: 41a7a069617516fb974a1e8a3fa85118c70e86fe (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
/* Copyright 2020 David Grote
*
* This file is part of WarpX.
*
* License: BSD-3-Clause-LBNL
*/
#ifndef WARPX_PARTICLES_COLLISION_COLLISIONHANDLER_H_
#define WARPX_PARTICLES_COLLISION_COLLISIONHANDLER_H_
#include "CollisionBase.H"
#include "Particles/MultiParticleContainer_fwd.H"
#include <AMReX_REAL.H>
#include <AMReX_Vector.H>
#include <memory>
#include <string>
/* \brief CollisionHandler is a light weight class that contains the
* list of collisions to be done.
*/
class CollisionHandler
{
public:
CollisionHandler (MultiParticleContainer const * const mypc);
/* Perform all of the collisions */
void doCollisions (amrex::Real cur_time, MultiParticleContainer* mypc);
private:
amrex::Vector<std::string> collision_names;
amrex::Vector<std::string> collision_types;
amrex::Vector< std::unique_ptr<CollisionBase> > allcollisions;
};
#endif // WARPX_PARTICLES_COLLISION_COLLISIONHANDLER_H_
|