PDA

Archiv verlassen und diese Seite im Standarddesign anzeigen : Timer ungenau?



Phips89
06.10.2010, 19:42
Zuerst einmal: Hallo!

Ich lese schon einige Zeit immer wieder im Forum und hole mir dadurch nützliches Wissen! Und eines muss gesagt werden, das Forum ist wirklich toll!
Jetzt muss ich aber doch einmal selbst schreiben, da ich nicht mehr weiterkomme!

Ich beiße mir nun schon seit 2-3 Tagen die Zähne an den Timern aus. Irgendwie habe ich damit leider so meine Probleme. Ich habe zwar die Vorladewerte mehrmals erfolgreich berechnet, komme aber in der Praxis nie zum richtigen Ergebnis.

Zuerst ging ich davon aus, dass die Timer mit dem externen Quarz arbeiten...Nach einigen Versuchen kam ich leider drauf, dass dies nicht so ist?

Ich habe mir dann Gedanken gemacht ob es noch irgendwo einen Takt gibt und habe es einmal mit dem Takt des Atmegas probiert. Und siehe da, bei einem Takt von 8 MHz und einem Vorladewert von 34285 an Timer1 war ich einer Sekunde nicht mehr so fern.

Meine neue Erkenntnis ist also, es ist vom Takt des Atmegas abhängig. Stutzig macht mich nur, dass ich eigentlich immer was von einem Quarz lese, welcher den Takt angibt.

Zur Annäherung habe ich ein kleines Programm geschrieben. Dieses gibt bei jedem Interrupt, also rein theoretisch, jede Sekunde die Uhrzeit und einen Zählerstand aus. Damit war es mir möglich Korrekturen beim Vorladewert zu treffen. Dies mache ich nun schon seit einem Tag mit mehreren Läufen, bekomme das aber nicht unter Kontrolle. Heute war dann ein Stromausfall und es fiel mir auf, dass bei gleichem Vorladewert in zwei Läufen die Abweichung unterschiedlich hoch ist. Im 1. Lauf war es eine Sekunde auf 20 Minuten und im 2. Lauf waren es 2 Sekunden auf 20 Minuten.

Kann mich bitte jemand aufklären, warum und wie das möglich ist?

Zum Einsatz kommt ein myAVR USB Board inkl. Display mit einem Atmega8.

Mein Annäherungsprogramm:

$regfile = "m8def.dat"
$crystal = 32768000
Config Lcdpin = Pin , Db4 = Portd.4 , Db5 = Portd.5 , Db6 = Portd.6 , Db7 = Portd.7 , E = Portd.3 , Rs = Portd.2
Config Lcd = 16 * 2
Config Portd = Output
Config Timer1 = Timer , Prescale = 256
On Timer1 Timer_irq
Enable Timer1
Const Timervorgabe = 33742
Dim Zaehler As Integer
Zaehler = -1

Config Pinc.2 = Output
Led3 Alias Portc.2

Enable Interrupts
Config Clock = Soft
Timer1 = Timervorgabe
Time$ = "00:00:00"

Do

Loop

Timer_irq:
Timer1 = Timervorgabe
Zaehler = Zaehler + 1
If Zaehler = 60 Then Zaehler = 0
Cls
Lcd Time$ ; " " ; Zaehler
Return


DANKE!
Lg
Phips[/code]

ceekay
06.10.2010, 19:57
Ich hab zwar keine Ahnung von Bascom. Aber was die Taktquelle angeht is es immer die, die du dem ATmega mit den Fuses angibst.

Stellst du die Fuses auf internen 8Mhz. läuft der Timer auch mit diesen. Stellst du auf extern läuft der Timer auch mit dem externen Quarz.

Zusätzlich kannst du noch einen Prescaler (Vorteiler) vorgeben. Beispielsweise 1024 dann wird der Timer mit Takt/1024 laufen.

Hoffe das meinstest du!?

Edit:


$crystal = 32768000

scheint mir recht hoch für nen mega8 oder täusch ich mich?

Phips89
06.10.2010, 20:18
Hallo,

danke für die schnelle Antwort! Das schafft schon einmal ein wenig mehr Klarheit.
Takt habe ich via Fuses auf 8 MHz und einen Prescaler von 256.

Die $crystal Angabe wurde mir von einem Freund so empfohlen, er meinte vielleicht hilft es. Habe jetzt aber noch einmal nachgelesen, da sollte der Takt des Atmega drinstehen. Habe dies eben korrigiert. Danke für den Hinweis!

Versuche es eben noch einmal mit der richtigen $crystal-Angabe und dem korrekt errechnetem Vorladewert. Mal sehen was diesmal dabei herauskommt.

DANKE!
Mfg
Phips

edit: Leider läuft das Programm schon nach einer Minute und zehn Sekunden mit einer Sekunde Vorsprung. Schade!

Hubert.G
06.10.2010, 20:56
Der interne Oszillator ist sehr ungenau und für eine Uhr ungeeignet.
Du könntest dich zwar mit dem Vorladewert hin tasten, solltest du aber einmal den Kontroller tauschen, fängt das wieder von vorne an.
Am besten einen Quarz nehmen, und zwar einen krummen wie z.B. 7,3728MHz, dieser Wert lässt sich besser teilen.

Phips89
06.10.2010, 21:06
Hallo,

eigentlich wollte ich mit Hilfe des Timers einen Tachometer realisieren und benötige ihn somit zum Stoppen einer extrem kurzen Zeitspanne.

Sind durch diese Ungenauigkeiten auch die Schwankungen zu erklären? Einmal schneller, einmal langsamer?

Da ich in meinem Projekt auch eine Uhr geplant habe, habe ich so und so einen 32,768 MHz Quarz als Uhrenquarz. Kann ich diesen auch gleichzeitig für den Timer verwenden?

DANKE!
Mfg
Phips

Jaecko
07.10.2010, 06:30
Das gemeine beim internen Oszillator ist noch, dass dessen Frequenz von der Betriebsspannung und der Temperatur abhängt. D.h. auch wenn du den jetzt so gut einstellst, dass es passt: Lass es mal kälter/wärmer werden und schon stimmts nicht mehr.

Ich hab an einem Projekt nen 16MHz Quarz hängen; da läuft die Uhrzeit seit 3 Monaten ohne merkliche Abweichungen.

32,768MHz sind für nen ATMega zu viel. Sollten das eher kHz sein?

Phips89
07.10.2010, 07:12
Hallo Jaecko,

danke für deine Antwort. Du hast mein Rätsel gelöst! Die Temperaturabhängigkeit dürfte wohl das große Problem sein!

Auch mit dem Quarz hast du recht, da habe ich wohl den falschen SI Prefix erwischt...es sind 32,768 kHz. So das es eben mit einem Prescaler von 256 genau 128 überläufe pro Sekunde ergibt.

Problem ist eben nur, dass ich den Quarz für die "Soft Clock" benötige und den Takt aber auch für meine Berechnung benötigen würde.
Ich habe gestern Abend noch versucht die Fuses über das myAVR-Progtool zu setzen, aber ohne Erfolg. Setze ich sie auf "ext. Low-Freq. Crystal; Start-Up time: 32K CK + 64 ms; [CKSEL=1001 SUT=10]", so wie es laut der Anleitung mit einem Uhrenquarz richtig ist, macht mein Atmega keinen Strich mehr. (CKOPT wurde natürlich auch aktiviert) Setze ich ihn wieder zurück auf die letzten Einstellungen, funktioniert wieder alles!

DANKE!
Mfg
Phips

BoGe-Ro
21.10.2010, 13:38
hmmm,

welche Hardware nutzt du?
Habe in Gedanken mal ein myAVR-Board unterstellt , da du das myAVR-Progtool nutzt.
Wenn dem so ist, wundert mich, dass du die Fuses wieder auf interne Frequenz setzen konntest.
Denn, wenn du auf externe Frequenz umgestellt hast und er keinen Strich mehr macht würde ich vermuten, macht er nichts, weil er keine Taktquelle mehr hat.
Ohne Taktquelle würdest du aber die Fuses nicht zurückgesetzt bekommen.

"Ein Teufelskreis"


Gruß

BoGe-Ro

hardware.bas
06.11.2010, 17:18
Der freilaufende Takt des AVR ist ziemlich ungenau, warscheinlich bis
2prozent Abweichung. Meine Erfahrung beim Bau einer Messkette,
wobei binnen einer Minute mehrere Messwerte übertragen werden, lag bei
fast 2 Sekunden am Ende der Minute. War für meine Zwecke jedoch nicht
so wichtig. Anderes Beispiel: Das Auslesen über die UART funktionierte
mit 9600 nur noch in Ausnahmefällen, mit 4800 so zu fifty/fifty und erst
mit 2400 halbwegs stabil. Für zeitrelevante Dinge also immer einen Quarz mit den ggffll. 2 Cs, also nur ein paar Cent mehr Aufwand. VG Micha

Vitis
07.11.2010, 10:00
Für timingkritische Programme geht nix ohne Quarz, am Einfachsten nen
Baudratenquarz.
Für ganz genau dann evtl. nen temperaturstabilisierten Quarzoszillator.

funkheld
09.11.2010, 12:44
Das Auslesen über die UART funktionierte
mit 9600 nur noch in Ausnahmefällen, mit 4800 so zu fifty/fifty und erst


das ist unsinn, mit dem internen kannste bis auf 19000 hoch und das fehlerfrei.
natürlich darfst du keine zusammengeschusterte platine haben wie das so oft der fall ist...geiz ist geil.

billigteile sind geil...

gruss

Richard
09.11.2010, 14:54
Hallo Jaecko,

danke für deine Antwort. Du hast mein Rätsel gelöst! Die Temperaturabhängigkeit dürfte wohl das große Problem sein!

Auch mit dem Quarz hast du recht, da habe ich wohl den falschen SI Prefix erwischt...es sind 32,768 kHz. So das es eben mit einem Prescaler von 256 genau 128 überläufe pro Sekunde ergibt.

Problem ist eben nur, dass ich den Quarz für die "Soft Clock" benötige und den Takt aber auch für meine Berechnung benötigen würde.
Ich habe gestern Abend noch versucht die Fuses über das myAVR-Progtool zu setzen, aber ohne Erfolg. Setze ich sie auf "ext. Low-Freq. Crystal; Start-Up time: 32K CK + 64 ms; [CKSEL=1001 SUT=10]", so wie es laut der Anleitung mit einem Uhrenquarz richtig ist, macht mein Atmega keinen Strich mehr. (CKOPT wurde natürlich auch aktiviert) Setze ich ihn wieder zurück auf die letzten Einstellungen, funktioniert wieder alles!

DANKE!
Mfg
Phips

Ich bekomme immer wieder ne Kriese wenn ich hier lese wie fahrlässig an den Fuses gebastelt wird. :-) Mit meinem STK500 und Hochvolt Programmierung komme ich zwar immer wieder an den Chip heran, hüte mich aber trotzdem vor den Fuses.

Ich habe schon einige Mega auf extern Quarz gestellt und nie Probleme gehabt ABER ich habe immer NUR den Externen Quarz aktiviert und sonst NIX!

Da ich keinen Mega 8 hier habe, einmal den Mega 16 mit 16 MHz Quarz einstellung.....

https://storage.driveonweb.de/dowdoc/1867b7c1f4c118737028b028e9e81c28.JPG

Gruß Richard

Besserwessi
09.11.2010, 16:18
Wenn es ums Stromsparen geht, ist der 32,... kHz Quarz die richtige Wahl für die Uhr. Vermutlich dann aber so, dass der 32 kHz Quarz für Timer 2 zuständig ist, und der Rest des µC mit dem internen Takt (z.B. ca. 1 MHz) läuft. Wenn man will kann man den internen Takt für den Tacho noch am Quarz abgleichen, aber für die Geschwindigkeit sind die 1-2% Feher des internen Taktes oft noch akzeptabel.

Wenn man nicht so sehr mit Strom sparen muss, kann man auch alles über einen 4-10 MHz Quarz laufen lassen, die sind auch nicht unbedingt schlechter als die Uhrenquarze , aber die Programmierung wird einfacher.

Alles über den 32 kHz Quarz laufen zu lassen, läßt wenig Rechengeschwindigkeit übrig, und bei der Übertragung per ISP muß es ganz langsam gehen.

hardware.bas
10.11.2010, 14:08
funkheld:
Ich habe hier lediglich meine praktische Erfahrung geschildert mit den
Baudraten über die UART. VG Micha

RedBaron
10.11.2010, 14:29
Der interne RC-Oszillator hat einen Temparaturkoeffizient im Pronzentbereich (s. Grafik "CALIBRATED 8MHz RC OSCILLATOR FREQUENCY vs. TEMPERATURE" im Datenblatt). Deine Messungenauigkeit von 1/1200 (ca. 1 Promille )liegt deutlich darunter. Der Unterschied beruht also wahrscheinlich auf Ungenauigkeiten des Oszillators. Dazu muss man wissen, das der Timer-Takt im Regelfall vom Prozessor-Takt abgeleitet wird.

Erste Maßnahme wäre es, den Prozessortakt über einen Quarz zu generieren (z.B. 1 MHz oder 8 oder 16 oder ...). Standardquarze haben eine Fehlertolaranz von 20 ppm, der Temperatur-Koeffizient liegt ebenfalls bei 20 ppm, ist also rd. 500 mal genauer als der interne RC-Oszillator.

Uhrenquarze von 32 kHz sind noch präziser (0,04 ppm Temperatur-Koeffizient). Sind aber häufig zu langsam für den Prozessortakt. Hier müsste man einen separaten Oszillator aufbauen (z.B. mit zwei NAND-Gattern) und den Timer über diesen externen Takt versorgen. Für den Prozessor-Takt reicht dann der interne RC-Oszillator.

Bei beiden Quarzlösungen ist zu beachten, das der Grundfehler in der Größenordnung von 20 ppm liegt. Wenn man hier genauer sein will, muss man dies über entsprechende Ziehkondensatoren oder durch Anpassung der Vorladewerts justieren.

Bei den höheren Taktfrequenzen muss man aber entweder den Prescaler einsetzen oder kleinere Zeiten (z.B. 1 mSec) messen und diese aufaddieren.

VG Red Baron

funkheld
10.11.2010, 15:18
Man..., die Fehlerquelle ist das Bascom.
Setzt die Routine mal nach Winavrc um, dann kannste sehen wie genau der Timer geht, super genau.
Die LCD-Rouine in Bascom ist eine mittlere Katastrophe im Zusammenhang mit dem Interrupt für eine Zeitmessung.

Gruss

Jaecko
10.11.2010, 15:40
Hm...
Mal ein älteres Zitat von weiter oben:

"Ich hab an einem Projekt nen 16MHz Quarz hängen; da läuft die Uhrzeit seit 3 Monaten ohne merkliche Abweichungen." (Mittlerweile sinds 4 Monate, und die Abweichung ist immer noch nicht subjektiv wahrnehmbar)

Geschrieben: in Bascom. LCD dran? Ja, 16x1, HD44780.

Ok, Bascom ist nicht perfekt. Aber als "Fehlerquelle" kann man das mit Sicherheit nicht bezeichnen; in Bascom hat man genau so wie in C vollen Zugriff auf alle Register; somit kann man z.B. einen Timer in Bascom durchaus im genaueren CTC-Modus laufen lassen ("Nachladen" in der ISR entfällt hier schon mal)

hardware.bas
10.11.2010, 16:26
funkheld:
jetzt soll auch noch BASCOM an der Ungenauigkeit Schuld sein?
Naja---- kein Kommentar meinerseits mehr zum Autor.
VG Micha

hardware.bas
10.11.2010, 16:37
Nachtrag;
meine natürlich hiermit nicht den urprünglichen Autor diesen Treads.
VG Micha