- LiTime Speicher und Akkus         
Seite 2 von 2 ErsteErste 12
Ergebnis 11 bis 16 von 16

Thema: Fuse-Bit nicht sichtbar // Frage zu einem Programm

  1. #11
    Erfahrener Benutzer Robotik Visionär Avatar von oberallgeier
    Registriert seit
    01.09.2007
    Ort
    Oberallgäu
    Beiträge
    8.651
    Anzeige

    LiFePo4 Akku selber bauen - Video
    Zitat Zitat von 021aet04 Beitrag anzeigen
    In dem Programm ist kein Fehler zu erkennen und auch mit dem Simulator funktioniert es (ca. 33s ein/aus) ..
    MMM...ähhh..Mein Fehler. Ich hab garnicht mehr daran gedacht, dass mit WGM1[3:0]=0 der Modus "Normal" gefahren wird. Und dieser Zustand ist ja aktuell nach jedem Power-on.

    Es wäre dem Kollegen gioR also allenfalls nur zu raten die Initialisierung des Timers auf
    ......TCCR1B |= (1<<CS11) | (1<<CS10); // Prescaler CPU Takt/64
    also langsames Blinken zu setzen oder mit
    ......TCCR1B |= (1<<CS11) ; // Prescaler CPU Takt/8
    ein schnell(er)es Blinken zu fahren - ca. 18 "Blitze" in 10 Sekunden.
    Ciao sagt der JoeamBerg

  2. #12
    Neuer Benutzer Öfters hier
    Registriert seit
    15.12.2018
    Beiträge
    5
    Hallo,

    ich hab den Fehler entdeckt... Es funktioniert tatsächlich.... peinlich peinlich...

    Ich habe nun mein Schalt-blitz soweit fertig das er FAST funktioniert wie er soll... Allerdings hängt sich das Programm öfters auf...
    Findet jemand den Fehler?

    Danke und viele Grüße






    #include <avr/io.h>
    #include <util/delay.h>

    // Status LED on

    #define LED1_on |= (1<<PB0);
    #define LED2_on |= (1<<PB1);
    #define LED3_on |= (1<<PB2);
    #define LED4_on |= (1<<PB3);
    #define LED5_on |= (1<<PB4);

    // Status LED off

    #define LED1_off &= ~(1<<PB0);
    #define LED2_off &= ~(1<<PB1);
    #define LED3_off &= ~(1<<PB2);
    #define LED4_off &= ~(1<<PB3);
    #define LED5_off &= ~(1<<PB4);


    int main(void)
    {

    uint16_t x, ergebnis; // Variablen für nachfolgendes Programm festlegen
    DDRB = 0xFF; // Alle Bits als Ausgang
    PORTC = 0x00; // Beim Einfang keine Pullups


    // Init Timer

    TCCR1B |= (1<<CS10); // 16bit Timer und Prescaler 1

    // Init ADC


    ADMUX = (1<<REFS0) | (1<<MUX0); // AVCC 5V als Vergleichsspannung und festlegen des Messkanales ADC1
    ADCSRA = (1<<ADEN) | (1<<ADPS0) | (1<<ADPS1); // ADC Aktivieren und Vorteiler für die ADC Wandlung festlegen auf 8 festlegen (125 khz)
    ADMUX |= (1<<ADLAR); // Ausgabe linksbündig


    // Dummy Readout
    ADCSRA |= (1<<ADSC); // Start ADC-Wandlung
    while (ADCSRA &(1<<ADSC)); // Auf Abschluss der Konvertierung warten
    x = ADC; // Das Ergebnis der 1. Wandlung in x speichern


    while (1)
    {





    ADCSRA |= (1<<ADSC); // Start ADC-Wandlung
    while (ADCSRA &(1<<ADSC)) // Führe ADC-Wandlung solange aus bis abgeschlossen
    ergebnis = ADC; // Ergebnis in ADC Port speichern
    ergebnis = ergebnis >> 6; // Ergebnis 6x nach rechts veschieben




    if(ergebnis > 200)

    {
    PORTB LED1_on
    }

    else
    {
    PORTB LED1_off
    }





    if(ergebnis > 400)

    {
    PORTB LED2_on
    }

    else
    {
    PORTB LED2_off
    }





    if(ergebnis > 600)

    {
    PORTB LED3_on
    }

    else
    {
    PORTB LED3_off
    }




    if(ergebnis > 800)

    {
    PORTB LED4_on
    }


    else
    {
    PORTB LED4_off

    }






    if(ergebnis > 999)

    {

    if (TCNT1 < 3276

    {
    PORTB LED5_on
    }


    else

    {
    PORTB LED5_off

    }

    }

    else

    {
    PORTB LED5_off


    }


    }

    }

  3. #13
    Erfahrener Benutzer Robotik Visionär Avatar von 021aet04
    Registriert seit
    17.01.2005
    Ort
    Niklasdorf
    Alter
    36
    Beiträge
    5.055
    Das Programm ist sehr schwer zu lesen. Bitte schreibe es (wie schon weiter oben geschrieben) in Code Tags, damit es so aussieht wie in Beitrag 8.

    Warum parametrierst du den ADC eigentlich linksbündig und schiebst das Ergebnis nach rechts? Mit "ADLAR = 0" hast du das selbe Ergebnis nur das du nicht nach rechts schieben musst. "ADLAR = 1" verwendet man nur wenn man mit 8Bit rechnet (der ADC wird erst aktualisiert wenn man ADCH gelesen hat).

    Die Variable "x" benötigst du nicht, das Ergebnis kannst du auch dort schon in die variable "ergebnis" schreiben, da es in der "while"-Schleife sofort überschrieben wird (weil zuerst der ADC neu gestartet und anschließend in "ergebnis" geschrieben wird).

    Was mir noch aufgefallen ist (was die Ursache sein kann). In der "while" Schleife startest du den ADC, Anschließend schreibst du solange "ADSC == 1" den ADC Wert in die Variable "ergebnis" und wenn die Wandlung fertig ist schreibst du den richtigen Wert nicht mehr in "ergebnis", weil du das ";" hinter der Zeile "while (ADCSRA &(1<<ADSC)) // Führe ADC-Wandlung solange aus bis abgeschlossen" vergessen hast.

    MfG Hannes

  4. #14
    Erfahrener Benutzer Robotik Visionär Avatar von oberallgeier
    Registriert seit
    01.09.2007
    Ort
    Oberallgäu
    Beiträge
    8.651
    Mit copy & paste - ohne sonst was! - in die "Codeklammern" eingesetzt siehts schon fast gut aus.

    Code:
    #include <avr/io.h>
    #include <util/delay.h>
    
    // Status LED on
    
    #define LED1_on  |= (1<<PB0);
    #define LED2_on  |= (1<<PB1);
    #define LED3_on  |= (1<<PB2);
    #define LED4_on  |= (1<<PB3);
    #define LED5_on  |= (1<<PB4);
    
    // Status LED off
    
    #define LED1_off &= ~(1<<PB0);
    #define LED2_off &= ~(1<<PB1);
    #define LED3_off &= ~(1<<PB2);
    #define LED4_off &= ~(1<<PB3);
    #define LED5_off &= ~(1<<PB4);
    
    
    int main(void)
    {
        
        uint16_t x, ergebnis;                                            // Variablen für nachfolgendes Programm festlegen 
        DDRB = 0xFF;                                                    // Alle Bits als Ausgang
        PORTC = 0x00;                                                    // Beim Einfang keine Pullups            
         
    
         // Init Timer
    
          TCCR1B |= (1<<CS10);                                                    // 16bit Timer und Prescaler 1
                
        // Init ADC
    
        
        ADMUX = (1<<REFS0) | (1<<MUX0);                                    // AVCC 5V als Vergleichsspannung und festlegen des Messkanales ADC1
        ADCSRA = (1<<ADEN) | (1<<ADPS0) | (1<<ADPS1);                    //  ADC Aktivieren und Vorteiler für die ADC Wandlung festlegen auf 8  festlegen (125 khz) 
        ADMUX  |=  (1<<ADLAR);                                            // Ausgabe linksbündig 
        
        
         // Dummy Readout
         ADCSRA  |= (1<<ADSC);                                                 // Start ADC-Wandlung
         while (ADCSRA &(1<<ADSC));                                            // Auf Abschluss der Konvertierung warten
         x = ADC;                                                            // Das Ergebnis der 1. Wandlung in x speichern
    
        
      while (1)
      {
           
    
    
    
    
          ADCSRA  |= (1<<ADSC);             // Start ADC-Wandlung
          while (ADCSRA &(1<<ADSC))            // Führe ADC-Wandlung solange aus bis abgeschlossen
          ergebnis = ADC;                    // Ergebnis in ADC Port speichern
          ergebnis = ergebnis >> 6;            // Ergebnis 6x nach rechts veschieben
          
          
    
          
          if(ergebnis > 200)
          
          {
              PORTB LED1_on
          }
          
          else
          {
              PORTB LED1_off
          }
          
          
          
          
          
          if(ergebnis > 400)
          
          {
              PORTB LED2_on
          }
          
          else
          {
              PORTB LED2_off
          }
          
          
          
          
          
          if(ergebnis > 600)
          
          {
              PORTB LED3_on
          }
          
          else
          {
              PORTB LED3_off
          }
          
          
          
          
          if(ergebnis > 800)
          
          {
              PORTB LED4_on
          }
          
          
          else
          {
              PORTB LED4_off
              
          }
          
          
          
          
          
          
          if(ergebnis > 999)
          
          {
              
              if (TCNT1 < 32768)
    
              {
                  PORTB LED5_on
              }
              
              
              else
              
              {
                  PORTB LED5_off
                  
              }
              
          }
          
          else
          
          {
              PORTB LED5_off
        
        
         }
     
     
      }
         
      }


    Dazu in der "erweiterten" Ansicht den Button mit dem Hash/Lattenzaun anklicken: diesen da: [#], dann bekommst Du ins Editorfenster die Folge [Code.][/Code.] eingefügt. Und mitten zwischen diese beiden Klammerausdrücke scheibst Du dann Deinen Ausdruck:

    [Code.]/* Diesda
    ist
    nur Kommentar */[/Code.]

    Vorsicht - um den Automatismus zu betuppen habe ich als Demo in den Codeklammern oben einen "unsichtbaren" Punkt eingefügt. Das Ergebnis ist dann:
    Code:
    /*    Diesda
          ist
          nur Kommentar */
    Nachtrag:
    Achtung mit ADLAR; Du weißt schon dass Du damit Du den Wert manipulieren kannst?

    ......Bild hier  
    Geändert von oberallgeier (23.12.2018 um 16:47 Uhr)
    Ciao sagt der JoeamBerg

  5. #15
    Neuer Benutzer Öfters hier
    Registriert seit
    15.12.2018
    Beiträge
    5
    ich danke euch!

    Programm funktioniert ! es war die variabel X das Problem


    Viele Grüße

  6. #16
    Erfahrener Benutzer Robotik Visionär Avatar von 021aet04
    Registriert seit
    17.01.2005
    Ort
    Niklasdorf
    Alter
    36
    Beiträge
    5.055
    @oberallgeier
    Es geht um einen Atmega8, dieser hat nur Single Ended ADCs.

    @gioR
    Ich glaube nicht das es an der Variable "x" liegt, diese wird nur einmal geschrieben und dann passiert damit nichts mehr (weder lesen noch schreiben).

    MfG Hannes

Seite 2 von 2 ErsteErste 12

Ähnliche Themen

  1. [ERLEDIGT] Frage zu einem Programm zur base
    Von Thorben W im Forum Robby RP6
    Antworten: 4
    Letzter Beitrag: 13.07.2013, 18:49
  2. Schon wieder Fuse Frage :-(
    Von Spongebob85 im Forum C - Programmierung (GCC u.a.)
    Antworten: 4
    Letzter Beitrag: 05.10.2007, 14:39
  3. Bitmap nicht sichtbar im Frontdesigner
    Von Zeroeightfifteen im Forum Konstruktion/CAD/3D-Druck/Sketchup und Platinenlayout Eagle & Fritzing u.a.
    Antworten: 0
    Letzter Beitrag: 31.12.2006, 15:21
  4. Frage zu Fuse-Bits
    Von rqd2 im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 3
    Letzter Beitrag: 27.12.2006, 11:46
  5. Eagle: Vcc/GND-Pin von OPV nicht sichtbar?
    Von Minifriese im Forum Konstruktion/CAD/3D-Druck/Sketchup und Platinenlayout Eagle & Fritzing u.a.
    Antworten: 2
    Letzter Beitrag: 23.12.2006, 16:11

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

LiTime Speicher und Akkus