Forum: Mikrocontroller und Digitale Elektronik PIC18F2550 und MLX90614 IR Sensor assembler


von Timothy B. (timothy_b)


Angehängte Dateien:

Lesenswert?

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.

von Max H. (hartl192)


Lesenswert?

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
von Timothy B. (timothy_b)


Lesenswert?

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
Noch kein Account? Hier anmelden.