Tool set for filtering and cleaning-up gps data. Remodels the data set as vectors in order to accomplish this.
Download node at nodejs.org and install it, if you haven't already.
npm install gps-filter --save
Included is a file called "browser_filter", compiled with browserify. Can be included in any html file, and will "gpsFilter" will be available globally.
# Points is expected to be an array of GPS points with a latitude, longitude, and timestamp;
# Valid formats: Latitude: [lat, latitude, y]
# Longitude[lng,longitude,x]
# Timestamp[time, timestamp, startime]
#Coordinate data in decimal, timestamp can be in any format momentjs can handle
#ALL SPEEDS ARE IN M/S
var gps-filter = require('gps-filter')
.positionFilter(points,min,max)
#Removes points where the change in position is outside the bounds
returns arrayOfFilteredPoints
.velocityFilter(points,min,max)
#Removes points where the velocity is outside the bounds
returns arrayOfFilteredPoints
.accelerationFilter(points,min,max)
#Removes points where the acceleration is outside the bounds
returns arrayOfFilteredPoints
.removeSpikes(points,sharpness,iterations)
#Remove points where the angle between the vector that starts there and ends there is greater than the sharpness
#E.g _/\_ -> _ _
#Sharpness: 0-Removes all points, 180-Removes None
#Iterations: defines the number of passes
returns arrayOfFilteredPoints
.smoothLine(points, threshold)
#Removes points by assuming that if the sum of two vectors is ~parallel to the one
#before it they should be combined
#E.G. __/\ -> ___
#~parallel is defined by threshold
#Threshold: 0-Vectors must be perfectly parallel 180-Every vector considered parallel (will delete everything!)
returns arrayOfFilteredPoints
npm install
npm test
- vectorize: Converts gps points to motion vectors
- chai: BDD/TDD assertion library for node.js and the browser. Test framework agnostic.
- coveralls: takes json-cov output into stdin and POSTs to coveralls.io
- istanbul: Yet another JS code coverage tool that computes statement, line, function and branch coverage with module loader hooks to transparently add coverage when running tests. Supports all JS coverage use cases including unit tests, server side functional tests
- mocha-lcov-reporter: LCOV reporter for Mocha
- victor: A JavaScript 2D vector class with methods for common vector operations
MIT
Generated by package-json-to-readme