Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/patrickfav/indoor-positioning
A full-featured indoor positioning system that was developed during my master thesis. It has a javascript based rich UI and has a server-client architecture.
https://github.com/patrickfav/indoor-positioning
angular couchdb highcharts iot javaee nearest-neighbors open-wrt received-signal-strength wifi
Last synced: 2 months ago
JSON representation
A full-featured indoor positioning system that was developed during my master thesis. It has a javascript based rich UI and has a server-client architecture.
- Host: GitHub
- URL: https://github.com/patrickfav/indoor-positioning
- Owner: patrickfav
- Created: 2016-08-07T18:16:32.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2024-01-12T22:09:58.000Z (about 1 year ago)
- Last Synced: 2024-01-13T12:39:34.092Z (about 1 year ago)
- Topics: angular, couchdb, highcharts, iot, javaee, nearest-neighbors, open-wrt, received-signal-strength, wifi
- Language: Java
- Homepage: https://repositum.tuwien.at/handle/20.500.12708/2080
- Size: 23.9 MB
- Stars: 50
- Watchers: 5
- Forks: 24
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Introduction
This is a full-featured indoor positioning system that was developed during my master thesis.
Its server component uses servlets and an Angular JS front end, whereas the Router/AP service is written in Lua.[![GitHub release](https://img.shields.io/github/release/patrickfav/indoor-positioning.svg)](https://github.com/patrickfav/indoor-positioning/releases/latest)
[![Github Actions](https://github.com/patrickfav/indoor-positioning/actions/workflows/build.yml/badge.svg)](https://github.com/patrickfav/indoor-positioning/actions)
[![Coverage](https://sonarcloud.io/api/project_badges/measure?project=patrickfav_indoor-positioning&metric=coverage)](https://sonarcloud.io/summary/new_code?id=patrickfav_indoor-positioning)
[![Technical Debt](https://sonarcloud.io/api/project_badges/measure?project=patrickfav_indoor-positioning&metric=sqale_index)](https://sonarcloud.io/summary/new_code?id=patrickfav_indoor-positioning)![UI Overview](https://github.com/patrickfav/indoor-positioning/blob/main/misc/ui-overview.png?raw=true)
# Requirements
## Software
* Java 11
* Tomcat 7
* CouchDB 1.5
* Maven 3## Hardware
* At least 4 OpenWRT compatible AP/Routers in a network with provided custom web services
* At least 1 OpenWrt compatible AP/Router as client with provided custom web services# Architecture/Procedure
The underlying architecture can be observed in the diagram below.
![Map Generation Procedure Diagram](https://github.com/patrickfav/indoor-positioning/blob/main/misc/map_generation_procedure_lowsat.jpg?raw=true)
Overall procedure to map the target area:
1. **Node Setup & RSS Measurement**
Active Nodes, which can be regular access points, are distributed
among the target area. Next a measurement phase is initialized
which takes about one to three hours.2. **Site Evaluation**
From the resulting data, the underlying radio propagation model
can be adjusted to meet the actual properties of the current site.3. **Map Generation & Positioning**
With the adapted model, radio wave propagation can be simulated over
a representation of the target area. Positioning works similar to the
scene analysis approach using a modified nearest neighbor algorithm.![Phases Diagram](https://github.com/patrickfav/indoor-positioning/blob/main/misc/simple_phases_lowsat.jpg?raw=true)
# Setup
## Server
Start Tomcat & CouchDB with standard ports. Compile project with
`mvn clean package`
and deploy the *.war on your Tomcat. The DB will be set up automatically, the name of the db will be derived from the
maven -> , so if you have a backup change the finalName accordingly.## AP/Routers
## System Configuration
As prerequisites, you must have at least 4 APs ready (with installed webservers) in your network (knowing the IPs of each).
Open the browser and enter the url you deployed the war (usually something like [http://localhost:8080/MyProject](http://localhost:8080/)).
Create a new network by pressing the box with the "+". Enter the details and set "Surveys Per Node to 100" and "Survey Schedule" to
"Every Minute" to accelerate measurement.
Then next to "Active Nodes", add new nodes with "Add Node". Enter name and IP address, then press "discover" to see if
the node is reachable. After adding all nodes wait a couple of hours to let it measure.Next press "Schedule Job" -> "Start Single Run Analysis" and wait a couple of seconds. The analysis should appear under
"Analysis", reload page if not. The click "Radio Path Loss Config" and click "Normalize Node Multipliers". In the bottom
table click on drop-down under "SSID" and choose "Targetdistance". Add the physical distances between nodes in meters
in the distance matrix or skip the entire step. After entering the distances you can press "Calculate Path Loss Model"
to optimize the used model -> "Update config".Next, again, press "Schedule Job" -> "Start Single Run Analysis" and wait a couple of seconds. Select the current analysis
(with the adapted model). Choose "Signal Strength Map" and correct the positions of the active nodes. You may want to upload
a floor plan blueprint first in the network details (the pen icon next to the main header). After that, go to map full screen
mode (four arrows icon). Scale the floor plan with the slider until the meter sizes are correct (you may have to correct the
positions of the Active Nodes again). Then press "Calculate" next to the "Extended Nodes" headers. This will calculate the positions
of all APs/Routers in the vicinity. You may want to correct the positions you know of. Press "save". You now are ready
to position.![Node Editor](https://github.com/patrickfav/indoor-positioning/blob/main/misc/ui-node-editor.jpg?raw=true)
# Positioning
You need an AP with the custom webservices installed, same as Active Nodes. This AP must be in your network.
![Positioning](https://github.com/patrickfav/indoor-positioning/blob/main/misc/ui-positioning.png?raw=true)
Go to "Positioning". Input the IP of the client (AP) and press "Find". If multiple networks match for this position
you have to select one, otherwise you will be shown a UI with the estimated position. You may press on a square in the grid
to select the actual position to let the system calculate the offset.# Performance
Properties of the Proposed System
* Adapts well to the specific environment
* Good scalability and low maintenance with easy setup
* Accuracy between 2 and 4 meters on average (see diagram)
* Initial positioning with trilateration works well
* Quality degrades with non-correlating RSS## Accuracy
The results indicate that the position accuracy offers a performance comparable to
a state-of-the-art solution. The following diagram shows the accumulated offsets
in all test locations.![Accuracy Diagram](https://github.com/patrickfav/indoor-positioning/blob/main/misc/ac_diagram.png?raw=true)
## Scalability
Based on extrapolated data, the proposed system delivers superior performance in
terms of maintainability and scalability. In the diagram below the required effort
for various target areas is depicted.![Scalability Diagram](https://github.com/patrickfav/indoor-positioning/blob/main/misc/maintain_diagram.png?raw=true)
# License
Currently proprietary