hallo Zusammen! Ich bin gerade dabei herauszufinden, wie die AD Wandlund (Converter) des ATMEGA8 funktioniert.. Ich bin sozusagen ein C Neuling, beschäftige mich jetzt seit 1 Woche damit.. Wie kann ich am besten das Ergebnis der Wandlung mit LEDs anzeigen? habe versucht den High-Teil des Ergebnisses direkt auf den Ausgangsport zu schieben. dieses zeigt mir jedoch nur PIN 3 hell und PIN4 ein bisschen hell. Das war bis jetzt immer das Zeichen, dass was nicht geht.. In der Anlage ist mein Versuch, vielleicht sieht einer von euch woran es liegt. Achso; ich benutze AVR Studio 4. Vielen Dank schonmal im Voraus! Grüße Jenny
jenny schrieb: > Wie kann ich am besten das Ergebnis der Wandlung mit LEDs anzeigen? Einfach am Port ausgeben. > habe versucht den High-Teil des Ergebnisses direkt auf den Ausgangsport > zu schieben. Du holst dir das Ergebnis in die Variable i. Warum benutzt du dann nicht auch i zur Ausgabe? ADCSRA = 0b11000101; mach sowas nicht. Alle Helfer müssen jetzt im Datenblatt nachsehen, was du da eigentlich alles aktiviert hast und was nicht. Hier http://www.mikrocontroller.net/articles/AVR-GCC-Tutorial#Der_interne_ADC_im_AVR findest du eine ADC Routine, die funktioniert.
Hallo In abhängigkeit von PDO wird mal ADCH oder mal 0xff ausgegeben. Das könnte doch schonmal ein Grund sein, das Pin4 ein bißchen hell ist? Gruß Joachim
@ kbuchegg in dem tutorial stand, dass man das Ergebnis lesen muss, damit es die anderen Ergebnisse nicht verfälscht, deswegen nehme ich i. i besteht aber aus 16bit und ich kann nur 8bit mit meinen 8 leds ausgeben, ich dachte das geht vielleicht nich.. habe das programm jetzt nocheinmal anders geschrieben, mit einer interruptroutine. jetzt ist es so, dass die LEDs aus sind, aber die Ausgabe auch nicht funktioniert.. Leider. achso; im tutorial steht ich muss das I-Bit im SREG setzten. Wie kann ich das machen?hab noch ein bisschen gesucht, wie das aussehen könnte, aber nicht wirklich was gefunden. ich würde es jetzt so versuchen:
1 | SREG |= (1<< I-BIT); |
Okay, das funktioniert so nich...
jenny schrieb: > @ kbuchegg > > in dem tutorial stand, dass man das Ergebnis lesen muss, damit es die > anderen Ergebnisse nicht verfälscht, deswegen nehme ich i. i besteht > aber aus 16bit und ich kann nur 8bit mit meinen 8 leds ausgeben, ich > dachte das geht vielleicht nich.. Wenn du dir die 16 Bit (von denen nur die unteren 10 Bit relevant sind) vor der Ausgabe zurecht schiebst, geht auch das. 10 Bit auf einem 8 Bit Port ausgeben geht nun mal nicht. Also muss man entscheiden wie man die 10 Bit 'eindampft'. 10 Bit, das sind Zahlen von 0 bis 1023 8 Bit, das sind Zahlen von 0 bis 255 Wenn man daher die 10 Bit durch 4 dividiert, 'passt' der 10 Bit Bereich in 8 Bit. Man verliert dann zwar ein bischen Auflösung, aber die Zahlen von 0 bis 1023 werden sinnvoll auf den Bereich 0 bis 255 abgebildet. > habe das programm jetzt nocheinmal anders geschrieben, mit einer > interruptroutine. Ach. Wenns auf die einfache Methode nicht funktioniert, probieren wir die kompliziertere, vielleicht geht ja die :-)
Ja... ;D Mein Timer hat auch am besten mit Interrupt funktioniert :) Also hab jetzt am Ende des ersten Programms (ohne Interrupt mit einmaliger AD-Wandlung per Tastendruck) das mit dem durch 4 teilen eingefügt. Das sieht jetzt so aus;
1 | i = ADCW; |
2 | i /= 4; |
3 | PORTD = i; |
Jetzt gibt mein Ausgangsport die ganze Zeit ne 0 aus (also alle LEDs leuchten)...das drehen an meinen angeschlossenen Potis (Potentiometern) - also angeschlossen an die Spannungseingänge- hat keinen Einfluss. Vorhin hatte ich noch ein ganz witziges Phänomen (schreibt man das so?) da veänderten sich die LEDs (sie flackerten und manche gingen aus oder wieder an), wenn man die hand über die Potis hielt :D grüße von jenny
Nochmal: Ich hab jetzt ehrlich keine Lust deine Konfigurationsbits auseinanderzudröseln. Benutze die ADC Routine aus dem Tutorial. Die ist in 10 Sekunden per Cut&Paste übernommen. Ruf sie auf und du kriegst einen Wert zurück, diesen Wert, geteilt durch 4, gibst du am Port aus. Wenns dann noch immer nicht funktioniert, hast du ein Hardwareproblem. Deine main kann so einfach aussehen
1 | int main(void) |
2 | |
3 | {
|
4 | DDRB = 0xff; // dort hängen die LED |
5 | |
6 | while( 1 ) |
7 | {
|
8 | PORTB = ReadChannel( 0 ) / 4; |
9 | }
|
10 | }
|
(ReadChannel ist die Funktion aus dem Tutoroial)
BTW, weil ichs gerade sehe: Was ist bei dir eigentlich wo angeschlossen? int main(void) { uint16_t i; DDRB = 0x00; DDRD = 0xff; PORTD = 0xff; Du konfigurierst Port B auf Eingabe, gibst dann aber über PORTB anscheinend auf die LED aus. Du konfigurierst Port D auf Ausgabe, fragst dann aber von dort die Schalter ab.
sorry wollte dir nich auf den keks gehen.. werds weiter versuchen, von mir aus auch mit dem programm aus dem tutorial. ich muss es nur verstehen, deswegen nützt mir copy&paste nix.. müssen hier gerade neue µCBoxen bauen , die am besten mit C programmiert werden. keiner hat ahnung wie und ich hab die aufgabe bekommen das herauszufinden und wenns dann nich geht liegts an mir.. also trotzdem danke für deine hilfe!!!!! liebe grüße jenny
jenny schrieb:
> ich muss es nur verstehen, deswegen nützt mir copy&paste nix..
Ähm.
Im Tutorial gibt es auch Text, den man lesen kann. Der erklärt
(hoffentlich) den dort gezeigten Code ausreichend genau, damit man,
bewaffnet mit dem Datenblatt des Prozessors, den Code auch verstehen
kann.
So funktioniert es zumindest in der Simulation. Du kannst ja mal vergleichen was ich geändert habe.
Hi, kann mir Bitte jemand erklären was die Zeile bedeutet? oder was passiert in dieser Zeile ADCSRA = 0b11000101; Lieben Gruß TEVA
guckst Du Datenblatt Seite 207 von 308 ADC Control and Status Register A = ADCSRA... da sind die einzeln Bits aufgedröselt! Die ersten beiden sind für ADEN & ADSC und die letzten sind für den Prescaler. In diesem Fall steht 0bxxxxx101 für 1/32... weil ADPS2 ADPS1 ADPS0 Division Faktor 1 0 1 32
Danke für die schnelle Antwort ich habe es aber nicht verstanden warum 0b davor steht. ich habe eine Frage und zwar sind die unteren beiden zeilen identisch? Wenn ja, warum steht im Quellcode von Hubert G. 2 mal das selbe ?? ADCSRA= (1<<ADEN)|(1<<ADSC)|(1<<ADPS2)|(1<<ADPS0); ADCSRA = 0b11000101; Lieben Gruß Teva
>sind die unteren beiden zeilen identisch?
Nein. Sie haben nur die gleiche Wirkung.
Hallo, ich würde dir zusätzlich zu dem Tutorial und den Fragen hier im Forum noch ein Buch empfehlen. Mir hat das Buch sehr geholfen, gerade beim verstehen des ADC und der Interupts. Man muß nicht unbedingt alles nachbauen was der Autor da aufbaut und kann auch die Kapitel die einen besonders interessieren mit einem Mega8 nachspielen. Noch ein Vorteil ist das da eine menge Code mitgeliefert wird der sich dann wenn verstanden auch gut in eigene Projekte einbauen lässt. Und noch was: es ist nicht so dick und manches kann man querlesen oder später darauf zurückkommen. Das Buch von Florian Schäffer, AVR, Hardware und C-Programmierung in der Praxis. Mir hats jedenfalls viel geholfen und ich habe nichts mit dem Autor zu tun, ist nur mein tip
Diese Zeile ist auskommentiert // ADCSRA = 0b11000101; //aktiviert ADC-Messung 0b ist für den Kompiler die Kennzeichnung für binär, 0x für Hexadezimal
Hi, Danke nochmal für schnelle Antworten... noch eine letzte Frage zu dem Quell-code.. was passiert in dieser Zeile?? while ((ADCSRA & (1<<ADSC))) Lieben Gruß Teva
In dieser Zeile wird gewartet bis das Bit ADSC im Register ADCSRA wieder 0 ist. Dann ist die Konversion beendet und das Resultat steht im Register ADC und kann abgefragt werden.
>In dieser Zeile wird gewartet bis das Bit ADSC im Register ADCSRA wieder >0 ist. Dann ist die Konversion beendet und das Resultat steht im >Register ADC und kann abgefragt werden. Dazu fehlt noch das Semikolon am Ende der Zeile...
Hi, ich möchte die Werte, die der ADC umwandelt an mein PC schicken und es dort speichern. hat jemand Ahnung wie man vorgehen soll?? an meinem Board habe ich ISP und RS232 Anschluss. ich habe schon einen Spannungsteiler am Eingang der ADC und will nur die umgewandelte Spannungswerte an PC schicken und speichern. Lieben Gruß TEVA
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.