0.3.0
Loading...
Searching...
No Matches
NAV::WiFiPositioning Class Reference

Numerically integrates Imu data. More...

Classes

struct  Device
 Device struct. More...
 
struct  State
 State estimated by the positioning algorithm. More...
 

Public Member Functions

void guiConfig () override
 ImGui config window which is shown on double click.
 
WiFiPositioningoperator= (const WiFiPositioning &)=delete
 Copy assignment operator.
 
WiFiPositioningoperator= (WiFiPositioning &&)=delete
 Move assignment operator.
 
void restore (const json &j) override
 Restores the node from a json object.
 
json save () const override
 Saves the node into a json object.
 
std::string type () const override
 String representation of the Class Type.
 
 WiFiPositioning ()
 Default constructor.
 
 WiFiPositioning (const WiFiPositioning &)=delete
 Copy constructor.
 
 WiFiPositioning (WiFiPositioning &&)=delete
 Move constructor.
 
 ~WiFiPositioning () override
 Destructor.
 
- Public Member Functions inherited from NAV::Node
virtual void afterCreateLink (OutputPin &startPin, InputPin &endPin)
 Called when a new link was established.
 
virtual void afterDeleteLink (OutputPin &startPin, InputPin &endPin)
 Called when a link was deleted.
 
bool doDeinitialize (bool wait=false)
 Asks the node worker to deinitialize the node.
 
bool doDisable (bool wait=false)
 Asks the node worker to disable the node.
 
bool doEnable ()
 Enable the node.
 
bool doInitialize (bool wait=false)
 Asks the node worker to initialize the node.
 
bool doReinitialize (bool wait=false)
 Asks the node worker to reinitialize the node.
 
virtual void flush ()
 Function called by the flow executer after finishing to flush out remaining data.
 
template<typename T >
std::optional< InputPin::IncomingLink::ValueWrapper< T > > getInputValue (size_t portIndex) const
 Get Input Value connected on the pin. Only const data types.
 
Mode getMode () const
 Get the current mode of the node.
 
const ImVec2 & getSize () const
 Get the size of the node.
 
State getState () const
 Get the current state of the node.
 
InputPininputPinFromId (ax::NodeEditor::PinId pinId)
 Returns the pin with the given id.
 
size_t inputPinIndexFromId (ax::NodeEditor::PinId pinId) const
 Returns the index of the pin.
 
void invokeCallbacks (size_t portIndex, const std::shared_ptr< const NodeData > &data)
 Calls all registered callbacks on the specified output port.
 
bool isDisabled () const
 Checks if the node is disabled.
 
bool isInitialized () const
 Checks if the node is initialized.
 
bool isOnlyRealtime () const
 Checks if the node is only working in real time (sensors, network interfaces, ...)
 
bool isTransient () const
 Checks if the node is changing its state currently.
 
std::string nameId () const
 Node name and id.
 
 Node (const Node &)=delete
 Copy constructor.
 
 Node (Node &&)=delete
 Move constructor.
 
 Node (std::string name)
 Constructor.
 
void notifyOutputValueChanged (size_t pinIdx, const InsTime &insTime, const std::scoped_lock< std::mutex > &guard)
 Notifies connected nodes about the change.
 
virtual bool onCreateLink (OutputPin &startPin, InputPin &endPin)
 Called when a new link is to be established.
 
virtual void onDeleteLink (OutputPin &startPin, InputPin &endPin)
 Called when a link is to be deleted.
 
Nodeoperator= (const Node &)=delete
 Copy assignment operator.
 
Nodeoperator= (Node &&)=delete
 Move assignment operator.
 
OutputPinoutputPinFromId (ax::NodeEditor::PinId pinId)
 Returns the pin with the given id.
 
size_t outputPinIndexFromId (ax::NodeEditor::PinId pinId) const
 Returns the index of the pin.
 
void releaseInputValue (size_t portIndex)
 Unblocks the connected node. Has to be called when the input value should be released and getInputValue was not called.
 
std::scoped_lock< std::mutex > requestOutputValueLock (size_t pinIdx)
 Blocks the thread till the output values was read by all connected nodes.
 
virtual bool resetNode ()
 Resets the node. It is guaranteed that the node is initialized when this is called.
 
virtual void restoreAtferLink (const json &j)
 Restores link related properties of the node from a json object.
 
void wakeWorker ()
 Wakes the worker thread.
 
virtual ~Node ()
 Destructor.
 

Static Public Member Functions

static std::string category ()
 String representation of the Class Category.
 
static std::string typeStatic ()
 String representation of the Class Type.
 
- Static Public Member Functions inherited from NAV::Node
static std::string toString (State state)
 Converts the state into a printable text.
 

Private Types

enum class  Frame : uint8_t {
  ECEF ,
  LLA
}
 Available Frames. More...
 
enum class  InitCovarianceBiasUnit : uint8_t {
  meter2 ,
  meter
}
 Possible Units for the initial covariance for the bias (standard deviation σ or Variance σ²) More...
 
enum class  InitCovariancePositionUnit : uint8_t {
  meter2 ,
  meter
}
 Possible Units for the initial covariance for the position (standard deviation σ or Variance σ²) More...
 
enum class  InitCovarianceVelocityUnit : uint8_t {
  m2_s2 ,
  m_s
}
 Possible Units for the initial covariance for the velocity (standard deviation σ or Variance σ²) More...
 
enum class  MeasurementNoiseUnit : uint8_t {
  meter2 ,
  meter
}
 Possible Units for the measurement noise (standard deviation σ or Variance σ²) More...
 
enum class  ProcessNoiseUnit : uint8_t {
  meter2 ,
  meter
}
 Possible Units for the process noise (standard deviation σ or Variance σ²) More...
 
enum class  SolutionMode : uint8_t {
  LSQ ,
  KF
}
 Available Solution Modes. More...
 

Private Member Functions

void deinitialize () override
 Deinitialize the node.
 
bool initialize () override
 Initialize the node.
 
void kfSolution ()
 Calculate the position.
 
LeastSquaresResult< Eigen::VectorXd, Eigen::MatrixXd > lsqSolution ()
 Calculate the position using the least squares method.
 
void recvWiFiObs (InputPin::NodeDataQueue &queue, size_t pinIdx)
 Receive Function for the WiFi Observations.
 
void updateNumberOfInputPins ()
 Adds/Deletes Input Pins depending on the variable _nNavInfoPins.
 

Private Attributes

std::vector< double > _deviceBias
 Input of biases.
 
std::vector< std::string > _deviceMacAddresses
 Input of mac addresses.
 
std::vector< Eigen::Vector3d > _devicePositions
 Input of positions.
 
std::vector< Device_devices
 Devices which are used for the positioning.
 
std::vector< double > _deviceScale
 Input of scales.
 
bool _estimateBias
 Selection of whether the bias will be additionally estimated.
 
Frame _frame
 Frame to calculate the position in.
 
double _initCovarianceBias
 GUI selection of the initial covariance diagonal values for bias (standard deviation σ or Variance σ²)
 
InitCovarianceBiasUnit _initCovarianceBiasUnit
 Gui selection for the Unit of the initial covariance for the bias.
 
Eigen::Vector3d _initCovariancePosition
 GUI selection of the initial covariance diagonal values for position (standard deviation σ or Variance σ²)
 
InitCovariancePositionUnit _initCovariancePositionUnit
 Gui selection for the Unit of the initial covariance for the position.
 
Eigen::Vector3d _initCovarianceVelocity
 GUI selection of the initial covariance diagonal values for velocity (standard deviation σ or Variance σ²)
 
InitCovarianceVelocityUnit _initCovarianceVelocityUnit
 Gui selection for the Unit of the initial covariance for the velocity.
 
State _initialState
 Initial state.
 
KalmanFilter _kalmanFilter
 Kalman Filter representation - States: 3xVel, 3xPos, (1xBias) - Measurements: 1xDist.
 
InsTime _lastPredictTime
 Time when the last prediction was triggered.
 
double _measurementNoise
 GUI selection of the process noise (standard deviation σ or Variance σ²)
 
MeasurementNoiseUnit _measurementNoiseUnit
 Gui selection for the Unit of the initial covariance for the position.
 
uint8_t _numMeasurements
 Number of measurements.
 
size_t _numOfDevices
 Number of devices.
 
uint8_t _numStates
 Number of states.
 
size_t _nWifiInputPins
 Amount of wifi input pins.
 
double _processNoise
 GUI selection of the process noise (standard deviation σ or Variance σ²)
 
ProcessNoiseUnit _processNoiseUnit
 Gui selection for the Unit of the initial covariance for the position.
 
SolutionMode _solutionMode
 Solution Mode.
 
State _state
 State estimated by the algorithm.
 
bool _useInitialValues
 Selection of whether the initial values should always be used or those of the last position.
 
bool _weightedSolution
 Selection of whether the solution will be weighted.
 

Static Private Attributes

static constexpr size_t INPUT_PORT_INDEX_WIFI_OBS
 WiFiObs.
 
static constexpr size_t OUTPUT_PORT_INDEX_WIFISOL
 WiFiPositioningSolution.
 

Additional Inherited Members

- Public Types inherited from NAV::Node
enum class  Mode : uint8_t {
  REAL_TIME ,
  POST_PROCESSING
}
 Different Modes the Node can work in. More...
 
enum class  State : uint8_t {
  Disabled ,
  Deinitialized ,
  DoInitialize ,
  Initializing ,
  Initialized ,
  DoDeinitialize ,
  Deinitializing ,
  DoShutdown ,
  Shutdown
}
 Possible states of the node. More...
 
- Public Attributes inherited from NAV::Node
bool callbacksEnabled
 Enables the callbacks.
 
ax::NodeEditor::NodeId id
 Unique Id of the Node.
 
std::vector< InputPininputPins
 List of input pins.
 
Kind kind
 Kind of the Node.
 
std::string name
 Name of the Node.
 
std::vector< OutputPinoutputPins
 List of output pins.
 
std::multimap< InsTime, std::pair< OutputPin *, size_t > > pollEvents
 Map with callback events (sorted by time)
 
- Protected Attributes inherited from NAV::Node
ImVec2 _guiConfigDefaultWindowSize
 
bool _hasConfig
 Flag if the config window should be shown.
 
bool _lockConfigDuringRun
 Lock the config when executing post-processing.
 
bool _onlyRealTime
 Whether the node can run in post-processing or only real-time.
 

Detailed Description

Numerically integrates Imu data.

Member Enumeration Documentation

◆ Frame

enum class NAV::WiFiPositioning::Frame : uint8_t
strongprivate

Available Frames.

Enumerator
ECEF 

Earth-Centered Earth-Fixed frame.

LLA 

Latitude-Longitude-Altitude frame.

◆ InitCovarianceBiasUnit

enum class NAV::WiFiPositioning::InitCovarianceBiasUnit : uint8_t
strongprivate

Possible Units for the initial covariance for the bias (standard deviation σ or Variance σ²)

Enumerator
meter2 

Variance [m^2].

meter 

Standard deviation [m].

◆ InitCovariancePositionUnit

enum class NAV::WiFiPositioning::InitCovariancePositionUnit : uint8_t
strongprivate

Possible Units for the initial covariance for the position (standard deviation σ or Variance σ²)

Enumerator
meter2 

Variance NED [m^2, m^2, m^2].

meter 

Standard deviation NED [m, m, m].

◆ InitCovarianceVelocityUnit

enum class NAV::WiFiPositioning::InitCovarianceVelocityUnit : uint8_t
strongprivate

Possible Units for the initial covariance for the velocity (standard deviation σ or Variance σ²)

Enumerator
m2_s2 

Variance [m^2/s^2].

m_s 

Standard deviation [m/s].

◆ MeasurementNoiseUnit

enum class NAV::WiFiPositioning::MeasurementNoiseUnit : uint8_t
strongprivate

Possible Units for the measurement noise (standard deviation σ or Variance σ²)

Enumerator
meter2 

Variance NED [m^2, m^2, m^2].

meter 

Standard deviation NED [m, m, m].

◆ ProcessNoiseUnit

enum class NAV::WiFiPositioning::ProcessNoiseUnit : uint8_t
strongprivate

Possible Units for the process noise (standard deviation σ or Variance σ²)

Enumerator
meter2 

Variance NED [m^2, m^2, m^2].

meter 

Standard deviation NED [m, m, m].

◆ SolutionMode

enum class NAV::WiFiPositioning::SolutionMode : uint8_t
strongprivate

Available Solution Modes.

Enumerator
LSQ 

Least Squares.

KF 

Kalman Filter.

Member Function Documentation

◆ deinitialize()

void NAV::WiFiPositioning::deinitialize ( )
overrideprivatevirtual

Deinitialize the node.

Reimplemented from NAV::Node.

◆ guiConfig()

void NAV::WiFiPositioning::guiConfig ( )
overridevirtual

ImGui config window which is shown on double click.

Attention
Don't forget to set _hasConfig to true in the constructor of the node

Reimplemented from NAV::Node.

◆ initialize()

bool NAV::WiFiPositioning::initialize ( )
overrideprivatevirtual

Initialize the node.

Reimplemented from NAV::Node.

◆ lsqSolution()

LeastSquaresResult< Eigen::VectorXd, Eigen::MatrixXd > NAV::WiFiPositioning::lsqSolution ( )
private

Calculate the position using the least squares method.

Returns
Least Squares solution

◆ recvWiFiObs()

void NAV::WiFiPositioning::recvWiFiObs ( InputPin::NodeDataQueue & queue,
size_t pinIdx )
private

Receive Function for the WiFi Observations.

Parameters
[in]queueQueue with all the received data messages
[in]pinIdxIndex of the pin the data is received on

◆ restore()

void NAV::WiFiPositioning::restore ( const json & j)
overridevirtual

Restores the node from a json object.

Parameters
[in]jJson object with the node state

Reimplemented from NAV::Node.

◆ save()

json NAV::WiFiPositioning::save ( ) const
nodiscardoverridevirtual

Saves the node into a json object.

Reimplemented from NAV::Node.

◆ type()

std::string NAV::WiFiPositioning::type ( ) const
nodiscardoverridevirtual

String representation of the Class Type.

Implements NAV::Node.


The documentation for this class was generated from the following file: