

# **XSG AC Motor Control Solution**

**Version 20.1 – 6/2020**

## How to Contact dSPACE

|         |                                                                |
|---------|----------------------------------------------------------------|
| Mail:   | dSPACE GmbH<br>Rathenaustraße 26<br>33102 Paderborn<br>Germany |
| Tel.:   | ++49 5251 1638-0                                               |
| Fax:    | ++49 5251 16198-0                                              |
| E-mail: | <a href="mailto:info@dspace.de">info@dspace.de</a>             |
| Web:    | <a href="http://www.dspace.com">http://www.dspace.com</a>      |

## How to Contact dSPACE Support

There are different ways to contact dSPACE Support:

- Visit our Web site at <http://www.dspace.com/goto/support>
- Send an e-mail or phone:
  - General Technical Support:  
[support@dspace.de](mailto:support@dspace.de)  
+49 5251 1638-941
  - SystemDesk Support:  
[support.systemdesk@dspace.de](mailto:support.systemdesk@dspace.de)  
+49 5251 1638-996
  - TargetLink Support:  
[support.ll@dspace.de](mailto:support.ll@dspace.de)  
+49 5251 1638-700
- Use the dSPACE Installation Manager:
  - On your dSPACE DVD at *\Tools\InstallationManager.exe*
  - Via Start – Programs – dSPACE Installation Manager (after installation of the dSPACE software)
  - At <http://www.dspace.com/goto?im>

You can always find the latest version of the dSPACE Installation Manager here.  
dSPACE recommends that you use the dSPACE Installation Manager to contact dSPACE Support.

## Software Updates and Patches

dSPACE strongly recommends that you download and install the most recent patches for your current dSPACE installation. Visit <http://www.dspace.de/goto/support> for software updates and patches.

## Important Notice

This document contains proprietary information that is protected by copyright. All rights are reserved. Neither the documentation nor software may be copied, photocopied, reproduced, translated, or reduced to any electronic medium or machine-readable form, in whole or in part, without the prior written consent of dSPACE GmbH.

© Copyright 2018 by:  
dSPACE GmbH  
Rathenaustraße 26  
33102 Paderborn  
Germany

This publication and the contents hereof are subject to change without notice.  
AutomationDesk, CalDesk, ConfigurationDesk, ControlDesk, SCALEXIO, SystemDesk and TargetLink are registered trademarks of dSPACE GmbH in the United States or other countries, or both. Other brand names or product names are trademarks or registered trademarks of their respective companies or organizations

# Contents

|                                                         |           |
|---------------------------------------------------------|-----------|
| <b>About This Guide.....</b>                            | <b>6</b>  |
| <i>Document Symbols and Conventions .....</i>           | 6         |
| <i>Accessing PDF File.....</i>                          | 7         |
| <i>Related Documents.....</i>                           | 8         |
| <i>Requirements.....</i>                                | 9         |
| <b>Target Hardware .....</b>                            | <b>10</b> |
| DS5203 FPGA Board.....                                  | 10        |
| DS1514 FPGA Board + DS1552/DS1553 I/O Module .....      | 11        |
| DS1302 FPGA Board (MicroLabBox) .....                   | 13        |
| DS2655 FPGA Board + DS2655M1/DS2655M2 I/O Modules ..... | 14        |
| Compatibility Matrix .....                              | 15        |
| <b>Simulink Model Structure.....</b>                    | <b>16</b> |
| General Description.....                                | 16        |
| Example of Interfacing .....                            | 17        |
| The Processor Setup Block.....                          | 18        |
| The FPGA Setup Block.....                               | 19        |
| <b>XSG AC Motor Control Solution .....</b>              | <b>20</b> |
| Library Contents.....                                   | 20        |
| Description / Overview.....                             | 21        |
| Library Structure .....                                 | 21        |
| Incremental Encoder Processing (TTL or Sine).....       | 24        |
| Processor Output.....                                   | 27        |
| FPGA Main Component.....                                | 33        |
| Processor Input.....                                    | 38        |
| Step/Direction Encoder Processing (TTL) .....           | 41        |
| Processor Output.....                                   | 43        |
| FPGA Main Component.....                                | 49        |
| Processor Input.....                                    | 53        |
| Hall Sensor Processing .....                            | 56        |
| Processor Output.....                                   | 58        |
| FPGA Main Component.....                                | 66        |
| Processor Input.....                                    | 69        |
| EnDat 2.1 Processing.....                               | 72        |
| Processor Output.....                                   | 73        |
| FPGA Main Component.....                                | 76        |
| Processor Input.....                                    | 78        |
| Resolver & LVDT Processing.....                         | 81        |
| Processor Output.....                                   | 84        |
| FPGA Main Component.....                                | 90        |
| Processor Input.....                                    | 95        |
| SSI & SPI Sensor Processing .....                       | 103       |

|                                                 |            |
|-------------------------------------------------|------------|
| Processor Output.....                           | 104        |
| FPGA Main Component.....                        | 110        |
| Processor Input.....                            | 113        |
| Asymmetric H Bridge PWM Generator .....         | 116        |
| Processor Output.....                           | 118        |
| FPGA Main Component.....                        | 122        |
| Processor Input.....                            | 124        |
| Block Commutated PWM Generator .....            | 126        |
| Processor Output.....                           | 127        |
| FPGA Main Component.....                        | 137        |
| Processor Input.....                            | 141        |
| Miscellaneous .....                             | 144        |
| Debounce.....                                   | 144        |
| Sync Generation .....                           | 145        |
| <b>Demos .....</b>                              | <b>146</b> |
| Overview .....                                  | 146        |
| Permanent Magnet Synchronous Machine Demo ..... | 150        |
| <b>DS1553 Framework .....</b>                   | <b>163</b> |
| Introduction .....                              | 163        |
| I/O Read Functions .....                        | 165        |
| Status In.....                                  | 165        |
| Digital In .....                                | 166        |
| ADC .....                                       | 167        |
| RS485 In .....                                  | 169        |
| Resolver IC .....                               | 170        |
| FPGA Temperature .....                          | 173        |
| I/O Write Functions .....                       | 175        |
| LED Out .....                                   | 175        |
| Digital Out .....                               | 175        |
| DAC .....                                       | 177        |
| RS485 Out.....                                  | 178        |
| Pin-Out.....                                    | 180        |



# About This Guide

## Document Symbols and Conventions

### Symbols

The following symbols may be used in this document:

|  |                                                                                                                                            |
|--|--------------------------------------------------------------------------------------------------------------------------------------------|
|  | Indicates a general hazard that may cause personal injury of any kind if you do not avoid it by following the instructions given.          |
|  | Indicates the danger of electric shock which may cause death or serious injury if you do not avoid it by following the instructions given. |
|  | Indicates a hazard that may cause material damage if you do not avoid it by following the instructions given.                              |
|  | Indicates important information that should be kept in mind, for example, to avoid malfunctions.                                           |
|  | Indicates tips containing useful information to make your work easier.                                                                     |

### Naming Conventions

The following abbreviations and formats are used in this document:

**%name%** Names enclosed in percent signs refer to environment variables for file and path names, for example, %DSPACE\_PYTHON25% specifies the location of your dSPACE installation in the file system.

**< >** Angle brackets contain wildcard characters or placeholders for variable file and path names, etc.

Precedes the document title in a link that refers to another document.

Indicates that a link refers to another document, which is available in dSPACE HelpDesk.

## Accessing PDF File

---

**Objective** After you install your dSPACE software, the documentation for the installed products is available as Adobe® PDF file.

---

**PDF files** You can access the PDF files as follows:

Documentation root: <%INSTALLDIR%>\Doc\XSG\_ACMC.pdf

## Related Documents

---

Below is a list of documents that you are recommended to read when working with the XSG ACMC Library.

- RTI Reference
- RTI FPGA Programming Blockset Guide
- RTI FPGA Programming Blockset - Processor Interface Reference
- RTI FPGA Programming Blockset - FPGA Interface Reference
- Hardware Installation and Configuration Reference
- DS5346 Data Sheet
- MABXII ACMC User Guide
- XSG Utils User Guide

## Requirements

The following tools have to be installed for using the dSPACE FPGA Boards:

- MATLAB & Simulink
- Xilinx Vivado including System Generator (e.g. System Edition)
- dSPACE Release

Below you can find the compatibility matrix for dSPACE Release, Xilinx and MATLAB for the XSG AC Motor Control Blockset for FPGA:

| RTI FPGA Programming Blockset | dSPACE Release | Operating System                             | MATLAB                                   | Xilinx Vivado and XSG |
|-------------------------------|----------------|----------------------------------------------|------------------------------------------|-----------------------|
| 3.9                           | 2020-A         | Windows 7<br>64-bit,<br>Windows 10<br>64-bit | R2018b,<br>R2019a,<br>R2019b<br>(64 Bit) | 2019.2<br>(64 Bit)    |

**Figure 1: Compatibility matrix for XSG ACMC 19.2**

In the following table you find the compatibility matrix for dSPACE Release and MATLAB for the XSG AC Motor Control Blockset for Processor:

| dSPACE Release     | Operating System                                | MATLAB                                           |
|--------------------|-------------------------------------------------|--------------------------------------------------|
| 2020-A<br>(64 bit) | Windows 7<br>(64 bit)<br>Windows 10<br>(64 bit) | R2018b<br>R2019a<br>R2019b<br>R2020a<br>(64 bit) |

# Target Hardware

## DS5203 FPGA Board

|                          |                                                                                                                                                           |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Board description</b> | With the DS5203 FPGA board (shown in the figure below), an integration of a FPGA application into a dSPACE modular PHS-Bus based system can be performed. |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|



Figure 2: DS5203 Boards (PHS-based)

The board provides a Xilinx® Kintex-7 FPGA which can be programmed by the user by using the RTI FPGA Programming Blockset. The board features the following onboard I/O:

- 6 A/D channels with 10 MHz sample rate and adjustable voltage range
- 6 D/A channels with 10 MHz update rate and  $\pm 10$  V voltage range
- 16 digital single-ended input or output channels with configurable input voltage threshold and output voltage of 3.3 V or 5 V

An additional piggy back module (M1) to double the I/O can also be added.

There are two FPGA types available:

- Kintex-7 325T (normal amount of resources)
- Kintex-7 410T (larger amount of resources)

The I/O of the DS5203 enables most of the features provided by the XSG AC Motor Control Solution. However, the processing of SSI sensors is not possible with the standard hardware, as it required RS485 or RS422 digital I/O drivers.

## DS1514 FPGA Board + DS1552/DS1553 I/O Module

### Board description

Using the DS1514 FPGA base board for MicroAutoBox in combination with the DS1552 Multi-I/O piggy-back module or the DS1553 ACMC piggy-back module (shown in the figure below), an integration of a FPGA application into a dSPACE MicroAutoBox can be performed.



**Figure 3: MicroAutoBox with DS1514 and DS1553**

The board provides a Xilinx® Kintex-7 FPGA which can be programmed by the user, for example, by using the RTI FPGA Programming Blockset.

The DS1553 I/O module features the following I/O:

- 8 A/D channels with 10 MHz sample rate and adjustable voltage range
- 2 D/A channels with 10 MHz update rate and  $\pm 20$  V voltage range
- 8 digital single-ended or differential 5V input channels
- 24 digital single-ended 5 V output channels
- 4 RS485 digital differential bi-directional channels
- 1 resolver IC with 16 bit position resolution and 500 kHz update rate

With the I/O provided by the DS1553, all features of the XSG AC Motor Control Solution can be applied.

The DS1552 I/O module features the following I/O:

- 8 A/D channels with a sample rate of 1 MHz and 0...5 V or  $\pm 10$  V voltage range
- 16 A/D channels with a sample rate of 200 kHz and  $\pm 10$  V voltage range
- 4 D/A channels with an update rate of 2.1 MHz and 0...5 V voltage range
- 16 digital single-ended 5 V input channels
- 16 digital single-ended output channels with configurable output voltage
- 8 digital single-ended input or output channels with configurable input voltage threshold and output voltage of 3.3 V or 5 V
- 3 crank/cam input channels with  $\pm 40$  V voltage range
- 1 Inductive zero voltage detector (for zero-crossing detection)
- 4 UART interfaces

The I/O of DS1552 enables most features of the XSG AC Motor Control. However, the DAC range is not suitable for all kinds of resolvers and LVDT. Additionally, the processing of SSI and EnDat sensors is not possible with the standard framework.

## DS1302 FPGA Board (MicroLabBox)

### Board description

Using the DS1302 FPGA board for MicroLabBox (shown in the figure below) with on-board I/O, an integration of a FPGA application into a dSPACE MicroLabBox can be performed.



**Figure 4: MicroLabBox with DS1302**

The DS1302 FPGA board provides a Xilinx® Kintex-7 FPGA which can be programmed by the user by using the RTI FPGA Programming Blockset. It features the following I/O:

- 8 A/D channels with 10 MHz sample rate and  $\pm 10$  V voltage range
- 24 A/D channels 1 MHz sample rate and  $\pm 10$  V voltage range
- 16 D/A channels with 1 MHz update rate and  $\pm 10$  V voltage range
- 48 digital single-ended input or output channels with configurable input voltage threshold and output voltage of 2.5V, 3.3 V or 5 V
- 12 digital differential RS485/RS422 channels

With the I/O provided by the MicroLabBox, all features of the XSG AC Motor Control Solution can be applied.

## DS2655 FPGA Board + DS2655M1/DS2655M2 I/O Modules

### Board description

With the DS2655 FPGA base module and the DS2655M1 I/O module (shown in the figure below), an integration of a FPGA application into a dSPACE modular IOCNET based system (SCALEXIO) can be performed.



**Figure 5: DS2655 FPGA base module and the DS2655M1 I/O module (SCALEXIO)**

The DS2655 FPGA base module provides a Xilinx® Kintex-7 FPGA which can be programmed by the user by using the RTI FPGA Programming Blockset. Up to 5 I/O modules can be connected to the DS2655.

The first module available for the DS2655 is the DS2655M1 and features the following I/O:

- 5 A/D channels with 2 MHz sample rate and adjustable voltage range
- 5 D/A channels with 7.8125 MHz update rate and  $\pm 10$  V voltage range
- 10 digital single-ended input or output channels with configurable input voltage threshold and output voltage of 3.3 V or 5 V

Additionally, there is another I/O module available, the DS2655M2, containing the following features.

- Up to 32 digital I/O channels, depending on configuration
- Digital I/O channels can be input, output or bidirectional
- Channels can be single-ended or differential
- Channels can be TTL (3.3 V or 5 V) or RS232, RS422, RS485

The DS2655M2 is required in case that SSI encoders are used or differential inputs are required for other sensors (e.g. incremental encoders)

# Compatibility Matrix

## Description

The following table shows the compatibility of XSG AC Motor Control Solution components in combination with the supported hardware.

| Component                 | DS5203 | DS1514<br>DS1552 | DS1514<br>DS1553 | DS1302 | DS2655<br>M1/M2 |
|---------------------------|--------|------------------|------------------|--------|-----------------|
| Incr. encoder             | ✓      | ✓                | ✓                | ✓      | ✓               |
| Step direction<br>encoder | ✓      | ✓                | ✓                | ✓      | ✓               |
| Hall sensor               | ✓      | ✓                | ✓                | ✓      | ✓               |
| Resolver & LVDT           | ✓      | ✗                | ✓                | ✓      | ✓               |
| SSI                       | -      | -                | ✓                | ✓      | ✓               |
| EnDat 2.1                 | -      | -                | ✓                | ✓      | ✓               |
| SPI                       | ✓      | ✓                | ✓                | ✓      | ✓               |
| PWM generation*           | ✓      | ✓                | ✓                | ✓      | ✓               |
| Miscellaneous             | ✓      | ✓                | ✓                | ✓      | ✓               |



Components marked with an asterisk (\*) are located in the XSG Utils library.

# Simulink Model Structure

## General Description

**Description** This chapter describes the user interface for accessing the FPGA board from Simulink. In general, there are two different ways to access the board, either via bus for communication between processor and FPGA or via digital or analog in channels on the board. The FPGA output is similar to its input: either information can be written from the FPGA to the processor via bus register, or information can be sent out via hardware channels.

Two interfaces are available for handling the communication.

- **Processor interface** (read and write on the processor side)
- **FPGA interface** (read and write on the FPGA side)

The processor interface comes with the regular RTI license, the FPGA interface comes with an extra RTI FPGA license. The figure below shows the library with FPGA and processor interface.



Figure 6: RTIFPGA library

|  |                                                                                                                                                      |
|--|------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <p>Separating these two libraries makes it possible to use precompiled FPGA applications without buying an additional license for FPGA modeling.</p> |
|--|------------------------------------------------------------------------------------------------------------------------------------------------------|

The XSG AC Motor Control Solution contents are designed to give you easy access to create the model that you require. Each main component blockset consists of five elements:

1. **Processor out interface** (<component>\_out (Processor Interface))  
All the required parameters and actual values are merged into the smallest necessary number of registers or buffers.
2. **FPGA in interface** (<component>\_in (FPGA Interface))  
The merged signals from the processor side are decoded on the FPGA side
3. **FPGA main component** (<component>\_FPGA (FPGA))  
Provides the actual model functionality of the component
4. **FPGA out interface** (<component>\_out (Processor Interface))  
All the required signals to be returned to the processor are merged here to utilize the smallest possible amount of registers
5. **Processor in interface** (<component>\_in (Processor Interface))  
The merged signals from the FPGA side are decoded on the processor side

## Example of Interfacing

### Example

The illustration below shows a structural example of how to implement the interfaces. The red blocks (1-5) are components from the dSPACE XSG AC Motor Control Solution. The other blocks (6-9) are RTI FPGA interface blocks that define the basic communication between FPGA, processor and I/O.



Figure 7: Using library components

A detailed view of the RTI interface is shown in the next figure below. In this example, the values calculated by the processor are written via bus interface to the FPGA (on the left-hand side) and the values calculated on the FPGA are written back to the processor (right-hand side). The I/O access is also shown (ADC1, DAC1).



Figure 8: RTI interface usage

## The Processor Setup Block

### Features



The Processor Setup block has to be located on the model root. All processor interface blocks can be placed anywhere inside the Simulink model except the FPGA subsystem. This block is not required for IOCNET platforms.

The number of FPGA boards which are used in the application has to be defined on the unit page, which is called double-clicking the processor setup block PROC\_SETUP\_BL1. Up to 16 FPGA boards can be handled. The subsystem, or precompiled binary file, has to be specified for each board. On the FPGA side the configuration can be stored in either the RAM or the flash memory.

The Interface lets you generate the interface blocks on the processor side automatically. Therefore only the interface blocks on the FPGA side have to be configured.

The Model Configuration page lets you switch between the FPGA Build and the Processor Build mode. For offline simulation, the FPGA build option must be used. Changes take effect when the Switch model mode button is clicked. If the Processor Build mode is selected, the FPGA subsystem is removed from the model file and stored inside a separate model file. When you switch back to FPGA Build mode, the FPGA subsystem is copied back to the application model.



When performing the build process on the processor side, it is mandatory to activate the Processor Build mode.

On the Advanced page, precompiled FPGA applications (\*.ini) can be added. After adding them there, you can select the application on the Unit page. The FPGA application is added to the generated processor files during the processor build process.



Because of the long synthesis time and the huge resource consumption of the FPGA build process, it is recommended to use a separate PC. The synthesis result (\*.ini file), can be linked to the application during a separate processor build on the modeling PC.

## The FPGA Setup Block

### Features



All blocks belonging either to the Xilinx System Generator (XSG) or to the RTI FPGA Programming Blockset have to be placed in one Simulink subsystem if they are assigned to the same FPGA board. The root directory of the FPGA subsystem must contain an FPGA Setup block from the RTIFPGA Library

The Unit page, which is opened by double-clicking the FPGA setup block, displays the board number on which the application is stored. You must also select the framework and the piggyback.

The Parameter page shows the clock period of the FPGA. The parameters for the down-sample factor and the offline simulation period can be specified here. To start a timing analysis, an FPGA Build process or a HDL simulation, click the Execute button.



Before starting an FPGA Build process (synthesis), it is recommended to perform a timing analysis in advance to ensure that the modeled design fits the timing constraints and the resources of the target FPGA.

It is also recommended to verify changes in the offline simulation before starting the synthesis



If inserting RTI FPGA interface blocks manually, ensure that all write/read registers are in an unsigned fixed format with a binary point of zero (UFix\_32\_0). Please note that the default setting is signed!

# XSG AC Motor Control Solution

## Library Contents

|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description / Overview</b> | The XSG AC Motor Control Solution is designed to provide easy access for rapid control prototyping of e-drive control or parts of it on Xilinx FPGAs. This includes commonly used functions like the processing of various position sensors, the generation of PWM pattern and components of the control algorithms.                                                                                                                                             |
| <b>Sensor Processing</b>      | <p>Position sensor processing for the following encoders:</p> <ul style="list-style-type: none"><li>▪ Incremental encoder (TTL or sine)</li><li>▪ Hall sensors</li><li>▪ Resolver and LVDT</li><li>▪ SSI encoders</li></ul>                                                                                                                                                                                                                                      |
| <b>Utils</b>                  | The library also contains a separate library called XSG_Utils. This library collected frequently used elements, which are relevant for all e-drive use cases (e.g. PWM generation and measurement, PI controller, digital filters, Clarke/Park transformations, scaling and scope functionalities). All FPGA main components include interfaces to the processor model. For further information about these blocks, please refer to the XSG Utils documentation. |
| <b>Demos</b>                  | <p>The XSG ACMC library also contains two separate demo models to illustrate an exemplary model structure of an FPGA application in combination with a control loop implemented on the processor platform.</p> <p>Therefore the following models are prepared:</p> <ul style="list-style-type: none"><li>▪ BLDC control</li><li>▪ PMSM control</li></ul>                                                                                                         |

# Description / Overview

|                  |                                                                                            |
|------------------|--------------------------------------------------------------------------------------------|
| <b>Objective</b> | The following section describes the general structure and features of the XSG ACMC Library |
|------------------|--------------------------------------------------------------------------------------------|

## Library Structure

|                            |                                                    |
|----------------------------|----------------------------------------------------|
| <b>General information</b> | The XSG AC Motor Control Solution is divided into: |
|----------------------------|----------------------------------------------------|

- XSG AC Motor Control Solution (FPGA-based blocks)
- XSG ACMC Interface Library (processor-based blocks)

The XSG AC Motor Control Solution contains the separate XSG Utils Library. The following figure illustrates the overall structure of the solution package.



**Figure 9: XSG ACMC Library**

To realize an easy user access to the different functionalities of the XSG Utils Library from the XSG ACMC Library hyperlinks are used. For further information about the blocks of the XSG Utils Library please find the XSG Utils Library documentation.

**XSG ACMC Library**

The XSG ACMC Library provides access to FPGA based position sensor processing. Combined with the PWM functionality of the XSG Utils Library and the I/O functions of the RTI FPGA Programming Blockset, closed-loop control for different kinds of e-drives can easily be realized. The library is divided into FPGA / Processor Interface and FPGA components as shown in the figure below. To open the library, type “XSG\_ACMC\_lib” in the MATLAB Command Window or access the library via Simulink browser.



**Figure 10: XSG AC Motor Control Solution**

The FPGA-based blocks are located in the FPGA subsystem. To simplify the realization of an interface for sending processor-based parameters to the FPGA and back, optimized FPGA and processor interface blocks are located in the subsystems FPGA Interface and Processor Interface.



The XSG AC Motor Control Solution also contains the XSG ACMC Interface Library.

For an example of the general structure of an FPGA programming model, refer to the Demos subsystem.

**XSG ACMC Interface Library**

If no user-defined adjustments have to be made in the FPGA code, the processor interface is separately located in the XSG ACMC Interface Library as shown in the figure below. To open the Processor Interface Library, type “XSG\_ACMCInterface\_lib” in the MATLAB Command Window or access the library via Simulink browser.



Figure 11: XSG ACMC Interface Library

The internal structure of the library is the same as the structure of the XSG ACMC Library, except that the interface library only contains the processor blocks.

## Incremental Encoder Processing (TTL or Sine)

### Objective

The Incremental Encoder Processing is used to derive position (angle) and velocity by decoding the output of incremental encoders. Different kinds of incremental encoders can be analyzed, dependent on the I/O connected. The most common sensors are TTL/HTL and sine encoders.

The incremental encoder processing outputs position and speed. For speed measurement, two different methods are implemented, which are described below.

### TTL Encoders

Incremental TTL encoders provide angular information as rectangle pulses with a frequency dependent on the current velocity. Using two identical tracks which are shifted by 90° the direction can be determined as well. The third track is the so-called index track which provides only one pulse per revolution, which enables determination of the absolute mechanical position. Prior to detection of the index pulse (worst case after one mechanical revolution) only the relative position and the velocity can be determined.

Typical high level output voltages of TTL encoders are 5V or 3.3V. Both single-ended as well as differential signals are common. HTL encoders use higher voltages of usually 24V.



Figure 12: Incremental TTL encoder shape

**Sine Encoders**

In contrast to TTL encoders, sine encoders output analog sine wave signals. By counting the zero crossings of the signals a position measurement like using TTL encoders can be performed. By additionally calculating the arc tangent of A/B, a finer position interpolation can be achieved. Like TTL encoders, sine encoders usually provide an index (also called reference) track for absolute position measurement as well. The index can be a digital rectangle pulse or an analog half sine wave with a width of usually 90°.

A common voltage output of a sine encoder is an analog signal of 1 V<sub>PP</sub> with a DC offset of 2.5 V<sub>DC</sub>.



**Figure 13: Incremental sine encoder shape**



At high motor speeds and/or high line count, it is possible that the A/D signal has too much noise and because of that sine/cosine processing can lose line information. To prevent that from happening it is advisable to filter the A/D inputs with PT1 filters to improve signal quality.

**Speed Measurement**

Two methods of velocity measurement are implemented for the incremental encoder processing:

- Position increment based measurement: The time elapsed between two identical edges of the input signals ( $360^\circ$ ) is evaluated. The measurement dead time is minimized, but dependent on the current speed. For high velocities, the dead time is negligible. However, the accuracy decreases, as jitter becomes significant for short measurement intervals.
- Sample time based measurement: The measurement time is defined by an external trigger, which is by default triggered with each sample of the processor output block. The number of edges during this period is counted, as well as the time elapsed between the first and the last edge considered. This method provides a relatively constant measurement dead time and more accurate results for high velocities.

The principle of the sample time based measurement is illustrated in the figure below.



**Figure 14: Principle of the sample time based speed measurement**

**Content**

The blockset contains the following elements:

- Processor Interface: INC\_ENCODER\_RCP\_out (Processor Interface)
- FPGA Interface: INC\_ENCODER\_RCP\_in (FPGA Interface)
- FPGA: INC\_ENCODER\_RCP (FPGA Main Component)
- FPGA Interface: INC\_ENCODER\_RCP\_out (FPGA Interface)
- Processor Interface: INC\_ENCODER\_RCP\_in (Processor Interface)

## Processor Output

### Block

Merges the processor signals and writes them to the FPGA.



Figure 15: INC\_ENCODER\_RCP\_out block

### Block Dialog

The processor output block provides the following dialog:



Figure 16: INC\_ENCODER\_RCP\_out dialog

The blockset dialog has the following parameters:

| Name                             | Unit      | Description                                                                                                                                                                                                                                                                                                                             | Range                                                                           |
|----------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Input type of A and B            | -         | 0 = digital input signals<br>1 = analog input signals                                                                                                                                                                                                                                                                                   | 0 1                                                                             |
| Debounce time                    | s         | Optional debounce time for digital input signals                                                                                                                                                                                                                                                                                        | Dependent on FPGA clock rate (@100MHz:<br>Range 0...10.23µs<br>Resolution 10ns) |
| DC offset                        | LSB (Bit) | In case of analog signals (A, B) a DC offset (usually 2.5V) can be specified                                                                                                                                                                                                                                                            | Range: 0...65535<br>Resolution: 1                                               |
| Symmetrical hysteresis           | LSB (Bit) | In case of analog signals a hysteresis can be defined to avoid multiple zero crossing detection caused by noise. A positive zero crossing will be detected when the input exceeds the specified hysteresis value, a negative zero crossing will be detected when the inputs falls below the negation of the specified hysteresis value. | Range: 0...1023<br>Resolution: 1                                                |
| Fine interpolation               | -         | In case of analog sine inputs, the position can be interpolated by calculating arctan(A/B) to increase accuracy                                                                                                                                                                                                                         | 0 1                                                                             |
| Input type of index              | -         | 0 = digital index signal<br>1 = analog index signal                                                                                                                                                                                                                                                                                     | 0 1                                                                             |
| Threshold for analog index       | LSB (Bit) | In case of an analog index, a threshold for detecting the index can be specified                                                                                                                                                                                                                                                        | Range: 0...65535<br>Resolution: 2                                               |
| Edges used for speed measurement | -         | Select which edges are used for speed measurement. Each measurement always uses a whole period of the signal. Each time a new valid measurement is completed, this measurement result is latched to the output.                                                                                                                         | 0 1 (4x)                                                                        |

|                                                           |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                       |
|-----------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| Use sample time based speed measurement if applicable     | - | If this option is deactivated, the speed measurement will be performed by measuring the time elapsed between two identical edges. If this option is activated, the speed is measured over multiple all periods of the incremental encoder signals which are passed within the last simulation step of this block. This method is not applicable if less than 1 whole period is passed in 1 simulation step. In this case the standard method will be applied.                                                                                                                                                                  | 0 1                                   |
| Resolution option for sample time based speed measurement | - | Using this option, the resolution of a sample time based speed measurement can be specified. The option should be set according to the maximum possible sample time of this block. The maximum sample time calculates as $T_{S FPGA} \cdot (2^{(16+x)} - 2)$ For DS5203 i.e. (100MHz) this means:<br>0: $T < 0.655\text{ms}$ , res. 10ns<br>1: $T < 1.310\text{ms}$ , res. 20ns<br>2: $T < 2.621\text{ms}$ , res. 40ns<br>3: $T < 5.242\text{ms}$ , res. 80ns<br>4: $T < 10.48\text{ms}$ , res. 160ns<br>5: $T < 20.97\text{ms}$ , res. 320ns<br>6: $T < 41.94\text{ms}$ , res. 640ns<br>7: $T < 83.89\text{ms}$ , res. 1,28μs | Range: 0...7<br>Resolution: 1         |
| Index position                                            | ° | The absolute mechanical position of the index signal rising edge during forward movement.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Range: 0...360°<br>Resolution: 0.005° |
| Position for Interrupt trigger                            | ° | Specifies a position for an optional position interrupt on the FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Range: 0...360°<br>Resolution: 0.005° |
| Number of lines                                           | - | Number of lines of the incremental encoder.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Range: 1...16384<br>Resolution: 1     |
| Sample time FPGA                                          | s | Sample time of the FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -                                     |

**Input**

The INC\_ENCODER\_RCP\_out block has the following inputs:

| Name   | Unit | Description              | Range |
|--------|------|--------------------------|-------|
| Enable | -    | Sensor processing enable | 0 1   |

**Output**

The Processor Out block outputs four register contents, mapped to two registers by time multiplexing. The sectioning is shown below:

**Register 1.1**

Figure 17: INC\_ENCODER\_RCP\_out Register 1.1

| Name               | Bits  | Description                                                                                                 |
|--------------------|-------|-------------------------------------------------------------------------------------------------------------|
| Enable             | 0     | Enables the encoder processing                                                                              |
| Use_A_Rising       | 1     | Use rising edge of input signal A for speed measurement                                                     |
| Use_A_Falling      | 2     | Use rising edge of input signal A for speed measurement                                                     |
| Use_B_Rising       | 3     | Use rising edge of input signal B for speed measurement                                                     |
| Use_B_Falling      | 4     | Use rising edge of input signal B for speed measurement                                                     |
| Resolution_Option  | 7..5  | The resolution option described for the processor interface                                                 |
| Use_TS_Speed       | 8     | Activate the sample time based speed measurement described for the processor interface                      |
| Position_Increment | 30..9 | The increment of the position at each edge of an input signal. The FPGA main component section for details. |

**Register 1.2**

Figure 18: INC\_ENCODER\_RCP\_out Register 1.2

| Name           | Bits   | Description                                       |
|----------------|--------|---------------------------------------------------|
| Enable         | 0      | Enables the encoder processing                    |
| No_of_Lines-1  | 14..1  | The number of lines of the encoder - 1            |
| Index_Position | 30..15 | The Position of the index signal scaled to 16 bit |

### Register 2.1



Figure 19: INC\_ENCODER\_RCP\_out Register 2.1

| Name            | Bits   | Description                                                                                                                                                               |
|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Index_Threshold | 14..0  | The threshold for detecting an analog index. 1 LSB in the register corresponds to 2 LSB set in the processor interface GUI and supplied at the FPGA main component input. |
| DC_Offset       | 30..15 | The DC offset of analog input signals (A, B).                                                                                                                             |

### Register 2.2



Figure 20: INC\_ENCODER\_RCP\_out Register 2.2

| Name                       | Bits   | Description                                                                    |
|----------------------------|--------|--------------------------------------------------------------------------------|
| Interrupt_Position         | 15..0  | Position for an optional position interrupt, scaled to 16 bit.                 |
| Analog_AB                  | 16     | Input signals A & B are analog (otherwise digital)                             |
| Analog_Index               | 17     | Index signal is analog (otherwise digital)                                     |
| Use_Fine_Position          | 18     | Use interpolation for sin encoders by $\arctan(A/B)$                           |
| Debounce_Time   Hysteresis | 28..19 | Debounce time for input digital signals or hysteresis for analog input signals |
| SPARE                      | 30..29 | -                                                                              |

# FPGA Main Component

## Block



Figure 21: INC\_ENCODER\_RCP FPGA Main block

## Block Dialog

You can define the parameters of the input and output registers for automatic interface generation. The dialog also contains a button to start interface generation. For more details about automatic interface generation, refer to the XSG Utils documentation chapter Automatic Interface Generation. The FPGA clock period can be configured too.



---

**Input**

The main block has the following inputs:

| Name               | Unit    | Description                                                                                                                         | Format          |
|--------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| A                  | -   Bit | Input signal A. The signal can either be digital (Boolean) or analog (signed integer, e.g. raw output from ADC)                     | Bool   Fix_16_0 |
| B                  | -   Bit | Input signal B. The signal can either be digital (Boolean) or analog (signed integer, e.g. raw output from ADC)                     | Bool   Fix_16_0 |
| Index              | -   Bit | Index signal. The signal can either be digital (Boolean) or analog (signed integer, e.g. raw output from ADC)                       | Bool   Fix_16_0 |
| Enable             | -       | Enables the encoder processing                                                                                                      | Bool            |
| Trig_Speed_Meas    | -       | Triggers the sample time based speed measurement                                                                                    | Bool            |
| Speed_Signals      | -       | Vector containing the flags [A rising, A falling, B rising, B falling] for the signal edges considered for speed measurement        | Bool (4x)       |
| Index_Position     | -       | Mechanical position of the index (rising edge during forward movement), scaled to 16 bit                                            | UFix_16_0       |
| Interrupt_Position | -       | Position for optional generation of a position interrupt, scaled to 16 bit                                                          | UFix_16_0       |
| Position_Increment | -       | The increment which has to be added to or subtracted from the current position (position scaled to 16 bit) in case of a signal edge | UFix_22_8       |
| Resolution_Option  | -       | The resolution option described for the processor interface                                                                         | UFix_3_0        |
| Use_Ts_Based_Speed | -       | Activates sample time based speed measurement                                                                                       | Bool            |
| No_of_Lines-1      | -       | The number of lines of the encoder - 1                                                                                              | UFix_14_0       |
| Debounce_Time      | Clocks  | The debounce time of signal inputs.                                                                                                 | UFix_10_0       |
| Analog_AB          | -       | Signals A&B are analog when 1 (otherwise digital)                                                                                   | Bool            |
| Analog_Index       | -       | Index is analog when 1 (otherwise digital)                                                                                          | Bool            |
| Analog_DC_Offset   | Bit     | DC offset for analog signals A&B                                                                                                    | UFix_16_0       |
| Index_Threshold    | Bit     | In case of an analog index, a threshold for detecting the index can be specified                                                    | UFix_16_0       |
| Use_Fine_Position  | -       | Activates arctan interpolation for sine input signals                                                                               | Bool            |

**Output**

The main block has the following outputs:

| Name                   | Unit   | Description                                                                                                                                                                    | Format     |
|------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| FPGASignalBus          | -      | Contains all output signals which are passed to the processor interface                                                                                                        | Bus        |
| Position               | -      | The calculated angle (0...360°), scaled to 0...1.                                                                                                                              | UFix_16_16 |
| PositionHD             |        | The calculated angle (0...360°), scaled to 0...1 in high definition.                                                                                                           | UFix_32_32 |
| Position_Valid         | -      | The valid flag is set to 1 after the index has been passed at least once and the position is referenced                                                                        | Bool       |
| Direction              | -      | The detected direction of the encoder movement. 0 = forward, 1 = backward                                                                                                      | Bool       |
| Pos_Delta_Based_Time   | -      | The number of clock cycles between two identical edges                                                                                                                         | UFix_28_0  |
| Pos_Delta_Based_Overfl | -      | Indicates that the time between two edges exceeds the maximum range                                                                                                            | Bool       |
| TS_Based_Time          | Clocks | The number of clock cycles for the last speed sample period                                                                                                                    | UFix_23_0  |
| TS_Based_Incr          | Edges  | The number of edges detected for the last speed sample period. A negative number of edges indicates backward movement                                                          | Fix_16_0   |
| TS_Based_Overflow      | -      | Indicates that the measurement time exceeds the maximum range                                                                                                                  | Bool       |
| Index_Crossing         | -      | Impulse indicating the detection of an index passing                                                                                                                           | Bool       |
| Position Interrupt     | -      | Impulse indicating that the specified interrupt position has been crossed. The output can be connected to an interrupt block of the RTI FPGA Programming Blockset if required. | Bool       |

## Processor Input

**Block** Adapts the FPGA signals for the processor side.



Figure 22: INC\_ENCODER\_RCP\_in block

**Block Dialog** The following parameters can be configured in the processor input dialog:



Figure 23: INC\_ENCODER\_RCP\_in dialog

The blockset dialog has the following parameters:

| Name                | Unit | Description             | Range |
|---------------------|------|-------------------------|-------|
| Sample time<br>FPGA | s    | Sample time of the FPGA | -     |

**Input** The processor input block has the following inputs:

**Register 1**

Figure 24: INC\_ENCODER\_PROCESSING\_in Register 1

| Name           | Bits   | Description                                                                                |
|----------------|--------|--------------------------------------------------------------------------------------------|
| Position       | 15..0  | The calculated angle, scaled to 16 bit                                                     |
| Position_Valid | 1      | The position valid flag (see main component)                                               |
| No_of_Lines-1  | 30..17 | The number of lines is passed back to the processor application                            |
| Use_Ts_Speed   | 31     | The flag for using the sample time based speed is passed back to the processor application |

**Register 2**

Figure 25: INC\_ENCODER\_RCP\_in Register 2

| Name                 | Bits   | Description                                                       |
|----------------------|--------|-------------------------------------------------------------------|
| Pos_Delta_Based_Time | 27..0  | The number of clock cycles between two identical edges            |
| Resolution_Option    | 30..28 | The resolution option is passed back to the processor application |
| Direction            | 31     | The direction bit (0 = forward, 1 = backward)                     |

**Register 3**

Figure 26: INC\_ENCODER\_RCP\_in Register 3

| Name          | Bits   | Description                                     |
|---------------|--------|-------------------------------------------------|
| Ts_Based_Time | 15..0  | Clock cycles for the last speed sample period   |
| Ts_Based_Incr | 31..16 | Edges detected for the last speed sample period |

**Output**

The INC\_ENCODER\_RCP\_in block has the following outputs:

| Name           | Unit | Description                                                                                              | Range                                                                           |
|----------------|------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Position       | °    | The angle calculated by the FPGA main component                                                          | Range: 0...360°<br>Resolution: 0.005°                                           |
| Speed          | rpm  | The speed calculated by the FPGA main component                                                          | Dependent on FPGA clock rate (@100MHz:<br>Range: >±0.17rpm<br>Resolution: 10ns) |
| Position_Valid | -    | The valid flag, which is raised as soon as the position is referenced (index is passed at least disable) | 0 1                                                                             |

# Step/Direction Encoder Processing (TTL)

## Objective

The Step/Direction Processing is used to derive position (angle) and velocity by decoding the output of step/direction encoders.

The Step/Direction encoder processing outputs position and speed. For speed measurement, two different methods are implemented, which are described below.

## Step/Direction Encoders

Step/Direction encoders provide angular information as rectangle pulses with a frequency dependent on the current velocity. The second pulse, the so called direction track, indicates the direction of the circular movement. The third track is the so-called index track which provides only one pulse per revolution, which enables determination of the absolute mechanical position. Prior to detection of the index pulse (worst case after one mechanical revolution) only the relative position and the velocity can be determined.

Typical high level output voltages of this kind of encoders are 5V or 3.3V.



Figure 27: Step/Direction encoder signal shape

**Speed Measurement**

Two methods of velocity measurement are implemented for the incremental encoder processing:

- Position increment based measurement: The time elapsed between two identical edges of the input signals ( $360^\circ$ ) is evaluated. The measurement dead time is minimized, but dependent on the current speed. For high velocities, the dead time is negligible. However, the accuracy decreases, as jitter becomes significant for short measurement intervals.
- Sample time based measurement: The measurement time is defined by an external trigger, which is by default triggered with each sample of the processor output block. The number of edges during this period is counted, as well as the time elapsed between the first and the last edge considered. This method provides a relatively constant measurement dead time and more accurate results for high velocities.

The principle of the sample time based measurement is illustrated in the figure below.



**Figure 28: Principle of the sample time based speed measurement**

**Content**

The blockset contains the following elements:

- Processor Interface: STEP\_DIR\_ENCODER\_RCP\_out (Processor Interface)
- FPGA Interface: STEP\_DIR\_ENCODER\_RCP\_in (FPGA Interface)
- FPGA: STEP\_DIR\_ENCODER\_RCP (FPGA Main Component)
- FPGA Interface: STEP\_DIR\_ENCODER\_RCP\_out (FPGA Interface)
- Processor Interface: STEP\_DIR\_ENCODER\_RCP\_in (Processor Interface)

## Processor Output

### Block

Merges the processor signals and writes them to the FPGA.



Figure 29: STEP\_DIR\_ENCODER\_RCP\_out block

### Block Dialog

The processor output block provides the following dialog:



Figure 30: STEP\_DIR\_ENCODER\_RCP\_out dialog

The blockset dialog has the following parameters:



| Name                                                      | Unit | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Range                                                                           |
|-----------------------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Debounce time                                             | s    | Optional debounce time for digital input signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Dependent on FPGA clock rate (@100MHz:<br>Range 0...10.23µs<br>Resolution 10ns) |
| Use sample time based speed measurement if applicable     | -    | If this option is deactivated, the speed measurement will be performed by measuring the time elapsed between two identical edges.<br>If this option is activated, the speed is measured over multiple all periods of the incremental encoder signals which are passed within the last simulation step of this block.<br>This method is not applicable if less than 1 whole period is passed in 1 simulation step. In this case the standard method will be applied.                                                                                  | 0 1                                                                             |
| Resolution option for sample time based speed measurement | -    | Using this option, the resolution of a sample time based speed measurement can be specified. The option should be set according to the maximum possible sample time of this block.<br>The maximum sample time calculates as $T_{S FPGA} \cdot (2^{(16+x)} - 2)$<br>For DS5203 i.e. (100MHz) this means:<br>0: T < 0.655ms, res. 10ns<br>1: T < 1.310ms, res. 20ns<br>2: T < 2.621ms, res. 40ns<br>3: T < 5.242ms, res. 80ns<br>4: T < 10.48ms, res. 160ns<br>5: T < 20.97ms, res. 320ns<br>6: T < 41.94ms, res. 640ns<br>7: T < 83.89ms, res. 1,28µs | Range: 0...7<br>Resolution: 1                                                   |
| Index position                                            | °    | The absolute mechanical position of the index signal rising edge during forward movement.                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Range: 0...360°<br>Resolution: 0.005°                                           |
| Position for Interrupt trigger                            | °    | Specifies a position for an optional position interrupt on the FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Range: 0...360°<br>Resolution: 0.005°                                           |

|                          |   |                                                                                                                                                                                                                                                                                              |                                   |
|--------------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Define direction bit     |   | Specifies how the direction bit of the step/direction encoder has to be interpreted. 0 interprets a high signal as CCW (positive direction) and a low signal as CW (negative direction). 1 interprets a high signal as CW (negative direction) and a low signal as CCW (positive direction). | 0 1                               |
| Index Zero Crossing Mode |   | Specifies on which signal edge of the index signal the zero crossing is detected.<br>0: direction dependent (CCW: rising edge, CW: falling edge)<br>1: always on rising edge<br>2: always on falling edge                                                                                    | 0 1 2                             |
| Number of steps          | - | Number of steps of the step/direction encoder.                                                                                                                                                                                                                                               | Range: 1...32768<br>Resolution: 1 |
| Sample time FPGA         | s | Sample time of the FPGA                                                                                                                                                                                                                                                                      | -                                 |

**Input**

The STEP\_DIR\_ENCODER\_RCP\_out block has the following inputs:

| Name   | Unit | Description              | Range |
|--------|------|--------------------------|-------|
| Enable | -    | Sensor processing enable | 0 1   |

**Output**

The Processor Out block outputs three register contents, for register 1 two registers are processed by time multiplexing. The sectioning is shown below:

**Register 1.1**

Figure 31: STEP\_DIR\_ENCODER\_RCP\_out Register 1.1

| Name               | Bits  | Description                                                                                                 |
|--------------------|-------|-------------------------------------------------------------------------------------------------------------|
| Enable             | 0     | Enables the encoder processing                                                                              |
| Use_A_Rising       | 1     | Use rising edge of input signal A for speed measurement                                                     |
| Use_A_Falling      | 2     | Use rising edge of input signal A for speed measurement                                                     |
| Resolution_Option  | 7..5  | The resolution option described for the processor interface                                                 |
| Use_TS_Speed       | 8     | Activate the sample time based speed measurement described for the processor interface                      |
| Position_Increment | 30..9 | The increment of the position at each edge of an input signal. The FPGA main component section for details. |

### Register 1.2



Figure 32: STEP\_DIR\_ENCODER\_RCP\_out Register 1.2

| Name                | Bits   | Description                                                |
|---------------------|--------|------------------------------------------------------------|
| Enable              | 0      | Enables the encoder processing                             |
| No_of_Bits-1[13..0] | 14..1  | The lower 14 bits of the bit value of the edge counter - 1 |
| Index_Position      | 30..15 | The Position of the index signal scaled to 16 bit          |

### Register 2



Figure 33: STEP\_DIR\_ENCODER\_RCP\_out Register 2

| Name                       | Bits   | Description                                                                    |
|----------------------------|--------|--------------------------------------------------------------------------------|
| Interrupt_Position         | 15..0  | Position for an optional position interrupt, scaled to 16 bit.                 |
| Zero_Crossing_Mode         | 17..16 | Definition of the used zero crossing mode                                      |
| No_of_Bits-1[14]           | 18     | The 14th bit of the bit value of the edge counter - 1                          |
| Debounce_Time   Hysteresis | 28..19 | Debounce time for input digital signals or hysteresis for analog input signals |
| CCW_CW_Toggle              | 29     | Defines how the direction bit of the encoder is interpreted.                   |
| No_of_Bits-1[15]           | 30     | The MSB of the bit value of the edge counter - 1                               |

# FPGA Main Component

## Block



Figure 34: STEP\_DIR\_ENCODER\_RCP FPGA Main block

## Block Dialog

You can define the parameters of the input and output registers for automatic interface generation. The dialog also contains a button to start interface generation. For more details about automatic interface generation, refer to the XSG Utils documentation chapter Automatic Interface Generation. The FPGA clock period can be configured too.



**Input**

The main block has the following inputs:

| Name               | Unit   | Description                                                                                                                                                        | Format    |
|--------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Step               | Bit    | Step input signal of the encoder.                                                                                                                                  | Bool      |
| Dir                | Bit    | Direction input signal of the encoder.                                                                                                                             | Bool      |
| Index              | Bit    | Index input signal of the encoder.                                                                                                                                 | Bool      |
| Enable             | -      | Enables the encoder processing                                                                                                                                     | Bool      |
| Trig_Speed_Meas    | -      | Triggers the sample time based speed measurement                                                                                                                   | Bool      |
| Speed_Signals      | -      | Vector containing the flags [Step rising, Step falling] for the signal edges considered for speed measurement                                                      | Bool (2x) |
| Index_Position     | -      | Mechanical position of the index (rising edge during forward movement), scaled to 16 bit                                                                           | UFix_16_0 |
| Interrupt_Position | -      | Position for optional generation of a position interrupt, scaled to 16 bit                                                                                         | UFix_16_0 |
| Position_Increment | -      | The increment which has to be added to or subtracted from the current position (position scaled to 16 bit) in case of a signal edge                                | UFix_22_0 |
| Resolution_Option  | -      | The resolution option described for the processor interface                                                                                                        | UFix_3_0  |
| Use_Ts_Based_Speed | -      | Activates sample time based speed measurement                                                                                                                      | Bool      |
| No_of_Bits-1       | -      | The bit value needed for edge detection of the step signals – 1. (2*No_of_Steps)-1                                                                                 | UFix_15_0 |
| Debounce_Time      | Clocks | The debounce time of signal inputs.                                                                                                                                | UFix_10_0 |
| CCW_CW_Toggle      | Bit    | Defines how the direction bit of the encoder is interpreted.                                                                                                       | Bool      |
| Zero_Crossing_Mode | -      | Definition of the used zero crossing mode.<br>0: direction dependent (CCW: rising edge, CW: falling edge)<br>1: always on rising edge<br>2: always on falling edge | UFix_2_0  |

**Output**

The main block has the following outputs:

| Name                   | Unit   | Description                                                                                                                                                                    | Format     |
|------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| FPGASignalBus          | -      | Contains all output signals which are passed to the processor interface                                                                                                        | Bus        |
| Position               | -      | The calculated angle (0...360°), scaled to 0...1.                                                                                                                              | UFix_16_16 |
| Position_Valid         | -      | The valid flag is set to 1 after the index has been passed at least once and the position is referenced                                                                        | Bool       |
| Direction              | -      | The detected direction of the encoder movement. 0 = forward, 1 = backward                                                                                                      | Bool       |
| Pos_Delta_Based_Time   | -      | The number of clock cycles between two identical edges                                                                                                                         | UFix_28_0  |
| Pos_Delta_Based_Overfl | -      | Indicates that the time between two edges exceeds the maximum range                                                                                                            | Bool       |
| TS_Based_Time          | Clocks | The number of clock cycles for the last speed sample period                                                                                                                    | UFix_23_0  |
| TS_Based_Incr          | Edges  | The number of edges detected for the last speed sample period. A negative number of edges indicates backward movement                                                          | Fix_16_0   |
| TS_Based_Overflow      | -      | Indicates that the measurement time exceeds the maximum range                                                                                                                  | Bool       |
| Index_Crossing         | -      | Impulse indicating the detection of an index passing                                                                                                                           | Bool       |
| Position Interrupt     | -      | Impulse indicating that the specified interrupt position has been crossed. The output can be connected to an interrupt block of the RTI FPGA Programming Blockset if required. | Bool       |

## Processor Input

**Block** Adapts the FPGA signals for the processor side.



Figure 35: STEP\_DIR\_ENCODER\_RCP\_in block

### Block Dialog

The following parameters can be configured in the processor input dialog:



Figure 36: STEP\_DIR\_ENCODER\_RCP\_in dialog

The blockset dialog has the following parameters:

| Name                | Unit | Description             | Range |
|---------------------|------|-------------------------|-------|
| Sample time<br>FPGA | s    | Sample time of the FPGA | -     |

### Input

The processor input block has the following inputs:

**Register 1****Figure 37: STEP\_DIR\_ENCODER\_PROCESSING\_in Register 1**

| Name           | Bits  | Description                                                                                |
|----------------|-------|--------------------------------------------------------------------------------------------|
| Position       | 15..0 | The calculated angle, scaled to 16 bit                                                     |
| Position_Valid | 1     | The position valid flag (see main component)                                               |
| Use_Ts_Speed   | 31    | The flag for using the sample time based speed is passed back to the processor application |

**Register 2****Figure 38: STEP\_DIR\_ENCODER\_RCP\_in Register 2**

| Name                 | Bits   | Description                                                       |
|----------------------|--------|-------------------------------------------------------------------|
| Pos_Delta_Based_Time | 27..0  | The number of clock cycles between two identical edges            |
| Resolution_Option    | 30..28 | The resolution option is passed back to the processor application |
| Direction            | 31     | The direction bit (0 = forward, 1 = backward)                     |

**Register 3****Figure 39: STEP\_DIR\_ENCODER\_RCP\_in Register 3**

| Name          | Bits   | Description                                     |
|---------------|--------|-------------------------------------------------|
| Ts_Based_Time | 15..0  | Clock cycles for the last speed sample period   |
| Ts_Based_Incr | 31..16 | Edges detected for the last speed sample period |

**Register 4**

Figure 40: STEP\_DIR\_ENCODER\_RCP\_in Register 3

| Name         | Bits  | Description                                                                                         |
|--------------|-------|-----------------------------------------------------------------------------------------------------|
| No_of_Bits-1 | 15..0 | The bit value needed for edge detection of the step signals – 1. ( $2^{\text{No\_of\_Steps}} - 1$ ) |

**Output**

The INC\_ENCODER\_RCP\_in block has the following outputs:

| Name           | Unit | Description                                                                                              | Range                                                                           |
|----------------|------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Position       | °    | The angle calculated by the FPGA main component                                                          | Range: 0...360°<br>Resolution: 0.005°                                           |
| Speed          | rpm  | The speed calculated by the FPGA main component                                                          | Dependent on FPGA clock rate (@100MHz:<br>Range: >±0.17rpm<br>Resolution: 10ns) |
| Position_Valid | -    | The valid flag, which is raised as soon as the position is referenced (index is passed at least disable) | 0 1                                                                             |

# Hall Sensor Processing

## Objective

Hall sensors use the magnetic field of the rotor in order to determine its orientation. If three digital hall sensors are mounted around the rotor in steps of 120°, a segmentation of the electrical rotor position in steps of 60° (called sectors) can be made by the digital output of each sensor. Hall sensors always measure the electrical position of a motor. If the number of motor pole pairs is 1, the mechanical position is equal to the electrical position.



Figure 41: Hall sector mapping

## Angle Extrapolation

To obtain more precise angle information, the angle can be extrapolated using the velocity information. As

$$\omega = \frac{d\epsilon}{dt}$$

the angle can be calculated as

$$\epsilon = \int \omega dt + \epsilon_0$$

The start angle  $\epsilon_0$  is known when a hall edge occurs. As velocity is also determined the angle can be extrapolated. This procedure shows good results at constant velocities but fails on rapidly changing velocities.



Figure 42: Hall sensor processing with and without extrapolation

---

**Content**

The blockset contains the following elements:

- Processor Interface: HALL\_SENSOR\_RCP\_out  
(Processor Interface)
- FPGA Interface: HALL\_SENSOR\_RCP\_in  
(FPGA Interface)
- FPGA: HALL\_SENSOR\_RCP  
(FPGA Main Component)
- FPGA Interface: HALL\_SENSOR\_RCP\_out  
(FPGA Interface)
- Processor Interface: HALL\_SENSOR\_RCP\_in  
(Processor Interface)

## Processor Output

|              |                                                           |
|--------------|-----------------------------------------------------------|
| <b>Block</b> | Merges the processor signals and writes them to the FPGA. |
|--------------|-----------------------------------------------------------|



Figure 43: HALL\_SENSOR\_RCP\_out block

### Block Dialog

The processor output block provides the following dialog:



Figure 44: HALL\_SENSOR\_RCP\_out dialog



The blockset dialog has the following parameters:

| Name                            | Unit | Description                                                                                                                                                                                                                                                                                                                                                                                                         | Range                                                                           |
|---------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Debounce time                   | s    | Optional debounce time for analog or digital input signals                                                                                                                                                                                                                                                                                                                                                          | Dependent on FPGA clock rate (@100MHz:<br>Range 0...10.23µs<br>Resolution 10ns) |
| Use sector time for speed meas. | -    | 0 = The speed is measured by evaluating the time elapsed for a whole electrical revolution. This time measurement is the most accurate, but has a high measurement dead time. It is updated with every Hall edge<br>1 = The speed is measured by evaluating the time elapsed for a single Hall sector. This measurement is less accurate but infers less measurement dead time. It is updated with every Hall edge. | 0 1                                                                             |
| Minimum speed for extrapolation | rpm  | For low speeds, angle extrapolation does not provide accurate results. According to this, a minimum speed for angle extrapolation can be defined. If this parameter is set to 0, angle extrapolation will be deactivated                                                                                                                                                                                            | Dependent on FPGA clock rate (@100MHz:<br>Range: > 1.4 rpm<br>Resolution: 40ns) |
| Sector start angles             | °    | The start angles for each Hall sector of the motor setup can be defined. The start angle is defined as the angle where the sector is entered in forward movement (left side in the diagram). All combinations of sectors are possible.                                                                                                                                                                              | Range: 0...360°<br>Resolution: 0.005°                                           |
| Position for Interrupt trigger  | °    | Specifies a position for an optional position interrupt on the FPGA                                                                                                                                                                                                                                                                                                                                                 | Range: 0...360°<br>Resolution: 0.005°                                           |
| Sample time FPGA                | s    | Sample time of the FPGA                                                                                                                                                                                                                                                                                                                                                                                             | -                                                                               |

**Input**

The HALL\_SENSOR\_RCP\_out block has the following inputs:

| Name   | Unit | Description              | Range |
|--------|------|--------------------------|-------|
| Enable | -    | Sensor processing enable | 0 1   |

**Output**

The Processor Out block outputs eight register contents, mapped to four registers by time multiplexing. The sectioning is shown below:

**Register 1.1**

Figure 45: HALL\_SENSOR\_RCP\_out Register 1.1

| Name               | Bits   | Description                                                    |
|--------------------|--------|----------------------------------------------------------------|
| Enable             | 0      | Enables the encoder processing                                 |
| Debounce_Time      | 10..1  | Debounce time for input signals                                |
| Speed_Option       | 11     | 0 = use revolution time<br>1 = use sector time                 |
| Interrupt_Position | 27..12 | Position for an optional position interrupt, scaled to 16 bit. |
| SPARE              | 30..28 | Use rising edge of input signal B for speed measurement        |

**Register 1.2**

Figure 46: HALL\_SENSOR\_RCP\_out Register 1.2

| Name         | Bits  | Description                                                                                                                                                                   |
|--------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable       | 0     | Enables the encoder processing                                                                                                                                                |
| Max_Rev_Time | 30..1 | The maximum number of clocks per revolution to apply angle extrapolation. The value is derived from the minimum speed defined by the block mask of the processor output block |

**Register 2.1**

Figure 47: HALL\_SENSOR\_RCP\_out Register 2.1

| Name          | Bits   | Description                                                                                                                    |
|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| Sector1_Start | 13..0  | The sector start angle, scaled to 14 bit                                                                                       |
| Sector1_Mult  | 27..14 | A multiplication factor which is calculated according to the sector length in order to derive revolution time from sector time |
| Sector1_Hall  | 30..28 | The state of the Hall signals A, B, C which define the sector. LSB is Hall signal A                                            |

### Register 2.2



Figure 48: HALL\_SENSOR\_RCP\_out Register 2.2

| Name          | Bits   | Description                                                                                                                    |
|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| Sector2_Start | 13..0  | The sector start angle, scaled to 14 bit                                                                                       |
| Sector2_Mult  | 27..14 | A multiplication factor which is calculated according to the sector length in order to derive revolution time from sector time |
| Sector2_Hall  | 30..28 | The state of the Hall signals A, B, C which define the sector. LSB is Hall signal A                                            |

### Register 3.1



Figure 49: HALL\_SENSOR\_RCP\_out Register 3.1

| Name          | Bits   | Description                                                                                                                    |
|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| Sector3_Start | 13..0  | The sector start angle, scaled to 14 bit                                                                                       |
| Sector3_Mult  | 27..14 | A multiplication factor which is calculated according to the sector length in order to derive revolution time from sector time |
| Sector3_Hall  | 30..28 | The state of the Hall signals A, B, C which define the sector. LSB is Hall signal A                                            |

### Register 3.2



Figure 50: HALL\_SENSOR\_RCP\_out Register 3.2

| Name          | Bits   | Description                                                                                                                    |
|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| Sector4_Start | 13..0  | The sector start angle, scaled to 14 bit                                                                                       |
| Sector4_Mult  | 27..14 | A multiplication factor which is calculated according to the sector length in order to derive revolution time from sector time |
| Sector4_Hall  | 30..28 | The state of the Hall signals A, B, C which define the sector. LSB is Hall signal A                                            |

**Register 4.1**

Figure 51: HALL\_SENSOR\_PROCESSING\_out Register 4.1

| Name          | Bits   | Description                                                                                                                    |
|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| Sector5_Start | 13..0  | The sector start angle, scaled to 14 bit                                                                                       |
| Sector5_Mult  | 27..14 | A multiplication factor which is calculated according to the sector length in order to derive revolution time from sector time |
| Sector5_Hall  | 30..28 | The state of the Hall signals A, B, C which define the sector. LSB is Hall signal A                                            |

**Register 4.2**

Figure 52: HALL\_SENSOR\_PROCESSING\_out Register 4.2

| Name          | Bits   | Description                                                                                                                    |
|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| Sector6_Start | 13..0  | The sector start angle, scaled to 14 bit                                                                                       |
| Sector6_Mult  | 27..14 | A multiplication factor which is calculated according to the sector length in order to derive revolution time from sector time |
| Sector6_Hall  | 30..28 | The state of the Hall signals A, B, C which define the sector. LSB is Hall signal A                                            |

## FPGA Main Component

### Block



Figure 53: HALL\_SENSOR\_RCP FPGA Main block

### Block Dialog

You can define the parameters of the input and output registers for automatic interface generation. The dialog also contains a button to start interface generation. For more details about automatic interface generation, refer to the XSG Utils documentation chapter Automatic Interface Generation. The FPGA clock period can be configured too.

**Input**

The main block has the following inputs:

| Name               | Unit   | Description                                                                                                                                                                                          | Format          |
|--------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| A                  | -      | Hall input signal A                                                                                                                                                                                  | Bool            |
| B                  | -      | Hall input signal B                                                                                                                                                                                  | Bool            |
| C                  | -      | Hall input signal C                                                                                                                                                                                  | Bool            |
| Enable             | -      | Enables the sensor processing                                                                                                                                                                        | Bool            |
| Debounce_Time      | Clocks | The debounce time of signal inputs.                                                                                                                                                                  | UFix_10_0       |
| Speed_Option       | -      | The time measurement for speed calculation, which will be provided for the processor application<br>0 = revolution time<br>1 = sector time                                                           | Bool            |
| Interrupt_Position | -      | Position for optional generation of a position interrupt, scaled to 16 bit                                                                                                                           | UFix_16_0       |
| Max_Rev_Time       | Clocks | The maximum number of clocks per revolution to apply angle extrapolation. The value is derived from the minimum speed defined by the block mask of the processor output block                        | UFix_32_0       |
| Sector_Start       | -      | The start angles for all sectors, sorted in ascending order                                                                                                                                          | UFix_16_0 (6x)  |
| Sector_Hall        | -      | The state of the Hall signals A, B, C which define the sectors. LSB is Hall signal A                                                                                                                 | UFix_3_0 (6x)   |
| Speed_Mult         | -      | A multiplication factor which is calculated according to the sector length in order to derive revolution time from sector time (if all sectors have the same length, all factors have the value 6.0) | UFix_14_10 (6x) |

**Output**

The main block has the following outputs:

| Name               | Unit   | Description                                                                                                                                                                                                                    | Format     |
|--------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| FPGASignalBus      | -      | Contains all output signals which are passed to the processor interface                                                                                                                                                        | Bus        |
| Position           | -      | The calculated angle (0...360°), scaled to 0...1                                                                                                                                                                               | UFix_16_16 |
| Direction          | -      | The detected direction of the encoder movement.<br>0 = forward, 1 = backward                                                                                                                                                   | Bool       |
| Revolution_Time    | Clocks | The number of clock cycles for an electrical revolution. The measurement is based on a whole mechanical revolution and is updated with each Hall edge.                                                                         | UFix_35_0  |
| Sector_Time        | Clocks | The number of clock cycles for an electrical revolution. The measurement is based on the last sector completed and is updated with each Hall edge.                                                                             | UFix_35_0  |
| Sector_Number      | -      | The number of the current Hall sector. Sector 1 is the sector with the lowest start angle, while sector 6 is the sector with the highest start angle. If the output is 0, the Hall input signals are invalid (all 0 or all 1). | UFix_3_0   |
| Position Interrupt | -      | Impulse indicating that the specified interrupt position has been crossed. The output can be connected to an interrupt block of the RTI FPGA Programming Blockset if required.                                                 | Bool       |

## Processor Input

**Block** Adapts the FPGA signals for the processor side.



Figure 54: HALL\_SENSOR\_RCP\_in block

**Block Dialog**

The following parameters can be configured in the processor input dialog:



Figure 55: HALL\_SENSOR\_RCP\_in dialog

The blockset dialog has the following parameters:

| Name                | Unit | Description             | Range |
|---------------------|------|-------------------------|-------|
| Sample time<br>FPGA | s    | Sample time of the FPGA | -     |

**Input**

The processor input block has the following inputs:

**Register 1**

**Figure 56: HALL\_SENSOR\_RCP\_in Register 1**

| Name          | Bits   | Description                            |
|---------------|--------|----------------------------------------|
| Position      | 15..0  | The calculated angle, scaled to 16 bit |
| Sector_Number | 18..16 | The number of the current sector       |
| Hall_A_Deb    | 19     | The debounced Hall input signal A      |
| Hall_B_Deb    | 20     | The debounced Hall input signal B      |
| Hall_C_Deb    | 20     | The debounced Hall input signal C      |

**Register 2**

**Figure 57: HALL\_SENSOR\_RCPG\_in Register 2**

| Name            | Bits  | Description                                                                                                                                                                                                                             |
|-----------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Revolution_Time | 29..0 | The number of clock cycles for 1 electrical revolution                                                                                                                                                                                  |
| Downscale       | 30    | Flag indicating, that the revolution time is downscaled by a factor of 32. This is used when the 30 bit register space is too small for the number of clocks per revolution. This way, lower revolution times (< 1 rpm) can be measured |
| Direction       | 31    | The direction bit (0 = forward, 1 = backward)                                                                                                                                                                                           |

**Output**

The HALL\_SENSOR\_RCP\_in block has the following outputs:

| Name          | Unit | Description                                                                                                                                                                                                                    | Range                                                                           |
|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Position      | °    | The angle calculated by the FPGA main component                                                                                                                                                                                | Range: 0...360°<br>Resolution: 0.005°                                           |
| Speed         | rpm  | The speed calculated by the FPGA main component                                                                                                                                                                                | Dependent on FPGA clock rate (@100MHz:<br>Range: >±0.17rpm<br>Resolution: 10ns) |
| Sector_Number | -    | The number of the current Hall sector. Sector 1 is the sector with the lowest start angle, while sector 6 is the sector with the highest start angle. If the output is 0, the Hall input signals are invalid (all 0 or all 1). | 1...6                                                                           |
| Hall State    | -    | Bus containing the debounced Hall input signals A, B, C                                                                                                                                                                        | 0 1 (3x)                                                                        |

## EnDat 2.1 Processing

---

**Objective** The EnDat interface from HEIDENHAIN is a digital, bidirectional interface for encoders. It is capable of transmitting position values from incremental and absolute encoders as well as transmitting or updating information stored in the encoder, or saving new information. Due to the serial transmission method only four signal lines are required.

---

**Content** The blockset contains the following elements:

- Processor Interface: ENDAT\_RCP\_out  
(Processor Interface)
- FPGA Interface: ENDAT\_RCP\_in  
(FPGA Interface)
- FPGA: ENDAT\_RCP  
(FPGA Main Component)
- FPGA Interface: ENDAT\_RCP\_out  
(FPGA Interface)
- Processor Interface: ENDAT\_RCP\_in  
(Processor Interface)

## Processor Output

### Block

Merges the processor signals and writes them to the FPGA.



Figure 58: ENDAT\_RCP\_out block

### Block Dialog

The processor output block provides the following dialog:



Figure 59: ENDAT\_RCP\_out dialog

The blockset dialog has the following parameters:

| Name                                 | Unit | Description                                                                                                                                                                                                                                                  | Range                                          |
|--------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| Counter-clockwise Rotation           | -    | The default orientation is defined as follows:<br>Clockwise rotation (front view of the motor shaft) means forward rotation.<br>Setting this value to one inverts rotor position determination.                                                              | 0 1                                            |
| Singleturn Resolution                | -    | Specifies the angular resolution of the encoder used in bit.                                                                                                                                                                                                 | Range: 1..32                                   |
| Multiturn Resolution                 | -    | Specifies the resolution for the revolution number of the encoder used in bit.                                                                                                                                                                               | Range: 0..31                                   |
| Serial Frequency                     | Hz   | The clock frequency of the serial data transfer. The frequency should be chosen according to the sensor data sheet and cable length.                                                                                                                         | Range: 100,000...<br>5,000,000<br>1/FPGA_clock |
| Synchronize to Real-Time Application |      | If this option is set the data transfer of a new position sample will be triggered with the call of this block. Otherwise the data transfer will be triggered as often as possible. A synchronous data transfer can have advantages for velocity processing. | 0 1                                            |
| Sample time FPGA                     | s    | Sample time of the FPGA                                                                                                                                                                                                                                      | -                                              |
| Processor fixed step size            |      | The processor sample time for offline simulation.                                                                                                                                                                                                            | -                                              |

**Input**

The ENDAT\_RCP\_out block has the following inputs:

| Name   | Unit | Description              | Range |
|--------|------|--------------------------|-------|
| Enable | -    | Sensor processing enable | 0 1   |

**Output**

The Processor Out block outputs two registers. The sectioning is shown below:

**Register 1:**

Figure 60: ENDAT\_RCP\_out Register 1

| Name             | Bits   | Description                                                                                                 |
|------------------|--------|-------------------------------------------------------------------------------------------------------------|
| Enable           | 0      | Enables the sensor processing                                                                               |
| SingleTurnRes-1  | 5..1   | Singleturn Resolution -1 for the Endat Proccessing.                                                         |
| MultiTurnRes     | 6..10  | Multiturn Resolution for the EnDat Processing.                                                              |
| SerialFrequency  | 23..11 | Clock frequency of the EnDat core in clocks.                                                                |
| Trigger_Mode     | 24     | Enable/disable triggered mode.<br>0: <i>Continuous mode</i><br>1: <i>Triggered by processor application</i> |
| Trigger          | 25     | Trigger bit from the processor, if trigger mode is enabled.                                                 |
| CounterClockwise | 26     | If '1', it reverses the interpretation of the position sent by the sensor.                                  |

**Register 2:**

Figure 61: ENDAT\_RCP\_out Register 2

| Name           | Bits   | Description                                                                           |
|----------------|--------|---------------------------------------------------------------------------------------|
| Delay_Error    | 0..15  | The amount of clock counts that will be waited in presence of a communication error.  |
| Delay_Standard | 16..31 | The amount of clock counts that will be waited in standard cases before transmitting. |

## FPGA Main Component

### Block



Figure 62: ENDAT\_RCP FPGA Main block

### Block Dialog

You can define the parameters of the input and output registers for automatic interface generation. The dialog also contains a button to start interface generation. For more details about automatic interface generation, refer to the XSG Utils documentation chapter Automatic Interface Generation. The FPGA clock period can be configured too.

---

| Input | Name                  | Unit   | Description                                                                           | Format    |
|-------|-----------------------|--------|---------------------------------------------------------------------------------------|-----------|
|       | Input_Data            | -      | Serial data bit received by an EnDat sensor.                                          | Bool      |
|       | Trigger               | -      | Triggers an EnDat cycle.                                                              | Bool      |
|       | Multiturn             | -      | Enables or disables multiturn mode.                                                   | Bool      |
|       | Serial_Clk_Period     | Clocks | Length of an EnDat clock in clocks.                                                   | UFix_13_0 |
|       | Singleturn_Resolution | -      | The EnDat sensor's singleturn resolution                                              | UFix_5_0  |
|       | Multiturn_Resolution  | -      | The EnDat sensor's multiturn resolution                                               | UFix_5_0  |
|       | Delay_Error           | Clocks | The amount of clock counts that will be waited in presence of a communication error.  | UFix_16_0 |
|       | Delay_Standard        | Clocks | The amount of clock counts that will be waited in standard cases before transmitting. | UFix_16_0 |
|       | Enable                | -      | Enables the XSG block.                                                                | Bool      |

---

**Output**

The main block has the following outputs:

| Name                  | Unit | Description                                                                                                                                | Format     |
|-----------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------|------------|
| FPGASignalBus         | -    | Contains all output signals which are passed to the processor interface                                                                    | Bus        |
| Output_Data           | -    | Serial bits that should be transmitted to the EnDat sensor                                                                                 | Bool       |
| Drive_Enable          | -    | Flag that indicates, that the Data line of the EnDat interface should be driven with Output_Data (1). Otherwise Data will be received (0). | Bool       |
| Position              | -    | Current position transmitted by the EnDat sensor. The position is normalized from 0 .. 1.                                                  | UFix_32_32 |
| Multiturn_Revolutions | -    | Current revolution transmitted by the EnDat sensor                                                                                         | UFix_31_0  |
| Error                 | -    | Flag that indicates a communication error                                                                                                  | Bool       |
| Update                | -    | Indicates refreshed output values                                                                                                          | Bool       |
| Clock                 | -    | The generated clock signal bit. Has to be connected to the EnDat clock line.                                                               | Bool       |

## Processor Input

**Block** Adapts the FPGA signals for the processor side.



Figure 63: ENDAT\_RCP\_in block

**Input**

The processor input block has the following inputs:

**Register 1**

**Figure 64: ENDAT\_RCP\_in Register 1**

| Name     | Bits  | Description                                                                              |
|----------|-------|------------------------------------------------------------------------------------------|
| Position | 31..0 | The calculated, normalized position angle, scaled to 32 bit which corresponds to 0 to 1. |

**Register 2**

**Figure 65: ENDAT\_RCP\_in Register 2**

| Name                 | Bits  | Description                                                                                                       |
|----------------------|-------|-------------------------------------------------------------------------------------------------------------------|
| Multiturn_Revolution | 30..0 | The number of revolutions sent by the EnDat sensor. The number depends on the Multiturn resolution of the sensor. |
| Error                | 31    | Flag that indicates a communication error.                                                                        |

**Output**

The ENDAT\_RCP\_in block has the following outputs:

| Name     | Unit | Description                                                                                                                                         | Range                                                                    |
|----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| Position | °    | This output provides the current mechanical angle (single-turn) in degrees. The angle provided is absolute as soon as the index signal is detected. | Singleturn: 0° .. <360°<br>Multiturn: 0° .. (MultiturnRevolution+1)*360° |
| Error    | -    | Indicates that the sensor sets the error bit in the position frame or time-out while waiting for the start bit.                                     | 0 1                                                                      |

# Resolver & LVDT Processing

## Objective

The Resolver and Processing is used to derive position and velocity by decoding the output of both resolvers and LVDT sensors. It is able to generate an excitation signal of variable frequency and amplitude. The resolver processing is capable of working with the self-generated excitation, as well as with an externally generated excitation. In addition to the position and speed processing, a signal analysis is performed, detecting amplitudes, offsets and phase shifts between the signals. Offsets and phase shifts can automatically be compensated to increase accuracy.

## Resolver Processing

Resolvers provide precise information about the absolute mechanical rotor position. A resolver mainly consists of three coils, a rotor and two stator coils. Either the rotor or the stator coils are excited with a sinusoidal signal which causes a position-dependent induction signal in the remaining coils. The angle is determined by calculating the arc tangent of  $S_1$  by  $S_2$  (also called "sine" and "cosine"). The best moment to calculate the arc tangent is during the extremes of the excitation signal, while it is undefined in the zero crossings of the excitation.



Figure 66: Resolver shape over 360°

## LVDT Processing

LVDTs (Linear Variable Differential Transformer) consist of a primary coil and one or two secondary coils. LVDTs are used to measure linear displacement. There are two general types: 4-wire and 5-wire LVDT. 4-wire LVDTs have only one secondary coil (A). 5-wire LVDTs have two secondary coils (A, B), which are connected in serial.

For 4-wire LVDT the position is calculated as  $A / EXC$ . For 5-wire LVDT the position is calculated as  $(A-B) / (A+B)$ . The best moment to calculate the position is during the extremes of the excitation signal, while it is undefined in the zero crossings of the excitation.

**Amplifier Module for Resolver & LVDT**

To provide an excitation signal to a resolver or LVDT, additional signal conditioning is required. This can be achieved by connecting a DS5346 amplifier module to the DAC output of the FPGA board or I/O module used.



**Figure 67: DS5346 amplifier module**

The most important electrical characteristics of the DS5346 are listed in the table below. For more detailed information, please refer to the DS5346 data sheet.

| Property                      | Value    | Unit       |
|-------------------------------|----------|------------|
| Number of channels            | 2        | -          |
| Input voltage range           | $\pm 10$ | V          |
| Gain (optional)               | 1.2      | -          |
| Maximum supply current output | 60       | mA         |
| Input resistance              | 20       | k $\Omega$ |
| Over-voltage protection       | $\pm 50$ | V          |
| Supply voltage                | $\pm 15$ | V          |

---

**Content**

The blockset contains the following elements:

- Processor Interface: RESOLVER\_LVDT\_RCP\_out  
(Processor Interface)
- FPGA Interface: RESOLVER\_LVDT\_RCP\_in  
(FPGA Interface)
- FPGA: RESOLVER\_LVDT\_RCP  
(FPGA Main Component)
- FPGA Interface: RESOLVER\_LVDT\_RCP\_out  
(FPGA Interface)
- Processor Interface: RESOLVER\_LVDT\_RCP\_in  
(Processor Interface)

## Processor Output

---

|              |                                                          |
|--------------|----------------------------------------------------------|
| <b>Block</b> | Merges the processor signals and writes them to the FPGA |
|--------------|----------------------------------------------------------|



Figure 68: RESOLVER\_LVDT\_RCP\_out block

**Block Dialog**

The processor output block provides the following dialog:



Figure 69: RESOLVER\_LVDT\_RCP\_out dialog

The blockset dialog has the following parameters:

| Name                                                 | Unit       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Range                             |
|------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Minimum excitation magnitude for position sampling   | Bit (LSBs) | Set the threshold sampling the position. The position will be sampled when the current magnitude of the excitation exceeds the specified value. If this parameter is set to 0, the position will only be sampled at the maxima and minima of the excitation.                                                                                                                                                                                                                   | Range: 0...32767<br>Resolution: 1 |
| Minimum signal amplitude for phase shift measurement | Bit (LSBs) | The phase shift measurement is not possible in position ranges where the amplitude of the secondary coils is nearly zero. The higher the position-dependent amplitude of the sine/cosine or A/B signals, the more accurate the phase shift measurement. A minimum signal amplitude can be defined, for which a phase shift measurement is valid. If the amplitude of a signal does not exceed this threshold, no measurement will be performed and the output stays unchanged. | Range: 0...32767<br>Resolution: 1 |
| Extrapolation                                        | -          | Setting this parameter to 1 enables extrapolation of the position at the times when no valid arctan measurement can be performed (e.g. near the zero crossing of the excitation)                                                                                                                                                                                                                                                                                               | 0 1                               |
| Phase shift compensation                             | -          | Setting this parameter to 1 enables automatic phase shift compensation between sine/A and cosine/B as well as excitation. Phase shift compensation is only valid in a phase shift range of 1000 FPGA clocks.                                                                                                                                                                                                                                                                   | 0 1                               |
| Sensor type                                          | -          | 0 = Resolver<br>1 = LVDT                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0 1                               |

|                                   |            |                                                                                                                                                                                                                                                                |                                                                                   |
|-----------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| LVDT type                         | -          | In case of LVDT processing, the type of LVDT sensor can be specified:<br>0 = 4-wire<br>1 = 5-wire                                                                                                                                                              | 0 1                                                                               |
| Input signal filter time constant | -          | All analog signals are filtered with a discrete PT1 to reduce noise. The filter time constant can be selected by the user.                                                                                                                                     | Dependent on FPGA clock rate (@100MHz:<br>Range:160ns..10μs<br>Resolution: 10ns)  |
| Speed averaging option            |            | The speed measurement is performed twice per excitation period. To receive higher accuracy multiple speed samples can be averaged on the FPGA. The number of samples to average calculates to $2^x$ , where x is the speed averaging option in the block mask. | Range: 0...7<br>Resolution: 1                                                     |
| Frequency of generated excitation | Hz         | The frequency of the excitation signal to be generated                                                                                                                                                                                                         | Dependent on FPGA clock rate (@100MHz:<br>Range:1kHz...30kHz<br>Resolution: 10ns) |
| Amplitude of generated excitation | Bit (LSBs) | The Amplitude of the generated excitation signal, scaled in LSBs of the DAC raw output.                                                                                                                                                                        | Range: 0...32767<br>Resolution: 1                                                 |
| DC offset of generated excitation | Bit (LSBs) | Optional DC offset for the generated excitation, e.g. for external offset compensation                                                                                                                                                                         | Range:-8192..8191<br>Resolution: 1                                                |
| Sample time FPGA                  | s          | Sample time of the FPGA                                                                                                                                                                                                                                        | -                                                                                 |

**Input**

The RESOLVER\_LVDT\_RCP\_out block has the following inputs:

| Name   | Unit | Description              | Range |
|--------|------|--------------------------|-------|
| Enable | -    | Sensor processing enable | 0 1   |

**Output**

The Processor Out block outputs four register contents, mapped to two registers by time multiplexing. The sectioning is shown below:

**Register 1.1**

Figure 70: RESOLVER\_LVDT\_RCP\_out Register 1.1

| Name              | Bits   | Description                                            |
|-------------------|--------|--------------------------------------------------------|
| Enable            | 0      | Enables the encoder processing                         |
| Gen_Exc_Frequency | 17..1  | The excitation frequency, scaled to the FPGA raw value |
| SPARE             | 30..18 | -                                                      |

**Register 1.2**

Figure 71: RESOLVER\_LVDT\_RCP\_out Register 1.2

| Name             | Bits   | Description                                                            |
|------------------|--------|------------------------------------------------------------------------|
| Enable           | 0      | Enables the encoder processing                                         |
| Gen_Exc_Offset   | 14..1  | The offset of the excitation output signal, scaled with a bias of 8192 |
| Averaging_Option | 18..15 | The option for averaging for speed measurement samples.                |
| SPARE            | 30..19 | -                                                                      |

**Register 2.1**

Figure 72: RESOLVER\_LVDT\_RCP\_out Register 2.1

| Name              | Bits   | Description                                      |
|-------------------|--------|--------------------------------------------------|
| Exc_Out_Amplitude | 14..0  | The amplitude of the generated excitation signal |
| Delay_Compens     | 15     | Phase shift compensation enable bit              |
| Sensor_Type       | 16     | 0 = Resolver, 1 = LVDT                           |
| LVDT_Type         | 17     | 0 = 4-wire, 1 = 5-wire                           |
| F_Filter          | 30..18 | The PT1 filter frequency, scaled to 13 bit       |

**Register 2.2**

Figure 73: RESOLVER\_LVDT\_RCP\_out Register 2.2

| Name                      | Bits   | Description                                                       |
|---------------------------|--------|-------------------------------------------------------------------|
| Delay_Measure_Threshold   | 14..0  | Signal amplitude threshold for measuring phase shifts             |
| Position_Sample_Threshold | 29..15 | Excitation magnitude threshold for sampling the resolver position |
| Extrapolation             | 30     | Extrapolation enable bit                                          |

## FPGA Main Component

### Block



Figure 74: RESOLVER\_LVDT\_RCP FPGA Main block

### Block Dialog

You can define the parameters of the input and output registers for automatic interface generation. The dialog also contains a button to start interface generation. For more details about automatic interface generation, refer to the XSG Utils documentation chapter Automatic Interface Generation. The FPGA clock period can be configured too.

**Input**

The main block has the following inputs:

| Name                      | Unit | Description                                                                                                                                    | Format     |
|---------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| Sine A                    | Bit  | Sine input (resolver) or input signal A (LVDT)                                                                                                 | Fix_16_0   |
| Cosine B                  | Bit  | Cosine input (resolver) or input signal B (LVDT)                                                                                               | Fix_16_0   |
| Excitation_In             | Bit  | Input for excitation. If self-generated excitation is used, connect this input to the excitation output (either directly or across analog I/O) | Fix_16_0   |
| Enable                    | -    | Enables the sensor processing                                                                                                                  | Bool       |
| Sensor_Type               | -    | 0 = Resolver, 1 = LVDT                                                                                                                         | Bool       |
| LVDT_Type                 | -    | 0 = 4-wire, 1 = 5-wire<br>In case of resolver processing this input will be ignored                                                            | Bool       |
| Delay_Measure_Threshold   | -    | The threshold for phase shift measurement as described in the processor interface section                                                      | UFix_15_0  |
| Position_Sample_Threshold | -    | The position sampling threshold as described in the processor interface section                                                                | UFix_15_0  |
| Extrapolation             | -    | Extrapolation enable                                                                                                                           | Bool       |
| Delay_Compensation        | -    | Phase shift compensation enable                                                                                                                | Bool       |
| f_Filter                  | -    | The input signal PT1 filter frequency in the unit 1/clocks                                                                                     | UFix_18_18 |
| Gen_Exc_Frequency         | -    | The frequency for the generated excitation, scaled to the FPGA raw input value                                                                 | UFix_17_14 |
| Gen_Exc_Amplitude         | Bit  | The amplitude for the generated excitation                                                                                                     | UFix_15_0  |
| Gen_Exc_Offset            | Bit  | The DC offset for the generated excitation                                                                                                     | Fix_14_0   |

---

**Output**

The main block has the following outputs:

| Name             | Unit   | Description                                                                                                                                                      | Format    |
|------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| FPGASignalBus    | -      | Contains all output signals which are passed to the processor interface                                                                                          | Bus       |
| Output_Valid     | -      | Flag indicating that the output are valid, which is the case after 2 valid excitation periods                                                                    | Bool      |
| Position         | -      | The calculated position. In case of resolver the position is scaled in the full range of 16 bit (0...65535), in case of LVDT the position is in the range -1...1 | UFix_16_0 |
| Delta_Pos        | -      | The position change between 2 equal edges of the excitation signal                                                                                               | Fix_16_0  |
| Delta_T          | Clocks | The number of clock cycles between 2 equal edges of the excitation signal                                                                                        | UFix_17_0 |
| Sin A_Delay      | Clocks | The delay between the excitation and sine/A. If the excitation is later than sine/A, the delay is negative.                                                      | Fix_17_0  |
| Cos B_Delay      | Clocks | The delay between the excitation and cosine/B. If the excitation is later than cosine/B, the delay is negative.                                                  | Fix_17_0  |
| Sin A_Amplitude  | Bit    | The position-dependent amplitude of sine/A                                                                                                                       | UFix_15_0 |
| Cos B_Amplitude  | Bit    | The position-dependent amplitude of cosine/B                                                                                                                     | UFix_15_0 |
| Exc_in_Amplitude | Bit    | The measured amplitude of the excitation input                                                                                                                   | UFix_15_0 |
| Sin A_Offset     | Bit    | The DC offset measured for sine/A input                                                                                                                          | Fix_14_2  |
| Cos B_Offset     | Bit    | The DC offset measured for cosine/B input                                                                                                                        | Fix_14_2  |
| Exc_In_Offset    | Bit    | The DC offset measured for excitation input                                                                                                                      | Fix_14_2  |
| Exc_In_Period    | Clocks | The measured number of clock cycles of the excitation input period                                                                                               | UFix_17_0 |

|                      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |
|----------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Phase_Shift_Flags    | -   | A Bus containing the following status signals:<br>(1) <i>Sin A_Meas_Active</i><br>This flag indicates that the phase shift measurement for sine/A is currently performed<br>(2) <i>Cos B_Meas_Active</i><br>This flag indicates that the phase shift measurement for cosine/B is currently performed<br>(3) <i>Delay_Meas_Valid</i><br>This flag indicates that phase shift measurements for all relevant signals have been performed at least once<br>(4) <i>Phase_Shift_Compens.</i><br>This flag indicates that the phase shifts are within a compensable range (< 1000 clock cycles) | Bool (4x) |
| Exc_Extremum         | -   | Impulse occurring at maxima and minima of excitation input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Bool      |
| Exc_Zero_Cross       | -   | Impulse occurring at zero crossings of excitation input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Bool      |
| Generated_Excitation | Bit | The generated excitation signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Fix_14_0  |

## Processor Input

**Block** Adapts the FPGA signals for the processor side.



Figure 75: RESOLVER\_LVDT\_RCP\_in block

### Block Dialog

The following parameters can be configured in the processor input dialog:



Figure 76: RESOLVER\_LVDT\_RCP\_in dialog

The blockset dialog has the following parameters:

| Name                | Unit | Description             | Range |
|---------------------|------|-------------------------|-------|
| Sample time<br>FPGA | s    | Sample time of the FPGA | -     |

**Input**

The processor input block has the following inputs:

**Register 1**

Figure 77: RESOLVER\_LVDT\_RCP\_in Register 1

| Name          | Bits   | Description                                                     |
|---------------|--------|-----------------------------------------------------------------|
| Position      | 15..0  | The calculated angle, scaled to 0..65535                        |
| Exc_In_Offset | 29..16 | The DC offset measured for the excitation input                 |
| Sensor_Type   | 30     | The sensor type is forwarded to the processor input for scaling |
| Output_Valid  | 31     | The output valid flag                                           |

**Register 2**

Figure 78: RESOLVER\_LVDT\_RCP\_in Register 2

| Name      | Bits   | Description                                                               |
|-----------|--------|---------------------------------------------------------------------------|
| Delta_T   | 16..0  | The number of clock cycles between 2 equal edges of the excitation signal |
| Delta_Pos | 31..17 | The position change between 2 equal edges of the excitation signal        |

**Register 3**

Figure 79: RESOLVER\_LVDT\_RCP\_in Register 3

| Name           | Bits   | Description                                                                                      |
|----------------|--------|--------------------------------------------------------------------------------------------------|
| Sin A_Offset   | 13..0  | The DC offset measured for sine/A input                                                          |
| Sin A_Meas_Act | 14     | Status bit indicating that a phase shift measurement is currently performed for the sine/A input |
| Sin A_Delay    | 31..15 | The delay between the excitation and sine/A                                                      |

**Register 4**

Figure 80: RESOLVER\_LVDT\_RCP\_in Register 4

| Name           | Bits   | Description                                                                                        |
|----------------|--------|----------------------------------------------------------------------------------------------------|
| Cos B_Offset   | 13..0  | The DC offset measured for cosine/B input                                                          |
| Cos B_Meas_Act | 14     | Status bit indicating that a phase shift measurement is currently performed for the cosine/B input |
| Cos B_Delay    | 31..15 | The delay between the excitation and cosine/B                                                      |

**Register 5**

Figure 81: RESOLVER\_LVDT\_RCP\_in Register 5

| Name             | Bits   | Description                                    |
|------------------|--------|------------------------------------------------|
| Exc_In_Period    | 16..0  | The measured period of the excitation input    |
| Exc_In_Amplitude | 31..17 | The measured amplitude of the excitation input |

**Register 6**

Figure 82: RESOLVER\_LVDT\_RCP\_in Register 6

| Name            | Bits   | Description                                                                                  |
|-----------------|--------|----------------------------------------------------------------------------------------------|
| Sin A_Amplitude | 13..0  | The position-dependent amplitude of sine/A                                                   |
| Cos A_Amplitude | 29..14 | The position-dependent amplitude of cosine/B                                                 |
| Delay_Meas_Val  | 30     | Status bit indicating that all phase shift measurements have been performed at least once    |
| Phase_Shift_Val | 31     | Status bit indicating that phase shifts are within a compensable range (< 1000 clock cycles) |

---

**Output**

The RESOLVER\_LVDT\_RCP\_in block has the following outputs:

| Name             | Unit       | Description                                                                                                                                                     | Range                                                                                                    |
|------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Position         | ° -        | The angle calculated by the FPGA main component                                                                                                                 | For Resolver:<br>Range: 0...360°<br>Resolution: 0.005°<br>For LVDT:<br>Range: -1...1<br>Resolution: 3e-5 |
| Speed            | 1/min      | The speed calculated by the FPGA main component                                                                                                                 | Range:0...(1/2T <sub>EXC</sub> )<br>Resolution: T <sub>S FPGA</sub>                                      |
| Phase_Shifts     | °          | The phase shift between the excitation and sine/A (1 <sup>st</sup> element) and the phase shift between the excitation and cosine/B (2 <sup>nd</sup> element).. | Range: -90°...90°<br>Resolution: T <sub>S FPGA</sub>                                                     |
| Amplitudes       |            | The current amplitude of sine/A (1 <sup>st</sup> element), cosine/B (2 <sup>nd</sup> element) and excitation input (3 <sup>rd</sup> element).                   | Range: 0...32767<br>Resolution: 1                                                                        |
| Offsets          | Bit (LSBs) | The DC offset measured for sine/A (1 <sup>st</sup> element), cosine/B (2 <sup>nd</sup> element) and excitation input (3 <sup>rd</sup> element).                 | Range: -2048...2047<br>Resolution: 0.25                                                                  |
| Exc_In_Frequency | Hz         | The measured frequency of the excitation input                                                                                                                  | Dependent on FPGA clock rate (@100MHz:<br>Range: 763Hz...32kHz<br>Resolution: 10ns)                      |
| Output_Valid     | -          | Flag indicating that the output are valid, which is the case after 2 valid excitation periods                                                                   | 0 1                                                                                                      |

|                   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |
|-------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Phase_Shift_Flags | - | A Bus containing the following status signals:<br>(1) <i>Sin/A_Meas_Active</i><br>This flag indicates that the phase shift measurement for sine/A is currently performed<br>(2) <i>Cos/B_Meas_Active</i><br>This flag indicates that the phase shift measurement for cosine/B is currently performed<br>(3) <i>Delay_Meas_Valid</i><br>This flag indicates that phase shift measurements for all relevant signals have been performed at least once<br>(4) <i>Phase_Shift_Compens.</i><br>This flag indicates that the phase shifts are within a compensable range (< 1000 clock cycles) | 0 1 (4x) |
|-------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|



# SSI & SPI Sensor Processing

---

## Objective

SSI (Synchronous Serial Interface) encoders are optical absolute encoders which contain integrated signal processing and send position information via a serial protocol based on the physical differential RS422 standard. Beside singleturn encoders, which provide position information, there are multiturn encoders, which provide the revolution number as well. Additional check or status bits (e.g. a parity bit) are sometimes transmitted as well. The output data is usually Gray coded. The SSI interface handles the SSI protocol with variable parameters and provides received data to the output block.

SPI (Serial Peripheral Interface) is used for various types of sensors. In contrast to SSI, communication in both directions is possible. SPI usually uses a single-ended interface.

---

## Content

The blockset contains the following elements:

- Processor Interface: SSI\_SPI\_RCP\_out  
(Processor Interface)
- FPGA Interface: SSI\_SPI\_RCP\_in  
(FPGA Interface)
- FPGA: SSI\_SPI\_RCP  
(FPGA Main Component)
- FPGA Interface: SSI\_SPI\_RCP\_out  
(FPGA Interface)
- Processor Interface: SSI\_SPI\_RCP\_in  
(Processor Interface)

## Processor Output

**Block**

Merges the processor signals and writes them to the FPGA



Figure 83: SSI\_SPI\_RCP\_out block

**Block Dialog**

The processor output block provides the following dialog:



Figure 84: SSI\_SPI\_RCP\_out dialog

The blockset dialog has the following parameters:

| Name                           | Unit | Description                                                                                                                                                                                                                                                     | Range                                                                             |
|--------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| Protocol Selection             | -    | Select between SSI (0) or SPI (1) protocol                                                                                                                                                                                                                      | 0 1                                                                               |
| Trigger Mode                   | -    | Set the mode for receiving new data words:<br>0 = As soon as the sensor is ready to transmit (continuous transmission / SSI only)<br>1 = triggered by the processor model (call of this block)<br>2 = triggered by an external input of the FPGA main component | Range: 0...2<br>Resolution: 1                                                     |
| Number of bits transmitted     | -    | The total number of bits to be transmitted each cycle                                                                                                                                                                                                           | Range: 0...48<br>Resolution: 1                                                    |
| Serial clock period            | s    | The period of the SSI or SPI serial clock (SCLK)                                                                                                                                                                                                                | Dependent on FPGA clock rate (@100MHz:<br>Range:0.02...163μs<br>Resolution: 20ns) |
| Maximum SSI monoflop time      | s    | The monoflop time is the minimum time between consecutive SSI data transmissions. After the monoflop time, the sensor sets the data line high. A maximum monoflop time must be specified to recognize communication timeouts                                    | Dependent on FPGA clock rate (@100MHz:<br>Range:0.02...163μs<br>Resolution: 20ns) |
| Gray encoded data transmission | -    | If this parameter is set to 1, the received serial data will be Gray decoded (usual for SSI, but not for SPI)                                                                                                                                                   | 0 1                                                                               |
| Bit order                      | -    | Select between LSB (0) or MSB (1) first. SSI usually uses MSB first                                                                                                                                                                                             | 0 1                                                                               |
| Clock polarity                 | -    | The idle state of the serial clock line. For SSI usually 1 (high)                                                                                                                                                                                               | 0 1                                                                               |
| Clock phase                    | -    | Describes if the first data bit is latched with the first (0) or second (1) serial clock edge. For SSI, clock phase is usually 0 (after one empty bit)                                                                                                          | 0 1                                                                               |
| Sample time FPGA               | s    | Sample time of the FPGA                                                                                                                                                                                                                                         | -                                                                                 |

|                                                                                   |                                                                                                                                                                        |
|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <p>SPI communication contains no <i>ready</i> feedback from the sensor.<br/>The trigger option has to be set to <i>processor model</i> or <i>external</i> for SPI.</p> |
|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**Input**

The SSI\_SPI\_RCP\_out block has the following inputs:

| Name        | Unit | Description                         | Range                                            |
|-------------|------|-------------------------------------|--------------------------------------------------|
| Enable      | -    | SSI or SPI data transmission enable | 0 1                                              |
| SPI_TX_Data | Bit  | Data to send in case of SPI         | Range: 0...(2 <sup>48</sup> -1)<br>Resolution: 1 |

**Output**

The Processor Out block provides four register outputs, mapped to two registers by time multiplexing. The sectioning is shown below:

**Register 1**

Figure 85: SSI\_SPI\_RCP\_out Register 1

| Name               | Bits  | Description                            |
|--------------------|-------|----------------------------------------|
| SPI_TX_Data (31:0) | 31..0 | The lower bits of data to send via SPI |

**Register 2.1**

Figure 86: SSI\_SPI\_RCP\_out Register 2.1

| Name               | Bits   | Description                                                                                      |
|--------------------|--------|--------------------------------------------------------------------------------------------------|
| SPI_TX_Data(47:32) | 15..0  | The higher bits of data to send via SPI                                                          |
| CN_Trigger         | 16     | Trigger from processor model                                                                     |
| SCLK_Period        | 29..17 | Period of the SSI or SPI serial clock. 1 LSB in the register corresponds to 2 FPGA clock cycles. |

**Register 2.2**

Figure 87: SSI\_SPI\_RCP\_out Register 2.2

| Name               | Bits   | Description                                                                                                                                              |
|--------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_TX_Data(47:32) | 15..0  | The higher bits of data to send via SPI                                                                                                                  |
| CN_Trigger         | 16     | Trigger from processor model                                                                                                                             |
| Max_Monoflop_Time  | 29..17 | The maximum monoflop time for SSI sensors as described in the processor output parameter table. 1 LSB in the register corresponds to 2 FPGA clock cycles |

**Register 2.3**

Figure 88: SSI\_SPI\_RCP\_out Register 2.3

| Name               | Bits   | Description                                                                                                    |
|--------------------|--------|----------------------------------------------------------------------------------------------------------------|
| SPI_TX_Data(47:32) | 15..0  | The higher bits of data to send via SPI                                                                        |
| CN_Trigger         | 16     | Trigger from processor model                                                                                   |
| En_Ext_Trig        | 17     | Enables the external trigger input                                                                             |
| No_of_Bits         | 23..18 | Number of data bits to be transmitted                                                                          |
| Gray_Decode        | 24     | Activates Gray decoding of serial input data                                                                   |
| Bit_Order          | 25     | Selects between LSB (0) or MSB (1) first                                                                       |
| CPOL               | 26     | Clock polarity (idle state of the SCLK line)                                                                   |
| CPHA               | 27     | Clock phase, determines if the first data bit is latched in with the first (0) or second (1) serial clock edge |
| Protocol_Type      | 28     | Select if SSI (0) or SPI (1) protocol is used                                                                  |
| Enable             | 29     | Enables the SSI or SPI master                                                                                  |

## FPGA Main Component

### Block



Figure 89: SSI\_SPI\_RCP FPGA Main block

### Block Dialog

You can define the parameters of the input and output registers for automatic interface generation. The dialog also contains a button to start interface generation. For more details about automatic interface generation, refer to the XSG Utils documentation chapter Automatic Interface Generation. The FPGA clock period can be configured too.

**Input**

The main block has the following inputs:

| Name                  | Unit   | Description                                                                                                 | Format    |
|-----------------------|--------|-------------------------------------------------------------------------------------------------------------|-----------|
| SDI                   | -      | The serial data received from the sensor (in case of SPI often called MISO)                                 | Bool      |
| Ext_Trigger           | -      | External trigger to start data transmission (continuous transmission if trigger remains high)               | Bool      |
| Enable                | -      | Enables the sensor processing                                                                               | Bool      |
| En_Ext_Trigger        | -      | Enables the external trigger input                                                                          | Bool      |
| CN_Trigger            | -      | Transmission trigger from processor model                                                                   | Bool      |
| No_of_Bits            | -      | Number of data bits to be transmitted                                                                       | UFix_6_0  |
| SCLK_Period           | Clocks | The period of the SSI or SPI serial clock                                                                   | UFix_14_0 |
| Bit_Order             | -      | Select between LSB (0) or MSB (1) first                                                                     | Bool      |
| Gray_Decode           | -      | Activates Gray decoding of serial input data                                                                | Bool      |
| SSI_Max_Monoflop_Time | Clocks | The maximum monoflop time of the SSI sensor as described in the processor output parameter table            | UFix_14_0 |
| CPOL                  | -      | Clock polarity (idle state of the SCLK line)                                                                | Bool      |
| CPHA                  |        | Clock phase, selects if the first data bit is latched in with the first (0) or second (1) serial clock edge | Bool      |
| Protocol_Type         | -      | Selects between SSI (0) or SPI (1)                                                                          | Bool      |
| SPI_TX_Data           | -      | The data to send in case of SPI                                                                             | UFix_48_0 |

**Output**

The main block has the following outputs:

| Name          | Unit | Description                                                                                              | Format    |
|---------------|------|----------------------------------------------------------------------------------------------------------|-----------|
| FPGASignalBus | -    | Contains all output signals which are passed to the processor interface                                  | Bus       |
| RX_Data       | -    | The data received during the last data transmission                                                      | UFix_48_0 |
| Data_Ready    | -    | Impulse indicating that a data transmission has been completed. Can e.g. be used as an interrupt trigger | Bool      |
| Parity_Odd    | -    | The parity of the bits received is calculated. This output represents the parity value                   | Bool      |
| SCLK          | -    | The serial clock to be provided for the sensor connected                                                 | Bool      |
| SPI_CS        | -    | The chip select signal. Only required for SPI                                                            | Bool      |
| SPI_SDO       | -    | The serial data output (MOSI). Only required for SPI                                                     | Bool      |

## Processor Input

|              |                                                 |
|--------------|-------------------------------------------------|
| <b>Block</b> | Adapts the FPGA signals for the processor side. |
|--------------|-------------------------------------------------|



Figure 90: SSI\_SPI\_RCP\_in block

|                     |                                                                           |
|---------------------|---------------------------------------------------------------------------|
| <b>Block Dialog</b> | The processor input does not provide any block dialog or mask parameters. |
|---------------------|---------------------------------------------------------------------------|

|              |                                                     |
|--------------|-----------------------------------------------------|
| <b>Input</b> | The processor input block has the following inputs: |
|--------------|-----------------------------------------------------|

### Register 1



Figure 91: SSI\_SPI\_RCP\_in Register 1

| Name           | Bits  | Description                                |
|----------------|-------|--------------------------------------------|
| RX_Data (31:0) | 31..0 | Bits 31..0 of the received SSI or SPI data |

### Register 2



Figure 92: SSI\_SPI\_RCP\_in Register 2

| Name            | Bits   | Description                                          |
|-----------------|--------|------------------------------------------------------|
| RX_Data (47:32) | 15..0  | Bits 47..32 of the received SSI or SPI data          |
| SSI_Com_Error   | 16     | Signals a communication timeout at the SSI interface |
| Parity_Odd      | 17     | Parity of received data is odd                       |
| SPARE           | 31..18 | -                                                    |

**Output**

The processor input block has the following outputs:

| Name          | Unit | Description                                                                                                                                | Range                                            |
|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| RX_Data       | Bit  | The received SSI or SPI raw data in LSBs.                                                                                                  | Range: 0...(2 <sup>48</sup> -1)<br>Resolution: 1 |
| SSI_Com_Error | -    | A communication error flag, which is raised when the SSI sensor does not set the data line high within the specified maximum monoflop time | 0 1                                              |
| Parity_Odd    | -    | The parity of the bits received is calculated. This output represents the parity value.                                                    | 0 1                                              |

# Asymmetric H Bridge PWM Generator

## Overview

The SRM PWM generates PWM for control an Asymmetric H Bridge inverter used to control a Switched reluctance machine. The SRM PWM block set can generate a rising edge or a pulse center synchronous PWM signal. A pulse center-synchronous interrupt can also be raised on the FPGA and caught on the processor side.

## Asymmetric H-Bridge PWM

SRM PWM is used to supply a Switched reluctance motor. The switched reluctance machine is a doubly salient machine, i.e. both rotor and stator have poles on them. The inductance of the motor is a function of position and current (if the motor is operating in saturation region). The standard inverter topology used to control a Switched reluctance machine is called Asymmetric H Bridge and it can be seen in Figure 1. The "single phase leg circuit" as shown in Figure 1 is the smallest unit of the inverter. There are two switches needed per phase and two anti-parallel diodes for freewheeling



Figure 93: Asymmetric H-Bridge Inverter Topology

For higher number of phases the legs are connected in parallel to the DC link and can be controlled independently with PWM signals. Each leg of the inverter has three states namely;

- Conducting
- Free wheeling
- Open

These three stages can be seen in Figure 2 a, b and c respectively. During conducting stage both the switches on the high side (HSD) and the Low side (LSD) are simultaneously conducting and putting the DC link voltage across

the motor winding. During the freewheeling stage only one of the switches are conducting while the other is off, this allows the current to pass through the conducting switch and anti-parallel diode. In this stage the voltage across the phase is due to the energy stored in the inductor. And finally, in the open stage the voltage across the phase is 0 as the antiparallel diodes are open in this condition



Figure 2: States of an Asymmetric H Bridge inverter

It is important to note that the switch in conducting state during the freewheeling is alternated between S1 and S2 in order to uniformly distribute the current over both switches and thereby uniformly distributing the heat losses. The following is a description of two-phase Asymmetric H Bridge PWM generator

## Content

The blockset contains the following elements:

- Processor Interface:  
TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM\_GENERATOR\_RCP\_out  
(Processor Interface)
- FPGA Interface:  
TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM\_GENERATOR\_RCP\_in  
(FPGA Interface)
- FPGA: TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM\_GENERATOR\_RCP  
(FPGA Main Component)
- FPGA Interface:  
TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM\_GENERATOR\_RCP\_out  
(FPGA Interface)
- Processor Interface:  
TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM\_GENERATOR\_RCP\_in  
(FPGA Interface)

## Processor Output

### Block



**Figure 3: TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM out block**

### Block Dialog

The processor output of the block-set contains the following dialog elements:



**Figure 4: TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM Parameter dialog**

The Parameter dialog of the Block Commutated blockset has the following parameters:

| Name | Unit | Description | Range |
|------|------|-------------|-------|
|------|------|-------------|-------|

|                             |     |                                                                                                                                                                                                                                                                                                                           |            |
|-----------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| PWM Aligning Mode           | [-] | Specify the modulation and the update algorithm of the duty cycle data from the inputs<br>0: rising-edge modulation and update<br>1: pulse-center modulation and update<br>2: pause-center modulation and update<br>3: pulse-center modulation with an update of the duty cycles every pulse- and pause center of the pwm | 0 ... 3    |
| Downsampling update trigger | [-] | If the duty cycle data is updated in the FPGA main block an update trigger flag is generated. The trigger event can be down sampled with this factor                                                                                                                                                                      | 1 ... 1023 |
| Sample time FPGA            | [s] | Sample time of the FPGA                                                                                                                                                                                                                                                                                                   | 1.....     |

**Input**

The processor output of the block-set has the following inputs:

| Name               | Unit | Description                                         | Range       |
|--------------------|------|-----------------------------------------------------|-------------|
| Enable             | [-]  | Enable of the output                                | 0 1         |
| PWM Frequency      | [Hz] | PWM Frequency at disabled external trigger          | 0 ... 5 MHz |
| Duty_Cycle A[-1_1] | [-]  | Duty cycle (scalar)                                 | -1 .....1   |
| Duty_Cycle B[-1_1] | [-]  | Duty cycle (scalar)                                 | -1 .....1   |
| Enable_Ext_Trigger | [-]  | Enable external pulse center synchronization signal | 0 1         |



**Output**

The processor output block provides 15 registers whose sectioning is shown below:

**Register 1 and 2**

Figure 5: TWO\_PHASE\_ASYM\_H\_BRIDGE\_PWM\_out Register 1

| Name       | Bits Used | Description                            | Range  |
|------------|-----------|----------------------------------------|--------|
| Duty_Cycle | 16...0    | Duty cycle is a scalar between 0 and 1 | -1...1 |

**Register 3**

Figure 6: BLOCK\_COMMUTATED\_PWM\_out Register 7 ... 12

| Name            | Bits Used | Description            | Range                                        |
|-----------------|-----------|------------------------|----------------------------------------------|
| PWM Period Time | 23...0    | Period time of the PWM | 0 ... 2^24-1<br>represents<br>0 ... 0.1678 s |
| SPARE           | 28...24   |                        |                                              |
| Enable          | 29        | Output Enable          | 0 1                                          |
| Aligning Mode   | 31...30   | PWM aligning mode      | 0...3                                        |

**Register 4**

| Name               | Bits Used | Description                              | Range    |
|--------------------|-----------|------------------------------------------|----------|
| SPARE              | 19...0    |                                          |          |
| Enable ext Trigger | 20        | Enable external Trigger                  | 0 1      |
| Downsampling       | 30...21   | Down sampling of the update trigger flag | 1...1023 |
| SPARE              | 31        |                                          |          |



Figure 6: BLOCK\_COMMUTATED\_PWM\_out Register 14



The parameters of the input and output registers can be defined for automatic interface generation (When checkbox is enabled) on the page Interface. The dialog also contains an additional button to start interface generation. For more details about automatic interface generation, refer to Automatic Interface Generation chapter of XSG\_Utils Documentation.

## FPGA Main Component

### Block



### Block Dialog

Figure 7: BLOCK\_COMMUTATED\_PWM Main block

The FPGA main blockset contains the following dialog.



Figure 8: BLOCK\_COMMUTATED\_PWM Main block dialog

### Input

The main block has the following inputs:

| Name               | Unit  | Description                                        | Format    |
|--------------------|-------|----------------------------------------------------|-----------|
| Ext_Trigger        | [ - ] | External pulse center trigger of an external PWM.  | Bool      |
| Enable             | [ - ] | Enable of the output                               | Bool      |
| Enable_Ext_Trigger | [ - ] | Enable of the external trigger                     | Bool      |
| Period_Time        | [Raw] | Period time of the PWM at disable external trigger | UFix_24_0 |
| Downsampling_Up_Tr | [ - ] | Downsampling of the update trigger flag            | UFix_10_0 |
| Duty_Cycle_A_-1_1  | [ - ] | Duty cycle (scalar)                                | Fix_17_16 |
| Duty_Cycle_B_-1_1  | [ - ] | Duty cycle (scalar)                                | Fix_17_16 |

**Output**

The blockset contains the following elements:

| Name          | Unit  | Description                                        | Format |
|---------------|-------|----------------------------------------------------|--------|
| FPGASignalBus | Bus   | Bus containing the blocks most significant signals | -      |
| UpdateTrigger | [ - ] | Update trigger flag                                | Bool   |
| En            | [ - ] | Enable Output                                      | Bool   |
| PWM_HSD_A     | [ - ] | High side of gate signal                           | Bool   |
| PWM_LSD_A     | [ - ] | Low side of gate signal                            | Bool   |
| PWM_HSD_B     | [ - ] | High side of gate signal                           | Bool   |
| PWM_LSD_B     | [ - ] | Low side of gate signal                            | Bool   |

## Processor Input

### Block

Adapts the FPGA signals for the processor side



Figure 9: BLOCK\_COMMUTATED\_PWM\_in block

### Block Dialog

The following parameters can be configured in the processor input dialog:



Figure 10: BLOCK\_COMMUTATED\_PWM\_in dialog

The dialog blockset has the following parameters:

| Name             | Unit | Description              | Range |
|------------------|------|--------------------------|-------|
| Sample time FPGA | [s]  | Sample time of the FPGA. | -     |

### Input

The processor input block has the following inputs:

**Register 1**



Figure 20: BLOCK\_COMMUTATED\_PWM\_in Register\_1

| Name            | Bits Used | Description                   | Range            |
|-----------------|-----------|-------------------------------|------------------|
| PWM Period Time | 23...0    | Period time of the PWM        | 0 ... $2^{24}-1$ |
| Valid Output    | 25        | Valid flag for the PWM output | 0 1              |

**Output**

The processor input block has the following outputs:

| Name            | Units | Description                   | Range         |
|-----------------|-------|-------------------------------|---------------|
| PWM Period Time | [s]   | Period time of the PWM        | 0 ... 83,9 ms |
| Valid Output    | [-]   | Valid flag for the PWM output | 0 1           |

# Block Commutated PWM Generator

## Overview

The Block Commutation block configures the block commutator that is implemented on the FPGA. It allows controlling one BLDC via block commutation. The Block Commuted PWM generator blockset can generate a rising edge or a pulse center synchronous PWM signal (single phase and three phase). The dead time and the duty cycle can be set on the processor side (online tuneable). A pulse center-synchronous interrupt can also be raised on the FPGA and caught on the processor side.

on the FPGA and caught on the processor side.

## Block Commutation

Block commutated PWM is used to supply a BLDC motor. One complete electrical rotation is divided into many sectors. The sectors (changing for multiple times in every electric cycle) is used to change the phase current flow direction. However, the current direction will not change within the same sectors. At any moment, only the upper bridge of one phase can be conducted with the lower bridge of the other phase.



Figure 94: Two Side Modulated Block Commutated PWM

In this Block set it is possible to do high side modulation and a low side modulation. In high side modulation only the upper half of the H-bridges are provided with PWM duty cycle and the lower half duty cycles are fixed at 100%. In low side modulation PWM is given to the low side switches only (similar to high side modulation).



Figure 2: High Side Modulated Block Commutated PWM

Fourth and final possibility is to provide power switches on the high and low side are provided with the PWM signal alternately. This is called "symmetric modulation" and provokes a uniform load on all switches



Figure 3: Symmetric Modulation Block Commutated PWM

## Content

The blockset contains the following elements:

- Processor Interface:  
BLOCK\_COMMUTATED\_PWM\_GENERATOR\_RCP\_out (Processor Interface)
- FPGA Interface: BLOCK\_COMMUTATED\_PWM\_GENERATOR\_RCP\_in (FPGA Interface)
- FPGA: BLOCK\_COMMUTATED\_PWM\_GENERATOR\_RCP (FPGA Main Component)
- FPGA Interface:  
BLOCK\_COMMUTATED\_PWM\_GENERATOR\_RCP\_out (FPGA Interface)
- Processor Interface:  
BLOCK\_COMMUTATED\_PWM\_GENERATOR\_RCP\_in (FPGA Interface)

## Processor Output

### Block

Figure 4: `BLOCK_COMMUTATED_PWM_out` block**Block Dialog**

The processor output of the block-set contains the following dialog elements:



Figure 5: BLOCK\_COMMUTATED\_PWM\_out Parameter dialog

The Parameter dialog of the Block Commutated blockset has the following parameters:

| Name              | Unit  | Description                                                                                                                                                                                                                                                                                                               | Range                                                                         |
|-------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| PWM Aligning Mode | [ - ] | Specify the modulation and the update algorithm of the duty cycle data from the inputs<br>0: rising-edge modulation and update<br>1: pulse-center modulation and update<br>2: pause-center modulation and update<br>3: pulse-center modulation with an update of the duty cycles every pulse- and pause center of the pwm | 0 ... 3                                                                       |
| Deadtime          | [ s ] | Deadtime between the generated low and high side gate signal                                                                                                                                                                                                                                                              | 0 ... 52.429 $\mu$ s resolution:<br>10e-9 s<br>(FPGA Sample time:<br>10e-9 s) |

|                             |       |                                                                                                                                                      |            |
|-----------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| Downsampling update trigger | [ - ] | If the duty cycle data is updated in the FPGA main block an update trigger flag is generated. The trigger event can be down sampled with this factor | 1 ... 1023 |
| Sample time FPGA            | [ s ] | Sample time of the FPGA                                                                                                                              | 1.....     |

The next tab is the Sector definition dialog of the Block Commutated blockset and it has the following parameters



Figure 6: BLOCK\_COMMUTATED\_PWM\_out Sector Definition dialog

| Name              | Unit  | Description                                                | Range         |
|-------------------|-------|------------------------------------------------------------|---------------|
| Number of sectors | [ - ] | Specify the Number of sectors for the Block commutated PWM | 0 ... 12      |
| Sector N End      | [deg] | Specifies the degrees at which the Nth sector ends         | 0 ... 360 Deg |



Figure 7: BLOCK\_COMMUTATED\_PWM\_out Switching Pattern Definition dialog

The next tab is the Switching pattern definition dialog of the Block Commutated blockset and it has the following parameters

| Name                                  | Unit  | Description                                                                                                                                                                          | Range          |
|---------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Leg A+ Sector 1 ..... Leg C- Sector N | [ - ] | <p>Specify the Switching pattern for a given phase in a given sector</p> <p>Low: No switching</p> <p>High: On throughout the sector</p> <p>PWM: Modulated with given duty Cycle.</p> | Low, High, PWM |



Figure 8: BLOCK\_COMMUTATED\_PWM\_out Position Source dialog

The final tab is the Position Source dialog of the Block Commutated blockset and it has the following parameters:

| Name                   | Unit | Description                                                                                                                                                                                           | Range     |
|------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Position Signal Source | [-]  | Specify the position signal used for block commutation<br>0: From the Processor<br>1: Hall Sensor position signal directly from the FPGA<br>2: Incremental Encoder position signal directly from FPGA | 0 ... 2   |
| Pole Pairs             | [-]  | Specifies the number of pole pairs of the BLDC motor                                                                                                                                                  | 0 ... 255 |

## Input

The processor output of the block-set has the following inputs:

| Name               | Unit  | Description                                         | Range       |
|--------------------|-------|-----------------------------------------------------|-------------|
| Enable             | [ - ] | Enable of the output                                | 0 1         |
| PWM Frequency      | [Hz]  | PWM Frequency at disabled external trigger          | 0 ... 5 MHz |
| Duty_Cycle         | [ - ] | Duty cycle (scalar)                                 | 0 .....1    |
| DIR                | [ - ] |                                                     |             |
| Offset             | [Deg] |                                                     |             |
| Enable_Ext_Trigger | [ - ] | Enable external pulse center synchronization signal | 0 1         |

**Output**

The processor output block provides 15 registers whose sectioning is shown below:

Register 1



Figure 8: BLOCK\_COMMUTATED\_PWM\_out Register 1

| Name       | Bits Used | Description                                                                                             | Range |
|------------|-----------|---------------------------------------------------------------------------------------------------------|-------|
| Position   | 15...0    | Position Signal Sent from the Processor 0 to 360 degree is scaled to an Unsigned value between 0 and 1. | 0...1 |
| Duty_Cycle | 31...16   | Duty cycle is a scalar between 0 and 1                                                                  | 0...1 |

Register 2 ... 5

| MSB                                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | LSB |
|----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----|
| Const Leg X Plus or Minus Sector N+... |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |

Figure 9: BLOCK\_COMMUTATED\_PWM\_out Register 2 ... 5

| Name                                   | Bits Used                    | Description                                                                                             | Range |
|----------------------------------------|------------------------------|---------------------------------------------------------------------------------------------------------|-------|
| Const Leg X Plus or Minus Sector N     | 1...0                        | Switching pattern for phase X and the sector N.<br>For example, Register 2 starts with Phase A sector 1 | 0...2 |
| Const Leg X Plus or Minus Sector N+... | 3...2/5...4/<br>... /30...31 | Switching pattern for phase X and the sector N+....                                                     | 0...2 |

**Register 6**

| MSB | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | LSB |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----|
| Dir |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |     |

Const\_No\_of\_Sectors

Figure 10: BLOCK\_COMMUTATED\_PWM\_out Register 6

| Name                               | Bits Used                   | Description                                         | Range                                           |
|------------------------------------|-----------------------------|-----------------------------------------------------|-------------------------------------------------|
| Const Leg X Plus or Minus Sector N | 1...0/3...2/<br>.../15...14 | Switching pattern for phase X and the sector N+.... | 0...2                                           |
| Const_No_of_Sectors                | 16...30                     | Number of sectors per phase                         | 0 ... 2^10-<br>1<br>represents<br>12<br>Sectors |
| Dir                                | 31                          | Direction of rotation                               | 0 1                                             |

**Register 7...12**

Figure 11: BLOCK\_COMMUTATED\_PWM\_out Register 7 ... 12

| Name                 | Bits Used | Description                                                          | Range |
|----------------------|-----------|----------------------------------------------------------------------|-------|
| Const_Sector_X_End   | 15...0    | Position of the send of Sector X scaled to number between 0 and 1.   | 0...1 |
| Const_Sector_X+1_End | 31...16   | Position of the send of Sector X+1 scaled to number between 0 and 1. | 0...1 |

**Register 13**

Figure 12: BLOCK\_COMMUTATED\_PWM\_out Register 7 ... 12

| Name            | Bits Used | Description            | Range                                  |
|-----------------|-----------|------------------------|----------------------------------------|
| PWM Period Time | 23...0    | Period time of the PWM | 0 ... 2^24-1 represents 0 ... 0.1678 s |
| SPARE           | 28...24   |                        |                                        |
| Enable          | 29        | Output Enable          | 0 1                                    |
| Aligning Mode   | 31...30   | PWM aligning mode      | 0...3                                  |

**Register 14**

| Name               | Bits Used | Description                               | Range                                        |
|--------------------|-----------|-------------------------------------------|----------------------------------------------|
| Deadtime           | 19...0    | Deadtime of the high and low side signals | 0 ... 2^19-1<br>1 represents 0 ... 52.429 μs |
| Enable ext Trigger | 20        | Enable external Trigger                   | 0 1                                          |
| Downsampling       | 30...21   | Down sampling of the update trigger flag  | 1...1023                                     |
| SPARE              | 31        |                                           |                                              |



Figure 13: BLOCK\_COMMUTATED\_PWM\_out Register 14

**Register 15**

Figure 14: BLOCK\_COMMUTATED\_PWM\_out Register 15

| Name                  | Bits Used | Description                                | Range   |
|-----------------------|-----------|--------------------------------------------|---------|
| Const_Position_Source | 1...0     | Select the source of position signal.      | 0...2   |
| Const_Pole_Pairs      | 31...16   | Pole pairs of the machine being controlled | 1...255 |

# FPGA Main Component

## Block



## Block Dialog

The FPGA main blockset contains the following dialog.

**Figure 16: BLOCK\_COMMUTATED\_PWM Main block**



Figure 17: BLOCK\_COMMUTATED\_PWM Main block dialog

|                                                                                     |                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | The parameters of the input and output registers can be defined for automatic interface generation (When checkbox is enabled) on the page Interface. The dialog also contains an additional button to start interface generation. For more details about automatic interface generation, refer to Automatic Interface Generation chapter of XSG_Utils Documentation. |
|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**Input**

The main block has the following inputs:

| Name                  | Unit  | Description                                       | Format     |
|-----------------------|-------|---------------------------------------------------|------------|
| Ext_Trigger           | [ - ] | External pulse center trigger of an external PWM. | Bool       |
| Hall_Position         | [ - ] | Position signal from Hall Sensor                  | UFix_16_16 |
| Incremental Position  | [ - ] | Position signal from Incremental Sensor           | UFix_16_16 |
| Incremental Valid     | [ - ] | Position signal from Incremental Sensor is valid  | Bool       |
| Hall Direction        | [ - ] | Direction from Hall sensor                        | Bool       |
| Incremental Direction | [ - ] | Direction from Incremental Direction              | Bool       |
| Enable                | [ - ] | Enable the Output                                 | UFix_1_0   |

|                      |       |                                                       |            |
|----------------------|-------|-------------------------------------------------------|------------|
| Enable_Ext_Trigger   | [ - ] | Enable of the external trigger                        | UFix_1_0   |
| PWM_Mode             | [ - ] | PWM aligning mode                                     | UFix_2_0   |
| Period_time          | [Raw] | Period time of the PWM at disable external trigger    | UFix_24_0  |
| Dead_Time            | [Raw] | Deadtime of PWM                                       | UFix_20_0  |
| Downsampling_Up_Tr   | [ - ] | Downsampling Update trigger flag                      | UFix_10_0  |
| Duty_Cycle           | [ - ] | Duty Cycle for the current PWM time period            | UFix_16_16 |
| A_Pos_Sector_Vector  | [Raw] | Switching Pattern definition for phase A positive leg | UFix_24_0  |
| B_Pos_Sector_Vector  | [Raw] | Switching Pattern definition for phase B positive leg | UFix_24_0  |
| C_Pos_Sector_Vector  | [Raw] | Switching Pattern definition for phase C positive leg | UFix_24_0  |
| A_Neg_Sector_Vector  | [Raw] | Switching Pattern definition for phase A negative leg | UFix_24_0  |
| B_Neg_Sector_Vector  | [Raw] | Switching Pattern definition for phase B negative leg | UFix_24_0  |
| C_Neg_Sector_Vector  | [Raw] | Switching Pattern definition for phase C negative leg | UFix_24_0  |
| Position_Signal_Proc | [ - ] | Position signal from processor                        | UFix_16_16 |
| Sector_Select        | [Raw] | Selects number of sectors for block commutation       | UFix_15_0  |
| Sector_1_End         | [ - ] | End of sector 1                                       | UFix_16_16 |
| Sector_2_End         | [ - ] | End of sector 2                                       | UFix_16_16 |
| Sector_3_End         | [ - ] | End of sector 3                                       | UFix_16_16 |
| Sector_4_End         | [ - ] | End of sector 4                                       | UFix_16_16 |
| Sector_5_End         | [ - ] | End of sector 5                                       | UFix_16_16 |
| Sector_6_End         | [ - ] | End of sector 6                                       | UFix_16_16 |
| Sector_7_End         | [ - ] | End of sector 7                                       | UFix_16_16 |
| Sector_8_End         | [ - ] | End of sector 8                                       | UFix_16_16 |

|                        |       |                                          |            |
|------------------------|-------|------------------------------------------|------------|
| Sector_9_End           | [ - ] | End of sector 9                          | UFix_16_16 |
| Sector_10_End          | [ - ] | End of sector 10                         | UFix_16_16 |
| Sector_11_End          | [ - ] | End of sector 11                         | UFix_16_16 |
| Position_Offset        | [ - ] | Offset added to the position signal      | UFix_16_16 |
| DIR                    | [ - ] | Direction of rotation from the processor | Bool       |
| Position_Source_Select | [ - ] | Select source of the position signal     | UFix_2_0   |
| Pole_Pairs             | [ - ] | Number of pole pairs                     | UFix_10_0  |

**Content**

The blockset contains the following elements:

| Name          | Unit  | Description                                        | Format |
|---------------|-------|----------------------------------------------------|--------|
| FPGASignalBus | Bus   | Bus containing the blocks most significant signals | -      |
| PWM_HSD_A     | [ - ] | High side of gate signal                           | Bool   |
| PWM_LSD_A     | [ - ] | Low side of gate signal                            | Bool   |
| PWM_HSD_B     | [ - ] | High side of gate signal                           | Bool   |
| PWM_LSD_B     | [ - ] | Low side of gate signal                            | Bool   |
| PWM_HSD_C     | [ - ] | High side of gate signal                           | Bool   |
| PWM_LSD_C     | [ - ] | Low side of gate signal                            | Bool   |
| UpdateTrigger | [ - ] | Update trigger flag                                | Bool   |
| En            | [ - ] | Enable Output                                      | Bool   |

## Processor Input

**Block** Adapts the FPGA signals for the processor side



Figure 18: `BLOCK_COMMUTATED_PWM_in` block

### Block Dialog

The following parameters can be configured in the processor input dialog:



Figure 19: `BLOCK_COMMUTATED_PWM_in` dialog

The dialog blockset has the following parameters:

| Name             | Unit | Description              | Range |
|------------------|------|--------------------------|-------|
| Sample time FPGA | [s]  | Sample time of the FPGA. | -     |

### Input

The processor input block has the following inputs:

#### Register 1



Figure 20: BLOCK\_COMMUTATED\_PWM\_in Register\_1

| Name            | Bits Used | Description                   | Range        |
|-----------------|-----------|-------------------------------|--------------|
| PWM Period Time | 23...0    | Period time of the PWM        | 0 ... 2^24-1 |
| Valid Output    | 25        | Valid flag for the PWM output | 0 1          |

**Register 2**

Figure 21: BLOCK\_COMMUTATED\_PWM\_in Register\_2

| Name     | Bits Used | Description                                 | Range    |
|----------|-----------|---------------------------------------------|----------|
| Sector   | 3 ... 0   | Current Sector number of the rotor position | 0...12   |
| Position | 19 ... 4  | Current Rotor position                      | 0 .... 1 |

**Output**

The processor input block has the following outputs:

| Name | Units | Description | Range |
|------|-------|-------------|-------|
|      |       |             |       |

|                 |       |                                             |               |
|-----------------|-------|---------------------------------------------|---------------|
| PWM Period Time | [s]   | Period time of the PWM                      | 0 ... 83,9 ms |
| Valid Output    | [ - ] | Valid flag for the PWM output               | 0 1           |
| Sector          | [ - ] | Current Sector number of the rotor position | 0...12        |
| Position        | [Deg] | Current Rotor position                      | 0 .... 360    |

# Miscellaneous

## Objective

The XSG AC Motor Control Solution contains a few smaller function blocks which can be useful typical measurement tasks. The small applications do not provide a processor interface.

## Debounce

### Description / Overview

This block handles bouncing digital inputs by ignoring successive input edges for a specified time.

### Block



Figure 95: DEBOUNCE block

### Input

The DEBOUNCE block has the following inputs:

| Name          | Unit   | Description                                                                                                                                                                         | Format   |
|---------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Signal In     | -      | The digital input signal                                                                                                                                                            | Bool     |
| Debounce Time | Clocks | The debounce time, during which all following edges will be ignored. The maximum range of the debounce time can be specified in the block dialog (default: 1023 FPGA clock cycles). | UFix_x_0 |

### Output

The DEBOUNCE block has the following outputs:

| Name       | Unit | Description                 | Format |
|------------|------|-----------------------------|--------|
| Deb_Signal | -    | The debounced output signal | Bool   |

## Sync Generation

|                               |                                                                                                                                                                                                                    |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Description / Overview</b> | This block detects a pulse-mid synchronous latch trigger and generates a synchronization signal of variable length and delay from it. If the period is known, it generates a pause-mid synchronous signal as well. |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### Block



Figure 96: SYNC\_GENERATION block

### Input

The SYNC\_GENERATION block has the following inputs:

| Name          | Unit   | Description                                                       | Format    |
|---------------|--------|-------------------------------------------------------------------|-----------|
| Latch_Trigger | -      | The PWM pulse-mid synchronous latch trigger                       | Bool      |
| Sync_Delay    | Clocks | The delay of the output sync pulse. Can be varied during runtime  | UFix_24_0 |
| Sync_Width    | Clocks | The length of the output sync pulse. Can be varied during runtime | UFix_24_0 |

### Output

The SYNC\_GENERATION block has the following outputs:

| Name           | Unit | Description                      | Format |
|----------------|------|----------------------------------|--------|
| Pulse_Mid_Sync | -    | PWM pulse-mid synchronous signal | Bool   |
| Pause_Mid_Sync | -    | PWM pause-mid synchronous signal | Bool   |

# Demos

## Overview

### Overview

The XSG ACMC Library comes with demonstration projects, to control a 3 phase PMSM in current and speed control mode. It consists of MATLAB Simulink Model (including parameterization), a ControlDesk project and in case of Scalexio a ConfigurationDesk project.



The XSG ACMC Demos require the license for:  
XSG\_ACMC\_FPGA, XSG\_ACMC\_PROC, XSG\_ACMC\_RTV plus  
XSG\_Utils\_FPGA, XSG\_Utils\_PROC, XSG\_Utils\_RTV

The Demos are precompiled for following hardware configurations

| Platform    | Processor Model | FPGA Model                |
|-------------|-----------------|---------------------------|
| MicroLabBox | DS1202          | DS1202 FPGA               |
| MABX III    | DS1403          | DS1514 (7K325) and DS1553 |

In case that a different hardware configuration should be used e.g. DS1401 with DS1514 (7K325) and DS1552, it is necessary to rebuild the FPGA & processor model

### Initial Installation

The Demo Model Setup is separated from XSG ACMC installation. To install the Demos necessary open the ACMC Library as shown in Figure below and double click the demos block.



Figure 97: Demos in the XSG ACMC library Figure

When the demo link is double clicked then the following pop up dialog appears.



**Figure 98: Dialog when opening a demo for the first time**

The demos will be installed inside the folder with the current version name under the path: My Documents\dSPACE\XSG\_ACMC\. Hence, the demo folder installation path, shown in the demo installation dialog will adjust, according to the user's login name.

#### Folder Structure

The Demos are copied using the following folder structure:

|                           |                  |
|---------------------------|------------------|
| 20.1                      | 19.05.2020 14:19 |
| Demos                     | 19.05.2020 14:19 |
| PHS                       | 19.05.2020 14:19 |
| Instrumentation           | 19.05.2020 14:19 |
| Simulation                | 19.05.2020 14:30 |
| Startup_Guide.pdf         | 19.05.2020 14:13 |
| Scalexio                  | 19.05.2020 14:19 |
| Configuration             | 19.05.2020 14:19 |
| Instrumentation           | 19.05.2020 14:19 |
| Simulation                | 19.05.2020 14:19 |
| Startup_Guide.pdf         | 19.05.2020 14:13 |
| xsg_acmc_DEMO_startDemo.m | 19.05.2020 16:11 |
| Doc                       | 19.05.2020 14:19 |

**Figure 99: Dialog for selecting a demo model**

The pdf document, Startup\_Guide, contains a brief start up guide that can be used to step through the various steps needed to get the demo up and running on the real time hardware. The simulation folder contains the Simulink model and the relevant scripts to parametrize the model. It also contains build results in case of the PHS demo. The Instrumentation folder contains the ControlDesk project as a back up and the Configuration folder contains the Configuration Desk project as back up for the Scalexio based Demo.

The selection between PHS and Scalexio system is provided by a pop up window immediately after the installation process is completed. This can be seen in the figure below



Figure 100: Dialog for selecting a demo model

After the model type has been chosen, MATLAB will change the working directory to the corresponding folder, run a startup script to initialize variables and finally open the Simulink model. The startup script can be modified by the user to change sample times or motor parameters. Run the script again to apply (overwrite the parameter structure inside the workspace) changes. The PHS bus demo is only available for rti1202 (MicroLabBox) environment. In order to open the demo Matlab needs to be configured for rti1202. If this is not the case, the following error message will appear.



Figure 101: Error Warning for wrong RTI Environment

The user can switch to the desired platform by entering the command "rti1202" inside the command window.

#### Reinstallation

After the initial demo installation is done, The user can choose to open the available demo or to reinstall and open the demo to receive a not modified version of the demo:



Figure 99: Reinstallation pop up Block

|  |                                                                                          |
|--|------------------------------------------------------------------------------------------|
|  | Any changes, on the demo model and experiment, will be lost after reinstalling the Demos |
|--|------------------------------------------------------------------------------------------|

# Permanent Magnet Synchronous Machine Demo

## Overview

The control of synchronous machines is achieved by sinusoidal phase currents which are generated using (sine commutation) from the control algorithm.

The PMSM motor control typically uses a field-oriented control algorithm. This means, the coordinate system of the control loop is rotated with the rotor position. This way, the sinusoidal set points for the currents transform into constant set points, which are easier to control.

It is implemented as a cascaded velocity controller with subordinate current controller as shown in the figure below. The torque inducing current component  $i_q$  and the field weakening current component  $i_d$  are controlled separately.

The commutation is performed using the generic PWM generator block of the XSG Utils library. The motor position is determined using the Hall Sensor and Incremental Encoder processing of the XSG ACMC library. Velocity is provided by using the incremental encoder processing. Currents are measured by connecting shunts to the FPGA board ADCs and latching new values at the pulse mid of the PWM. The controller is triggered synchronously to the PWM pulse mid by using the RTI FPGA Programming Blockset interrupts.

The Demo has the possibility of switching between Processor and FPGA based current control.

The processor-based control is located inside the CONTROLLER\_TASK, this is a triggered subsystem and is called at every PWM center. This structure affords the demo application the opportunity to switch between the four different modes, namely:

- Speed Control
- Current Control
- Open\_Loop (V\_abc)
- Open\_Loop (V\_dq)

**Speed Control:** In this mode the processor-based Speed controller receives the actual speed from the position processing and the speed setpoint from the environmental control. According to the difference the setpoints for the current controller  $i_d$  and  $i_q$  (direct and quadrature axis current) are calculated.

**Current Control:** This mode takes the set point values from the environmental control, for example from ControlDesk during online simulation. There are two setpoint required for current control, direct axis current setpoint ( $i_d$ \_Set[A]) and quadrature axis current setpoint ( $i_q$ \_Set[A]).

**Open Loop (V\_abc):** In this mode direct axis voltage ( $V_d$ \_Set[V]) and quadrature axis voltage ( $V_q$ \_Set[V]) along with open loop electrical frequency ( $OL_f$ \_Set[Hz]) can be directly specified by the user. Out of these settings ideal sinusoidal three phase voltages ( $V_a$ ,  $V_b$ ,  $V_c$ ) are generated and applied to the space vector modulator. These **voltages are not aligned to the rotor position**. The space vector modulator block calculates the corresponding duty cycles for the 3 phase

PWM generator stage. Its outputs are routed via digital outputs to the inverter stage to apply the calculated voltage to the device under test (e-motor).

**Open Loop (V\_dq):** In this mode direct axis voltage ( $V_d$ \_Set[V]) and quadrature axis voltage ( $V_q$ \_Set[V]) can be specified. With the **position information coming from the position encoder**, corresponding phase voltages ( $V_a$ ,  $V_b$ ,  $V_c$ ) are calculated. The space vector modulator block calculates the corresponding duty cycles for the PWM generator stage. Its outputs are routed via digital outputs to the inverter stage to apply the calculated voltage to the device under test (e-motor).



Figure 100: Principle of the PMSM controller

## Structure

This section provides a general description of the Simulink model. The figure below shows the Simulink root model. The FPGA containing part is placed on the top left corner, inside here everything is modelled with the use of the Xilinx System Generator. This subsystem contains all the calculation which later run on the FPGA platform.

The processor application, here everything is modelled with standard Simulink blocks, is placed in the centre of the model. The CONTROLLER\_TASK subsystem (top of the processor-based blocks) is an asynchronous called function which is aligned to the PWM generation. It contains the processor speed- and current-controller als well as interfaces to the FPGA part.

The communication between the FPGA and the processor application for a Scalexio based system is carried out using buffer interface (for PHS it is register interface). Like shown on the right side of the model. The input to the processor part (output of the FPGA part) is marked in yellow and the output of the processor part (input of the FPGA part) is marked in magenta. These subsystems contain Buffer 2 Register and Register 2 Buffer blocks from XSG Utils. For more information please refer to the XSG Utils Documentation.



Figure 101: PMSM Controller Demo Root

**CONTROLLER\_TASK**

The controller task has a cascaded control architecture. The **SENSOR** subsystem collects all the sensor signals coming from the FPGA: phase currents, d&q currents, DC link voltage and position sensor signals from Hall and Incremental encoders. The communication between the FPGA and this asynchronous task is realised within the B1D2 (board = 1, TaskID = 2) subsystems (yellow and Magenta blocks).



Figure 1022: PMSM processor controller model

The **SPEED\_CONTROL** subsystem contains a PI controller for the speed control loop. The PI controller takes the set points from the **ENVIRONMENTAL CONTROL** (e.g. via ControlDesk during online simulation) and generates a quadrature axis current set point, the direct axis current setpoint is fix set to zero. These currents are routed via a switch, to provide a pure current control functionality without speed controller, directly to the input of the current controller.

Either the current setpoints are given to the **CURRENT\_CONTROL** subsystem from the speed controller (if activated) or from the environmental control. There are two current controllers implemented, one processor- and the second FPGA based. Both take the same setpoints and the feedback from the phase current sensors. The output of this system are two voltage set points ( $V_d$  &  $V_q$ ). Via an open loop switch, these calculated values can be overwritten by user defined signals coming from environmental control. The DQ voltages are converted to three phase voltages (using inverse Clark park transformation), with help of the actual rotor position. These voltages are fed into the two-level space vector modulator block. Another open loop switch allows to apply a certain three phase voltage independently from the rotor position. Here a user defined (constant) voltage ( $d$  &  $q$ ) is transformed with a user defined frequency into phase voltages (abc)

An automatic position encoder offset calibration functionality is part of this system. It is necessary that the position sensor is calibrated, since otherwise the control algorithm cannot perform the required transformation. In case the offset position of the motor is not calibrated then this function prevents the motor from being switched on. The position calibration applies predefined constant voltages to the motor winding. These voltages lead to a rotation of the rotor, when rotor stops rotating it is located inside the electrical zero-degree position of the motor. The corresponding angular position value from the position sensor is recorded and used in the algorithm as position sensor offset.

|                                                                                     |                                                                                                                                                          |
|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | During offset calibration the shaft is rotating. Ensure safety during calibration process.                                                               |
|  | The motor shaft should not be loaded or blocked during position sensor calibration. The offset calibration is possible when the rotor can rotate freely. |

The **space vector modulator** takes the three phase voltages and the DC link voltage and converts them three-phase duty cycles. This three-phase duty cycles are given to a PWM modulator block which generates the corresponding switching signal for the power electronic. These switching signals are wired to the inverter, so that the inverter outputs the desired voltages to the connected motor.

**ACTUATOR** subsystem: In case of processor based current control, the gate duty cycles are taken from the space vector modulator located on the processor side. These duty cycles are provided as input to the PWM generator. The PWM generator is a standard coming from XSG\_Utils, it provides the parameters for dead time, aligning mode and frequency. For more details refer to the XSG Utils documentation. In case of the FPGA based current control is activated, only the frequency, dead time and aligning mode are taken from here. The duty cycle for the FPGA based current controller are directly calculated on the FPGA.

#### ENVIRONMENTAL\_CO NTROL

The processor application generated from the Simulink model is interfaced with ControlDesk using the Environment Control subsystem. This subsystem contains those signals and parameters which mainly are displayed and tuned inside ControlDesk. Like setpoints, control modes and other parameters

The display subsystem is connected to various LEDs and warning messages on the ControlDesk experiment that monitor the state of the motor and reports the current operating condition.

The parameter subsystem houses the standard motor and inverter parameters next to other environmental information needed by the controller. It contains also the motor safety relevant parameters.

The setpoint subsystem contains the setpoints for all controller and open loop modes. Next to static- also dynamic-setpoints (1D LUT) can be activated.

---

|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>LOAD_MACHINE</b>        | The demo setup comes with a magnetic brake where the load torque can be applied to the device under test via PWM signal signal. The strength is in this configuration a function of the PWM duty cycle.                                                                                                                                                                                                                                                        |
| <b>CURRENT_CONTROLLER</b>  | Interfaces for FPGA based field orientated current controller. Parameters coming from the environmental control such as PI controller parameter, control mode and filter time constants are sent from here to the FPGA based control algorithm. Next to this, motor specific parameter like $L_d$ , $L_q$ , pole pairs, phase resistance, etc. are also transferred.                                                                                           |
| <b>POSITION_SENSOR</b>     | Parameterization interface for the FPGA based position sensors Hall and Incremental Encoder.                                                                                                                                                                                                                                                                                                                                                                   |
| <b>SERVICES</b>            | Contains the XSG Utils multiscope block, which can visualize signals from the FPGA directly to Control Desk with a time resolution of up to the FPGA sampling rate. A drive Safety block which protects to the motor for over current and thermal overheating and a library version block that verifies the correctness of the used XSG solutions versions provided by dSPACE. For more information on Multiscope please refer to the XSG_Utils documentation. |
| <b>SCALE_IO</b>            | Parametrization interface for linear scaling of all analog to digital converter (ADC) and digital to analog converter (DAC) available on the hardware. Next to the scaling (gain, offset, min,max) PT1 filters for the analog inputs (ADC) can be configured.. These standard components are located inside the XSG_Utils.lib. Please refer to the XSG_Utils documentation for more information.                                                               |
| <b>FPGA Model Overview</b> | A view inside the FPGA subsystem shows the FPGA based implementation, inside here everything is modeled by using the Xilinx System Generator. An overview of the FPGA implementation is shown in the figure below.                                                                                                                                                                                                                                             |

---



**Figure 103: PMSM Demo FPGA Model**

The FPGA setup block is on the left side of the FPGA model. Here the specification of desired the hardware platform (framework) is made. The FPGA build actions block is used to perform automated actions after a successful FPGA Build, e.g. backup of the current model and its settings. The analyse model block provides numerous useful functionalities for ease of FPGA programming with the dSPACE XSG based solutions. For more information refer to XSG Utils documentation. The yellow and magenta coloured subsystems contain the buffer communication between the processor and FPGA application.

---

|                                   |                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>IO</b>                         | All hardware in- and outputs are inside this subsystem. The IO subsystem is used to configure sensors and read sensor output, as well as phase current and battery supply voltage. This subsystem also has Digital Out Blocks which can be configured for different applications such as PWM. In here, scale ADC and scale DAC as well as the PT1 filters are located. |
| <b>POSITION_SENSOR_PROCESSING</b> | Contains the hall and incremental encoder processing from the XSG_ACNC library. They receive the digital inputs from the IO subsystem and calculate the actual position which is used for the controller algorithms.                                                                                                                                                   |
| <b>CURRENT_CONTROLLER</b>         | The measured currents, rotor position and DC link voltages are input to the current controller subsystem and the output are three phase voltage setpoints. Next to the standard closed loop behavior of the controller, it comes with two open loop modes which maybe useful during the put into operation phase.                                                      |

---



**Figure 104: FPGA based Current Controller**

The figure above shows the basic structure of the current controller. The current sensor inputs for all three phases are taken in along with the mechanical sensor position and transformed into d-q coordinate frame. This is further given to two PT1 filters which then serves as inputs to two different PI controller each for d and q axis currents. The set points for the same are obtained from the processor. After the PI controller there is voltage decoupling network with back EMF feedforward. The output of the decoupling network is the d and q axis voltage setpoints which are provided to an inverse Clark Park transformation block and the three phase voltages hence obtained are the sent an inputs to Space Vector modulation blocks which take in the three phase voltages along with DC Link voltage to generate the duty cycles for all three legs of the inverter. Finally, the duty cycles are converted to corresponding switching signals in the PWM generator block.

The functionality of the FPGA based current controller is same as the processor based current controller as it affords the user the opportunity to select between the four different control mode available. In case the **Speed control** mode is selected the current set, points generated by the processor-based speed controller are received from the processor application and are fed as set point to the PI controller on the FPGA side. In case pure **Current Control** mode is selected then the setpoints obtained from the ENVIRONMENTAL\_CONTROL on the processor application provided to set points to the current PI controllers. In case **open loop mode (V\_abc)** is selected the corresponding voltages for the three phase  $V_a$ ,  $V_b$  and  $V_c$  are calculated and sent over to the current controller. The current controller takes these voltages and sends them over directly to space vector modulator for generation of duty cycles. If the **open loop mode (V\_dq)** is selected then the setpoints  $V_d\text{Set}[v]$  and  $V_q\text{Set}[v]$  originating from the ENVIRONMENTAL\_CONTROL subsystem are provided to the current controller on the FPGA. The current controller converts these setpoints to three phase voltage setpoints using the inverse clark park transformation block and the sends the value to the space vector modulator block.

#### SPACE\_VECTOR\_MODULATOR

Space vector modulation (SVM) is an algorithm for the control of pulse width modulation (PWM). It is used for the creation of alternating current (AC) waveforms; most commonly to drive 3 phase AC powered motors at varying speeds. An inverter

converts a DC supply, via a series of switches, to three output legs which could be connected to a three-phase motor.

These switches must be controlled so that at no time both switches of a leg are activated at the same time, because this would result a shorten DC supply voltage and destroy the power amplifier. This requirement is met by the complementary operation of the switches within a leg. i.e. if A+ is on the A- is off and vice versa. This leads to eight possible switching vectors for the inverter, V0 through V7 with six active switching vectors and two zero vectors in the case of a three-phase inverter.

| Vector | A+  | B+  | C+  | A-  | B-  | C-  | VAB              | VBC              | VCA              |
|--------|-----|-----|-----|-----|-----|-----|------------------|------------------|------------------|
| V0     | OFF | OFF | OFF | ON  | ON  | ON  | 0                | 0                | 0                |
| V1     | ON  | OFF | OFF | OFF | ON  | ON  | +V <sub>dc</sub> | 0                | -V <sub>dc</sub> |
| V2     | ON  | ON  | OFF | OFF | OFF | ON  | 0                | +V <sub>dc</sub> | -V <sub>dc</sub> |
| V3     | OFF | ON  | OFF | ON  | OFF | ON  | -V <sub>dc</sub> | +V <sub>dc</sub> | 0                |
| V4     | OFF | ON  | ON  | ON  | OFF | OFF | -V <sub>dc</sub> | 0                | +V <sub>dc</sub> |
| V5     | OFF | OFF | ON  | ON  | ON  | OFF | 0                | -V <sub>dc</sub> | +V <sub>dc</sub> |
| V6     | ON  | OFF | ON  | OFF | ON  | OFF | +V <sub>dc</sub> | -V <sub>dc</sub> | 0                |
| V7     | ON  | ON  | ON  | OFF | OFF | OFF | 0                | 0                | 0                |

In the table above  $V_{dc}$  is the DC link voltage. The space vector modulator block takes in the three phase reference phase voltages and converts them to their respective duty cycles for each of the three legs of the inverter. These duty cycles are the inputs of a 3 phase PWM generator block.

---

**THREE\_PHASE\_PWM\_GENERATOR** Its inputs are the duty cycles that come either from the FPGA- or processor-based current controller. A switch, which can be activated on the processor side, routes either the signals coming from the processor- or the FPGA based controller to the generator.

---

**DRIVE\_SAFETY** The drive safety block which provides long term (and with this also thermal protection) and short term over current protection along with zero current protection for the motor. The inputs of the system is three phase currents. It observes the current waveform and disables the digital outputs responsible for switching the inverter if the allowable limits are exceeded.

---

**LOAD\_MACHINE** This subsystem contains a single phase PWM generator. The output of this system is fed to a magnetic brake which is built in the demonstration setup. The amount of braking load is determined by the voltage (duty cycle) supplied to the brake.

---

**SERVICES** Contains utilities such as the FPGA MultiScope and version information block from XSG\_Utils library. The FPGA multiscope can take up to sixteen signals from the FPGA at the FPGA clock rate and send the data to the processor application. For more details on the scope refer to the XSG Utils documentation. The version information block transmits the version information of the XSG solutions located on the FPGA side to the processor application.

## Control Desk Environment

To open the prepared ControlDesk backup, first start ControlDesk. Then, select File - Open – Project + Experiment from Backup.



Figure 103: Open Control Desk Backup Project

Navigate to the demo installation directory at:

C:\Users\<UserName>\Documents\dSPACE\XSG\_ACMC<Version\_Number>\Demos\<Platform>\Instrumentation

For Example:

C:\Users\Admin\Documents\dSPACE\XSG\_ACMC\20.1\Datas\Scalexio\Instrumentation

After the backup is loaded, the following layout is shown:



Figure 104: Control Desk Controller Layout

Now, register the processor board and start the online calibration/measurement. The real-time application will be downloaded. The entire ControlDesk experiment comes with 4 different layouts: Controller, Dynamic Setpoints, ADC and System Information.

## Controller Layout

The controller layout can be seen organized in two distinct rows. The top row has a standard plotter to the left and an XSG\_Utils FPGA Scope instrument to the right. Via the setting instrument, the measurement can be configured, like e.g. the trigger condition or a pre- or post-trigger time. The XY-Plotter in the centre displays the signals recorded on the FPGA side, here signals with a time resolution of up to FPGA Clock Speed (e.g. 12.5ns) can be visualized! These instruments are used to visualize the speed, current, voltage, and position signals used in the demo.

The lower row has four distinct instruments. On the left-hand side are the control instruments with which several setpoints and control modes can be selected. In the centre there is a schematic diagram which displays the most relevant actual values for the speed and current controller. On the right end of the row we have the online encoder offset calibration instrument and the Drive safety instrument.

The drive safety instrument as seen in the figure below, it provides protection of the drive against over current respectively over temperature. It can protect in case of a sensor failure with a zero current detection along with long term and short term over current with i2 and i2Fi thresholds.

| Drive Safety Settings |           |     |              |            |  |
|-----------------------|-----------|-----|--------------|------------|--|
| Global_Error[0 1]     | Threshold | Err | Actual Value | Hold Value |  |
| Zero Current [A]      | 1         |     | 0.01         | 0.01       |  |
| i2 [A2]               | 150       |     | 0.43         | 0.43       |  |
| i2_Fi [A2]            | 100       |     | 0.39         | 0.39       |  |

Figure 1057: Drive Safety Instrument

Online offset calibration is needed to find the electrical zero position of the motor. By using this instrument, it is very easy to identify this position. After pushing the start button, a rotating electrical field is applied to the motor as long as the position sensor can detect a valid position (index pulse of the TTL). In the second step a constant voltage in the d axis is applied which lets the rotor move into the electrical zero position.



Figure 1068: Position Offset Control Desk Instrument

## Dynamic Setpoints Layout

Inside the dynamic setpoint layout, the user can specify repeating sequences of time depending setpoints. In keeping with the theme of the demo it is possible to select between the four different control modes and provide the setpoints using one dimensional look up (LUT) tables. Each setpoint LUT has 10 discrete values that repeats after a specified period length. The period length can be altered from the input field on the top and the table content can be modified during runtime.



Figure 109: Dynamic Setpoint Layout

## ADC Layout

The ADC Scaling layout allows the user to adjust the sensor scaling (within a linear region, inclusive saturation) and filter times for analog input channels. For more information refer to XSG\_Utils documentation.



Figure 107: ADC-DAC Scaling Layout

## System Information Layout

The system information layout shows the version information of different FPGA and processor based XSG libraries provided by dSPACE. There are two plotters that display the periodic - and interrupt - task turnaround time. After the real-time application is downloaded and the real-time process is executed, the XSG library version info will show the recognized versions numbers for the FPGA and Processor model. These numbers must be equal!



Figure 1081: Tasks and Versions Layout

## Configuration Desk Environment

In case of using an SCALEXIO based platform, like e.g. MABX III a ConfigurationDesk project comes with the demo. To open the prepared ConfigurationDesk backup project, first start ConfigurationDesk. Then, select File - Open – Project + Experiment from Backup.



Figure 109: Open Configuration Desk Backup Project

Navigate to the demo installation directory at:

C:\Users\<UserName>\Documents\dSPACE\XSG\_ACMC\<Version\_Number>\Demos\<Platform>\Configuration

For Example:

C:\Users\Admin\Documents\dSPACE\XSG\_ACMC\20.1\Demos\Scalexio\Configuration

# DS1553 Framework

## Introduction

### Overview

Together with the XSG AC Motor Control Solution, a FPGA framework for the DS1553 AC Motor Control I/O-Board in conjunction with the DS1514 FPGA base board is delivered.



### Installation

The DS1553 framework has to be installed for every dSPACE installation it is used with. To install the framework for the currently active dSPACE release, click on the "Inst. Framework" button on the top level of the XSG AC Motor library.



Figure 113: Button to install the DS1553 FPGA framework

A dialog prompt will appear, asking to confirm that the framework will be installed. After the framework has been installed, the framework will be available in the framework selection window of the FPGA setup block.



Figure 114: Button to install the DS1553 FPGA framework



Figure 1105: Dialog to select DS1514 with DS1553 as target platform

# I/O Read Functions

---

## Overview

The DS1553 provides the following I/O read functions:

- 1x Status In
- 8x Digital In
- 8x ADC
- 4x RS485 In
- 1x Resolver IC
- 1x FPGA Temperature

## Status In

---

### Block

This block provides the internal status of the hardware initialization to the model.



**Figure 1116: FPGA\_IO\_READ block (Status In)**

---

### Output

The main block has the following outputs:

| Name      | Unit | Description                              | Format   |
|-----------|------|------------------------------------------|----------|
| Init Done | -    | Signals that the hardware is initialized | UFix_1_0 |

## Digital In

**Block**

The 8 digital inputs provide a signal level of  $V_H=5V$  and are configurable between single-ended or differential input signal in groups.



Figure 1127: FPGA\_IO\_READ block (Digital In)

**Block Dialog**

The block provides the following dialog:



Figure 1138: FPGA\_IO\_READ dialog (Digital In)

The blockset dialog has the following parameters:

| Name                   | Unit | Description                                                                                                                                                                                                                                                                                                                                             | Range                       |
|------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| Input type             | -    | Set the digital input group to single ended or differential input. For the 1 <sup>st</sup> group (1,2,3) this option is set in the block mask of Digital In 1, for the 2 <sup>nd</sup> group (4,5,6) this option is set in the block mask of Digital In 4 and for the 3 <sup>rd</sup> group (7,8) this option is set in the block mask of Digital In 7. | single ended   differential |
| Enable simulation port | -    | Creates a stimulus input port for offline simulation of the I/O. The stimulus data has to be a Simulink input scaled in V.                                                                                                                                                                                                                              | on   off                    |

#### Output

The main block has the following outputs:

| Name | Unit | Description                                   | Format   |
|------|------|-----------------------------------------------|----------|
| Data | -    | The logical signal level at the digital input | UFix_1_0 |



## ADC

#### Block

The 8 differential ADCs provide a resolution of 14 bit, a sample rate of 10 MHz and a configurable voltage range.



Figure 1149: FPGA\_IO\_READ block (ADC)

**Block Dialog**

The block provides the following dialog:



**Figure 1150: FPGA\_IO\_READ dialog (ADC)**

The blockset dialog has the following parameters:

| Name                   | Unit | Description                                                                                                                | Range                            |
|------------------------|------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Input voltage range    | V    | Set the ADC input voltage range to $\pm 5V$ , $\pm 15V$ or $\pm 30V$ .                                                     | $\pm 5V$   $\pm 15V$   $\pm 30V$ |
| Scaling                | -    | Select if the output is scaled in ADC LSBs (bit) or mV.                                                                    | Bit   mV                         |
| Enable simulation port | -    | Creates a stimulus input port for offline simulation of the I/O. The stimulus data has to be a Simulink input scaled in V. | on   off                         |

**Output**

The main block has the following outputs:

| Name | Unit     | Description                                                                    | Format   |
|------|----------|--------------------------------------------------------------------------------|----------|
| Data | Bit   mV | The signal level at the analog input scaled in ADC LSBs (-8192...+8191) or mV. | Fix_16_0 |

## RS485 In

### Block

RS485 ports are bidirectional digital differential drivers with a signal low level of -2.5V and a signal high level of +2.5V. The ports RS485 In and RS485 out share the same physical driver.



Figure 116: FPGA\_IO\_READ block (RS485 In)

### Block Dialog

The block provides the following dialog:



Figure 11722: FPGA\_IO\_READ dialog (RS485 In)

The blockset dialog has the following parameters:

| Name                   | Unit | Description                                                                                                                | Range    |
|------------------------|------|----------------------------------------------------------------------------------------------------------------------------|----------|
| Enable simulation port | -    | Creates a stimulus input port for offline simulation of the I/O. The stimulus data has to be a Simulink input scaled in V. | on   off |

**Output**

The main block has the following outputs:

| Name | Unit | Description                                  | Format   |
|------|------|----------------------------------------------|----------|
| Data | -    | The digital signal level at the RS485 input. | UFix_1_0 |

## Resolver IC

**Block**

The DS1553 I/O board provides an integrated resolver processing IC. The IC provides position information of a resolver connected to the FPGA model. It also provides warnings concerning signal quality. The update rate of the resolver IC is 500 kHz.



Figure 118: FPGA\_IO\_READ block (Resolver IC)

**Block Dialog**

The block provides the following dialog:



Figure 124: FPGA\_IO\_READ dialog (Resolver IC)

The blockset dialog has the following parameters:

| Name                      | Unit | Description                                                                                                                                                                                   | Range                                  |
|---------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| Sine / cosine RMS voltage | V    | Selection of the input voltage range of the sine and cosine signal.                                                                                                                           | 1.5V   3.5V   5V                       |
| Excitation RMS voltage    | V    | Selection of the RMS voltage of the generated excitation.                                                                                                                                     | 3V   7V   10V                          |
| Excitation Frequency      | Hz   | Selection of the frequency for the generated excitation.                                                                                                                                      | Range:2kHz..20kHz<br>Resolution: 250Hz |
| Resolution                | Bit  | Resolution of the resolver processing. The resolution effects the maximum trackable velocity as followed:<br>10 bit: 150000 rpm<br>12 bit: 60000 rpm<br>14 bit: 30000 rpm<br>16 bit: 7500 rpm | 10bit   12bit   14 bit   16 bit        |
| Enable simulation port    | -    | Creates a stimulus input port for offline simulation of the I/O. The stimulus data (position) has to be a Simulink input scaled in degrees.                                                   | on   off                               |

**Input**

The main block has the following inputs:

| Name     | Unit | Description                                | Format   |
|----------|------|--------------------------------------------|----------|
| Cl.Warn. | -    | Resets warnings raised by the resolver IC. | UFix_1_0 |

**Output**

The main block has the following outputs:

| Name     | Unit | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Format     |
|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| Position | -    | The position output of the resolver IC. The position range (0...360°) is scaled to 0...1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | UFix_16_16 |
| Warnings | -    | <p>The warnings raised by the resolver IC. The warnings are as followed:</p> <p><i>Bit 0 – Input amplitude low:</i><br/>The sine/cosine input amplitude is more than ~20% lower than specified. Once this warning occurs it can only be cleared manually.</p> <p><i>Bit 1 – Input amplitude high:</i><br/>The sine/cosine input amplitude is more than ~20% higher than specified. Once this warning occurred it can only be cleared manually.</p> <p><i>Bit 2 – Loss of tracking:</i><br/>The position could not be tracked. This warning will disappear if the position tracking could be successfully resynchronized.</p> <p><i>Bit 3 – Velocity over-range:</i><br/>The current velocity is higher than the resolver processing is able to track. This warning will disappear if the velocity is low enough again to be tracked.</p> <p><i>Bit 4 – Phase lock error:</i><br/>The phase of the sine/cosine input does not match the phase of the excitation output. Check if the resolver is plugged and correctly working. This warning will disappear once the sine/cosine phase matches the excitation phase again.</p> | UFix_5_0   |
| Data New | -    | Flag indicating that the position data is updated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | UFix_1_0   |

# FPGA Temperature

## Block

The DS1514 base board contains an integrated FPGA temperature measurement. The raw value of the temperature measurement is provided to the user model.



Figure 11925: FPGA\_IO\_READ block (FPGA Temperature)

## Block Dialog

The block provides the following dialog:



Figure 1206: FPGA\_IO\_READ dialog (FPGA Temperature)

The blockset dialog has the following parameters:

|                        |   |                                                                                                                                           |          |
|------------------------|---|-------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Enable simulation port | - | Creates a stimulus input port for offline simulation of the I/O. The stimulus data (temperature) has to be a Simulink input scaled in °C. | on   off |
|------------------------|---|-------------------------------------------------------------------------------------------------------------------------------------------|----------|

**Output**

The main block has the following outputs:

| Name     | Unit | Description                                                  | Format    |
|----------|------|--------------------------------------------------------------|-----------|
| RAW_Temp | -    | The raw temperature sensor output. The scaling is 130 LSB/K. | UFix_16_0 |
| High     | -    | Flag indicating that the FPGA temperature is >125°C.         | UFix_1_0  |

# I/O Write Functions

## Overview

The DS1553 provides the following I/O write functions:

- 1x LED Out
- 24x Digital Out
- 2x DAC
- 4x RS485 Out

## LED Out

### Block

This block controls the status LED of the DS1514 FPGA board.



Figure 1217: FPGA\_IO\_WRITE block (LED Out)

### Input

The main block has the following Inputs:

| Name | Unit | Description                                                | Format   |
|------|------|------------------------------------------------------------|----------|
| Data | -    | Sets the color of the FPGA LED to orange (1) or green (0). | UFix_1_0 |

## Digital Out

### Block

The 24 digital outputs provide a signal level of  $V_H=5V$ .



Figure 1228: FPGA\_IO\_WRITE block (Digital Out)

**Block Dialog**

The block provides the following dialog:



**Figure 1239: FPGA\_IO\_WRITE dialog (Digital Out)**

The blockset dialog has the following parameters:

| Name                   | Unit | Description                                                                                                           | Range    |
|------------------------|------|-----------------------------------------------------------------------------------------------------------------------|----------|
| Enable simulation port | -    | Creates a stimulus output port for offline simulation of the I/O. The stimulus data is a Simulink output scaled in V. | on   off |

**Input**

The main block has the following inputs:

| Name | Unit | Description                                            | Format   |
|------|------|--------------------------------------------------------|----------|
| Data | -    | The logical signal level to set at the digital output. | UFix_1_0 |

# DAC

## Block

The 2 differential DACs (referenced to ground) provide a resolution of 12 bit, an update rate of 20MHz and voltage range of -20V...+20.



Figure 124: FPGA\_IO\_WRITE block (DAC)

## Block Dialog

The block provides the following dialog:



Figure 125: FPGA\_IO\_WRITE dialog (DAC)

The blockset dialog has the following parameters:

| Name                   | Unit | Description                                                                                                           | Range    |
|------------------------|------|-----------------------------------------------------------------------------------------------------------------------|----------|
| Scaling                | -    | Select if the input is scaled in DAC LSBs (bit) or mV.                                                                | Bit   mV |
| Enable simulation port | -    | Creates a stimulus output port for offline simulation of the I/O. The stimulus data is a Simulink output scaled in V. | on   off |

**Input**

The main block has the following Inputs:

| Name | Unit     | Description                                                                         | Format   |
|------|----------|-------------------------------------------------------------------------------------|----------|
| Data | Bit   mV | The signal level set at the analog output scaled in DAC LSBs (-2048...+2047) or mV. | Fix_16_0 |

|                                                                                   |                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <p>The DAC (+) and DAC (-) pins are both referenced to ground. To change the voltage range to -10V...+10V connect to ground instead of DAC (-). The scaling in mV is not valid in this case, so it is recommended to use scaling in bit when applying the -10V...+10V range.</p> |
|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## RS485 Out

**Block**

RS485 ports are bidirectional digital differential drivers with a signal low level of -2.5V and a signal high level of +2.5V. The ports RS485 In and RS485 out share the same physical driver.



Figure 126: FPGA\_IO\_WRITE block (RS485 Out)

**Block Dialog**

The block provides the following dialog:



Figure 127: FPGA\_IO\_WRITE dialog (RS485 Out)

The blockset dialog has the following parameters:

| Name                   | Unit | Description                                                                                                           | Range    |
|------------------------|------|-----------------------------------------------------------------------------------------------------------------------|----------|
| Enable simulation port | -    | Creates a stimulus output port for offline simulation of the I/O. The stimulus data is a Simulink output scaled in V. | on   off |

**Input**

The main block has the following inputs:

| Name   | Unit | Description                                                        | Format   |
|--------|------|--------------------------------------------------------------------|----------|
| Data   | -    | The digital signal level set at the RS485 output.                  | UFix_1_0 |
| Enable | -    | Sets the direction of the RS485 driver to output (1) or input (0). | UFix_1_0 |

## Pin-Out

### Layout

The pin-out of ZIF connector on the DS1553 ACMC I/O module is shown in the table on the next page. The layout of the ZIF connector (upper connector of the MicroAutoBox) is illustrated in the figure below. The location of ground pins can be seen in this figure as well.



Figure 128: Layout of the DS1553 ZIF connector

| Group          | Pin | Signal      | Dir. | Group         | Pin | Signal         | Dir.   |
|----------------|-----|-------------|------|---------------|-----|----------------|--------|
| Digital Input  | D3  | DigIn 1 (+) | in   | Analog Input  | A6  | ADC 1 (+)      | in     |
|                | E6  | DigIn 1 (-) | in   |               | A2  | ADC 1 (-)      | in     |
|                | D4  | DigIn 2 (+) | in   |               | A5  | ADC 2 (+)      | in     |
|                | D5  | DigIn 2 (-) | in   |               | A4  | ADC 2 (-)      | in     |
|                | E5  | DigIn 3 (+) | in   |               | A3  | ADC 3 (+)      | in     |
|                | E4  | DigIn 3 (-) | in   |               | B6  | ADC 3 (-)      | in     |
|                | U3  | DigIn 4 (+) | in   |               | B5  | ADC 4 (+)      | in     |
|                | U5  | DigIn 4 (-) | in   |               | B4  | ADC 4 (-)      | in     |
|                | T3  | DigIn 5 (+) | in   |               | c2  | ADC 5 (+)      | in     |
|                | U4  | DigIn 5 (-) | in   |               | c3  | ADC 5 (-)      | in     |
|                | V6  | DigIn 6 (+) | in   |               | b2  | ADC 6 (+)      | in     |
|                | V5  | DigIn 6 (-) | in   |               | c4  | ADC 6 (-)      | in     |
|                | T5  | DigIn 7 (+) | in   |               | a2  | ADC 7 (+)      | in     |
|                | U6  | DigIn 7 (-) | in   |               | Z2  | ADC 7 (-)      | in     |
|                | F6  | DigIn 8 (+) | in   |               | c5  | ADC 8 (+)      | in     |
|                | E3  | DigIn 8 (-) | in   |               | Y2  | ADC 8 (-)      | in     |
| Digital Output | R3  | DigOut 1    | out  | Resolver IC   | a4  | Excitation (+) | out    |
|                | R5  | DigOut 2    | out  |               | b6  | Excitation (-) | out    |
|                | S5  | DigOut 3    | out  |               | a5  | Sine (+)       | in     |
|                | R4  | DigOut 4    | out  |               | a6  | Sine (-)       | in     |
|                | R6  | DigOut 5    | out  |               | c6  | Cosine (+)     | in     |
|                | S4  | DigOut 6    | out  |               | b5  | Cosine (-)     | in     |
|                | H3  | DigOut 7    | out  | RS485         | W3  | RS485 1 (+)    | in/out |
|                | H4  | DigOut 8    | out  |               | X4  | RS485 1 (-)    | in/out |
|                | G3  | DigOut 9    | out  |               | V4  | RS485 2 (+)    | in/out |
|                | G4  | DigOut 10   | out  |               | V3  | RS485 2 (-)    | in/out |
|                | S3  | DigOut 11   | out  |               | W6  | RS485 3 (+)    | in/out |
|                | F5  | DigOut 12   | out  |               | W4  | RS485 3 (-)    | in/out |
|                | F3  | DigOut 13   | out  |               | X3  | RS485 4 (+)    | in/out |
|                | T4  | DigOut 14   | out  |               | Y4  | RS485 4 (-)    | in/out |
|                | F4  | DigOut 15   | out  | Analog Output | C3  | DAC 1 (+)      | out    |
|                | G6  | DigOut 16   | out  |               | D6  | DAC 1 (-)      | out    |
|                | X6  | DigOut 17 * | out  |               | C5  | DAC 2 (+)      | out    |
|                | C6  | DigOut 18 * | out  |               | C4  | DAC 2 (-)      | out    |
|                | H6  | DigOut 19 * | out  | Sensor Supply | E2  | Supply +5V     | out    |
|                | X5  | DigOut 20 * | out  |               | F2  | Supply +5V     | out    |
|                | G5  | DigOut 21 * | out  |               | C2  | Supply +12V    | out    |
|                | H5  | DigOut 22 * | out  |               | D2  | Supply +12V    | out    |
|                | S6  | DigOut 23 * | out  |               |     |                |        |
|                | W5  | DigOut 24 * | out  |               |     |                |        |

 The pins marked with an asterisk (\*) are only available if the DS1514 base board hardware is reconfigured. Please inquire about hardware reconfiguration if these digital outputs are required. The use of additional IP modules will not be possible after modification!