Thursday, 12 December 2013

Split and move GPS track segments

Some GPS devices record tracks with random errors like this:

I followed a smooth path here, the actual GPS track looks pretty irregular. To fix it you need to move every point, or just use a real GPS (instead of a smartphone "GPS" :-).

Other times your track may look something like this:

Note that the first part of the track follows the road but then it "decides" to leave the road (in reality, I never went off-road there) and then, later, it returns back on the road. To fix a problem like this one until now you had to use the "Edit points" option and move points one by one.

This is a problem people from CadenceVR had. For their product (a virtual reality cycling/training application), they need to have reliable tracks files. But when the GPS make an error like the above -- they need to fix many (thousands!) points by moving them one by one, and every move by the same few meters in the same direction.

After a few days of emailing back and forth with ideas on how to fix problems like this one, a new feature of Trackprofiler is born. You can now use the Segment editor to split segments and move them around:

How to do it...

  • Click on the track to split the segment into two new (you can merge them back later)
  • Drag the marker with the number at the start of the segment. The entire segment will move accordingly. 
  • When the segment is moved where it should have been you can merge the segments again.

Wednesday, 16 October 2013

Track segment editor

Let's suppose you recorded a track like this:

Note that the path is "broken" in 4 smaller parts. Those parts are called track segments. Every track can have multiple track segments and GPS devices will usually create a new segment every time it lost GPS satellite visibility (for example if you entered in a tunnel or  a deep canyon) or you temporarily switched it off.

But we have another problem here. When we reached the peak the batteries of our GPS discharged and that's why we don't have the return of our trip recorded. BTW, the return was the same path.

This is a typical scenario where you would use the new "Track segment editor" on Trackprofiler. When you click on the "segment editor" tab you will see the map with numbered segments and on the right the list with all possible operations on single segments:

By selecting the drop-down with the number you can change the segment order in your GPS file. Use  to reverse the order of points inside that segment. With  you can duplicate the segment or delete it with .

Use  to join two segments.

Now back to our problematic track. We need to:
  • Join all our segments using ,
  • copy the resulting segment with ,
  • reverse the points on the second segment (the returning path) with ,
  • join them together with .
...and the result will be the complete path without "holes":

The Track segment editor is online now

Feedback is welcome!

Tuesday, 8 October 2013

Geoelevations for Ruby

WGS84 Undulations map of the Earth

Just released another open source project related to Trackprofiler. Geoelevations.rb is a SRTM and EGM2008 undulations parser library for Ruby:
Geoelevations.rb is a SRTM and EGM2008 undulations parser library for ruby. Geoelevation.rb allows you to retrieve the elevation for any point in Earth (if present in the SRTM dataset) and the Geoid undulation (the difference between the WGS84 ellipsoid and the actual Earth size). 
SRTM: "The Shuttle Radar Topography Mission (SRTM) obtained elevation data on a near-global scale to generate the most complete high-resolution digital topographic database of Earth." 
EGM2008: "The official Earth Gravitational Model EGM2008". Part of this dataset is a "geoid undulation values with respect to WGS 84".
Basically it is simillar to the existing Python SRTM library (used in Trackprofiler to add elevations to GPS tracks) with two differences:
Geoelevations.rb is hosted here:

Wednesday, 4 September 2013

GPS, Navigation and our Brains

This sounds true to me:
How GPS affects our natural ability to navigate is a question that has, in recent years, begun to attract the attention of researchers around the world. What they are finding suggests that (...) I was one of millions of people for whom technology is disrupting something the human brain is supposed to do well. When we use GPS, the research indicates, we remember less about the places we go, and put less work into generating our own internal picture of the world.

Often referred to as mental maps, these schematics tell us where things are in relation to each other and allow us to navigate among them. They are as powerful as they are mysterious, even to specialists who have devoted their careers to studying how they work. “They are very individual,” said Julia Frankenstein, a researcher at the Center for Cognitive Science at the University of Freiburg in Germany. “The things which matter to you might be completely different to those that matter to your wife or your children.”

With the option to use GPS to do our wayfinding for us, it might seem like we don’t have much need for mental maps anymore. But according to Veronique Bohbot, a neuroscientist affiliated with McGill University and the Douglas Institute who studies spatial memory and navigation, the process of generating mental maps also plays a role in activities that have nothing to do with getting to work. Becoming overly reliant on GPS and letting that skill atrophy, she and others suggest, might actually be bad for us.
Later in the article it says that things maybe aren't that bad. But anyway, nobody is sure how bad things are.

Let's suppose things are bad. My experience tells me that is true not only for GPS navigation but even when people go hiking but somebody else is reading the map and telling them where to turn. I think that the quoted article is true. But if true, what to do? If every one of us becomes overly reliant to GPS navigation? What then?

I think I have a solution. Use the GPS to record the path you took but not to navigate. When outside do experiment, try alternative paths, study paper maps, ... Only when everything else fails -- look at the GPS map. I may be a little extreme but I still have my 8-years-old Garmin GPS60 without maps.

Because the quoted research says nothing about GPS. It says that the navigation without thinking about the surroundings is something that might atrophy our skills. But we can use GPS outside and still think about our surroundings.

PS. I think that Trackprofiler users are typically the kind of people (mountainbikers, hikers, paragliders, ...) who do think about surroundings and don't rely too much on car navigation.

Thursday, 15 August 2013

Better GPS track elevation data

Few weeks ago we made a nice little hiking trip near Pazin. I forgot my Garmin and recorded the trip with my Android smartphone. The resulting elevation graph was pretty strange. Look at the black line:

The blue line is the elevation computed from SRTM (Shuttle Radar Topography Mission) data.

Is it obvious why the Android elevations were strange? The first thing is that the graph was cca 40 meters above the actual elevation lines. But this isn't something that bothers me too much. Because if it were only this -- the actual elevation gain should be the same (but the maximum/minimum elevations would be wrong).

But the second thing is what was really strange. Android cooked up a hill in the first 700 meters of our trip. A big hill, almost 420m high. But in reality there was no hill there.

This is why I added an option "Add GPS track elevation" on Trackprofiler. It is online almost two months now. But the actual data used is raw-SRTM data. And that's why the resulting graph was sometimes not a smooth line but a succession of horizontal lines (Look at the blue line in the graph).

I've been experimenting with few different algorithms to make a better elevation graphs from NASA's elevation data. And I think I finally found a good approximation. The result is the red line:

This new (and better) algorithm for elevation detection will be deployed is on Trackprofiler soon now.

PS. I'm not sure but the fact that my Android elevations are cca 40 meters higher may be because of the deviation between the ideal geoid and the actual Earth surface. 

Sunday, 4 August 2013

Add missing time on GPS tracks

It is easy to add new points on an existing track. Just click on the track and move the points marked with (or move the if you need to move existing points):

Those new points don't have the same metadata as the old ones. For example, new points don't have elevations. That's why the elevation graph looks like this:

There is a "empty hole" on the part of the track where the new points are. This is easy to solve: Just go to "Add elevation" and click on "Add missing elevations" and the result is:

By the way, you could use the "Add elevations" option instead of "Add missing elevations" if you want to override even the existing elevation data

But there still is one thing missing. Look at the analytics page, the speed graph:

Here, too, there is the same "empty hole", and that's because the new points have no time(stamps) saved

For situations like this I'm finishing/testing a new feature on Trackprofiler. When choosing it, the application will try to interpolate times for all points where the time data is missing. The interpolation is based on distances between points.

The "Add missing time" feature is almost ready and will be online soon is deployed now.  (BTW. Watch us on Trackprofiler on Twitter, Facebook or Google+ for notifications about the new versions deployed.)

Sunday, 28 July 2013

Print only selected track elements

From now on, you can decide which elements to include when printing the track:

Feedback is welcome.

Wednesday, 24 July 2013

New layout for GPS track analytics page

There was a few deploys with loads of new features on trackprofiler in the last few months. This is the first of a series of blog posts covering new features introduced lately.

If you remember, the original "Track analytics" page was just a series of graphs. Yesterday a new version was rolled out with the new version:

For every graph you can see:
  • Elevation graph
  • Speed graph
  • Steepness graph
For every graph by moving over it -- you can see exactly on the map where that point was recorder. 

See an example here.

Saturday, 23 February 2013

GPS elevation graphs

This blog post is a short history on the evolution of GPS elevation graphs on trackprofiler.

When starting the service I created a simple javascript based graph library and used it for GPS tracks elevation graphs:

...but over time, some problems arose. First of all it was slow and rendered in the browser. That means that for slower computers the graphs slowed the rendering of the entire page by more than a second.

And, there was another thing I wanted to show on the graph -- the speed graph. So, a month ago a new version of TrackProfiler was deployed. The graph is now a PNG image created on the server -- no client's CPU is used. The graph, then, looked like:

The green graph is speed, the gray one is elevation.

But, there still was one thing in the evolution of the graph I wanted to make. For example on the GPS track shown -- it started on elevation 197m and never went below. So, it don't make sense to show the vertical  part of the graph from zero. It only makes the uphill and downhill slopes flatter.

After another iteration (online for the last 3 days) -- the vertical part of the graph now starts from the minimum elevation found on the graph. And the uphill/downhill slopes are better visible:

See an example here, or try it yourself on TrackProfiler.

Saturday, 12 January 2013

Gpxpy version 0.8.0

Gpxpy is an open source python library for parsing and manipulating GPX files. It is one of the core parts of the TrackProfiler web site, and one of the open sourced parts of it. In the last few months a lot of work is done. Two new important features:

  • gpxpy can now use lxml (if available) to parse GPX files (contribution from Isaev Igor)
  • Python 3 support (contribution from Robert Smallshire)

...and many more small bug fixes and unit tests to make it faster and more stable.

It is licensed under Apache 2.0 and there should be no problems using it even with your own closed-source commercial apps.

PS. The original trackprofiler utility app and the library used to show analytics graphs (cartesius) are also open source.