Version 10.11.8.7
hhmmm neue Version?
Version 10.11.8.7
hhmmm neue Version?
...
Hallo linux_80,
ich habe jetzt Version 1.11.9.2 installiert und habe NUR die Zeile: Case " " : Portb = 0
eingefügt und schon kommt der Fehler.
Kannst du bitte den Code mal bei die compilieren und mir sagen ob es geht?
Tobas
Code:'------------------------------------------------------------------------------- $regfile = "m8def.dat" 'AT-Mega8 $crystal = 8000000 'Quarz: 8 MHz $baud = 9600 'Baudrate der UART: 9600 Baud '------------------------------------------------------------------------------- 'Konfiguration Ein- / Ausgänge Ddrb = &B11111111 '1 Ausgang, 0 Eingang => Pin PB7-0 als Ausgang Ddrc = &B1111110 '1 Ausgang, 0 Eingang => Pin PC6-1 als Ausgang; 0 als Eingang Ddrd = &B11110001 '1 Ausgang, 0 Eingang => Pin PD7-4,0 als Ausgang; 1-3 als Eingang '------------------------------------------------------------------------------- 'Konfiguration LCD Config Lcd = 16 * 2 Config Lcdpin = Pin , Db4 = Portd.4 , Db5 = Portd.5 , Db6 = Portd.6 , Db7 = Portd.7 , E = Portd.0 , Rs = Portc.6 Cursor Off Noblink '------------------------------------------------------------------------------- 'Konfiguration ADC Config Adc = Single , Prescaler = Auto , Reference = Avcc '------------------------------------------------------------------------------- 'Konfiguration Timer0 Config Timer0 = Timer , Prescale = 1024 On Timer0 Timer0_isr Const Timervorgabe0 = 230 '312 mal / Sekunde!!! Enable Timer0 Enable Interrupts '------------------------------------------------------------------------------- 'Konfiguration Timer1 Config Timer1 = Timer , Prescale = 256 On Timer1 Timer1_isr Const Timervorgabe1 = 55118 '3 mal / Sekunde!!! Enable Timer1 Enable Interrupts '------------------------------------------------------------------------------- 'Variablen Anzeige: Dim Wert As Long ' (-2147483648 bis 2147483647) Dim Wert_pos As Word 'gewandelter wert Dim Negativ As Bit 'Merker = 1 wnn Wert negativ! ' variablen für die display routine Dim Wertstr As String * 5 Dim Y As Byte Dim Tempbyte As Byte ' Variable für Digitansteuerung Dim Digit As Byte 'Anzeige im Ganzen Dim Fivedigitdisplay As String * 5 Dim Umdreh As Byte 'führende Nullen entfernen Dim Digit_aus As Bit 'Merker =0 wenn Stelle =0 'ADC Dim Analog_in0 As Long 'Word '=0-1023 vom Analogeingang Dim Pro1 As Integer Dim Pro2 As Single Dim Pro3 As Integer Dim Proz_anzeige As Byte 'Variablen LCD Dim Ani_1 As Integer 'Zähler für Startannimation LCD Dim Ende As Word 'zum Animation beenden 'Variablen Taster Dim S1 As Bit 'Schalter 1 Dim S2 As Bit 'Schalter 2 Dim S2_m As Bit Dim S3 As Bit 'Schalter 3 Dim S3_m As Bit 'Schalter 3 MERKER Dim Taste_s1 As Word 'Programmverteilung über Timer0 Dim Zeit As Word 'wird 312 mal / Sekunde mit 1 addiert 'Variablen zum testen...... Dim Test2 As Integer 'zum hochzählen zum testen Dim Test As Integer '------------------------------------------------------------------------------- 'Annimation LCD Goto Sprung Do Cls For Ani_1 = 16 To 1 Step -1 'Von 1 bis 16 wird gezählt Locate 1 , Ani_1 'Die entsprechende Position im Display anwählen. Lcd "> TOBIAS BLOME <" Waitms 250 Next Locate 2 , 1 Lcd "BI - EMR 10/2008" Waitms 500 Locate 2 , 1 Lcd " " Waitms 500 Locate 2 , 1 Lcd "BI - EMR 10/2008" Waitms 500 Locate 2 , 1 Lcd " " Waitms 500 Locate 2 , 1 Lcd "BI - EMR 10/2008" Wait 3 Loop Until Ende => 1 Sprung: '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- 'Setzen: Digit_aus = 0 'alle Segmente aus Portb = 0 Digit = 0 Test2 = 9900 Start Adc Do '---Programm aufteilen--- If Zeit => 150 Then 'also eine halbe Sekunde Zeit = 0 'Zeit zurücksetzen End If '---ENDE Programmaufteilung--- 'zum testen um etwas zu "sehen" ' Incr Test ' If Test = 10 Then ' Test = 0 ' Incr Test2 ' End If ' If Test2 > 99999 Then ' Test2 = 0 ' End If Loop '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- 'Sprungmarken '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- Timer0_isr: 'Timer1-Interruptroutine (312 x pro Sekunde) '------------------------------------------------------------------------------- Timer0 = Timervorgabe0 Gosub 7seganzeige 'Routine für 7 Segmentanzeige Incr Zeit 'Zeitgeber If S1 = 1 Then 'soll nur hochgezählt werden, wenn Taste links gedrückt Incr Taste_s1 'wenn taste lange gedrückt soll etwas passieren (LCD "e" wechsel) Else Taste_s1 = 0 End If Return '------------------------------------------------------------------------------- Timer1_isr: 'Timer1-Interruptroutine (3 x pro Sekunde) '------------------------------------------------------------------------------- Timer1 = Timervorgabe1 Analog_in0 = Getadc(0) 'Analog in Variable schreiben Wert = Analog_in0 - 500 'Wert für Anzeige If Wert < 0 Then 'wenn wert negativ Wert_pos = Wert * -1 Negativ = 1 Else Wert_pos = Wert Negativ = 0 End If 'Print "Digit0: " ; Digit0 'Print "Digit1: " ; Digit1 'Print "Digit2: " ; Digit2 'Print "Digit3: " ; Digit3 Return '------------------------------------------------------------------------------- Analog: 'Analogeingänge Auslesen: '------------------------------------------------------------------------------- 'Analog_in0 = Getadc(0) 'Analog in Variable schreiben ' Wert = Analog_in0 'Wert für Anzeige ' Pro1 = Analog_in0 - 204 'Prozent1Wert analog 204-1005 also -204 = 0-801 ' Pro2 = Pro1 * 0.12484 'Rechnen: 100% / max(801) = 0.12484 ' Pro3 = Round(pro2) ' If Pro3 > 100 Then 'damit keine größenren Werte als 100% auf dem LCD stehen ' Pro3 = 100 ' End If ' ' If Pro3 < 0 Or Pro3 > 110 Then 'wenn errechneter %Wert falsch (kleiner 0 oder größer 110 dann immer 0 (110 wegen 4-20mA Ungenauigkeit) ' Proz_anzeige = 0 ' Else ' Proz_anzeige = Pro3 ' End If '------------------------------------------------------------------------------- 7seganzeige: ' Code 7 Segmentanzeige: '------------------------------------------------------------------------------- 'Formatiere das Display Wertstr = Str(wert_pos) Fivedigitdisplay = Format(wertstr , "00000") 'Nullen geben die Anzahl der Stellen an, damit die Stellen richtig gesetzt werden ' jeder Lauf durch die Hauptschleife zeigt ein anderes Digit Incr Digit 'Waitms 6 'Zeit für die Anzeige (je länger wait desto mehr flackert es) Portb = 0 'Ghosting vermeiden If Digit = 5 Then 'mache das , bis 5 erreicht ist Digit = 0 End If ' addiere 1 zum Digitcounter, weil MID 1-basiert ist Y = Digit + 1 ' und hol das Digit, das wir brauchen Wertstr = Mid(fivedigitdisplay , Y , 1) 'Anzeige auswählen Tempbyte = 2 ^ Digit 'Tempbyte = 1,2,4,8,16 'Digitansteuerung auf portC: PC1-5 Umdreh = Tempbyte * 2 'Umdreh = 2,4,8,16,32 'Ansteuerung umdrehen für gemeinsame Anoden Portc = Umdreh 'Port für die Stellen auswahl 'Führende Nullen entfernen: 'INFO: 'wertstr hat immer nur eine Ziffer und wechselt also nacheinander alle 5 Stellen durch! 'wenn wertstr = 0 ist dann wird nachgesehen, in welchem Digit (Stelle) wir uns befinden. 'wenn Digit = 0 -also die ganz linke Stelle- dann auf jeden Fall Portc.1 = 0 (Transistor der Stelle) abschalten 'Digit0 = 0 -> ist nur ein Merker für die folgenden Stellen d.h. 'wenn wertstr=0 dann fragen ob Digit=1 (also 2te Stelle von links) UND der Merker Digit0=0 'dann Transistor abschalten und weiteren Merker für diese Stelle setzen 'ZehnTausenderstelle If Val(wertstr) = 0 Then 'Führende Null wegblenden If Wert => 0 Then 'Wert muss = > 0 sein wegem negativen Vorzeichen If Digit = 0 Then : Portc.1 = 0 : Digit_aus = 0 'C.1=Digit Transistor End If End If Else Digit_aus = 1 End If 'Tausenderstelle If Val(wertstr) = 0 Then 'Führende Null wegblenden If Digit = 1 And Digit_aus = 0 Then : Portc.2 = 0 : Digit_aus = 0 'C.2=Digit Transistor End If Else Digit_aus = 1 End If 'Hunderterstelle If Val(wertstr) = 0 Then 'Führende Null wegblenden If Digit = 2 And Digit_aus = 0 Then : Portc.3 = 0 : Digit_aus = 0 'C.3=Digit Transistor End If Else Digit_aus = 1 End If ''ENTFERNT WEIL MIT KOMMASTELLE UND DANN MUSS IN DER LETZTEN STELLE NE NULL STEHEN UND DARF NICHT AUSGEBLENDET WERDEN!!! ''Zehnerstelle 'If Val(wertstr) = 0 Then 'Führende Null wegblenden ' If Digit = 3 And Digit_aus = 0 Then : Portc.4 = 0 : Digit_aus = 0 'C.4=Digit Transistor ' End If ' Else ' Digit_aus = 1 'End If 'Dieser Teil erledigt die Wandlung in 7 Segment Code 'Für Anzeigen mit gemeinsamer Anode Select Case Val(wertstr) Case 0 : Portb = 126 'NULL Case 1 : Portb = 12 'EINS Case 2 : Portb = 182 'ZWEI Case 3 : Portb = 158 'DREI Case 4 : Portb = 204 'VIER Case 5 : Portb = 218 'FÜNF Case 6 : Portb = 250 'SECHS Case 7 : Portb = 14 'SIEBEN Case 8 : Portb = 254 'ACHT Case 9 : Portb = 222 'NEUN Case " " : Portb = 0 'Case Else : Portb = 128 'mittleres Segment Case Else : Portb = 226 '"F" End Select 'Minusvorzeichen If Digit = 0 And Negativ = 1 Then Portb = 128 'mittleres Segment End If 'Komma setzen 'If Portc = 2 Then Portb.0 = 1 '4 Kommastellen 'If Portc = 4 Then Portb.0 = 1 '3 Kommastellen 'If Portc = 8 Then Portb.0 = 1 '2 Kommastellen If Portc = 16 Then Portb.0 = 1 '1 Kommastelle 'negatives Vorzeichen setzen If Portc = 2 Then 'wenn Pin gem. Anode ganz linke Stelle gesetzt If Wert < 0 Then 'wenn Wert kleiner 0 Portb = 128 'Binär 1000 0000 -> Dezimal = 128 (nur Segment G) End If End If '------------------------------------------------------------------------------- Anzeige1: '------------------------------------------------------------------------------- Return '------------------------------------------------------------------------------- Anzeige2: '------------------------------------------------------------------------------- Return '------------------------------------------------------------------------------- Anzeige3: '------------------------------------------------------------------------------- Return
...
Hallo linux_80,
ich habe jetzt Version 1.11.9.2 installiert und habe NUR die Zeile: Case " " : Portb = 0
eingefügt und schon kommt der Fehler.
Kannst du bitte den Code mal bei die compilieren und mir sagen ob es geht?
Tobias
Code:'------------------------------------------------------------------------------- $regfile = "m8def.dat" 'AT-Mega8 $crystal = 8000000 'Quarz: 8 MHz $baud = 9600 'Baudrate der UART: 9600 Baud '------------------------------------------------------------------------------- 'Konfiguration Ein- / Ausgänge Ddrb = &B11111111 '1 Ausgang, 0 Eingang => Pin PB7-0 als Ausgang Ddrc = &B1111110 '1 Ausgang, 0 Eingang => Pin PC6-1 als Ausgang; 0 als Eingang Ddrd = &B11110001 '1 Ausgang, 0 Eingang => Pin PD7-4,0 als Ausgang; 1-3 als Eingang '------------------------------------------------------------------------------- 'Konfiguration LCD Config Lcd = 16 * 2 Config Lcdpin = Pin , Db4 = Portd.4 , Db5 = Portd.5 , Db6 = Portd.6 , Db7 = Portd.7 , E = Portd.0 , Rs = Portc.6 Cursor Off Noblink '------------------------------------------------------------------------------- 'Konfiguration ADC Config Adc = Single , Prescaler = Auto , Reference = Avcc '------------------------------------------------------------------------------- 'Konfiguration Timer0 Config Timer0 = Timer , Prescale = 1024 On Timer0 Timer0_isr Const Timervorgabe0 = 230 '312 mal / Sekunde!!! Enable Timer0 Enable Interrupts '------------------------------------------------------------------------------- 'Konfiguration Timer1 Config Timer1 = Timer , Prescale = 256 On Timer1 Timer1_isr Const Timervorgabe1 = 55118 '3 mal / Sekunde!!! Enable Timer1 Enable Interrupts '------------------------------------------------------------------------------- 'Variablen Anzeige: Dim Wert As Long ' (-2147483648 bis 2147483647) Dim Wert_pos As Word 'gewandelter wert Dim Negativ As Bit 'Merker = 1 wnn Wert negativ! ' variablen für die display routine Dim Wertstr As String * 5 Dim Y As Byte Dim Tempbyte As Byte ' Variable für Digitansteuerung Dim Digit As Byte 'Anzeige im Ganzen Dim Fivedigitdisplay As String * 5 Dim Umdreh As Byte 'führende Nullen entfernen Dim Digit_aus As Bit 'Merker =0 wenn Stelle =0 'ADC Dim Analog_in0 As Long 'Word '=0-1023 vom Analogeingang Dim Pro1 As Integer Dim Pro2 As Single Dim Pro3 As Integer Dim Proz_anzeige As Byte 'Variablen LCD Dim Ani_1 As Integer 'Zähler für Startannimation LCD Dim Ende As Word 'zum Animation beenden 'Variablen Taster Dim S1 As Bit 'Schalter 1 Dim S2 As Bit 'Schalter 2 Dim S2_m As Bit Dim S3 As Bit 'Schalter 3 Dim S3_m As Bit 'Schalter 3 MERKER Dim Taste_s1 As Word 'Programmverteilung über Timer0 Dim Zeit As Word 'wird 312 mal / Sekunde mit 1 addiert 'Variablen zum testen...... Dim Test2 As Integer 'zum hochzählen zum testen Dim Test As Integer '------------------------------------------------------------------------------- 'Annimation LCD Goto Sprung Do Cls For Ani_1 = 16 To 1 Step -1 'Von 1 bis 16 wird gezählt Locate 1 , Ani_1 'Die entsprechende Position im Display anwählen. Lcd "> TOBIAS BLOME <" Waitms 250 Next Locate 2 , 1 Lcd "BI - EMR 10/2008" Waitms 500 Locate 2 , 1 Lcd " " Waitms 500 Locate 2 , 1 Lcd "BI - EMR 10/2008" Waitms 500 Locate 2 , 1 Lcd " " Waitms 500 Locate 2 , 1 Lcd "BI - EMR 10/2008" Wait 3 Loop Until Ende => 1 Sprung: '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- 'Setzen: Digit_aus = 0 'alle Segmente aus Portb = 0 Digit = 0 Test2 = 9900 Start Adc Do '---Programm aufteilen--- If Zeit => 150 Then 'also eine halbe Sekunde Zeit = 0 'Zeit zurücksetzen End If '---ENDE Programmaufteilung--- 'zum testen um etwas zu "sehen" ' Incr Test ' If Test = 10 Then ' Test = 0 ' Incr Test2 ' End If ' If Test2 > 99999 Then ' Test2 = 0 ' End If Loop '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- 'Sprungmarken '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- Timer0_isr: 'Timer1-Interruptroutine (312 x pro Sekunde) '------------------------------------------------------------------------------- Timer0 = Timervorgabe0 Gosub 7seganzeige 'Routine für 7 Segmentanzeige Incr Zeit 'Zeitgeber If S1 = 1 Then 'soll nur hochgezählt werden, wenn Taste links gedrückt Incr Taste_s1 'wenn taste lange gedrückt soll etwas passieren (LCD "e" wechsel) Else Taste_s1 = 0 End If Return '------------------------------------------------------------------------------- Timer1_isr: 'Timer1-Interruptroutine (3 x pro Sekunde) '------------------------------------------------------------------------------- Timer1 = Timervorgabe1 Analog_in0 = Getadc(0) 'Analog in Variable schreiben Wert = Analog_in0 - 500 'Wert für Anzeige If Wert < 0 Then 'wenn wert negativ Wert_pos = Wert * -1 Negativ = 1 Else Wert_pos = Wert Negativ = 0 End If 'Print "Digit0: " ; Digit0 'Print "Digit1: " ; Digit1 'Print "Digit2: " ; Digit2 'Print "Digit3: " ; Digit3 Return '------------------------------------------------------------------------------- Analog: 'Analogeingänge Auslesen: '------------------------------------------------------------------------------- 'Analog_in0 = Getadc(0) 'Analog in Variable schreiben ' Wert = Analog_in0 'Wert für Anzeige ' Pro1 = Analog_in0 - 204 'Prozent1Wert analog 204-1005 also -204 = 0-801 ' Pro2 = Pro1 * 0.12484 'Rechnen: 100% / max(801) = 0.12484 ' Pro3 = Round(pro2) ' If Pro3 > 100 Then 'damit keine größenren Werte als 100% auf dem LCD stehen ' Pro3 = 100 ' End If ' ' If Pro3 < 0 Or Pro3 > 110 Then 'wenn errechneter %Wert falsch (kleiner 0 oder größer 110 dann immer 0 (110 wegen 4-20mA Ungenauigkeit) ' Proz_anzeige = 0 ' Else ' Proz_anzeige = Pro3 ' End If '------------------------------------------------------------------------------- 7seganzeige: ' Code 7 Segmentanzeige: '------------------------------------------------------------------------------- 'Formatiere das Display Wertstr = Str(wert_pos) Fivedigitdisplay = Format(wertstr , "00000") 'Nullen geben die Anzahl der Stellen an, damit die Stellen richtig gesetzt werden ' jeder Lauf durch die Hauptschleife zeigt ein anderes Digit Incr Digit 'Waitms 6 'Zeit für die Anzeige (je länger wait desto mehr flackert es) Portb = 0 'Ghosting vermeiden If Digit = 5 Then 'mache das , bis 5 erreicht ist Digit = 0 End If ' addiere 1 zum Digitcounter, weil MID 1-basiert ist Y = Digit + 1 ' und hol das Digit, das wir brauchen Wertstr = Mid(fivedigitdisplay , Y , 1) 'Anzeige auswählen Tempbyte = 2 ^ Digit 'Tempbyte = 1,2,4,8,16 'Digitansteuerung auf portC: PC1-5 Umdreh = Tempbyte * 2 'Umdreh = 2,4,8,16,32 'Ansteuerung umdrehen für gemeinsame Anoden Portc = Umdreh 'Port für die Stellen auswahl 'Führende Nullen entfernen: 'INFO: 'wertstr hat immer nur eine Ziffer und wechselt also nacheinander alle 5 Stellen durch! 'wenn wertstr = 0 ist dann wird nachgesehen, in welchem Digit (Stelle) wir uns befinden. 'wenn Digit = 0 -also die ganz linke Stelle- dann auf jeden Fall Portc.1 = 0 (Transistor der Stelle) abschalten 'Digit0 = 0 -> ist nur ein Merker für die folgenden Stellen d.h. 'wenn wertstr=0 dann fragen ob Digit=1 (also 2te Stelle von links) UND der Merker Digit0=0 'dann Transistor abschalten und weiteren Merker für diese Stelle setzen 'ZehnTausenderstelle If Val(wertstr) = 0 Then 'Führende Null wegblenden If Wert => 0 Then 'Wert muss = > 0 sein wegem negativen Vorzeichen If Digit = 0 Then : Portc.1 = 0 : Digit_aus = 0 'C.1=Digit Transistor End If End If Else Digit_aus = 1 End If 'Tausenderstelle If Val(wertstr) = 0 Then 'Führende Null wegblenden If Digit = 1 And Digit_aus = 0 Then : Portc.2 = 0 : Digit_aus = 0 'C.2=Digit Transistor End If Else Digit_aus = 1 End If 'Hunderterstelle If Val(wertstr) = 0 Then 'Führende Null wegblenden If Digit = 2 And Digit_aus = 0 Then : Portc.3 = 0 : Digit_aus = 0 'C.3=Digit Transistor End If Else Digit_aus = 1 End If ''ENTFERNT WEIL MIT KOMMASTELLE UND DANN MUSS IN DER LETZTEN STELLE NE NULL STEHEN UND DARF NICHT AUSGEBLENDET WERDEN!!! ''Zehnerstelle 'If Val(wertstr) = 0 Then 'Führende Null wegblenden ' If Digit = 3 And Digit_aus = 0 Then : Portc.4 = 0 : Digit_aus = 0 'C.4=Digit Transistor ' End If ' Else ' Digit_aus = 1 'End If 'Dieser Teil erledigt die Wandlung in 7 Segment Code 'Für Anzeigen mit gemeinsamer Anode Select Case Val(wertstr) Case 0 : Portb = 126 'NULL Case 1 : Portb = 12 'EINS Case 2 : Portb = 182 'ZWEI Case 3 : Portb = 158 'DREI Case 4 : Portb = 204 'VIER Case 5 : Portb = 218 'FÜNF Case 6 : Portb = 250 'SECHS Case 7 : Portb = 14 'SIEBEN Case 8 : Portb = 254 'ACHT Case 9 : Portb = 222 'NEUN Case " " : Portb = 0 'Case Else : Portb = 128 'mittleres Segment Case Else : Portb = 226 '"F" End Select 'Minusvorzeichen If Digit = 0 And Negativ = 1 Then Portb = 128 'mittleres Segment End If 'Komma setzen 'If Portc = 2 Then Portb.0 = 1 '4 Kommastellen 'If Portc = 4 Then Portb.0 = 1 '3 Kommastellen 'If Portc = 8 Then Portb.0 = 1 '2 Kommastellen If Portc = 16 Then Portb.0 = 1 '1 Kommastelle 'negatives Vorzeichen setzen If Portc = 2 Then 'wenn Pin gem. Anode ganz linke Stelle gesetzt If Wert < 0 Then 'wenn Wert kleiner 0 Portb = 128 'Binär 1000 0000 -> Dezimal = 128 (nur Segment G) End If End If '------------------------------------------------------------------------------- Anzeige1: '------------------------------------------------------------------------------- Return '------------------------------------------------------------------------------- Anzeige2: '------------------------------------------------------------------------------- Return '------------------------------------------------------------------------------- Anzeige3: '------------------------------------------------------------------------------- Return
...
Hi,
so gehts nicht, Du musst es so machen wie ich angefangen habe, nicht nur einfach die eine Zeile dazubauen !
Also bei allen Zeile die "" mit dazu, und das Val() bei Select weglassen, dann gehts.
Hi,
ja, nunn funktioniert es einwandfrei und der gesamt code ist viel kürzer dadurch, dass die Segmente einfach abgeschaltet werdenDer Code mit den negativen Zahlen funktioniert auch
Aber eine Frage hab ich natürlich:
Welchen Bereich hat eine Single / Double Variable? von bis und wieviele kommastellen?
Der µC mach rundungsfehler: es müsste eigendlich 2,0488.... sein und in der Single steht wohl nur 2,05 obwohl ich das gar nicht gerundet habe....
Tobias
...
Hi,
Zu Datentypen findet sich was in der Bascom-Hilfe:
http://avrhelp.mcselec.com/language_fundamentals.htm -> Data Types
Der AVR ist nur für Ganzzahlen ausgelegt, alles andere muss Softwaremässig gemacht werden, was die Programmgrösse schnell ansteigen lässt, was schlecht ist, wenn es um Performance geht.
Danke,
da steht zwar nichts von den Nachkommastellen aber dafür weiß ich nun wieviele Stellen die Variable hat.
Wie ich auf die Kommastellen gekommen bin:
Der Wert auf der Anzeige wird "falsch" angezeigt - zumindest wenn ich das mit Excel vergleiche: hab das nachgerechnet weil Excel einen glatten Wert errechnet hat (1111). Aber die Abweichung ist in Wirklichkeit MINIMAL! Excel sagt als Ergebnis 1111,0 und der µC hat 1110,99991. Anscheinend rechnet der µC "nur" mit 7nachkommastellen... Mal sehen, wenn der µC zu langsam wird rechne ich alles *1000 oder so um das Komma weg zubekommen (und weniger Leistung zu verschwenden)
Tobias
PS. hier noch mal der Komplette funktionierende Code falls jemand Interesse hat
Code:'7 Segmentanzeige im multiplexbetrieb mit Analogeingang ' für die Anzeige wird ein kompletter Port (0-7 = 7Seg+DP) benötigt ' für Anzeigen mit gemeinsamer Anode ' ' Anschlüsse: ' 7 Segmente = PB 0 - PB 7 (PB0=DP) ' 4 Anzeigen = PC 4 - PC 1 (4 Anzeigen) ' 5 Anzeigen = PC 5 - PC 1 (5 Anzeigen) PC5 = Einerstelle ganz rechts!!!! ' ' '------------------------------------------------------------------------------- $regfile = "m8def.dat" 'AT-Mega8 $crystal = 8000000 'Quarz: 8 MHz '------------------------------------------------------------------------------- 'Konfiguration Ein- / Ausgänge Ddrb = &B11111111 '1 Ausgang, 0 Eingang => Pin PB7-0 als Ausgang Ddrc = &B1111110 '1 Ausgang, 0 Eingang => Pin PC6-1 als Ausgang; 0 als Eingang Ddrd = &B11110001 '1 Ausgang, 0 Eingang => Pin PD7-4,0 als Ausgang; 1-3 als Eingang '------------------------------------------------------------------------------- 'Konfiguration LCD Config Lcd = 16 * 2 Config Lcdpin = Pin , Db4 = Portd.4 , Db5 = Portd.5 , Db6 = Portd.6 , Db7 = Portd.7 , E = Portd.0 , Rs = Portc.6 Cursor Off Noblink '------------------------------------------------------------------------------- 'Konfiguration ADC Config Adc = Single , Prescaler = Auto , Reference = Avcc '------------------------------------------------------------------------------- 'Konfiguration Timer0 Config Timer0 = Timer , Prescale = 1024 On Timer0 Timer0_isr Const Timervorgabe0 = 245 '230 '312 mal / Sekunde!!! Enable Timer0 Enable Interrupts '------------------------------------------------------------------------------- 'Konfiguration Timer1 Config Timer1 = Timer , Prescale = 256 On Timer1 Timer1_isr Const Timervorgabe1 = 55118 '3 mal / Sekunde!!! Enable Timer1 Enable Interrupts '------------------------------------------------------------------------------- 'Variablen Anzeige: Dim Anfangswert As Long 'Anfangswert vom Benutzer Dim Endwert As Long 'Endwert vom Benutzer Dim Differenz As Long 'Endwert - Anfangswert Dim Zergebnis_1 As Single 'Zwischenergebnis 1 Dim Zergebnis_2 As Single 'Zwischenergebnis 2 Dim Zergebnis_3 As Single 'Zwischenergebnis 2 Dim Wert As Long ' (-2147483648 bis 2147483647) Dim Wert_pos As Long 'gewandelter wert Dim Negativ As Bit 'Merker = 1 wnn Wert negativ! ' variablen für die display routine Dim Wertstr As String * 5 Dim Y As Byte Dim Tempbyte As Byte ' Variable für Digitansteuerung Dim Digit As Byte 'Anzeige im Ganzen Dim Fivedigitdisplay As String * 5 'führende Nullen entfernen Dim Digit_aus As Bit 'Merker =0 wenn Stelle =0 'ADC Dim Analog_in0 As Word 'Word '=0-1023 vom Analogeingang Dim Pro1 As Integer Dim Pro2 As Single Dim Pro3 As Integer Dim Proz_anzeige As Byte 'Variablen LCD Dim Ani_1 As Integer 'Zähler für Startannimation LCD Dim Ende As Word 'zum Animation beenden 'Variablen Taster Dim S1 As Bit 'Schalter 1 Dim S2 As Bit 'Schalter 2 Dim S2_m As Bit Dim S3 As Bit 'Schalter 3 Dim S3_m As Bit 'Schalter 3 MERKER Dim Taste_s1 As Word 'Programmverteilung über Timer0 Dim Zeit As Word 'wird 312 mal / Sekunde mit 1 addiert 'Variablen zum testen...... Dim Test2 As Integer 'zum hochzählen zum testen Dim Test As Integer '------------------------------------------------------------------------------- 'Annimation LCD Goto Sprung Do Cls For Ani_1 = 16 To 1 Step -1 'Von 1 bis 16 wird gezählt Locate 1 , Ani_1 'Die entsprechende Position im Display anwählen. Lcd "> TOBIAS BLOME <" Waitms 250 Next Locate 2 , 1 Lcd "BI - EMR 10/2008" Waitms 500 Locate 2 , 1 Lcd " " Waitms 500 Locate 2 , 1 Lcd "BI - EMR 10/2008" Waitms 500 Locate 2 , 1 Lcd " " Waitms 500 Locate 2 , 1 Lcd "BI - EMR 10/2008" Wait 3 Loop Until Ende => 1 Sprung: '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- 'Setzen: Digit_aus = 0 'alle Segmente aus Portb = 0 Digit = 0 'Benutzerangaben: Anfangswert = -987 'Anfangswert vom Benutzer Endwert = 1111 'Endwert vom Benutzer Start Adc Do '---Programm aufteilen--- If Zeit => 150 Then 'also eine halbe Sekunde Zeit = 0 'Zeit zurücksetzen End If '---ENDE Programmaufteilung--- Loop '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- 'Sprungmarken '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- '------------------------------------------------------------------------------- Timer0_isr: 'Timer1-Interruptroutine (312 x pro Sekunde) '------------------------------------------------------------------------------- Timer0 = Timervorgabe0 Gosub 7seganzeige 'Routine für 7 Segmentanzeige Incr Zeit 'Zeitgeber If S1 = 0 Then 'soll nur hochgezählt werden, wenn Taste links gedrückt Incr Taste_s1 'wenn taste lange gedrückt soll etwas passieren (LCD "e" wechsel) Else Taste_s1 = 0 End If Return '------------------------------------------------------------------------------- Timer1_isr: 'Timer1-Interruptroutine (3 x pro Sekunde) '------------------------------------------------------------------------------- Timer1 = Timervorgabe1 Gosub Analog 'gosub springt zurück! Return '------------------------------------------------------------------------------- Analog: 'Analogeingänge Auslesen: '------------------------------------------------------------------------------- Analog_in0 = Getadc(0) 'Analog in Variable schreiben 'Analogwert umrechnen: FORMEL = Anfangswert+(Analogeingang*((Endwert-Anfangswert)/1023)) Differenz = Endwert - Anfangswert Zergebnis_1 = Differenz / 1023 Zergebnis_2 = Analog_in0 * Zergebnis_1 Zergebnis_3 = Anfangswert + Zergebnis_2 Wert = Zergebnis_3 * 10 'damit bei einer Kommastelle auch eine RICHTIGE Kommastelle ist! If Wert < 0 Then 'wenn wert negativ Wert_pos = Wert * -1 Negativ = 1 Else Wert_pos = Wert Negativ = 0 End If Return '------------------------------------------------------------------------------- 7seganzeige: ' Code 7 Segmentanzeige: '------------------------------------------------------------------------------- 'Formatiere das Display Wertstr = Str(wert_pos) Fivedigitdisplay = Format(wertstr , " 00") 'Nullen geben die Anzahl der Stellen an, damit die Stellen richtig gesetzt werden ' jeder Lauf durch die Hauptschleife zeigt ein anderes Digit Incr Digit Portb = 0 'Ghosting vermeiden If Digit = 5 Then 'mache das , bis 5 erreicht ist Digit = 0 End If ' addiere 1 zum Digitcounter, weil MID 1-basiert ist Y = Digit + 1 ' und hol das Digit, das wir brauchen Wertstr = Mid(fivedigitdisplay , Y , 1) 'Anzeige auswählen Tempbyte = 2 ^ Digit 'Tempbyte = 1,2,4,8,16 'Digitansteuerung auf portC: PC1-5 Portc = Tempbyte * 2 'Umdreh = 2,4,8,16,32 'Führende Nullen entfernen: 'Dieser Teil erledigt die Wandlung in 7 Segment Code 'Für Anzeigen mit gemeinsamer Anode Select Case Wertstr Case "0" : Portb = 126 'NULL Case "1" : Portb = 12 'EINS Case "2" : Portb = 182 'ZWEI Case "3" : Portb = 158 'DREI Case "4" : Portb = 204 'VIER Case "5" : Portb = 218 'FÜNF Case "6" : Portb = 250 'SECHS Case "7" : Portb = 14 'SIEBEN Case "8" : Portb = 254 'ACHT Case "9" : Portb = 222 'NEUN Case " " : Portb = 0 'nichts - kein Segment 'Case Else : Portb = 128 'mittleres Segment Case Else : Portb = 226 '"F" End Select 'Komma setzen 'If Portc = 2 Then Portb.0 = 1 '4 Kommastellen 'If Portc = 4 Then Portb.0 = 1 '3 Kommastellen 'If Portc = 8 Then Portb.0 = 1 '2 Kommastellen If Portc = 16 Then Portb.0 = 1 '1 Kommastelle 'negatives Vorzeichen setzen / Minus If Portc = 2 Then 'wenn Pin gem. Anode ganz linke Stelle gesetzt If Wert < 0 Then 'wenn Wert kleiner 0 Portb = 128 'Binär 1000 0000 -> Dezimal = 128 (nur Segment G) End If End If
...
Nachkommastellen alleine kann man schlecht angeben, das hängt davon ab wieviel Vorkommastellen man schon verbraucht hat.
und was heiß das genau, wenn ich schon 6 vorkommastellen der Single "verbraucht" habe?
...
Lesezeichen