# Application Note Potentiometer Controlled by an Encoder

# **AN-CM-320**

# Abstract

This application note illustrates how to use the SLG47004 to control a potentiometer with an encoder and to implement an adjustable voltage divider based on it. The application note comes complete with design files which can be found in the References section.

# Contents

| Ab  | stract |           |                                   | 1 |
|-----|--------|-----------|-----------------------------------|---|
| Co  | ntents | 5         |                                   | 2 |
| Fig | ures.  |           |                                   | 2 |
| Tal | oles   |           |                                   | 2 |
| 1   | Term   | s and D   | efinitions                        |   |
| 2   | Refe   | rences    |                                   |   |
| 3   | Intro  | duction.  |                                   |   |
| 4   | Syste  | em Over   | view                              | 5 |
| 5   | Func   | tional B  | lock Architecture                 | 6 |
|     | 5.1    | Digital L | _ogic Description                 | 6 |
|     |        | 5.1.1     | Determining the Encoder Direction | 6 |
|     |        | 5.1.2     | Determing the Encoder Speed       | 7 |
|     |        | 5.1.3     | Detents and Pulses per Revolution | 7 |
|     | 5.2    | Potentio  | ometer Mode                       |   |
|     | 5.3    | Macroc    | ells Settings                     |   |
| Co  | nclus  | ions      |                                   |   |
| Re  | vision | History   |                                   |   |

# **Figures**

| Figure 1: General Schematic of a Voltage Divider Controlled by the Encoder                | 4  |
|-------------------------------------------------------------------------------------------|----|
| Figure 2: GreenPAK Designer Project                                                       |    |
| Figure 3: Timing Diagrams for Clockwise Encoder Rotation                                  | 6  |
| Figure 4: Timing Diagrams for Counterclockwise Encoder Rotation                           |    |
| Figure 5: Digital Rheostats Settings                                                      | 9  |
| Figure 6: Delays Settings                                                                 | 10 |
| Figure 7: One Shots Settings when the Number of Pulses and Detents Do Not Match           | 11 |
| Figure 8: One Shots Settings when the Number of Pulses and Detents Match                  | 12 |
| Figure 9: Frequency Detectors Settings when the Number of Pulses and Detents Do Not Match | 13 |
| Figure 10: Frequency Detectors Settings when the Number of Pulses and Detents Match       | 14 |

# **Tables**

| Table 1: 2-bit LUTs Settings |  |
|------------------------------|--|
| Table 2: DFF Settings        |  |
| Table 3: PINs Settings       |  |
| Table 4: OSC Settings        |  |
|                              |  |

| Ap | plic | atio | n N | lote |
|----|------|------|-----|------|
|    |      |      |     |      |

# **1** Terms and Definitions

CLK Clock DFF D Flip-Flop

# 2 References

For related documents and software, please visit:

GreenPAK<sup>™</sup> Programmable Mixed-Signal Products | Renesas

Download our free GreenPAK Designer software [1] to open the .gp file [1] and view the proposed circuit design. Use the GreenPAK development tools [2] to freeze the design into your own customized IC in a matter of minutes. Find out more in a complete library of application notes [3] featuring design examples, as well as explanations of features and blocks within the GreenPAK IC.

- [1] GreenPAK Designer Software, Software Download and User Guide
- [2] AN-CM-320 Potentiometer Controlled by Encoder.gp, GreenPAK Design File
- [3] GreenPAK Development Tools, GreenPAK Development Tools Webpage
- [4] GreenPAK Application Notes, GreenPAK Application Notes Webpage

Author: Marian Hryntsiv

# 3 Introduction

There are a variety of applications where a mechanical potentiometer is part of a user control interface. These mechanical potentiometers can be changed to more updated and reliable encoder controlled elements and digital rheostats, being components that change electrical parameters of the signal.

SLG47004 is a perfect solution that combines two digital rheostats and configurable logic to process the encoder information. This combination allows to implement many designs: a regulated power supply, an amplifier with a tunable gain, and others. In addition, the presence of digital logic allows determining the speed of rotation of the encoder. This approach is shown in Figure 1.



SLG47004

Figure 1: General Schematic of a Voltage Divider Controlled by the Encoder

RENESAS

# 4 System Overview

Figure 2 shows the internal design based on the SLG47004.



Figure 2: GreenPAK Designer Project

An incremental encoder generates its A and B output signals which are used to change digital rheostats resistance. Rheostats form the potentiometer and allow to implement the adjustable voltage divider to regulate an output voltage.

At any particular time, the phase difference between the A and B signals will be positive or negative depending on the encoder's direction of movement.

A speed determination function is built from Frequency Detectors, One Shots and Multiplexers.

In this application note the EC11 encoder was used. The encoder produces noisy output oscillations due to switch bounce. To eliminate that noise, 2 mS delays were used. Please note that this delay is adjusted for the EC11 encoder (according to its datasheet). For other encoders the delay value should be assessed accordingly.

|                  | Desident 4.0 | 05 4 0004   |
|------------------|--------------|-------------|
| Application Note | Revision 1.0 | 25-Aug-2021 |

# 5 Functional Block Architecture

# 5.1 Digital Logic Description

### 5.1.1 Determining the Encoder Direction

At first, Delay macrocells delay both edges of the encoder output signals for 2 mS. Delay macrocells work like a deglitch filter to eliminate switch bouncing. Delayed signal B appears on DLY inputs of One Shots and Frequency Detectors, and CLK input of DFF. Delayed signal A appears on D input of DFF. When the encoder disk is rotating in a clockwise direction signal A leads signal B and DFF output is High, and when the disk is rotating in a counterclockwise direction signal B leads signal A and DFF output is Low. So DFF can determine the direction of rotation. High or Low signal on Rheostat Up/Down input determines if internal counter's value increases or decreases for each pulse at CLK input.

A timing diagram for the clockwise encoder rotation is shown in Figure 3 and for the counterclockwise encoder rotation in Figure 4.



Figure 3: Timing Diagrams for Clockwise Encoder Rotation

| Appl | ication  | Note |
|------|----------|------|
| ,    | ioution. |      |

**Revision 1.0** 





Figure 4: Timing Diagrams for Counterclockwise Encoder Rotation

### 5.1.2 Determing the Encoder Speed

The SLG47004 has 10-bit digital rheostats, which in turn allows implementation of 1024 regulation steps. The adjustable voltage divider has 3 regulation modes. The user can change output signal with step = 1 digital code (mode 1), step = 10 digital codes (mode 2) and step = 100 digital codes (mode 3). To have 3 modes was used 2 frequency detectors. The first mode is assigned to adjust the output signal smoothly and accurately. It activates when a user adjusts a knob with a frequency less than 10 Hz. The second mode activates when the frequency is greater than 10 Hz, but less than 25 Hz.

One Shots set time intervals for the required number of pulses.

Digital multiplexers provide the passage of either one, or ten, or hundred pulses on CLK input of rheostat according to frequency detectors outputs.

### 5.1.3 Detents and Pulses per Revolution

The encoder with a different number of pulses and detents (positions) was used in this project. With 15 pulses, you have two detents per full pulse. This means that for every pulse (or cycle) in the rotary encoder there are two detents: rising edge of the pulse (one change) and falling edge of the pulse (another change). If your rotary encoder has one detent per pulse, then it has two changes for every pulse. For this type of encoder, the design remains the same, except for Frequency Detectors and One Shots settings. In their settings, Edge Select should be set "Falling" or "Rising". In encoders where the number of pulses and detents do not match, Edge Select should be set to "Both".

#### **Application Note**

**Revision 1.0** 

## 5.2 Potentiometer Mode

For this design we used digital rheostats in potentiometer mode. This mode allows two 2-pin rheostats to work as one 3-pin potentiometer. When this mode is active (register [917] = 1), the user changes the value of the RH0 internal counter. In this mode, the value of the RH1 counter is the inverted value of the RH0 counter. Note that the RH0\_B pin and the RH1\_A pin must be connected externally.

### 5.3 Macrocells Settings

3-bit LUT1 and 3-bit LUT3 settings: Standard Gate - Multiplexer.

#### Table 1: 2-bit LUTs Settings

| IN1 | IN0 | LUT1 OUT | LUT2 OUT |
|-----|-----|----------|----------|
| 0   | 0   | 0        | 0        |
| 0   | 1   | 0        | 0        |
| 1   | 0   | 0        | 0        |
| 1   | 1   | 1        | 1        |

#### **Table 2: DFF Settings**

| Properties        | DFF0          |  |
|-------------------|---------------|--|
| Туре              | DFF/LATCH     |  |
| Mode              | DFF           |  |
| Initial Polarity  | Low           |  |
| Q Output Polarity | Inverted (nQ) |  |

#### **Table 3: PINs Settings**

| Properties     | PINs 6, 7, 8, 9     | PINs 15, 16                        |
|----------------|---------------------|------------------------------------|
| I/O Selection  | Analog Input/Output | Digital Input                      |
| Input Mode     | Analog Input/Output | Digital In with Schmitt<br>Trigger |
| Output Mode    | Analog Input/Output | None                               |
| Resistor       | Floating            | Pull Up                            |
| Resistor Value | Floating            | 10 kΩ                              |

#### Table 4: OSC Settings

| Properties          | OSC1          |
|---------------------|---------------|
| Control Pin Mode    | Power Down    |
| OSC Power Mode      | Auto Power On |
| Clock Selector      | OSC           |
| OSC1 Frequency      | 2.048 MHz     |
| 'CLK' Pre-divider   | 4             |
| OUT0 Second Divider | 64            |

**Application Note** 

#### Revision 1.0



| Properties          | OSC1 |  |
|---------------------|------|--|
| OUT1 Second Divider | 8    |  |

| Digital                      | Rheostat0                | Digital Rheostat1 |                              |                       |  |
|------------------------------|--------------------------|-------------------|------------------------------|-----------------------|--|
| Mode:                        | None                     | -                 | Mode:                        | Potentiometer 💌       |  |
| Charge Pump<br>Enable:       | Always On                | •                 | Charge Pump<br>Enable:       | Always On 🔻           |  |
| Charge Pump<br>Clock: (7)    | Auto selection           | •                 | Charge Pump<br>Clock: (7)    | Auto selection 🔻      |  |
| Auto-Trim:                   | Disable                  | •                 | Auto-Trim:                   | Enable 👻              |  |
| Active level for<br>UP/DOWN: | Up when HIGH             | •                 | Active level for<br>UP/DOWN: | Up when LOW 🔻         |  |
| Resistance (initial data):   | 923<br>(Range: 0 - 1023) | \$                | Resistance (initial data):   | 100 (Range: 0 - 1023) |  |
| Con                          | nections                 |                   | Connections                  |                       |  |
| UP/DOWN<br>source:           | Ext. (From matrix)       | •                 | UP/DOWN<br>source:           | Ext. (From matrix)    |  |
| Clock:                       | Ext. Clk. (From mat      | •                 | Clock:                       | Ext. Clk. (From mat 💌 |  |

Figure 5: Digital Rheostats Settings

**Application Note** 

# Potentiometer Controlled by an Encoder

| 8-bit CNT4/DLY4 (MF4)    |                      |           | 8-bit CNT3/DLY3 (MF3)    |                      |
|--------------------------|----------------------|-----------|--------------------------|----------------------|
| Multi-function mode:     | CNT/DLY -            |           | Multi-function mode:     | CNT/DLY -            |
| Mode:                    | Delay 👻              |           | Mode:                    | Delay 🔻              |
| Counter data:            | 127 (Range: 1 - 255) |           | Counter data:            | 127                  |
| Delay time<br>(typical): | 2 ms <u>Formul</u>   | <u>la</u> | Delay time<br>(typical): | 2 ms <u>Formula</u>  |
| Edge select:             | Both 🔻               |           | Edge select:             | Both 🔻               |
| DLY IN init.<br>value:   | Bypass the initial 🔻 |           | DLY IN init.<br>value:   | Bypass the initial 🔻 |
| Output polarity:         | Non-inverted (OU' 🔻  |           | Output polarity:         | Non-inverted (OU1 💌  |
| Up signal sync.:         | None                 |           | Up signal sync.:         | None 🔻               |
| Keep signal<br>sync.:    | None                 |           | Keep signal<br>sync.:    | None 💌               |
| Mode signal sync.:       | Bypass 💌             |           | Mode signal sync.:       | Bypass 💌             |
| Connections              |                      |           | Сог                      | nnections            |
| Clock:                   | OSC1 /8 👻            |           | Clock:                   | OSC1 /8 👻            |
| Clock source:            | OSC1 Freq. /4 /8     |           | Clock source:            | OSC1 Freq. /4 /8     |
| Clock frequency:         | 64 kHz               |           | Clock frequency:         | 64 kHz               |

Figure 6: Delays Settings

# Potentiometer Controlled by an Encoder

| 8-bit CNT1/DLY1 (MF1)     |                                          | 8-bit CNT5/DLY5 (MF5) |                           |                                              |
|---------------------------|------------------------------------------|-----------------------|---------------------------|----------------------------------------------|
| Multi-function<br>mode:   | CNT/DLY                                  | -                     | Multi-function<br>mode:   | CNT/DLY -                                    |
| Mode:                     | One shot                                 | •                     | Mode:                     | One shot 💌                                   |
| Counter data:             | 8                                        | \$                    | Counter data:             | 99                                           |
| Pulse width<br>(typical): | (Range: 1 - 255)<br>1.125 ms <u>Forn</u> | nula                  | Pulse width<br>(typical): | (Range: 1 - 255)<br>1.5625 ms <u>Formula</u> |
| Edge select:              | Both                                     | -                     | Edge select:              | Both 💌                                       |
| DLY IN init.<br>value:    | Bypass the initial                       | -                     | DLY IN init.<br>value:    | Bypass the initial 💌                         |
| Output polarity:          | Non-inverted (OU                         | •                     | Output polarity:          | Non-inverted (OU1 💌                          |
| Up signal sync.:          | None                                     | -                     | Up signal sync.:          | None                                         |
| Keep signal<br>sync.:     | None                                     | -                     | Keep signal<br>sync.:     | None 👻                                       |
| Mode signal<br>sync.:     | Bypass                                   | •                     | Mode signal<br>sync.:     | Bypass 💌                                     |
| Connections               |                                          |                       | Cor                       | nnections                                    |
| Clock:                    | OSC1 /64                                 | •                     | Clock:                    | OSC1 /8 👻                                    |
| Clock source:             | OSC1 Freq. /4 /64                        |                       | Clock source:             | OSC1 Freq. /4 /8                             |
| Clock frequency:          | 8 kHz                                    |                       | Clock frequency:          | 64 kHz                                       |

Figure 7: One Shots Settings when the Number of Pulses and Detents Do Not Match

# Potentiometer Controlled by an Encoder

| 8-bit CNT1/DLY1 (MF1)     |                                             | 8-bit CNT5/DLY5 (MF5)     |                                              |
|---------------------------|---------------------------------------------|---------------------------|----------------------------------------------|
| Multi-function<br>mode:   | CNT/DLY -                                   | Multi-function<br>mode:   | CNT/DLY -                                    |
| Mode:                     | One shot 💌                                  | Mode:                     | One shot 💌                                   |
| Counter data:             | 8                                           | Counter data:             | 99                                           |
| Pulse width<br>(typical): | (Range: 1 - 255)<br>1.125 ms <u>Formula</u> | Pulse width<br>(typical): | (Range: 1 - 255)<br>1.5625 ms <u>Formula</u> |
| Edge select:              | Falling 💌                                   | Edge select:              | Falling 💌                                    |
| DLY IN init.<br>value:    | Bypass the initial 🔻                        | DLY IN init.<br>value:    | Bypass the initial 🔻                         |
| Output polarity:          | Non-inverted (OU) 🔻                         | Output polarity:          | Non-inverted (OU1 💌                          |
| Up signal sync.:          | None 🔻                                      | Up signal sync.:          | None                                         |
| Keep signal<br>sync.:     | None 👻                                      | Keep signal<br>sync.:     | None 💌                                       |
| Mode signal<br>sync.:     | Bypass 💌                                    | Mode signal<br>sync.:     | Bypass 💌                                     |
| Connections               |                                             | Co                        | onnections                                   |
| Clock:                    | OSC1 /64 💌                                  | Clock:                    | OSC1 /8 💌                                    |
| Clock source:             | OSC1 Freq. /4 /64                           | Clock source:             | OSC1 Freq. /4 /8                             |
| Clock frequency:          | 8 kHz                                       | Clock frequency:          | 64 kHz                                       |

Figure 8: One Shots Settings when the Number of Pulses and Detents Match

# Potentiometer Controlled by an Encoder

| 8-bit CNT2/DLY2 (MF2)   |                       | 8-bit CNT6/DLY6 (MF6)   |                      |
|-------------------------|-----------------------|-------------------------|----------------------|
| Multi-function<br>mode: | CNT/DLY -             | Multi-function<br>mode: | CNT/DLY -            |
| Mode:                   | Frequency detect 🔻    | Mode:                   | Frequency detect 🔻   |
| Counter data:           | 99                    | Counter data:           | 39                   |
| Period (typical):       | 100 ms <u>Formula</u> | Period (typical):       | 40 ms <u>Formula</u> |
| Edge select:            | Both 💌                | Edge select:            | Both 💌               |
| DLY IN init.<br>value:  | Bypass the initial 🔻  | DLY IN init.<br>value:  | Bypass the initial 🔻 |
| Output polarity:        | Non-inverted (OU1 🔻   | Output polarity:        | Non-inverted (OU1 🔻  |
| Up signal sync.:        | None 🔻                | Up signal sync.:        | None 🔻               |
| Keep signal<br>sync.:   | None 🔻                | Keep signal<br>sync.:   | None 🔻               |
| Mode signal<br>sync.:   | Bypass 💌              | Mode signal<br>sync.:   | Bypass 💌             |
| Connections             |                       | Co                      | nnections            |
| Clock:                  | OSC1 /512 💌           | Clock:                  | OSC1 /512 💌          |
| Clock source:           | OSC1 Freq. /4 /512    | Clock source:           | OSC1 Freq. /4 /512   |
| Clock frequency:        | 1 kHz                 | Clock frequency:        | 1 kHz                |

Figure 9: Frequency Detectors Settings when the Number of Pulses and Detents Do Not Match

| <b>Application</b> | Note |
|--------------------|------|
|--------------------|------|

### Potentiometer Controlled by an Encoder

| 8-bit CNT2/DLY2 (MF2)   |                       | 8-bit CNT6/DLY6 (MF6)   |                                          |
|-------------------------|-----------------------|-------------------------|------------------------------------------|
| Multi-function<br>mode: | CNT/DLY -             | Multi-function<br>mode: | CNT/DLY -                                |
| Mode:                   | Frequency detect 💌    | Mode:                   | Frequency detect 💌                       |
| Counter data:           | 99 (Range: 1 - 255)   | Counter data:           | 39 <b></b>                               |
| Period (typical):       | 100 ms <u>Formula</u> | Period (typical):       | (Range: 1 - 255)<br>40 ms <u>Formula</u> |
| Edge select:            | Falling 🔻             | Edge select:            | Falling 🔻                                |
| DLY IN init.<br>value:  | Bypass the initial 💌  | DLY IN init.<br>value:  | Bypass the initial 💌                     |
| Output polarity:        | Non-inverted (OU' 🔻   | Output polarity:        | Non-inverted (OU' 🔻                      |
| Up signal sync.:        | None 🔻                | Up signal sync.:        | None 🔻                                   |
| Keep signal<br>sync.:   | None 🔻                | Keep signal<br>sync.:   | None 🔻                                   |
| Mode signal sync.:      | Bypass 👻              | Mode signal<br>sync.:   | Bypass 💌                                 |
| Connections             |                       | Cor                     | nnections                                |
| Clock:                  | OSC1 /512 💌           | Clock:                  | OSC1 /512 💌                              |
| Clock source:           | OSC1 Freq. /4 /512    | Clock source:           | OSC1 Freq. /4 /512                       |
| Clock frequency:        | 1 kHz                 | Clock frequency:        | 1 kHz                                    |

Figure 10: Frequency Detectors Settings when the Number of Pulses and Detents Match

# Conclusions

The SLG47004 has two digital rheostats which allow implementing a myriad of useful applications. A case in point is using digital rheostats to replace an analog potentiometer with the help of a modern encoder. This application note illustrates how to use the SLG47004 to implement the adjustable voltage divider which is a versatile solution and can be applied to an adjustable power supply, amplifier's gain control, and others. This solution is cost-effective and with low energy consumption.



# **Revision History**

| Revision | Date        | Description     |
|----------|-------------|-----------------|
| 1.0      | 25-Aug-2021 | Initial Version |

**Application Note** 

**Revision 1.0** 

#### IMPORTANT NOTICE AND DISCLAIMER

RENESAS ELECTRONICS CORPORATION AND ITS SUBSIDIARIES ("RENESAS") PROVIDES TECHNICAL SPECIFICATIONS AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT OF THIRD-PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for developers who are designing with Renesas products. You are solely responsible for (1) selecting the appropriate products for your application, (2) designing, validating, and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. Renesas grants you permission to use these resources only to develop an application that uses Renesas products. Other reproduction or use of these resources is strictly prohibited. No license is granted to any other Renesas intellectual property or to any third-party intellectual property. Renesas disclaims responsibility for, and you will fully indemnify Renesas and its representatives against, any claims, damages, costs, losses, or liabilities arising from your use of these resources. Renesas' products are provided only subject to Renesas' Terms and Conditions of Sale or other applicable terms agreed to in writing. No use of any Renesas resources expands or otherwise alters any applicable warranties or warranty disclaimers for these products.

(Disclaimer Rev.1.01 Jan 2024)

#### **Corporate Headquarters**

TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan www.renesas.com

#### Trademarks

Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners.

#### **Contact Information**

For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit <u>www.renesas.com/contact-us/</u>.