TORCS  1.3.9
The Open Racing Car Simulator
Polytope.h
Go to the documentation of this file.
1 /*
2  SOLID - Software Library for Interference Detection
3  Copyright (C) 1997-1998 Gino van den Bergen
4 
5  This library is free software; you can redistribute it and/or
6  modify it under the terms of the GNU Library General Public
7  License as published by the Free Software Foundation; either
8  version 2 of the License, or (at your option) any later version.
9 
10  This library is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  Library General Public License for more details.
14 
15  You should have received a copy of the GNU Library General Public
16  License along with this library; if not, write to the Free
17  Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18 
19  Please send remarks, questions and bug reports to gino@win.tue.nl,
20  or write to:
21  Gino van den Bergen
22  Department of Mathematics and Computing Science
23  Eindhoven University of Technology
24  P.O. Box 513, 5600 MB Eindhoven, The Netherlands
25 */
26 
27 #ifndef _POLYTOPE_H_
28 #define _POLYTOPE_H_
29 
30 #ifdef _MSC_VER
31 #pragma warning(disable:4786) // identifier was truncated to '255'
32 #endif // _MSC_VER
33 
34 #include "Convex.h"
35 #include "IndexArray.h"
36 #include "VertexBase.h"
37 
38 class Polytope : public Convex {
39 public:
40  Polytope(const VertexBase& b, int c, const unsigned int v[]) :
41  base(b), index(c, v) {}
42  virtual ~Polytope() {}
43  virtual Point support(const Vector&) const = 0;
44 
45  const Point& operator[](int i) const { return base[index[i]]; }
46  int numVerts() const { return index.size(); }
47 
48 private:
49  const VertexBase& base;
51 };
52 
53 #endif
virtual ~Polytope()
Definition: Polytope.h:42
IndexArray index
Definition: Polytope.h:50
const VertexBase & base
Definition: Polytope.h:49
Definition: Convex.h:39
int size() const
Definition: IndexArray.h:46
virtual Point support(const Vector &) const =0
const Point & operator[](int i) const
Definition: Polytope.h:45
int numVerts() const
Definition: Polytope.h:46
Definition: Vector.h:32
Polytope(const VertexBase &b, int c, const unsigned int v[])
Definition: Polytope.h:40
Definition: Point.h:34