2008-04-11 10:11:29 +02:00
|
|
|
#ifndef _POINT_HH_
|
|
|
|
#define _POINT_HH_
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <math.h>
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
class Point
|
2009-05-29 13:46:49 +02:00
|
|
|
{
|
|
|
|
protected:
|
|
|
|
float x;
|
|
|
|
float y;
|
|
|
|
float z;
|
2008-07-03 15:04:30 +02:00
|
|
|
|
2009-05-29 13:46:49 +02:00
|
|
|
public:
|
|
|
|
Point(const float &_x = 0, const float &_y = 0, const float &_z = 0)
|
|
|
|
{
|
|
|
|
x = _x;
|
|
|
|
y = _y;
|
|
|
|
z = _z;
|
|
|
|
} ;
|
|
|
|
Point(const Point &p)
|
|
|
|
{
|
|
|
|
x = p.x;
|
|
|
|
y = p.y;
|
|
|
|
z = p.z;
|
|
|
|
} ;
|
|
|
|
Point(const float c[3])
|
|
|
|
{
|
|
|
|
x = c[0] ;
|
|
|
|
y = c[1] ;
|
|
|
|
z = c[2] ;
|
|
|
|
} ;
|
|
|
|
~Point() {};
|
Incorporation de la dernière version de Julien
Extrait de son courriel :
« Par rapport à la précédente j'ai surtout corrigé des bugs. »
Note : la version du listener portable sur Fonera, envoyée en même temps
par Julien, viendra plus tard (le temps que je l'incorpore).
Détail des changements après analyse du code :
aggregator : correction de bogues.
positioning :
* Ajout d'un fichier de config format boost (cfg/config.cfg).
* Makefile : implantation des cibles "install" et "uninstall" ; la cible
"astyle" devient "style".
* accesspoint.{hh,cc}, area.cc, measurement.hh, point.{hh,cc},
referencepoint.{hh,cc} : cosmétique.
* owlps-positioning.c : correction de la lecture du fichier de config
(ajout d'une option permettant de spécifier un fichier alternatif).
* server.cc : essentiellement correction des requêtes.
* libowlps-positioning.{hh,cc} : passage de "unsigned long long" à
"uint64_t" comme type de retour de timeval_to_ms().
writeInDb :
* Ajout de la gestion d'un fichier de config.
* Ajout de deux scripts pour la BDD.
git-svn-id: https://pif.pu-pm.univ-fcomte.fr/svn/loc@96 785a6c6c-259e-4ff1-8b91-dc31627914f0
2009-07-01 15:39:58 +02:00
|
|
|
|
2009-05-29 13:46:49 +02:00
|
|
|
float getX()const
|
|
|
|
{
|
|
|
|
return x;
|
|
|
|
};
|
|
|
|
float getY()const
|
|
|
|
{
|
|
|
|
return y;
|
|
|
|
};
|
|
|
|
float getZ()const
|
|
|
|
{
|
|
|
|
return z;
|
|
|
|
};
|
Incorporation de la dernière version de Julien
Extrait de son courriel :
« Par rapport à la précédente j'ai surtout corrigé des bugs. »
Note : la version du listener portable sur Fonera, envoyée en même temps
par Julien, viendra plus tard (le temps que je l'incorpore).
Détail des changements après analyse du code :
aggregator : correction de bogues.
positioning :
* Ajout d'un fichier de config format boost (cfg/config.cfg).
* Makefile : implantation des cibles "install" et "uninstall" ; la cible
"astyle" devient "style".
* accesspoint.{hh,cc}, area.cc, measurement.hh, point.{hh,cc},
referencepoint.{hh,cc} : cosmétique.
* owlps-positioning.c : correction de la lecture du fichier de config
(ajout d'une option permettant de spécifier un fichier alternatif).
* server.cc : essentiellement correction des requêtes.
* libowlps-positioning.{hh,cc} : passage de "unsigned long long" à
"uint64_t" comme type de retour de timeval_to_ms().
writeInDb :
* Ajout de la gestion d'un fichier de config.
* Ajout de deux scripts pour la BDD.
git-svn-id: https://pif.pu-pm.univ-fcomte.fr/svn/loc@96 785a6c6c-259e-4ff1-8b91-dc31627914f0
2009-07-01 15:39:58 +02:00
|
|
|
|
2009-05-29 13:46:49 +02:00
|
|
|
void setX(const float &_x)
|
|
|
|
{
|
|
|
|
x = _x;
|
|
|
|
};
|
|
|
|
void setY(const float &_y)
|
|
|
|
{
|
|
|
|
y = _y;
|
|
|
|
};
|
|
|
|
void setZ(const float &_z)
|
|
|
|
{
|
|
|
|
z = _z;
|
|
|
|
};
|
Incorporation de la dernière version de Julien
Extrait de son courriel :
« Par rapport à la précédente j'ai surtout corrigé des bugs. »
Note : la version du listener portable sur Fonera, envoyée en même temps
par Julien, viendra plus tard (le temps que je l'incorpore).
Détail des changements après analyse du code :
aggregator : correction de bogues.
positioning :
* Ajout d'un fichier de config format boost (cfg/config.cfg).
* Makefile : implantation des cibles "install" et "uninstall" ; la cible
"astyle" devient "style".
* accesspoint.{hh,cc}, area.cc, measurement.hh, point.{hh,cc},
referencepoint.{hh,cc} : cosmétique.
* owlps-positioning.c : correction de la lecture du fichier de config
(ajout d'une option permettant de spécifier un fichier alternatif).
* server.cc : essentiellement correction des requêtes.
* libowlps-positioning.{hh,cc} : passage de "unsigned long long" à
"uint64_t" comme type de retour de timeval_to_ms().
writeInDb :
* Ajout de la gestion d'un fichier de config.
* Ajout de deux scripts pour la BDD.
git-svn-id: https://pif.pu-pm.univ-fcomte.fr/svn/loc@96 785a6c6c-259e-4ff1-8b91-dc31627914f0
2009-07-01 15:39:58 +02:00
|
|
|
|
2009-05-29 13:46:49 +02:00
|
|
|
float squareDistance(const Point &p)const
|
|
|
|
{
|
|
|
|
return ((x-p.x)*(x-p.x))+((y-p.y)*(y-p.y))+((z-p.z)*(z-p.z));
|
|
|
|
};
|
|
|
|
float squareDistance(const float &mx, const float &my, const float &mz)const
|
|
|
|
{
|
|
|
|
return ((x-mx)*(x-mx))+((y-my)*(y-my))+((z-mz)*(z-mz));
|
|
|
|
};
|
|
|
|
float distance(const Point &p)const
|
|
|
|
{
|
|
|
|
return sqrt(((x-p.x)*(x-p.x))+((y-p.y)*(y-p.y))+((z-p.z)*(z-p.z)));
|
|
|
|
};
|
|
|
|
float distance(const float &mx, const float &my, const float &mz)const
|
|
|
|
{
|
|
|
|
return sqrt(((x-mx)*(x-mx))+((y-my)*(y-my))+((z-mz)*(z-mz)));
|
|
|
|
};
|
|
|
|
|
|
|
|
Point operator=(const Point &p) ;
|
|
|
|
bool operator==(const Point &p) const
|
|
|
|
{
|
|
|
|
return ((x == p.x) && (y == p.y) && (z == p.z)) ;
|
|
|
|
} ;
|
|
|
|
bool operator!=(const Point &p) const
|
|
|
|
{
|
|
|
|
return !(*this == p) ;
|
|
|
|
} ;
|
|
|
|
bool operator<(const Point &p) const ;
|
|
|
|
bool operator>(const Point &p) const
|
|
|
|
{
|
|
|
|
return (p < *this) ;
|
|
|
|
} ;
|
|
|
|
bool operator<=(const Point &p) const
|
|
|
|
{
|
|
|
|
return (*this < p || *this == p) ;
|
|
|
|
} ;
|
|
|
|
bool operator>=(const Point &p) const
|
|
|
|
{
|
|
|
|
return (p <= *this) ;
|
|
|
|
} ;
|
|
|
|
friend ostream &operator<<(ostream & os, const Point &p);
|
|
|
|
};
|
2008-04-11 10:11:29 +02:00
|
|
|
|
|
|
|
#endif
|