1
/////////////////////////////////////////////////////////////
3
// Copyright (c) 2007-2011 by The University of Queensland //
4
// Earth Systems Science Computational Centre (ESSCC) //
5
// http://www.uq.edu.au/esscc //
7
// Primary Business: Brisbane, Queensland, Australia //
8
// Licensed under the Open Software License version 3.0 //
9
// http://www.opensource.org/licenses/osl-3.0.php //
11
/////////////////////////////////////////////////////////////
13
#ifndef __ELLIPSOID_VOL_H
14
#define __ELLIPSOID_VOL_H
16
// --- Project includes ---
17
#include "AVolume3D.h"
19
// --- STL includes ---
24
class EllipsoidVol : public AVolume3D
27
double m_lx,m_ly,m_lz;
32
EllipsoidVol(const Vector3&,double,double,double);
33
virtual ~EllipsoidVol(){};
35
virtual pair<Vector3,Vector3> getBoundingBox();
36
virtual Vector3 getAPoint(int) const;
37
virtual const map<double,const AGeometricObject*> getClosestObjects(const Vector3&,int) const;
38
virtual bool isIn(const Vector3&) const;
39
virtual bool isIn(const Sphere&);
40
virtual bool isFullyOutside(const Sphere&);
42
friend ostream& operator << (ostream&,const EllipsoidVol&);
45
#endif // __ELLIPSOID_VOL_H