<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://www.mikrocontroller.net/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=62.206.18.42</id>
	<title>Mikrocontroller.net - Benutzerbeiträge [de]</title>
	<link rel="self" type="application/atom+xml" href="https://www.mikrocontroller.net/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=62.206.18.42"/>
	<link rel="alternate" type="text/html" href="https://www.mikrocontroller.net/articles/Spezial:Beitr%C3%A4ge/62.206.18.42"/>
	<updated>2026-04-10T21:58:21Z</updated>
	<subtitle>Benutzerbeiträge</subtitle>
	<generator>MediaWiki 1.39.7</generator>
	<entry>
		<id>https://www.mikrocontroller.net/index.php?title=Fahrradcomputer&amp;diff=9731</id>
		<title>Fahrradcomputer</title>
		<link rel="alternate" type="text/html" href="https://www.mikrocontroller.net/index.php?title=Fahrradcomputer&amp;diff=9731"/>
		<updated>2005-08-07T01:56:27Z</updated>

		<summary type="html">&lt;p&gt;62.206.18.42: /* Vertikalgeschwindigkeit */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;[[Category:AVR]]&lt;br /&gt;
[[Category:Projekte]]&lt;br /&gt;
&lt;br /&gt;
= Features =&lt;br /&gt;
&lt;br /&gt;
* Kilometerzähler                                                                                 &lt;br /&gt;
** Gesamtstrecke&lt;br /&gt;
** Tourstrecke &lt;br /&gt;
** Tagesstrecke&lt;br /&gt;
** Strecke seit der letzten Pause&lt;br /&gt;
* Geschwindigkeitsmessung&lt;br /&gt;
** Momentangeschwindigkeit&lt;br /&gt;
** Tourmittel&lt;br /&gt;
** Tagesmittel&lt;br /&gt;
** Mittel seit der letzten Pause&lt;br /&gt;
* Kurbeldrehzahl&lt;br /&gt;
* Temperatur                                                                              &lt;br /&gt;
* Uhrzeit&lt;br /&gt;
* Akkuspannungsüberwachung&lt;br /&gt;
* Pulsfrequenzmessung&lt;br /&gt;
* Vertikalgeschwindigkeit&lt;br /&gt;
* Lesen des NMEA-Outputs von GPS-Empfängern&lt;br /&gt;
* Logging der Daten im ser.Flash des Butterfly oder einer MMC.&lt;br /&gt;
* Kommunikation mit PC zum Datenauslesen&lt;br /&gt;
&lt;br /&gt;
Die Messung der Radumdrehung soll außer der Reedkontaktmethode auch über die Frequenz des [http://www.nabendynamo.de/detail.htm Schmidt-Nabendynamos] möglich sein.&lt;br /&gt;
&lt;br /&gt;
= Offene Punkte/Fragen =&lt;br /&gt;
&lt;br /&gt;
* Die Verwendung von printf aus der gcclib kostet 5k Flash und braucht manchmal etwas RAM. Dafür ist es bequem. Oder doch besser eine LowCost-Lösung?&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
= Target =&lt;br /&gt;
&lt;br /&gt;
* [[AVR_Butterfly|Butterfly]]&lt;br /&gt;
* [[ATmega]]* mit externem Display&lt;br /&gt;
* ATtiny* ohne Display&lt;br /&gt;
                                                                                                                                                                                    &lt;br /&gt;
&lt;br /&gt;
= Funktionsdetails =&lt;br /&gt;
&lt;br /&gt;
== System Timer ==&lt;br /&gt;
&lt;br /&gt;
Der Timer2 erzeugt aus dem 38kHz-Oszillatortakt einen periodischen Interrupt im 1/4 Sekunden Abstand.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Menu ==&lt;br /&gt;
&lt;br /&gt;
Auswahl der Anzeige über Up/Down. Kurze Zeit wird die Funktion als Text angezeigt, danach der Zahlenwert.&lt;br /&gt;
Mit Left wird der Funktionstext erneut angezeigt.&lt;br /&gt;
Right führt zu einem ev. Submenü der Funktion.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Entfernungsmessung ==                                                                  &lt;br /&gt;
Der Radumfang wird in 1/256 Metern gespeichert. Dieser wird bei jeder Radumdrehung zum Gesamt(kilo)meterzähler addiert.&lt;br /&gt;
&lt;br /&gt;
Der Reedkontakt am Rad löst einen Interrupt aus.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Verwendung des SON als Tachogeber ===&lt;br /&gt;
&lt;br /&gt;
Frequenzbereich: 5 Hz - 200 Hz (geschätzt, muss noch gemessen werden).&lt;br /&gt;
&lt;br /&gt;
Schaltungsvorschlag zur Frequenzmessung des Nabendynamos und damit auch zur Geschwindigkeitsmessung: &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[bild:son_diode.png|SON Frequenzmessung]]&lt;br /&gt;
&lt;br /&gt;
[[Media:son_diode.sch|EAGLE-Schaltplan]]&lt;br /&gt;
&lt;br /&gt;
== Geschwindigkeitsmessung ==&lt;br /&gt;
&lt;br /&gt;
Bei jedem Radinterrupt wird der Timer2 und die Systime ausgelesen.&lt;br /&gt;
Mit Timer2prescaler 32 ergibt sich eine Auflösung von 1/1024 Sekunden.&lt;br /&gt;
&lt;br /&gt;
Die maximale Geschwindigkeit wird mit 30 m/s festgelegt. Daraus folgt bei einem 20 Zoll Rad eine maximale Raddrehzahl von ca. 17 Hz (min. Peridendauer &amp;gt; 50ms). Die Körnigkeit der Messung liegt also bei der Maximalgeschwindigkeit so in der Gegend von 2%.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Kurbeldrehzahl ==&lt;br /&gt;
&lt;br /&gt;
Der Reedkontakt geht auch auf einen Interrupteingang.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Temperatur ==&lt;br /&gt;
&lt;br /&gt;
Der Butterfly hat einen NTC an einem Analogport.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Uhrzeit ==&lt;br /&gt;
&lt;br /&gt;
Die Uhrzeit wird nicht wie beim Butterfly-Demo in Sekunden-, Minuten- und Stundenvariablen sondern als 1/4-Sekundenzähler gespeichert. Soll die Uhzeit angezeigt werden, wird eine Umrechnungsfunktion aufgerufen.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Vertikalgeschwindigkeit ==&lt;br /&gt;
&lt;br /&gt;
Die absolute Höhe ist uninteressant.&lt;br /&gt;
Aus der Vertikalgeschwindigkeit kann die Steigung und die Steigleistung ermittelt werden.&lt;br /&gt;
&lt;br /&gt;
Wie bei den Variometern der Segel- und Drachenflieger wird die Ausgangsspannung eines Drucksensors differenziert.&lt;br /&gt;
&lt;br /&gt;
Alternativ könnte man auch die Steigung direkt messen. Bob Pease schreibt in der Electronic Design September 2004, daß er sowas für seine Nepaltour gebaut hatte. Bergauf hätte es aber wg. des Gewackels nicht funktioniert (vermutlich fährt er ein gefedertes Mountainbike). Schaltungsdetails hat er kein angegeben, nur, daß er ein Öl-Fett-Gemisch als Dämpfer verwendet.&lt;br /&gt;
&lt;br /&gt;
Vielleicht kann man sowas auch nach dem Wasserwaagenprinzip bauen.&lt;br /&gt;
&lt;br /&gt;
== Logging ==&lt;br /&gt;
Alle Daten werden in einer Reihe gespeichert.&lt;br /&gt;
Die Art des Eintrags wird anhand einer 4-bit ID bestimmt.&lt;br /&gt;
Dannach folgen 12 Bit Daten.&lt;br /&gt;
Die kleinste Zeiteinheit im Logging, die Logging Unit, ist 2 Sekunden.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Timestamp ===&lt;br /&gt;
Die Timestamp enthält die Zeit in Vielfachen von 256 Logging Units.&lt;br /&gt;
&lt;br /&gt;
| ID | Timestamp |&lt;br /&gt;
&lt;br /&gt;
=== Deltatimestamp ===&lt;br /&gt;
Das ist kein eigener Loggingeintrag, sondern Teil der sich unregelmäßig ändernden Loggingeinträge, wie Temperatur oder Puls. Es werden die letzten 8 bit der Zeit in Logging Units gespeichert.&lt;br /&gt;
&lt;br /&gt;
=== Entfernung ===&lt;br /&gt;
Die Entfernungsdaten werden in einem festen Zeitintervall, der Logging Unit, gespeichert.&lt;br /&gt;
Sollte es zu Aussetzern kommen (z.B. weil das Fahrzeug steht), wird vor dem neuen Eintrag ein Timestamp geschrieben.&lt;br /&gt;
&lt;br /&gt;
| ID | Entfernungsdifferenz |&lt;br /&gt;
&lt;br /&gt;
=== Trittfrequenz ===&lt;br /&gt;
Die Trittfrequenz wird, wie die Temperatur, als Änderung gegenüber dem vorhergehenden Wert gespeichert. Gelegentlich wird der tatsächliche Wert geschrieben.&lt;br /&gt;
&lt;br /&gt;
| ID | Delta Frequenz | Delta Timestamp |&lt;br /&gt;
&lt;br /&gt;
=== Temperatur ===&lt;br /&gt;
Die Temperatur wird normalerweise als Änderung gegenüber der vorhergehenden Temperatureintrag gespeichert. Gelegentlich wird die tatsächliche Temperatur ohne Deltatimestamp geschrieben.&lt;br /&gt;
&lt;br /&gt;
| ID | Delta Temperature | Delta Timestamp |&lt;br /&gt;
&lt;br /&gt;
| ID | Temperatur |&lt;br /&gt;
&lt;br /&gt;
=== Puls ===&lt;br /&gt;
Der Puls wird, wie die Temperatur, als Änderung gegenüber dem vorhergehenden Wert gespeichert. Gelegentlich wird der tatsächliche Puls geschrieben.&lt;br /&gt;
&lt;br /&gt;
| ID | Delta Puls | Delta Timestamp |&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== GPS-Connection ==&lt;br /&gt;
&lt;br /&gt;
Über RS232 werden die NMEA-Daten eingelesen. Damit kann die Uhr gestellt werden und Position und Höhe mitgeloggt werden.&lt;br /&gt;
&lt;br /&gt;
== PC-Kommunikation ==&lt;br /&gt;
&lt;br /&gt;
Über RS232 werden die geloggten Daten auf den PC übertragen.&lt;br /&gt;
&lt;br /&gt;
= Software =&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Warnung:&#039;&#039;&#039; Das ist kein fertiger Radcomputer, sondern eine Diskussionsgrundlage für die Entwicklung.&lt;br /&gt;
&lt;br /&gt;
[[Media:Radcomputer-0.0.tar.gz]]&lt;br /&gt;
&lt;br /&gt;
== In Arbeit ==&lt;br /&gt;
* Logging&lt;br /&gt;
* Xmodem Protoll zur Datenübertragung&lt;br /&gt;
&lt;br /&gt;
== TODO ==&lt;br /&gt;
* Sensordatenfilterung&lt;br /&gt;
* NMEA-Auswertung&lt;br /&gt;
* Stromverbrauch senken&lt;br /&gt;
&lt;br /&gt;
= Links =&lt;br /&gt;
*[http://www.mikrocontroller.net/forum/read-1-79785.html Thread im Forum zur Seite]&lt;br /&gt;
*[[Pulsuhrempfänger_mit_AVR_Butterfly]]&lt;br /&gt;
*[http://homepages.compuserve.de/SIGIBORST/ Fahrradcomputer mit Pulsmesser]&lt;br /&gt;
*[http://www.avrfreaks.net/Freaks/freakshow.php?keyword_is_id=1&amp;amp;keywords=10 Variometer] bei avrfreaks.net&lt;br /&gt;
*[http://www.circuitcellar.com/avr2004/DA1300.html Variometer-Altimeter for Free Flying] bei www.circuitcellar.com&lt;br /&gt;
*[[AVR Butterfly]]&lt;/div&gt;</summary>
		<author><name>62.206.18.42</name></author>
	</entry>
</feed>