BT747 Einstellungen für i-Blue 747A+ GPS Datenlogger

Meine BT747 Einstellungen für den Transystem i-Blue 747A+ GPS Bluetooth Datenlogger möchte ich hier vorstellen.

In der Vergangenheit habe ich immer sehr erfolgreich meine GPS Tracks mit einem i-Blue 747 aufgezeichnet. Nachdem ich den Datenlogger bei meinem letzten Mapping-Trip in Thailand an ortsansässige OSM Neueinsteiger verschenkt hatte musste ich mir einen Ersatz suchen. Bei Ebay konnte ich das aktuelle Nachfolgemodell 747A+ ersteigern. Im Vergleich zum Vorgänger ist der modernere GPS Chip MT3329 enthalten, der nun 66 Kanäle verwendet, einen doppelt so großen Speicher hat und AGPS für einen schnelleren Fix unterstützt.

Die Gelegenheit hat sich angeboten dann gleich zu dokumentieren wie ich den Logger passend für OpenStreetMap konfiguriere. Die Anleitung bezieht sich hier auf den 747A+, das Programm funktioniert aber mit vielen Loggern die auf dem gleichen Design basieren. Unter anderem Geräte von Royaltek und Qstarz. Für andere Logger wird das Programm nicht funktionieren, die prinzipielle Vorgehensweise sollte aber die gleiche sein.

Die Software

Ich verwende auf dem PC die OpenSource Software BT747 die sämtliche Werkzeuge bietet um den Logger zu konfigurieren und auszulesen. Die Software kann entweder per Java Webstart gestartet werden oder lokal installiert werden. Sie läuft auf jedem System das Java kann, zusätzlich auf j2me und windows ce Geräten.

Nach dem Anstecken (Einschalten) an USB fordert einen Windows auf Treiber zu installieren. Die Treiber für alle Windows Versionen bis Windows 7 gibt es direkt beim Hersteller. Windows 8.1 installiert automatisch einen passenden Treiber.

Die Einstellungen

Bevor es los geht muss der Logger natürlich per USB verbunden und eingeschaltet (auf LOG) werden. Mit dem Connect Knopf links unten kann man die USB Verbindung herstellen.

In den Device settings stelle ich die Parameter ein wie häufig der Logger Daten aufzeichnet und welche Daten gespeichert werden.

BT747 Device Settings Dialog

Beim Zeitformat wähle ich die normale UTC Zeit und Zusätzlich Millisekunden da ich häufiger als ein mal pro Sekunde logge. Irgendwie muss das ja in den Daten unterscheidbar sein. Also UTC Time und Miliseconds anwählen.

Für OpenStreetMap benötige ich nur die Koordinate, also Latitude und Longitude. Geschwindigkeit und Richtung kann später JOSM alleine berechnen, das brauche ich nicht. Auch auf die Höhe verzichte ich. Dadurch passen mehr Daten in den Speicher und so sonderlich genau ist die Höhenangabe bei GPS auch nicht. Für Höhenangaben zu Bergen verlasse ich mich lieber auf die Infotafeln vor Ort.

Weil ich später nur die „guten“ Daten in meinem Track haben will speichere ich den GPS Fix Type, HDOP und NSAT mit ab. Mit diesen Daten lässt sich erkennen wie gut die berechnete Position ist. Im Fix Type vermerkt der Logger ob er überhaupt eine Position über GPS ermitteln konnte. NSAT sind die Anzahl an Satelliten die der Empfänger gesehen hat. Je mehr Satelliten empfangen werden desto höher ist die Chance auf eine gute Positionsbestimmung. Ich nehme diese Angabe mit ins Log weil ich der reinen HDOP nicht ganz traue und Peilungen mit wenigen Satelliten auch ausschließe. Wenn man sich nur auf das HDOP verlässt kann man ohne diese Daten nochmal ca. 5% mehr Punkte speichern. Der HDOP Wert gibt an wie gut der berechnet Wert ist. Unter 1.0 sind die Punkte richtig gut, bis 2 kann ich sie noch akzeptieren. In JOSM lassen sich die HDOP Genauigkeitswerte auch als Kreise um die GPS-Punkte herum anzeigen.

Mit dem Reason RCR protokolliert der Logger mit warum etwas aufgezeichnet wurde. Da ich Tastendrücke auf den Marker erkennen will muss ich das mit aufzeichnen.

Mittels Set Format & Erase wird der Speicher entsprechend den neuen Einstellungen formatiert. Daten die vorher drauf waren werden dabei gelöscht und sollten vorher gespeichert werden. Aber bei den vielen Warnhinweisen der Software kann man das nicht übersehen.

Mit dem Schalter Use SBAS WAAS lassen sich Ionosphären Korrekturdaten verwenden um die Genauigkeit der Positionsbestimmung nochmal zu steigern. Diese sind unter den Kürzeln WAAS, EGNOS und MSAS bekannt. Die Korrekturdaten haben eine begrenze räumliche Gültigkeit und sind in Nordamerika, Europa und Japan gültig. Da mit den Korrekturdaten auch eine Information über den Gültigkeitsbereich gesendet wird sollte es kein Problem sein das immer eingeschaltet zu lassen. Es gibt allerdings Gerüchte dass manche Logger diese Prüfung nicht sauber implementieren. Wenn man also sicher außerhalb eines versorgten Gebietes ist kann man zur Sicherheit das auch ausschalten. Nicht vergessen mit dem Set Schalter die Einstellung zu speichern.

Bereits gesammelte Daten will ich auf keinen Fall überschreiben, daher stelle ich den Logger so ein dass er aufhört wenn der Speicher voll ist. Stop when full. Der Logger zeigt das mit einer rot leuchtenden LED an. Bei einem Rest von 20% fängt die an zu Blinken. Mit meinen Einstellungen reicht das für 18 Stunden Aufzeichnung. Danach muss ich mit Computer oder Smartphone die Daten auslesen.

Ich möchte zweimal pro Sekunde die Position aufzeichnen um auch in einer Kurve noch genügend Datenpunkte zu haben um ohne Luftbild den Straßenverlauf ahnen zu können. Für diese 2Hz Updates stelle ich auf Fix every 500 ms. Damit hat der Logger intern zwei mal pro Sekunde eine Position berechnet. Die weiteren Einstellungen legen fest wann diese ins Log geschrieben werden. Die Bedingungen sind alternativ. Mit Time every 1.0 seconds ist jede Sekunde ein Eintrag im Log, auch wenn der Logger nicht bewegt wird. Die Zahl kann auch etwas größer gewählt werden. Mit Distance every 1.0 m wird ein Punkt geloggt wenn sich die Position um mehr als einen Meter verändert hat. Das kann bei meinen Einstellungen also bis zu zwei mal pro Sekunde sein. Am Schluss speichere ich die Einstellungen mit Set.

Der Abstand zwischen zwei Punkten bei einer gegebenen Geschwindigkeit lässt sich einfach berechnen. Die Geschwindigkeit in Kilometern pro Stunde wird einfach durch 3,6 geteilt. Dann hat man Meter pro Sekunde. Das teilt man durch die Anzahl Punkte die pro Sekunde aufgezeichnet werden und schon hat man den Abstand zwischen zwei Punkten. Beispielsweise wird bei einer Geschwindigkeit von 72 km/h und 2Hz Loggingfrequenz alle 10 Meter ein Punkt geloggt.

Hilfsdaten

Damit das Gerät schneller eine erste Position hat, im englischen TTFF -Time To First Fix- genannt kann man die Bahndaten der Satelliten schon im Gerät ablegen. Das sind berechnete Daten die um so ungenauer werden je weiter in der Zukunft die Daten liegen. Der Logger unterstützt Bahndaten für bis zu sechs Tage in der Zukunft. Diese Assisted-GPS Daten bekommt das Programm aus dem Internet. Mit Upload APGS data to device werden die Daten geladen und auf den Logger gespeichert. Kurz bevor ich auf Tour gehe lasse ich die AGPS Daten aktualisieren.

BT747 AGPS Dialog

Die Filter Einstellungen

Eventuell kommt es bei der Erfassung der Daten draußen im Gelände zu Situationen in denen der Empfang nicht besonders gut ist und die GPS Tracks entsprechend schlecht sind. Ich denke dass solche schlechten GPS Punkte in OSM mehr schaden als nützen, deswegen möchte ich sie nicht hochladen. Um Dateien zu bekommen bei denen das erst gar nicht enthalten ist lassen sich in BT747 Filterbedingungen einstellen die festlegen welche Daten in die Ausgabedatei übernommen werden und welche nicht.

BT747 Filters Dialog

Unterschieden werden drei Arten von Filtern. Man Kann festlegen was als Trackpoint (also die normalen Brotkrumenpunkte) mitgenommen wird, was für die Waypoints (wenn ich den Marker drücke) gilt und welche Einstellungen auf alles angewendet werden.

Ich stelle Trackpoints auf SPS, DGPS, PPS, RTK, FRTK und die Log Reason auf Time, Button, User. Ist etwas mehr als tatsächlich gebraucht wird aber ich will erst mal alle Punkte haben. Die Ausnahme sind Punkte bei denen der Logger schon erkennt dass es keine gültige Position ist (das wären vor allem No fix und Estimate).

Für die Waypoints gilt es entsprechend.

Spannend wird es bei den gemeinsamen Filtern. Da ich die 2D Genauigkeit HDOP mit aufzeichnen lasse kann ich auch danach filtern. Bei HDOP Werten schlechter als 1.98 will ich die Punkte nicht im Trace haben. Schlechte Werte können auftreten wenn nur Satelliten sichtbar sind die in einer sehr ungünstigen Geometrie zueinander stehen. Da dann die Position mit hoher Wahrscheinlichkeit ungenau ist will ich das später auch nicht im Editor sehen. Dann weiß ich wenigstens woran ich bin. Die Einschränkung auf Positionen mit mindestens 4 Satelliten bei NSAT geht in die gleiche Richtung. Die „kleiner-gleich“ Zeichen sind hier etwas missverständlich. Es landen Werte im Trace mit einem HDOP kleiner als dem angegebenen Wert und mit Satelliten größer dem angegebenen Wert. Selbst wenn die Werte diese Filter passieren kann es bei ungünstiger Empfangslage zum Beispiel Reflexionen an Gebäuden geben die die Position verfälschen. GPS Positionen sind als immer mit gesundem Misstrauen zu sehen.

Das Dateiformat

Im Reiter für das Ausgabeformat habe ich fast alle Felder markiert. Daten die es nicht gibt werden nicht in die Ausgabedatei geschrieben. Das reguliert sich von selbst.

BT747 Output Settings Dialog

Einige Punkte möchte ich gesondert erläutern. Die Zeitzone lasse ich auf UTC +0 laufen (TimeZone UTC +0). Da ich häufig zwischen verschiedenen Zeitzonen wechsle könnte es sonst zu leicht passieren dass die falsche Zeit verwendet wird. Von der Position her kenne ich die Zeitzone. So ist eine spätere Zuordnung kein Problem. Pro Track lasse ich eine einzelne Datei schreiben (One file per track). So kann ich verschiedene Strecken die ich an einem Tag geloggt habe einfach auseinanderhalten. Wenn eine Pause länger als 15 Minuten erkannt wird soll eine neue Datei begonnen werden (New Track after 15 min. pause). Ebenso wenn der Logger eingeschaltet wird (New track when GPS logger switched on).

Damit die Dateien nicht zu umfangreich werden verzichte ich darauf jeden einzelnen Punkt mit Namen zu versehen. Das wären Add Track Point Info und Add Track Point Name. Für die Waypoints lasse ich das eingeschaltet.

 Daten runterladen und konvertieren

Nach dem Mapping Ausflug kommt der große Moment. Der Logger wird angeschlossen und verbunden.

BT747 Log Operations Dialog

Den Pfad für die Ausgabedateien habe ich eingestellt (Output Folder), ebenso eine Datei festgelegt in die die Rohdaten gespeichert werden (Raw Log File). Die Methode Smart Download beschleunigt den Prozess indem nur die neuen Daten geladen werden. Mit klick auf Download geht es los.

Nach einigen Sekunden ist der Trace auf dem Computer. Ich konvertiere meine Traces nach GPX um sie in JOSM anzusehen und zu OpenStreetMap hochzuladen. Zusätzlich gebe ich sie als HTML aus. Da lassen sich die Traces lokal im Browser vor OSM Karten oder auch Satellitenbildern anzeigen. Super um einen schnellen Eindruck zu bekommen wo der Thread genau war. Dateien die keine sinnvollen Daten enthalten weil es zum Beispiel eine Situation war in der der Logger im Haus eingeschaltet war lassen sich so schnell erkennen und aussortieren.

Bei Bedarf kann der Speicher auf der Seite mit den Device Settings mit einem Klick auf den Erase button für den nächsten Ausflug geleert werden.

Videolan aus dem Kontextmenü verbannen

English: VLC icon

Videolan (VLC) verewigt sich auch im Kontextmenü. Wenn man das wieder loswerden will gibt es keine Option im Einstellungsdialog. Aber ähnlich dem Windows Media Player lässt er sich durch einen kleinen Eingriff in die Registry entfernen. Wie man den WMP aus dem Kontextmenü entfernt hatte ich bereits beschrieben, jetzt geht es dem VLC an den Kragen.

Bevor Änderungen an der Registry gemacht werden sollte ein Backup angelegt werden.

Unter [plain]HKEY_CLASSES_ROOT\Directory\shell[/plain] finden sich die Einträge die man einfach löschen kann.

Etwas weniger technisch wäre eine Neuinstallation von VLC und beim Installer die Checkbox für das Kontextmenü nicht setzen.

GeoSetter Positionskorrektur beim Photomapping mit OpenStreetMap

GeoSetter ist eines meiner Lieblingstools für das Photomapping mit OpenStreetMap. Damit kann ich rasend schnell die Bilder sortieren die ich beim Photomapping geschossen habe.

Da es passieren kann das meine Kamera – eine Sony DSC-HX5V – noch keinen gültigen GPS Fix hatte führt das dazu dass die Bilder die letzte bekannte Position zugewiesen bekommen. Für normale Bilder eine tolle Sache, beim Photomapping stört das gewaltig. Glücklicherweise ist die Kamera so schlau und vermerkt das in den EXIF-Daten.

Das lässt sich dann später mit Tools wie dem GeoSetter korrigieren.

Zusätzlich zum GPS in der Kamera zeichne ich die Tracks beim Mapping mit einem speziellen GPS Logger auf. Ich verwende den Transystem i-Blue 747.

Wenn die Empfangslage schwierig ist hat der Logger eine bessere Position als die Kamera. Daher möchte ich später im Editor beide Positionen angezeigt bekommen.

Vorbereitung

Mit Hilfe von GeoSetter ist das ganz einfach. Zuerst erzeuge ich eine Kopie meiner Bilder. Die Originale möchte ich behalten um später eine „zweite Meinung“ bezüglich der Position zu haben. Dann benenne ich die Kopien der Bilder um. GeoSetter bietet mir da das passende Werkzeug „Bilddateien umbenennen„. Ich füge hier einfach die Zeichenkette „_logger“ an den Dateinamen an.

Bilddateien umbenennen

Koordinaten anpassen mit GeoSetter

Als nächstes lasse ich die Koordinaten des Bildes an die des Loggers anpassen. Das funktioniert deswegen weil Logger und Kamera die GPS Uhrzeit verwenden. In den Bildern steht die genau Zeit in den EXIF Daten drin. Damit kann man aus dem GPX-Track des Loggers die Position holen. Da ich sowohl die Kamera als auch den Logger trage befinden sich beide zur gleichen Zeit am gleichen Fleck.

Ich markiere im GeoSetter die GPX Dateien in der Auswahl die für die Anpassung der Koordinate verwendet werden sollen. Dann die Bilddateien markieren und die Funktion „Synchronisierung mit GPS-Datendateien“ wählen.

Da die Uhrzeit der Kamera von GPS kommt und ich nur die Bilder synchronisieren will bei denen auch wirklich zeitgleich ein Logger verwendet wurde habe ich den Schwellenwert für die maximal zulässige Zeitdifferenz sehr kurz gewählt. Alles innerhalb dieser Zeitspanne für das es keine exakte Position gibt wird ggf. auf den ersten, bzw. den letzten Trackpunkt gesetzt. Gleichzeitig lasse ich auch noch die Zeitzone in die EXIF-Daten schreiben.

Synchronisierung mit GPS-Datendateien

Sollte ich Bilder haben bei denen der Logger nicht bereit war (oder einfach nicht eingeschaltet ;)) so bemerkt GeoSetter das und teilt mir das in einer Statusmeldung mit.

keine passende Position

In meinem Fall gab es vier Bilder zu denen ich keinen passenden GPX Track habe und bei denen ich mich auf die GPS-Position der Kamera verlassen muss. Damit ich später nicht durcheinanderkomme kann ich die Bilder wieder löschen. Nicht vergessen: zu Beginn habe ich eine Kopie angelegt. Die geänderten Dateien zeigt das Programm in rot an. Für die restlichen Bilder übernimmt GeoSetter die neuen Koordinaten nach einem Klick auf das Diskettensymbol „Alle Änderungen in Bildern speichern“.

geänderte Dateien

Verwenden im Editor

Für das Editieren der OpenStreetMap Daten verwende ich JOSM. Dort kann ich einfach die Dateien und GPX-Tracks per Drag’n’Drop anzeigen lassen. Falls die Position eines Bildes im Kamera GPS und im Logger deutlich abweicht muss ich mich eben für eine Position entscheiden. Da sich zusätzlich auch Bing Luftbilder einblenden lassen ist das meiner Meinung nach eine der besten Möglichkeiten Daten zu erfassen. Durch den eingebauten Kompass ist auch gleich klar in welche Richtung man fotografiert hat. JOSM zeigt das durch einen kleinen Pfeil an.

Anzeige in JOSM

Die GPX-Dateien müssen übrigens auch manchmal vor dem Upload bereinigt werden. „Punktewolken“ stören nur beim Editieren. Aber das ist ein anderer Artikel.

Nervige Windows Media Player Einträge im Kontextmenü

Im Kontextmenü nerven Einträge vom Windows Media Player. Die will ich da nicht haben. So werde ich sie los. Denn meine Musik spiele ich aus Tradition noch mit Winamp ab.

Nun hat Microsoft in den Einstellungsdialogen vom Media Player nichts vorgesehen mit dem man die Anzeige im Kontextmenü kontrollieren kann. Da muss man selbst Hand anlegen und die Verknüpfungen aus der Registry entfernen.

Die Einträge „Add to Windows Media Player list“ und „Play with Windows Media Player“ werden durch eine Shell Erweiterung kontrolliert.

Bevor Änderungen an der Registry vorgenommen werden sollte unbedingt ein Backup angefertigt werden. Alles passiert auf eigene Verantwortung.

Im Registry Editor öffne ich folgenden Schlüssel

HKEY_CLASSES_ROOT\SystemFileAssociations\audio\shellex\ContextMenuHandlers

und lösche die Unterschlüssel. Damit sind die Einträge aus dem Kontextmenü verschwunden.

HKEY_CLASSES_ROOT\SystemFileAssociations\audio\shellex\ContextMenuHandlers\WMPAddToPlaylist
HKEY_CLASSES_ROOT\SystemFileAssociations\audio\shellex\ContextMenuHandlers\WMPPlayAsPlaylist

Indem ich meine Sicherung zurückspiele kann ich die Einträge auch später wieder zurückholen.

Das Kontextmenü auf Verzeichnissen setzt nochmal einen Eintrag drauf, „Shop for music online„. Als ob ich das nicht auch ohne die Hilfe von Microsoft kann. Also wird auch mit den Einträgen unter diesem Key kurzer Prozess gemacht.

HKEY_CLASSES_ROOT\SystemFileAssociations\Directory.Audio\shellex\ContextMenuHandlers

So sah es aus bevor ich das alles gelöscht habe

Da es nebendran noch weitere Einträge gab bei denen diese ClassID verwendet wurde habe ich in der Registry noch danach gesucht und vorsichtshalber diese Stellen auch noch abgeschaltet. Wo Windows die weiteren Winträge verwendet hätte kann ich aber nicht sagen.

Und damit ist jetzt endlich Ruhe im System und im Kontext Menü finde ich wieder die Einträge die mich wirklich interessieren.

Eventuell würde es auch damit funktionieren die wmpshell.dll zu de-registrieren. Da ich nicht sicher bin welche Programme sich da noch dazuklinken um irgendwie den Media Player zu verwenden habe ich die Änderungen an der Registry gemacht.

Einen Versuch wäre es aber wert:

Rückgängig macht man das mit

Damit entfernt man direkt die ClassID Registrierung aus dem System. Der Explorer hat nichts mehr anzuzeigen.