16 #ifndef DIFFRACTION_ANGLE_SELECTOR
17 #define DIFFRACTION_ANGLE_SELECTOR
20 #include "Geometry/3d.h"
43 vector<boost::shared_ptr<Event>>* events = r->getEvents();
46 if ((events->size() == 0) || (r->getDiff() == 0))
51 vec3 beginPos = r->getSource()->getPosition();
52 vec3 currentPos, nextPos, N, N1, N2, W, From, To;
56 decimal F1 = 0., F2 = 0., T1 = 0., T2 = 0., FT = 0.;
58 vector<boost::shared_ptr<Event>>::iterator iter = events->begin();
63 beginPos = (*iter)->getPosition();
68 currentPos = (*iter)->getPosition();
75 From = (currentPos - beginPos);
78 if ((iter + 1) != events->end())
80 nextPos = (*(iter + 1)).get()->getPosition();
84 nextPos =
static_cast<Recepteur*
>(r->getRecepteur())->getPosition();
87 To = (nextPos - currentPos);
127 beginPos = currentPos;
129 }
while (iter != events->end());
134 virtual void insert(T* r,
unsigned long long& replace)
141 vector<boost::shared_ptr<Event>>* events = r->getEvents();
143 if ((events->size() == 0) || (r->getDiff() == 0))
148 vec3 beginPos = r->getSource()->getPosition();
149 vec3 currentPos, nextPos, N, N1, N2, W, From, To;
153 decimal F1 = 0., F2 = 0., T1 = 0., T2 = 0., FT = 0.;
155 vector<boost::shared_ptr<Event>>::iterator iter = events->begin();
160 beginPos = (*iter)->getPosition();
165 currentPos = (*iter)->getPosition();
172 From = (currentPos - beginPos);
175 if ((iter + 1) != events->end())
177 nextPos = (*(iter + 1)).get()->getPosition();
181 nextPos =
static_cast<Recepteur*
>(r->getRecepteur())->getPosition();
184 To = (nextPos - currentPos);
224 beginPos = currentPos;
226 }
while (iter != events->end());
236 return typeid(
this).
name();
: Select diffracted rays that are launched in the shadow zone of the obstacle (closed angle) Other ar...
virtual bool insertWithTest(T *r)
Select the ray if it respects the criteria of this Selector.
virtual const char * getSelectorName()
Return the class type of the selector.
DiffractionAngleSelector()
Constructor.
virtual SELECTOR_RESPOND canBeInserted(T *r, unsigned long long &replace)
Check if the ray respects the criteria of this Selector and return a SELECTOR_RESPOND.
virtual void insert(T *r, unsigned long long &replace)
Select the ray.
virtual Selector< T > * Copy()
Copy Selector.
Shape * getShape()
Return the primitive of the impact.
Receptor inherits from a Sphere Shape.
Base class for Selector (used to keep or disable rays according different criterias)
void setIsDeletable(bool _isDeletable)
Set deletable flag.
bool deletable
Flag to know if the selector may be deleted or not.
virtual vec3 getNormal(const vec3 pos=vec3())
Get normal.
base_vec3< decimal > vec3