00001
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00033
00034 #ifndef GROOVX_VISX_SNAKE_H_UTC20050626084016_DEFINED
00035 #define GROOVX_VISX_SNAKE_H_UTC20050626084016_DEFINED
00036
00037 #include "geom/vec2.h"
00038
00039 #include "rutz/arrays.h"
00040
00041 namespace rutz
00042 {
00043 class urand;
00044 }
00045
00046 struct GaborArrayElement
00047 {
00048 enum Type { OUTSIDE, INSIDE, CONTOUR };
00049
00050 GaborArrayElement() {}
00051
00052 GaborArrayElement(double x, double y, double th, Type t) :
00053 pos(x,y), theta(th), type(t)
00054 {}
00055
00056 GaborArrayElement(const geom::vec2<int>& v, double th, Type t) :
00057 pos(v), theta(th), type(t)
00058 {}
00059
00060 geom::vec2d pos;
00061 double theta;
00062 Type type;
00063 };
00064
00065 class Snake
00066 {
00067 public:
00068 Snake(int l, double spacing, rutz::urand& urand);
00069 ~Snake();
00070
00071 GaborArrayElement getElement(int n) const;
00072
00073 private:
00074 const int itsLength;
00075 rutz::fixed_block<geom::vec2<double> > itsElem;
00076
00077 geom::vec2<double>& elem(int i)
00078 {
00079 i = i % itsLength;
00080 if (i < 0) i += itsLength;
00081 return itsElem[i];
00082 }
00083
00084 const geom::vec2<double>& elem(int i) const
00085 {
00086 i = i % itsLength;
00087 if (i < 0) i += itsLength;
00088 return itsElem[i];
00089 }
00090
00091
00092 bool jiggle(rutz::urand& urand);
00093 void transformPath(int i1, const geom::vec2<double>& new1,
00094 int i2, const geom::vec2<double>& new2);
00095 };
00096
00097 static const char __attribute__((used)) vcid_groovx_visx_snake_h_utc20050626084016[] = "$Id: snake.h 10065 2007-04-12 05:54:56Z rjpeters $ $HeadURL: file:
00098 #endif // !GROOVX_VISX_SNAKE_H_UTC20050626084016_DEFINED