Guten Tag Habe ein kleines Problem mit meinem PIC18f2550. Weis einfach nicht wie ich die Temperatur berechnet bekomme die der MLX90614 Infrarotsensor in die 2 Register DataH:DataL schreibt. Ich weiß, dass ich das Ergebnis entweder mit 0,02 Multiplizieren muss oder durch 50 teilen. Im beispiel habe ich versucht erst mal mit 2 zu Multiplizieren, so habe ich die Möglichkeit die Nachkommastelle einfacher auf dem Display auszugeben. Wie im kleinen beispiel habe ich also versucht das das ganze mit dieser Formel zu rechnen: 256*DataH*2 + DataL*2 Leider steht dem PIC nur 8 bit Speicherplatz zur Verfügung und nun weiß ich nicht wie ich es hin bekomme diese 24Bit in einzelne Register zu speichern oder den zu benötigenden platz zu reservieren. Im Bilder wird kelvin mit 2 initialisiert und highB mit 256. Die 256 könnte man auch durch schieben ersetzen. Währe schön wenn mir jemand helfen könnte.
Timothy B. schrieb: > Leider steht dem PIC nur 8 bit Speicherplatz zur Verfügung Eine Speicherzelle hat 8 bit, da es mehr als eine davon gibt sind es viel mehr als 8 bit, bei deinem PIC 2048 mal 8 bit. > und nun weiß ich nicht wie ich es hin bekomme diese 24Bit in einzelne > Register zu speichern In einzelne Register geht das nicht, du musst du 3 8-bit Zellen verwenden. > oder den zu benötigenden platz zu reservieren. Das könnte z.B. so aussehen
1 | udata 0x20 ;oder welche Adresse auch immer |
2 | result res 3 |
3 | |
4 | ;.... |
5 | |
6 | ; reult = 256 * DataH + DataL |
7 | MOVFF DataH, result + 1 |
8 | MOVFF DataL, result |
9 | |
10 | ; result = result * 2 |
11 | CLRC |
12 | RLCF result, f, a/b ; abhängig von der Adress access (a) RAM oder banked (b) |
13 | RLCF result + 1, f, a/b |
14 | RLCF result + 2, f, a/n |
BTW: Quellcode kann man auch direkt im Text posten, da muss man keine jpg mit Kompressionsartefakten verwenden. Mit deinem Code wird das sowieso nichts, da du den MULWF befehl mMn nicht verstanden hast:
1 | MULWF Multiply W with f |
2 | |
3 | An unsigned multiplication is carried |
4 | out between the contents of W and the |
5 | register file location ‘f’. The 16-bit |
6 | result is stored in the PRODH:PRODL |
7 | register pair. PRODH contains the |
8 | high byte. Both W and ‘f’ are |
9 | unchanged. |
Und 256 ist in einer 8 bit Speicherzelle gleich 0.
:
Bearbeitet durch User
Danke für die Antwort ! Hat mir sehr weitergeholfen !. Ist eigentlich ganz einfach. Werde es heute ausprobieren.
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.