Artikel pedia
| Home | Kontakt | Artikel einreichen | Oberseite 50 artikel | Oberseite 50 autors
 
 


Artikel kategorien
Letztes fugte hinzu
    Ms-access

   Instrumentation + schnittstellen

   Pc tuning - volle kraft voraus für ihr system

   Informatorische grundlagen

   Javascript

   Interne sortieralgorithmen - der kern der sache

   Plotter und sonstige drucker

   Frage 20 (rössl priska)

   Internet - programmierung

   Monitore

   Semesterarbeit und spezialgebiet für informatik

   Erörterungs zum thema

   Inhaltsverzeichnis

   Einführung in die entwicklung ganzheitlicher informationssysteme:

   Titel dokument
alle kategorien

  Semesterbericht

        Semesterbericht Hardware/Software 3. Semester Jahrgang 1996  Thema: Programmentwurf eines Mikrocontrollergesteuerten Hochregalroboters   .....

......

......

......

......

......

....   ..

......

......

......

......

......

......

. Stempel Firma   Datum Ausbildungsleiter Datum Betreuer             .....

......

......

......

......

......

....   ..

......

......

......

......

......

......

. Stempel Berufsakademie Datum Prüfungsausschuß Datum Prüfungsausschuß               Inhaltsverzeichnis                     1. EINFÜHRUNG 3 1.1. Formelle Aufgabenstellung für die gesamte Gruppe 3 1.2.

Organisatorisches Umfeld 3 1.3. Aufgabenstellung Programmausarbeitung 3 2. GRUNDLAGEN 4 2.1. Speicherverwaltung 4 2.

2. Spezialfunktionsregister (SFR) 4 2.3. Übersicht über die Maschinenbefehle 5 2.3.1.

Arithmetische Befehle 5 2.3.2. Logische Befehle 5 2.3.3.

Datentransferbefehle 5 2.3.4. Boolsche Befehle 5 2.3.5.

Bedingte und unbedingte Sprünge 5 2.4. Assemblerfunktionen 5 2.5. Programmierung der Peripherie 6 2.5.

1. Ansteuerung der Tastatur 6 2.5.2. Ansteuerung des Displays 6 2.5.

3. Motorsteuerung: 6 2.5.4. Serielle Schnittstelle zum PC 7 3. REALISIERUNG / IMPLEMENTIERUNG 7 3.

1. Allgemeines 7 3.2. Befehlsbibleothek 7 3.2.1.

Display: 7 3.2.2. Tastatur: 8 3.2.3.

Motorsteuerung: 8 3.2.4. Serielle Schnittstelle zum PC 8 3.3. Hauptprogramm des Hochregalroboters 9 3.

3.1. Bedienung 9 3.3.2. Programmroutinen des Hauptprogrammes 10           Anhänge:   Quellennachweis Listings motor.

mak (auf Diskette) system.mak roboter.a51 Einführung  Die Hardware-Semesterarbeit besteht aus der Aufgabe, einen mikrocontrollergesteuerten Hochregalroboter zu fertigen. Hierfür stand der ELVamat Baukasten zur Verfügung, der neben drei Schrittmotoren auch diverse mechanische Teile zum Bau von verschiedenen “Robotern” beinhaltet. Die Basis ist ein Mikrocontrollersystem auf der Basis des Intel 87C52. Die Software zum Betrieb des Roboters wird in Assembler geschrieben und in einem EPROM abgelegt.

An dieses System angeschlossen sind eine I/O-Baugruppe, die Tastatur, das Display und eine Motoransteuerung, die einen Logikteil und die Treiberstufen enthält. In dieser Dokumentation wird näher auf die Programmausarbeitung eingegangen.   Formelle Aufgabenstellung für die gesamte Gruppe Aufgabe: Hochregalroboter Teilnehmer: Michael Kuß, Thomas Jüngel, Matthias Buchhorn, Andreas Spiller Zeitraum: 8 Wochen  Mit dem ELVamat Baukasten wird ein Hochregalroboter gebaut, der Gegenstände in ein Hochregallager ein-, aus- und umlagern kann. Die Steuerung erfolgt über eine Mikrocontrollerbaugruppe. Die gesamte Steuerung erfolgt durch ein Assemblerprogramm, das auf der Mikrocontrollerbaugruppe in einem EPROM gespeichert ist. Die Hardware teilt sich in die drei folgenden Teilbereiche: Logik &Treiber, Ein- und Ausgabeeinheit und Mikrocontrollerbaugruppe.

Die Steuerung des Roboters erfolgt über die Tastatur, die Eingaben können auf dem Display überprüft werden. Die Mikrocontrollerbaugruppe verarbeitet die Eingaben und gibt die Signale für die Schrittmotorsteuerung.Der Funktionsnachweis ist zu führen. Das fertige Projekt wird mit einer kompletten Dokumentation präsentiert     Organisatorisches Umfeld                                 Aufgabenstellung Programmausarbeitung Grundlage für alle weiteren Programme sind zwei Befehlsbibliotheken, welche alle elementaren Funktionen in sich vereinigt und somit erst ein effizienteres Programmieren ermöglicht. Die Bibliothek “system.mak” soll alle Funktionen zum Ansteuern der Tastatur und des Displays beinhalten.

Desweiteren stellt die Bibliothek “motor.mak” alle Funktionen zum Steuern der Schrittmotoren bereit. Es gibt mehrere Möglichkeiten zum Ansteuern der Motoren, sei es vom PC aus, über eine seriellen Schnittstelle , manuell oder automatisch mit den Mikrocontroller. Das Hauptprogramm bedient sich dieser Funktionen und erfüllt folgende Aufgaben: Gegenstand aus dem Fach nehmen Gegenstand in das Fach legen Steuerung über PC manuelle Steuerung des Roboters über die Cursortasten Hilfe Der Benutzer sollte mit einer möglichst intuitive und einer rasch erlernbare Bedienoberfläche arbeiten. Grundlagen Speicherbelegungstabelle 4 Registerbänke, Stackpointer Tastatur Daten zum Display Befehle zum Display 4001h 4000h 4002h C000h Motorsteuerung Speichervariablen Interrupts 00h 80h RAM extern ROM extern Spezialfunktionsregister RAM intern Programmeinsprungadresse  00h Speicherverwaltung Alle Bausteine der MCS-51 Familie haben einen getrennten Adreßbereich für Programm- und Datenspeicher von jeweils maximal 64 KByte Größe. Die CPU holt sich, die für die Abarbeitung von Programmen nötigen Befehlen aus dem Programmspeicher (EEPROM), Speichervariablen werden jedoch in den Datenspeicher abgelegt bzw.


ausgelesen. Bei einem Zugriff auf die RAM-Bausteine wird die Leseleitung (\RD) angesprochen, sobald Befehle vom Programmspeicher angefordert werden, wird die Programmspeicherfreigabeleitung (\PSEN) aktiviert. Die Funktionen des Mikrocontrollers schalten selbstständig die Steuerleitungen frei, so das dieser Vorgang beim Programmieren transparent bleibt. Die Software des Mikrocontrollersystems wurde am PC, mit einem sogenannten Cross-Assembler entwickelt. Dieses kleine MS-DOS Programm wandelt den Assemblercode in einen funktionstüchtigen Maschinencode um. Diese Datei mit der Endung <bin> wird mit Hilfe einer Eprom-Brenner-Software in den Eprom geschrieben.

Der Umfang der Assemblerbefehle ist sehr umfangreich. Der Mikrocontroller verfügt über 256 Befehle und ein komfortables Spezialfunktionsregister. Mit Hilfe dieser Mnemonik läßt sich der Speicher auf zwei Arten adressieren. Bei der direkten Adressierung wird der Operand mit einer 8-Bit Adresse verknüpft, somit kann nur das interne RAM und die Spezialregister angesprochen werden. Bei der indirekten Adressierung wird der Befehl mit einem Adreßregister verknüpft. Nur die 8 Bit R0/R1 Register und das 16 Bit Datenpointregister beinhalten die Adresse des Operanden.

Ein Adreßregister wird durch das Zeichen @ gekennzeichnet. Es existieren vier Registerbänke, jede dieser Registerbänke besitzen acht Register, somit kann mit dieser Adressierungsmethode auf die ersten vierundzwanzig RAM-Plätze zugegriffen werden. Der Zugriff auf dieses 8 Bit Register wird durch die Registerbefehle R0-R7 vereinfacht. Die Registerbänke werden mit dem 3. und 4. Bit des Programmstatuswortes angesprochen.

Weiterhin besteht die Möglichkeit Konstanten, mit dem DB-Befehl zu vereinbaren. Die Interrupts beginnen nach der Programmeinsprungadresse auf der Adresse 0003 und weitere Interrupts folgen im Abstand von 8 Bytes. Interrupts sind z.B. Externer Interrupt 0, Timer 0, Externer Interrupt 1, Timer 1, serieller Port Interrupt und Timer 2.   Spezialfunktionsregister (SFR) Im oberen Datenspeicher befindet sich im Bereich der Adresse 80-FF die Spezialfunktionsregister (SFR) die weitere umfangreiche Funktionen bieten : SFR Code Beschreibung Akkumulator Acc Bei Operationen der ALU wird dieses Register benutzt.

B Register B Wird bei der Division und Multiplikation benutzt. Programmstatuswort P Das Flagregister bietet folgende Informationen: CY - Carry Flag AC - Hilfscarryflag F0 - freies Flag RS1,RS2 - Registerbänke OV - Überlaufflag P - Parityflag Stackpointer SP Durch Beschreiben dieses Registers legt man den Stack an eine andere Stelle des Speichers.(default=07) Datenpointer DPL, DPH, (DPTR) Der 16-Bit Datenpointer teilt sich in Low und Highbyte. Damit ist eine Adressierung bis zu 64k Byte möglich. Ports 0-3 P0, P1, P2, P3 Ports können eingelesen bzw. beschrieben werden.

serieller Datenbuffer SBUF Besteht aus zwei getrennten 8-Bit-Registern. Beim Lesen wird der Empfangspuffer, beim Schreiben der Sendepuffer angespochen. Timer TL0, TL1, TH0, TH1 Diese Register stehen für die beiden 16-Bit Timer-register. Kontrollregister PCON, TCON, TMOD, SCON, IE, IP Diese Register dienen zum Steuern der Timer und Interrupts. Übersicht über die Maschinenbefehle Arithmetische Befehle Die arithmetischen Befehle kennzeichnen einfache mathematische Befehle wie Addieren, Subtrahieren, Multiplizieren, Dividieren und Erhöhen bzw. Erniedrigen eines Wertes.

Für Berechnungen dieser Art verwendet die ALU (arithmetic logic unit) den Akkumulator und das B-Register. Die Funktionen ADD,SUBB, INC und DEC setzt beim Überschreiten von 0ffh bzw. Unterschreiten von 0 das Übertragsflag. Die Befehle ADDC und SUBB beziehen das Übertragflag in die Berechnung mit ein. So können größere Zahlen addiert bzw. subtrahiert werden.

Eine Möglichkeit, zwei Zahlen nach Größe zu vergleichen, ist z.b. das Subtrahieren zweier Zahlen und das Auswerten des Übertragflags. Nach jeder BCD-Addition muß der DA A-Befehl zur Korrektur ausgeführt werden. Logische Befehle Die logischen Befehle bieten verschiedenste Verknüpfungsmethoden zwischen zwei Bytes. Logikbefehle sind AND(ANL), OR(ORL), XOR(XRL), NOT(CPL).

Weiterhin bietet der Mikrocontroller Befehle wie Rotate(RR,RL), Swap(SWAP), Clear(CRL). Die Rotatefunktion schiebt die 8 Bit des Akumulators nach rechts oder links. Damit läßt sich z.b. ein schnelles Multiplizieren mit einer Zweierpotenz gewährleisten. XOR-Logik wird auch dazu verwendet zwei Werte zu vergleichen.

Sind beide Werte identisch, so ist der Akkumulator null und kann mit dem bedingten Sprungbefehl JZ ( jump zero) und JNZ (jump not zero) ausgewertet werden. Datentransferbefehle Die Datentransferbefehle MOVX und MOVC greifen auf den externen Speicherbereich der RAM- bzw. der ROM-Bausteine zu. Der MOV-Befehl kann nur auf internen Speicher zugreifen, somit können Register, Spezialfunktionsregister und Variablen bearbeitet werden. Alle Datentransferbefehle verschieben 8 oder 16 Bit große Datenpakete zu beliebigen Zielen. Interrupts und Subprozeduren unterbrechen den Ablauf des Hauptprogrammes, um deshalb wieder in den normalen Programmablauf zurückzukehren, werden alle Registerinhalte mit Pop in den Stack gesichert und nach Beenden der Routine mit Push wiederhergestellt.

Boolsche Befehle Mit Hilfe von boolschen Befehlen ist die Verknüpfung von einzelnen Bits möglich. Alle logischen Befehle arbeiten auch mit Bits. Weiterhin bietet der Mikrocontroller bedingte Sprungbefehle, welche den Zustand der Bits auswerten und einen Sprung an einer relativen Programmadresse veranlassen. Die Carry-Flag-Befehle spielen ein große Rolle, da sie den Übertrag bei Addition, Subtraktion, Inkrement- oder Dekrementierung registrieren. Bedingte und unbedingte Sprünge Ohne bedingte und unbedingte Sprünge ist nur eine sequenzielle Abarbeitung des Programmes möglich. Sprünge erlauben erst das Arbeiten mit Unterprogrammen, Subroutinen und Interrupts.

Prozeduren werden mit <Call Name> aufgerufen. Die vorherige Adresse wird auf den Stack abgelegt und es wird zu der Adresse des Unterprogrammes gesprungen. Mit dem RET -Befehl wird die alte Adresse vom Stack gelesen und so zum Hauptprogramm zurückgekehrt. Mit einer einfachen Konstruktion < loop: ...

CJNE zähler,loop> erhält man eine funktionierende Schleife. Der CJNE-Befehl ist ein bedingter Sprung, der ähnlich wie die repeat-until Schleife funktioniert.   Assemblerfunktionen Der verwendete MCS-51 Assembler besitzt über die einfache Mnemonik hinaus, Kontrollstrukturen, Verwaltung von Variabeln und Labels. Konstanten werden im Programmspeicher abgelegt Es können 8-Bit große Zahlen mit dem Befehl DB abgelegt werden, 16-Bit große Zahlen werden mit der DW-Anweisung im ROM deklariert. Mit der ORG-Anweisung wird eine absolute Adresse festgelegt. Diese Anweisung wird z.

b. für die Programmeinsprungsadresse und der Speicheradresse der Konstanten verwendet. Die Registerbänke werden mit der Funktion USING <Bank> umgeschaltet. Variablen können als unterschiedlichste Typen definiert werden. Die CODE-Anweisung definiert die Varible als ROM-Adresse. DATA, IDATA, XDATA definiert sie als direkte, indirekte bzw.

externe RAM-Adresse. Bitadressen werden mit Befehl BIT festgelegt. Das Arbeiten mit Bibliotheken macht den Quellcode übersichtlicher und portabler. Deshalb bietet der Assembler die Möglichkeit eine oder mehrere externe Programmdateien in das Hauptprogramm, mit der $INCLUDE(<NAME>)-Anweisung, einzubinden. Die IF-ELSE-ENDIF Struktur vergleicht eine Varible mit null . Liefert das Ergebnis den Wert true so werden die Anweisungen nach dem IF ausgeführt, ansonsten werden die Anweisungen nach dem ENDIF ausgeführt.

Die Kontrollstruktur wird mit der ENDIF-Anweisung abgeschlossen. Das Programm wird mit der END-Anweisung beendet. Vordefinierte Variblen sind vor allem die Spezialfunktionsregister. Eine Ausführliche Beschreibung lesen Sie bitte weiter oben.  Programmierung der Peripherie Ansteuerung der Tastatur  Es wird eine 3x4 Tastaturmatrix verwendet. Die Tastaturinformation liegt an Adresse 04000h.

Der eingelesende Wert wird in ASCII -Code umgewandelt: Wert ASCII-Code Wert ASCII-Code 6Fh 30 - ‘0’ F5h 36 - ‘6’ DEh 31 - ‘1’ DBh 37 - ’7’ 7Eh 32 - ‘2’ 7Bh 38 - ‘8’ F6h 33 - ‘3’ F3h 39 - ‘9’ DDh 34 - ‘4’ CFh 20- ‘ ’ <Cancel> 7Dh 35 - ‘5’ E7h A0- ‘ ’ <Enter> Ansteuerung des Displays  Ist das 1./2. und 9.Bit des Adressbytes gesetzt, so wird das Display angesprochen.Das 2.Bit gibt an, ob es sich bei dem empfangende Byte um eine Date oder ein Befehl handelt.

Somit trägt die Befehlsadresse den Wert 4001h und die Datenadresse den Wert 4002h. Erklärung zum Befehlsbyte: Wert-binär Befehl Beschreibung 0000 0001 Clear Display löscht das Display und setzt den Cursor an Position 0 0000 001- Return Home setzt den Cursor an Position 0 0000 01xy Eintragemodus regelt die Richtung der Cursorbewegung (x) und das Displayshift (y) 0000 1xyz Display on/off schaltet Anzeige (x), Cursor (y) u. Cursorblinken (z) an/aus, 0001 xy-- Shift Bewegt den Cursor (x) und verschiebt die Anzeige (y) 001x yz-- Interface setzt Datenbreite(x), Zahl der Zeilen (y) und Größe des Zeichens (z) 01xx xxxx setzeBefehlsadr. alle nachfolgenden Daten gelangen in den gesetzten Charakter-RAM 1xxx xxxx setze Datenadr. alle nachfolgenden Daten gelangen in den gesetzten Daten-RAM xyyy yyyy lese Adr.&Busy setzt das Busy flag (x) und liest den Adreßzähler der Anzeige (x) Motorsteuerung: Die Hauptaufgabe besteht natürlich darin, den Hochregalroboter zu steuern.

Der Roboter kommuniziert über die Adresse C000h. Ließt der Microcontroller von dieser Adresse , wird der Zustand der Taster übermittelt. Mit einem Schreibbefehl werden die Motoren angesteuert. Es ist möglich, bis zu drei Bitfolgen miteinander zuverknüpfen, um so die Motoren gleichzeitig laufen zu lassen. So können Anfahrtswege mit einen Linienalgorithmus verkürzt werden. Der Breesenham-Algorithmus arbeitet nur mit Integerwerten und ist somit sehr schnell.

Es sind keine komplitzierten Realzahlberechnungen notwendig.   Bewegungsrichtung des Roboters horizontal vertikal Greifer vor 1111 1110=FEh 1111 1011=FBh 1110 1111=EFh zurück (init) 1111 1100=FCh 1111 0011=F3h 1100 1111=CFh   Taster in Bewegungsrichtung des Roboters Rückgabewert links FEh rechts FDh hoch/vor E7h runter/zurück EBh   Jeder Motor muß mit einer Linksdrehung initialisiert werden. Es genügt, wenn der Microcontroller ein Byte mit dem Wert 0h zur Motorsteuerung schickt. Die Wartezeit zwischen den Betrieb eines Motors sollte nicht 4,0 ms unterschreiten, da die Motoren bei kürzeren Signalzwischenzeiten nicht die nötige Kraft zum Bewegen des Roboters aufbringen können. Wird ein Taster gedrückt, muß der Motor in dieser Richtung gestoppt werden. Serielle Schnittstelle zum PC   Der Lagerroboter soll die Möglichkeit besitzen, über einen PC komfortabler gesteuert zu werden, dafür besitzt der Mircocontroller die Möglichkeit über serielle Ports mit anderen Prozessoren in Verbindung zu treten.

Auf dieser seriellen Schnittstelle können gleichzeitig Daten versendet und empfangen werden. Damit der Mircocontroller, der über den UART-Standart verfügt, mit einen PC kommunizieren kann, wird der Baustein MAX232 verwendet. Dieser wandelt die Logik von 0V/5V des UART-Standard in den RS-232-Standart mit der Logik von -12V/ +12V um. Der Ein- und Ausgang der seriellen Ports ist gebuffert. Die Empfangs- und Sendebuffer liegen zwar auf der selben Adresse (99h), sind aber physikalisch zwei verschiedene Register. Ein Schreibbefehl auf diese Adresse lenkt die Daten in das Senderegister, ein Lesebefehl holt die Daten aus den Empfangsregister.

Der serielle Port kann in vier Modi arbeiten. Sie werden über das SCON-Register gesetzt. Modi 2und 3 sind Multiprozessormodi und spielen in der Verständigung zwischen Prozessoren eine große Rolle, da simultane Datensendung und -empfang möglich ist. Modus 0 schiebt mit konstanten Geschwindigkeit die Bits mit Hilfe eines Schieberegisters über die serielle Schnittstelle, Modi 1 bis 3 arbeitet im üblichen UART/RS232-Format. Dieses Protokall arbeitet mit einem Startbit, acht (Modus 1) oder neun (Modi 2/3) Datenbits und einem oder zwei Stoppbits. Für die Anwendung des Hochregalroboters genügt Modus 1, da nie Daten gleichzeitig gesendet und empfangen werden müssen.

Außerdem arbeitet der Modus mit 8-bit Datenbits und die Baudrate ist beliebig, über das TH1-Register, einstellbar. Die Timer werden mit dem Register TMOD gesetzt, um eine konstante Baudrate zu erzeugen.      Realisierung / Implementierung   Allgemeines In der Testphase wurde der Eprom-Baustein mit einem Bootstrapprogramm beschrieben. Dieses 8K Byte große Programm liefert Debug-Informationen an den PC. Über die serielle Schnittstelle wird das Hochregalroboter-programm mit dem Programm Term95 auf das RAM geschrieben. Die Projektsoftware muß im Adressbereich 2000h-3FFFh organisiert werden, da hier der RAM-Bereich liegt.

Es wurde ein Shareware-Crossassembler benutzt, welcher über Internet bezogen wurde.   Befehlsbibleothek Die Befehlsbibleothek enthält elementare Funktionen zum Ansteuern des Displays, der Tastatur und des Roboters. Display: Zeichen ausgeben Befehl an das Display schicken Display initialisieren Display löschen Zeichenkette vom ROM lesen und auf Display ausgeben    Das Unterprogramm DISPLAY hat die Aufgabe den Buchstaben, welcher im Akkumulator liegt, auf dem Display anzuzeigen. Da das Display wie langsamer RAM-Speicher angesprochen wird, muß mit Hilfe des Busy-Signals auf das Display gewartet werden. Erst dann können die Daten an die Adresse E003 geschickt werden. DISPLAY_BEFEHL funktioniert ähnlich wie die Subroutine DISPLAY, hier wird jedoch ein Befehlsbyte zum Display, an die Adresse E001 gesendet.

Diese beiden Funktionen sind Grundlage für alle weiteren Displayfunktionen.Das Display wird in der Subroutine “DISPINI” initialiesiert. Der Display-Controller wird in den 2 Zeilenmodus-geschalten, der Bildschirm wird gelöscht, das automatische Weiterbewegen des Cursors wird angeschalten und als letzes wird der Cursor ausgestellt. Die Funktion “DISPCLR” löscht den Bildschirm. Die Funktion “CURSOR” ließt aus dem Akkumulator die Cursorposition. Die erste Position der Zeile 1 hat dem Wert 00h, die erste Position in Zeile 2 wird mit Cursorwert 40h aktiviert.

Mit dem Befehl DB können Daten und Zeichenketten ins ROM abgelegt werden. Die Subroutine “ROM2DISP” bedient sich desMaschienenbefehles MOVC, der diese Zeichenketten aus dem ROM ausliest. Eine Zeichenkette ist definiert als Menge von ASCII-Zeichen, die mit dem Byte 0 abgeschlossen wird. Das DPTR-Register enthält die Adresse des Strings und eine Anzahl von 256 Zeichen kann eingelesen werden. Tastatur: Taste einlesen Zeichenkette einlesen 2 Byte String in eine Dezimalzahl umwandeln Tastaturstatus übergeben  Als Eingabemedium wird eine 3x4 Tastaturmatrix verwendet. Die Tastatur schickt an die Adresse ein Byte, welches den momentanen Status der Tastatur zurückgibt.

Die Funktion “TASTE” ließt ein Zeichen von Tastatur, wandelt dieses Zeichen in ein ASCII-Zeichen um und legt diesen Wert in den Akkumulator ab. Die Tastaturmatrix muß über die Software entprellt werden. Das erledigt eine sehr kurze Warteschleife, danach wird noch ein Zeichen vom Eingabegerät gelesen und mit dem vorherigen Zeichen verglichen. Sind beide Zeichen gleich, hat ist die Taste immer noch gedrückt. Das Zeichen wird erst an das Hauptprogramm zurückgegeben, wenn der Benutzer die Taste losläßt. Die Subroutine “READLN” nutzt diese Funktion, um ein komplette Zeichenkette von der Tastatur zu lesen.

Die Eingabe wird mit dem Enterzeichen oder mit der maximalen Anzahl der Zeichen beendet. Mit der Cancel-Taste kann jederzeit die Eingabe abgebrochen werden. Mit dem Unterprogramm “STR2DEZ” kann eine mehrstellige Zahl, welche im ASCII-Code im Speicher liegt, in eine Dezimalzahl umgewandelt werden. Motorsteuerung: Drehe Motor automatische Motorsteuerung nach dem Linienalgorithmus von Breesenham manuelle Motorsteuerung PC-Steuerung Motorstatus ausgeben Die Subroutine DREH übermittelt den Akkumulatorinhalt an die Adresse C000h des Motors 96 mal hintereinander. Damit bewegt sich der Greifer um einen Millimeter. Zwischen den Motoraufrufen befindet sich eine Warteschleife von 4 ms.

Weiterhin ruft diese Routine die Funktion Motor_status auf. Es wird getestet, ob einer der Endtaster bereits betätigt ist. Ist dies der Fall, wird der Akkumulatorinhalt so modifiziert, daß sich der Greifer vom jeweiligen Endtaster wegbewegt. Die Ansteuerung der einzelnen Motoren ist weiter oben beim Themapunkt Grundlagen erklärt. Die Funktion “MOTOR” fährt automatisch von Position 0 zu einen angegebenen Fach und nimmt einen Gegenstand auf oder legt diesen ab. Der Funktion müssen zwei Werte übergeben werden.

Im Register R0 befindet sich die horizontale Position des Faches und im Register R1 wird die vertikale Position übergeben. Um die nötige Auflösung zu erhalten, werden die X- und Y-Koordinaten mit den Fachabständen multipliziert, daraus ergibt sich eine 16-Bit Information. Die Register R3,R5 sind die Lowbytes und die Register R4, R6 sind die High-Bytes der beiden Koordinaten. Mit den Anfangskoordinaten (0 , 0) und den Endkoordinaten bewegt der Roboter seinen Greifer auf einer Linie. Ein schneller Linienalgorithmus ist der Bresenham-Algorithmus. Beide 16-Bit Zahlen werden verglichen.

Ist der Anstieg in X größer als Anstieg in Y, wird der Programmteil “ABARBEITUNGX” aufgerufen, ist der Y-Anstieg jedoch größer, wird die Subroutine “ABARBEITUNGY” aufgerufen. Der Breesenham-Algorithmus funktioniert nun folgendermaßen. Der Roboter bewegt sich Schritt für Schritt auf der ausgewählten Achse und benutzt das 16-Bit Hilfsregister zum testen. Das Hilfsregister wird um den maximalen Achsenwert der kürzeren Seite erhöht. Das Hilfsregister wird mit der längeren Seite verglichen. Ist das Hilfsregister größer, wird der der Robotor vertikal und horizontal bewegt und das Hilfregister gelöscht, ansonsten wird der Roboter nur horzontal bewegt.

Die Prozedur “manuell_Steuern” fragt ständig den Tastaturstatus mit dem Befehl “Press” ab. Ist die Taste “cancel” gedrückt, wird aus dem Programm gesprungen und zum Hauptmenu zurückgekehrt. Die anderen Tasten werden weiter ausgewertet und in den Code der Motorsteuerung umgewandelt. Mit diesem Parameter, der im Akkumulator liegt, wird die Funktion “Dreh” aufgerufen. Die Cursorsteuerung bewegt den Greifer horizontal und Vertikal, Taste “0” und “Enter” bewegen den Greifer vor und zurück. Die Funktion “PC-Steuerung” wartet auf ein Zeichen von der Seriellen Schnittstelle.

Dieses Warten kann mit der Taste “Abbruch” beendet werden und der Benutzer kehrt zum Hauptprogramm zurück. Wird ein Wert vom PC empfangen, wertet der Mircocontroller dieses Byte aus, welches die Nummer der Funktion beinhaltet. Der Funktion müssen jedoch noch Parameter übergeben werden. Also wartet der Mircocontroller auf weitere Daten. Wenn alle notwendige Daten übermittelt wurden, wird die Funktion mit diesen Parametern gestartet. Ist die Funktion beendet schickt der Mircocomputer dem PC ein Signal , welches die Bereitschaft bekannt gibt, neue Befehle aufzunehmen.

Serielle Schnittstelle zum PC Die Prozeduren für die serielle Schnittstelle liegen in der Befehlsbibliothek “motor.mak” und ist unter PC-Steuerung zu finden. Die Register werden initialisiert. Der serielle Modus 1, 8 bit UART und 4800 Baud wird eingestellt und der Timer1 wird gestartet. Der Mircrocontroller wartet auf einen Datenbyte. Dieses Byte gibt an, wie der Roboter sich bewegt.

Der ASCII-Code der numerischen Tastatur übernimmt die Funktion der Steuerung. Nur die Tasten “+” und “-” varieren zum 3x4 Tastaturblock. Bei Betätigung dieser Tasten wird der Greifer vor und zurück bewegt. Wenn der auzuführende Prozess des Mircocontrollers beendet ist, schickt das Programm ein Zeichen zum PC. Damit gibt der Mircocontroller dem PC bekannt, daß er neue Befehlsdaten emfangen kann.   Hauptprogramm des Hochregalroboters Bedienung   Der Benutzer kann ohne Vorkennis den Roboter bedienen.

Dies ist durch eine intuitive Menusteuerung möglich:  HILFE STEUERN NEHMEN ABLEGEN             1 links/hoch 2 hoch 3 rechts/hoch 4 links 5 6 rechts 7 links/runter 8 runter 9 rechts/runter Abbruch 0 Greifer vor Bestätigen Greifer zurück  MANUELL STEUERN PC-STEUERUNG     Menüsteuerung im Programm des Hochregalroboters     Mehrfachbelegung der 3x4 Tastaturmatrix   Der jeweilige Menupunkt wird mit den Cursortasten ausgewählt und mit der Taste “Bestätigen” aktiviert. Der Punkt “Ablegen” fordert die Fachnummer vom Benutzer. Nach der Eingabe fährt der Roboter das gewünschte Fach an, legt den Gegenstand ab und kehrt zum Ausgangspunkt zurück. Der Menupunkt “Nehmen” fährt nach der Eingabe das gewünschte Fach an , nimmt den Gegenstand und kehrt zur Anfangsposition zurück. Der Benutzer hat weiterhin die Möglichkeit den Roboter manuell oder über einen Computer zu steuern. Der Menupunkt “Steuern” gibt ein Untermenu auf dem Display aus.

Dieses Menu hat die Auswahlmöglichkeiten “PC-Steuerung” und “manuell Steuern”. Der Mircocontroller besitzt die Möglichkeit mit einem Personalcomputer über die serielle Schnittstelle zu kommunizieren. Der PC sendet ein Befehlsbyte an den Mircocontroller, welcher den Roboter steuert. Der zweite Menupunkt ermöglicht es dem Benutzer den Hochregalroboter manuell zu steuert. Die Cursortasten bewegen den Greifer in horizontaler und vertikaler Richtung. Die Tasten “0” und “Enter” Bewegen den Greifer vor und zurück.

Mit den “Abbruch” Taste wird zum Hauptmenu zurückgesprungen. Mit dem Menupunkt “Hilfe” wird dem Benutzer eine kurze Hilfe in Form einer Scrollschrift gegeben. Mit der “Abbruch” Taste gelangt der Benutzer ins Hauptmenu zurück. Programmroutinen des Hauptprogrammes                           Programmablaufplan des Hauptprogrammes     Das Unterprogramm MENU gibt, nach der kurzen Information, ein Auswahlmenü auf dem Display aus. Das Auswahlmenü wird mit Hilfe des DB-Befehls in den EPROM abgelegt und mit der Subroutine ROM2DISP auf das Display geschrieben. Ein beliebiger Menupunkt kann mit den Cursortasten ausgewählt werden.

Die folgenden Zahlen stehen für Cursorbewegungen < 2-oben, 8-unten, 4-links, 6-rechts >. Mit der Funktion TASTE werden diese Zahlen eingelesen und mit der Entertaste (Zeichen 12) bestätigt. Die Varible Menu_status gibt die Cursorposition an. Die Funktion ABLEGEN ruft das Programm EINGABE auf. Die Funktion READLN ließt die Fachnummer ein. Die Zeichenkette wird mit STR2DEZ in die Nummer des Faches umgewandelt.

Diese Date wird mit Hilfe der Variable Fachx dividiert. Die Y-Koordinate steht nun im Akkumulator und die X-Koordinate liegt im B-Register. Diese Werte werden in das Register R0,R1 geschrieben und der Funktion “MOTOR” übergeben. Der Funktion wird weiterhin das Befehlsbit F0 übergeben. Ist dieses Bit gelöscht wird die Funktion Ablegen aktiviert. Das Unterprogramm NEHMEN arbeitet mit den gleichen Funktionen wie ABLEGEN.

Diese Funktion wird mit dem gesetzten Bit F0 aktiviert. Das Unterprogramm STEUERN ruft den Befehl ROM2DISP auf, um die Menupunkte auf den Bildschirm anzuzeigen. Der Benutzer hat die Möglichkeit zwischen den Menüpunkten PC-STEUERUNG, MANUELL STEUERN auszuwählen. Die Funktion Menu_Steuerung2 gibt den ausgewählten Menupunkt zum Hauptprogramm zurück. Die Funktion Menu_steuerung2 funktioniert nach dem Prinzip der Funktion Menu_steuerung. Das Unterprogramm PC-Steuerung ermöglicht die Kommunikation zwischen PC und Mircocontroller mit Hilfe der seriellen Schnittstelle.

Der zweite Menupunkt Manuell Steuern ermöglicht es dem Benutzer den Greifarm über die Cursortasten zu steuern. Mit der Funktion Press wird ständig der Tastaturstatus überprüft. Wird ein anderer Wert als FFh an das Hauptprogramm übergeben, wertet das Programm den Tastaturstatus aus. Je nach gedrückter Taste wird der Akkumulator mit den Wert der Motorsteuerung geladen und die Funktion Dreh aufgerufen. Dieses Programm schleift solange, bis die Taste “Abbruch” gedrückt wird. Der letzte Hauptmenupunkt HILFE schreibt eine Zeichenkette an die Cursorposition 040h.

Die Zeichenkette wird vorher im ROM mit dem DB-Befehl abgelegt. Es wird ein 16-Zeichen großer Ausschnitt vom kompletten String an Cursorposition 0 des Displays ausgegeben. Nach einer kurzen Warteschleife wird dieser Auschnitt, um zwei Zeichen nach links verschoben, wieder an Position 0 angezeigt. Der Tastaturstatus wird ständig mit der Funktion Press überprüft und solange die Laufschrift ausgegeben, bis die Taste “Abbruch” gedrückt wird. Quellnachweis :   Bücher  “8 bit-Einchip-Mikrocontroller” - Datenbuch Phillips - 1988 “Das Mikrocontroller Kochbuch”, “Das Mikrocontroller Applikations Kochbuch” - Andreas Roth IWT Thomson, Bonn 97   Internet   Suche im Worlwideweb: https://www.altavista.

digital.com FTP-Server : https://www.ftp-search.com Datenblätter und Tutorials im PDF, WORD und HTML Format. https:://www.hitex.

com https:://www.ece.orst.edu/Shareware-Crossassembler 1.2 : Copyright (c) 1994, 1996 by W.W.

Heinz

Suchen artikel im kategorien
Schlüsselwort
  
Kategorien
  
  
   Zusammenfassung Der Vorleser

   sachtextanalyse

   interpretation zwist

   Fabel interpretation

   literarische charakteristik

   interpretation bender heimkehr

   felix lateinbuch

   interpretation der taucher von schiller

   textbeschreibung

   charakterisierung eduard selicke
Anmerkungen:

* Name:

* Email:

URL:


* Diskussion: (NO HTML)




| impressum | datenschutz

© Copyright Artikelpedia.com