



## Cursor (Cur)

# Vorlesung Digitales Design (DiD)



**Orientierung:** Informatik und Kommunikationswissenschaften (ISC)

**Spezialisierung:** Data Engineering (DE)

**Kurs:** Digitales Design (DiD)

**Authoren:** Silvan Zahno, Axel Amand, François Corthay, Christophe Bianchi

**Datum:** 28.11.2025

**Version:** v3.1



# Inhalt

|                                    |    |
|------------------------------------|----|
| 1 Einführung .....                 | 3  |
| 2 Spezifikation .....              | 4  |
| 2.1 Funktionen .....               | 4  |
| 2.2 Schaltung .....                | 4  |
| 2.3 Szenario (Beispiel) .....      | 6  |
| 2.4 HDL-Designer Projekt .....     | 7  |
| 3 Komponenten .....                | 8  |
| 3.1 Schlitten .....                | 8  |
| 3.2 Motorsteuerungsschaltung ..... | 8  |
| 3.2.1 Gleichstrommotor .....       | 9  |
| 3.3 Encoder (Drehgeber) .....      | 10 |
| 3.4 Reed-Relais .....              | 10 |
| 3.5 FPGA-Platine .....             | 11 |
| 3.6 Knöpfe und LEDs .....          | 12 |
| 4 Bewertung .....                  | 13 |
| 5 Erste Schritte .....             | 14 |
| 5.1 Tips .....                     | 14 |
| Glossar .....                      | 15 |



# 1 | Einführung

Ziel dieses Projekts ist es, das erworbene Wissen anhand eines praktischen Beispiels am Ende des Semesters konkret anzuwenden. Es umfasst die Steuerung eines Gleichstrommotors, um einen Schlitten präzise entlang einer Gewindespindel zu vordefinierten Positionen zu bewegen. Dieses Positionierungssystem ist in der [Abbildung 1](#) dargestellt.



Abbildung 1 - Hardwareaufbau Cursor (EBS2)

Die Mindestspezifikationen (siehe [Abschnitt 2](#)) müssen erfüllt sein, aber die Studierenden werden ermutigt, zusätzliche Funktionen zu implementieren. Beispielsweise kann ein [Liquid Crystal Display \(LCD\)](#)-Bildschirm verwendet werden, um verschiedene Informationen anzuzeigen.



Durch die Implementierung zusätzlicher Funktionen können zusätzliche Punkte in der abschliessenden Bewertung erzielt werden.



## 2 | Spezifikation

### 2.1 Funktionen

Die Grundfunktionen sind wie folgt definiert:

- Wenn die Taste **restart** gedrückt wird, bewegt sich der Cursor zur Startposition, die durch ein Reed-Relais ([Abschnitt 3.4](#)) in der Nähe des Gleichstrommotors ([Abschnitt 3.2.1](#)) angezeigt wird.
- Wenn die Taste Position<sub>1</sub> gedrückt wird, muss der Cursor zuerst gleichmäßig zur Position 1 ( $p_1$ ) beschleunigen, dann mit voller Geschwindigkeit vorwärts fahren und schliesslich gleichmäßig abbremsen, um an Position 1 ( $p_1$ ) anzuhalten. Dies kann von der Startposition oder von Position 2 aus erfolgen, siehe [Abbildung 2](#).
- Wenn die Taste Position<sub>2</sub> gedrückt wird, muss der Cursor zuerst gleichmäßig zur Position 2 ( $p_2$ ) beschleunigen, dann mit voller Geschwindigkeit vorwärts fahren und schliesslich gleichmäßig abbremsen, um an Position 2 ( $p_2$ ) anzuhalten, siehe [Abbildung 2](#).



Abbildung 2 - Diagramm der Geschwindigkeit des Schlittens



Abbildung 3 - Cursor Schaltung

### 2.2 Schaltung

Der Schaltungsaufbau ist wie folgt:



- Der Gleichstrommotor ([Abschnitt 3.2.1](#)) wird durch die drei Signale  $\text{motorOn}$ ,  $\text{side}_1$ ,  $\text{side}_2$  gesteuert. Seine Geschwindigkeit wird durch eine **Pulse Width Modulation (PWM)** Modulation auf die Signale  $\text{side}_1$  oder  $\text{side}_2$  kontrolliert.
- Zwei Reed-Relais ([Abschnitt 3.4](#)) sind an den Enden der Schiene platziert [1]. Sie detektieren die Anwesenheit des Cursor-Schlittens ( $\text{sensor}_1$  sowie  $\text{sensor}_2$ ).
- Der Encoder ([Abschnitt 3.3](#)) wird verwendet, um die Position des Schlittens zu verfolgen, respektive zu zählen. Seine drei Ausgänge,  $\text{encoder}_A$ ,  $\text{encoder}_B$  und  $\text{encoder}_I$ , erlauben es die Bewegungen der Spindel zu verfolgen.
- Drei Tasten werden verwendet, um das System zu steuern:  $\text{restart}$ ,  $\text{go}_1$  und  $\text{go}_2$ . Eine zusätzliche Taste,  $\text{button}_4$ , kann für optionale Funktionen verwendet werden.
- Die  $\text{testOut}$  Pins können verwendet werden, um zusätzliche Informationen aus dem System herauszuführen, beispielsweise für Debugging oder zur Steuerung der **Light Emitting Diodes (LEDs)**.

Das leere Toplevel Design ([cursor-toplevel-empty.pdf](#)) zeigt alle Signale, die mit dem **Field Programmable Gate Array (FPGA)** Board verbunden sind [Abbildung 4](#).



Abbildung 4 - Leere Toplevel Schaltung



## 2.3 Szenario (Beispiel)

In [Abbildung 5](#) werden drei verschiedene Szenarien dargestellt. Zuerst wird die restart-Taste gedrückt und der Schlitten bewegt sich mit voller Geschwindigkeit zur Startposition (sensor<sub>1</sub>). Die beiden anderen Szenarien go<sub>2</sub> und go<sub>1</sub> bewegen den Schlitten zur position<sub>2</sub> und zur position<sub>1</sub> respektive, ein variables **PWM** Signal wird auf die Signale side<sub>2</sub> und side<sub>1</sub> angewendet, um den Schlitten zu beschleunigen und zu verlangsamen.



Abbildung 5 - Cursor Szenario



Die oben genannten Szenarien sind Beispiele, die von den Studierenden vervollständigt werden müssen.



## 2.4 HDL-Designer Projekt

Ein vordefiniertes HDL-Designer Projekt kann von [Cyberlearn](#) oder [Github](#) heruntergeladen oder geklont werden. Die Dateistruktur des Projekts sieht wie folgt aus:

```
did_cursor
+--Board/          # Project and files for programming the FPGA
|   +-concat/      # Complete VHDL file including PIN-UCF file
|   +-ise/          # Xilinx ISE project
+--Cursor/         # Library for the components of the student solution
+--Cursor_test/    # Library for the simulation testbenches
+--doc/            # Folder with additional documents relevant to the project
|   +-Board/        # All schematics of the hardware boards
|   +-Components/  # All data sheets of hardware components
+--img/             # Pictures
+--Libs/            # External libraries which can be used e.g. gates, io, sequential
+--Prefs/           # HDL-Designer settings
+--Scripts/         # HDL-Designer scripts
+--Simulation/     # Modelsim simulation files
```



Der Pfad des Projektordners darf keine Leerzeichen enthalten.



Im Projektordner **doc/** können viele wichtige Informationen gefunden werden. Datenblätter, Projektbewertung sowie Hilfsdokumente für HDL-Designer um nur einige zu nennen.



## 3 | Komponenten

Das System besteht aus 3 verschiedenen Hardwareplatinen, die in der [Abbildung 1](#) zu sehen sind.

- Ein Schlittenaufbau mit einer **Printed Circuit Board (PCB)**-Platine, die den Motor steuert und die Sensoren ausliest ([Abbildung 6](#))
- Eine **FPGA**-Entwicklungsplatine ([Abbildung 13](#) oder [Abbildung 14](#))
- Eine Steuerplatine mit 4 Tasten und 8 LEDs ([Abbildung 15](#))



Abbildung 6 - Cursor Schlittenaufbau

### 3.1 Schlitten

Der Schlittenaufbau beinhaltet den Gleichstrommotor, die beiden Reed-Relais [Abschnitt 3.4](#) sowie den Schlitten und die Spindel. Das Gewinde der Spindel hat eine Grösse von M12x1.75, was bedeutet, dass eine Distanz von 1.75mm pro Umdrehung zurückgelegt wird ([Abbildung 7](#)).



Abbildung 7 - Cursor Schlittenaufbau Detail

### 3.2 Motorsteuerungsschaltung

Der Gleichstrommotor des Wagens wird mit 12V versorgt. Die Stromversorgungsplatine besitzt eine H-Brücke, die durch digitale Signale gesteuert wird. Auf der Stromversorgungsplatine erzeugt ein 5V-Regler die richtige Spannung für die Versorgung der **FPGA**-Platine [2].



### 3.2.1 Gleichstrommotor

Der Gleichstrommotor wird von einem L6207 H-Brücken-Treiber [3] gesteuert, siehe Abbildung Abbildung 8. Die Maximale Schaltfrequenz der H-Brücke beträgt 100kHz. Dies sollte bei der Erstellung des PWM Signales in Betracht gezogen werden.



Abbildung 8 - H-Brücke L6207N Schaltung [3]

Um die Geschwindigkeit des Gleichstrommotors anzupassen, muss ein PWM-Signal an die  $\text{side}_1$  oder  $\text{side}_2$  Signale angelegt werden, wobei die maximale Frequenz 100kHz beträgt. Je länger die Spannung am Motor angelegt wird, desto schneller dreht er sich. In der Abbildung 9 dreht sich der Motor langsamer mit dem grünen Signal als mit dem blauen Signal und als mit dem roten Signal.



Abbildung 9 - PWM Signale



### 3.3 Encoder (Drehgeber)

Der Winkel der Spindel kann mithilfe eines **inkrementalen Drehgebers** gemessen werden. Das Modell, das im Aufbau verwendet wird, ist ein AEDB-9140-A12 [4] (Abbildung 11) mit 500 **Counts per Revolution (CPR)** (Impulse pro Umdrehung) pro Kanal, dargestellt in der Abbildung 10.



Abbildung 10 - Signale inkrementaler Drehgeber



Abbildung 11 - Encoder AEDB-9140-A12 [4]

Es ist möglich, ihn auf zwei Arten zu verwenden:

- Durch die Verwendung eines einzigen Kanals, was eine Auflösung von  $500 \frac{\text{Impulse}}{\text{Umdrehung}}$  ergibt.
- Durch die Verwendung beider Kanäle als **QEI (Quadrature Encoder Interface)**, indem die steigenden und fallenden Flanken beider Kanäle gezählt werden, wodurch die Auflösung auf  $2000 \frac{\text{Impulse}}{\text{Umdrehung}}$  erhöht wird. Diese Schnittstelle ermöglicht auch die Erkennung der Drehrichtung des Motors.

### 3.4 Reed-Relais

Das Reed-Relais ist ein Schalter, der mit Hilfe von Elektromagneten umgeschaltet werden kann [1]. Wenn sich ein Magnet in der Nähe des Sensors befindet, schliesst sich der Kontakt (Abbildung 12). Auf dem Modul werden 2 Reed-Relais verwendet ( $\text{sensor}_1$  und  $\text{sensor}_2$ ), um die linke und rechte Grenze des Schlittens zu identifizieren.



Abbildung 12 - Reed Schalter [5]



Die Signale  $\text{sensor}_1$  und  $\text{sensor}_2$  sind „1“, wenn der Kontakt geschlossen ist (Magnet in der Nähe), sonst „0“.

### 3.5 FPGA-Platine

Die Hauptplatine ist die FPGA-EBS 2 Laborentwicklungsplatine der Schule [6]. Diese beherbergt eine [Xilinx Spartan xc3s500e FPGA](#) [7], [8] und verfügt über viele verschiedene Schnittstellen ([Universal Asynchronous Receiver Transmitter \(UART\)](#), [Universal Serial Bus \(USB\)](#), Ethernet, etc.). Der benutzte Oszillator erstellt ein Taktsignal (**clock**) mit einer Frequenz von  $f_{\text{clk}} = 66\text{MHz}$  [9].



Abbildung 13 - [FPGA Platine](#) [6]

Auf der EBS3-Karte erzeugt der verwendete Oszillator ein Taktsignal (**clock**) mit einer Frequenz von  $f_{\text{clk}} = 100\text{MHz}$ , die durch PLL auf  $f_{\text{clk}} = 60\text{MHz}$  reduziert wird.



Abbildung 14 - [FPGA Platine](#) [10]



Die Simulators sind standardmässig für die EBS3 boards eingestellt. Um sie zu ändern, öffnen Sie einen Block von testbench **xxx\_tb** und doppelklicken Sie auf die **Pre-User**-Deklarationen (oben links auf der Seite), um die Variable **clockFrequency** auf den gewünschten clock-Wert zu ändern.

### 3.6 Knöpfe und LEDs

Die Platine mit den Knöpfen und **LEDs** [11] wird an die **FPGA** Platine angeschlossen. Sie hat 4 Tasten und 8 **LEDs**, die im Design verwendet werden können. Falls gewünscht kann diese Platine mit einer **LCD** Anzeige ausgestattet werden [12], [13].



Abbildung 15 - Knöpfe-**LEDs-LCD** Platine [11]



## 4 | Bewertung

Im Ordner **doc/** zeigt die Datei **evaluation-bewertung-cursor.pdf** das detaillierte Bewertungsschema, [Tabelle 1](#).

Die Schlussnote beinhaltet den Bericht, den Code sowie eine Präsentation eurerseits des Systems.

| Evaluierte Aspekte                  | Punkte     |
|-------------------------------------|------------|
| <b>Bericht</b>                      | <b>55</b>  |
| Einleitung                          | 3          |
| Spezifikation                       | 5          |
| Entwurf                             | 20         |
| Verifizierung und Validation        | 10         |
| Integration                         | 9          |
| Schlussfolgerung                    | 3          |
| Formale Aspekte des Berichtes       | 5          |
| <b>Funktionalität der Schaltung</b> | <b>30</b>  |
| <b>Qualität der Lösung</b>          | <b>10</b>  |
| <b>Präsentation</b>                 | <b>10</b>  |
| <b>Total</b>                        | <b>105</b> |

Tabelle 1 - Bewertungsraster



Das Bewertungsraster gibt bereits Hinweise über die Struktur des Berichtes. Für einen guten Bericht konsultieren Sie das Dokument „Wie verfasst man einen Projektbericht?“ [\[14\]](#).



## 5 | Erste Schritte

Um mit dem Projekt zu beginnen, kann folgendermassen vorgehen werden:

- Lest die obigen Spezifikationen und Informationen genau durch.
- Schaut euch die Hardware und testet das vorprogrammierte Programm.
- Stöbert durch die Dokumente im Ordner **doc/** eures Projektes.
- Entwickelt ein detailliertes Blockdiagramm. Die Signale und deren Funktionen solltet Ihr erklären können.
- Implementierung und Simulation der verschiedenen Blöcken.
- Testen der Lösung auf der Platine und finden etwaiger Fehler .

### 5.1 Tips

Anbei noch einige zusätzlichen Tips um Probleme und Zeitverlust zu vermeiden:

- Teilt das Problem in verschiedene Blöcke auf, benutzt hierzu das leere Toplevel Dokument (**cursor-toplevel-empty.pdf**). Es ist ein ausgeglichener Mix zwischen Anzahl Komponenten und Komponentengrösse empfohlen.
- Analysiert die verschiedenen Ein- sowie Ausgangssignale, hierzu sollten teilweise die Datenblätter zu Hilfe genommen werden.
- Beachtet bei der Erstellung des Systems das DiD Kapitel „Methodologie für die Entwicklung von digitalen Schaltungen (MET)“ [15].
- Es wird empfohlen das System in zwei Schritten zu realisieren.



Vergesst nicht Spass zu haben.





# Glossar

**CPR** – Counts per Revolution [10](#)

**FPGA** – Field Programmable Gate Array [5, 8, 11, 12](#)

**LCD** – Liquid Crystal Display [3, 12](#)

**LED** – Light Emitting Diode [5, 8, 12](#)

**PCB** – Printed Circuit Board [8](#)

**PWM** – Pulse Width Modulation [5, 6, 9](#)

**UART** – Universal Asynchronous Receiver Transmitter [11](#)

**USB** – Universal Serial Bus [11](#)



# Literatur

- [1] „Reed Relay“. 5. Dezember 2020. Zugegriffen: 24. November 2021. [Online]. Verfügbar unter: [https://en.wikipedia.org/w/index.php?title=Reed\\_relay&oldid=992433034](https://en.wikipedia.org/w/index.php?title=Reed_relay&oldid=992433034)
- [2] Olivier Walpen, „Schematic: Cursor Chariot Power Circuit“. 2009.
- [3] STMicroelectronics, „Datasheet: DMOS Dual Full Bridge Driver with PWM Current Controller“. 2003.
- [4] Agilent Technologies, „Datasheet Agilent AEDB-9140 Series Three Channel Optical Incremental Encoder Modules with Codewheel, 100 CPR to 500 CPR“. 2005.
- [5] „Magnetic-Reed-Switch-Above-Closed-and-open-reed-switch-in-response-to-magnet-placement.Png (850×345)“. Zugegriffen: 24. November 2021. [Online]. Verfügbar unter: <https://www.researchgate.net/profile/Sidakpal-Panaich-2/publication/51169357/figure/fig1/AS:394204346896388@1470997048549/Magnetic-reed-switch-Above-Closed-and-open-reed-switch-in-response-to-magnet-placement.png>
- [6] Silvan Zahno, „Schematic: FPGA-EBS v2.2“. 2014.
- [7] Xilinx, „Spartan-3 FPGA Family“. Zugegriffen: 20. November 2021. [Online]. Verfügbar unter: <https://www.xilinx.com/products/silicon-devices/fpga/spartan-3.html>
- [8] Xilinx, „Datasheet Spartan-3E FPGA Family“. 2008.
- [9] CTS, „Datasheet CTS Model CB3 & CB3LV HCMOS/TTL Clock Oscillator“. 2006.
- [10] A. Amand und S. Zahno, „FPGA-EBS3 Electornic Technical Documentation“. 2022.
- [11] Silvan Zahno, „Schematic: Parallelport HEB LCD V2“. 2014.
- [12] Sitronix, „Datasheet Sitronix ST7565R 65x1232 Dot Matrix LCD Controller/Driver“. 2006.
- [13] Electronic Assembly, „Datasheet: DOGM Graphics Series 132x32 Dots“. 2005.
- [14] Christophe Bianchi, François Corthay, und Silvan Zahno, „Wie Verfasst Man Einen Projektbericht?“. 2021.
- [15] François Corthay, Silvan Zahno, und Christophe Bianchi, „Méthodologie de Conception de Circuits Numériques“. 2021.