51 lines
1.7 KiB
C++
51 lines
1.7 KiB
C++
#ifndef _ACCESSPOINT_HH_
|
|
#define _ACCESSPOINT_HH_
|
|
|
|
#include <iostream>
|
|
#include <string>
|
|
#include "point.hh"
|
|
|
|
using namespace std;
|
|
using std::string;
|
|
|
|
#define AP_DEFAULT_ADDR ""
|
|
#define AP_DEFAULT_FRIIS_INDEX 0
|
|
#define AP_DEFAULT_FREQ 2412
|
|
#define AP_DEFAULT_ANTENNA_GAIN 2 // A good value
|
|
#define AP_DEFAULT_OUTPUT_POWER 20 // Another good value, eq. to 100mW
|
|
|
|
class AccessPoint
|
|
{
|
|
protected:
|
|
Point coordinates;
|
|
string ap_addr;
|
|
float friis_index;
|
|
unsigned int freq;
|
|
float antenna_gain;
|
|
float output_power;
|
|
|
|
public:
|
|
AccessPoint(string addr = AP_DEFAULT_ADDR, float fidx = AP_DEFAULT_FRIIS_INDEX, Point coords = Point(), unsigned int f = AP_DEFAULT_FREQ, float antg = AP_DEFAULT_ANTENNA_GAIN, float outp = AP_DEFAULT_OUTPUT_POWER);
|
|
AccessPoint(const AccessPoint &ap);
|
|
~AccessPoint() {};
|
|
string getApAddr()const { return ap_addr; };
|
|
float getFriisIndex()const { return friis_index; };
|
|
Point getCoordinates()const { return coordinates; };
|
|
float getAntennaGain()const { return antenna_gain; };
|
|
unsigned int getFrequency()const { return freq; };
|
|
float getOutputPower()const { return output_power; };
|
|
void setApAddr(string addr) { ap_addr = addr; };
|
|
void setFriisIndex(float fidx) { friis_index = fidx; };
|
|
void setCoordinates(Point apc) { coordinates = apc; };
|
|
void setCoordinates(float x, float y, float z) { Point apc(x, y, z); coordinates = apc; };
|
|
void setFrequency(unsigned int f) { freq = f; };
|
|
void setAntennaGain(float antg) { antenna_gain = antg; };
|
|
void setOutputPower(float outp) {output_power = outp; };
|
|
bool operator==(const AccessPoint &ap)const;
|
|
bool operator!=(const AccessPoint &ap)const;
|
|
AccessPoint operator=(const AccessPoint &ap);
|
|
friend ostream &operator<<(ostream & os, AccessPoint & ap);
|
|
};
|
|
|
|
#endif
|