Encoder Guide
Encoders measure the movement of mechanical parts. This guide discusses how encoders work, encoder interfaces, types of encoders, and more.
The PhidgetEncoder Highspeed 4-Input interfaces with any 5V quadrature encoder. A quadrature encoder is the most commonly used feedback device for a DC or stepper motor. With an encoder, you can keep track of how far your motor has turned, which then allows you to control the position and velocity in your code. This Phidget connects to your computer via USB.
You can protect your board from dust and debris by purchasing an enclosure. An enclosure will also prevent unintentional shorts caused by objects touching the pins on the bottom of the board or any terminal screws.
Product | Physical Properties | |
---|---|---|
Part Number | Price | Material |
Acrylic Enclosure for the 1047
|
$7.50 | Clear Acrylic |
The PhidgetEncoder HighSpeed 4-Input can be used with any open collector or push-pull incremental quadrature encoder. For more details on the different kinds of encoders, have a look at the Encoder Guide. All of the encoders listed below are compatible with this Phidget:
Product | Encoder Properties | |||
---|---|---|---|---|
Part Number | Price | Output Circuit Type | Encoder Resolution | Encoder Speed Max |
Rotary Encoder - 8mm Hollow Shaft 1000CPR with Index
|
$50.00 | Push-Pull | 1000 CPR | 6000 RPM |
Rotary Encoder - 12mm Hollow Shaft 1000CPR with Index
|
$50.00 | Push-Pull | 1000 CPR | 6000 RPM |
Rotary Encoder - 12mm Solid Shaft 1000CPR with Index
|
$60.00 | Push-Pull | 1000 CPR | 2000 RPM |
Rotary Encoder - 4mm Solid Shaft 360CPR
|
$40.00 | Push-Pull | 360 CPR | 6000 RPM |
Rotary Encoder - 6mm Solid Shaft 1000CPR with Index
|
$40.00 | Push-Pull | 1000 CPR | 6000 RPM |
Rotary Encoder - 6mm Solid Shaft 600CPR
|
$25.00 | Push-Pull | 600 CPR | 6000 RPM |
Rotary Encoder - 8mm Solid Shaft 1000CPR with Index
|
$45.00 | Push-Pull | 1000 CPR | 6000 RPM |
Rotary Encoder - For 4mm Motor Shaft 300 CPR
|
$25.00 | Push-Pull | 300 CPR | 6000 RPM |
Rotary Encoder - For 4mm Motor Shaft 40 CPR
|
$10.00 | Push-Pull | 40 CPR | 6000 RPM |
Rotary Encoder - For 5mm Motor Shaft 1000CPR
|
$30.00 | Push-Pull | 1000 CPR | 5000 RPM |
These linear encoders can all be used with the 1047:
Product | Physical Properties | |
---|---|---|
Part Number | Price | Travel |
Linear Encoder - 300mm
|
$90.00 | 300 mm |
Linear Encoder - 500mm
|
$95.00 | 500 mm |
Linear Encoder - 700mm
|
$100.00 | 700 mm |
Linear Encoder - 900mm
|
$110.00 | 900 mm |
Linear Encoder - 1100mm
|
$120.00 | 1.1 m |
Linear Encoder - 1400mm
|
$340.00 | 1.4 m |
Linear Encoder - 1700mm
|
$360.00 | 1.7 m |
Linear Encoder - 2000mm
|
$380.00 | 2 m |
Here are all of the draw-wire encoders that can be used with the 1047:
Product | Encoder Properties | Physical Properties | |||
---|---|---|---|---|---|
Part Number | Price | Output Circuit Type | Length Resolution | Wire Pull Length | Weight |
Draw-Wire Encoder - 1000mm
|
$100.00 | Push-Pull | — | 1 m | 400 g |
Draw-Wire Encoder - 3000mm
|
$150.00 | Push-Pull | — | 3 m | 790 g |
These 5-wire encoder cables can be soldered onto an encoder in order to easily connect to the 1047.
Product | Physical Properties | ||
---|---|---|---|
Part Number | Price | Cable Length | Cable Gauge |
HighSpeed Encoder Cable 50cm
|
$5.00 | 500 mm | 26 AWG |
Use a USB cable to connect this Phidget to your computer. We have a number of different lengths available, although the maximum length of a USB cable is 5 meters due to limitations in the timing protocol. For longer distances, we recommend that you use a Single Board Computer to control the Phidget remotely.
Product | Physical Properties | |||
---|---|---|---|---|
Part Number | Price | Connector A | Connector B | Cable Length |
USB-A to Mini-B Cable 28cm 24AWG
|
$3.00 | USB Type A | USB Mini-B | 280 mm |
USB-A to Mini-B Cable 28cm Right Angle
|
$3.50 | USB Type A | USB Mini-B (90 degree) | 280 mm |
USB-A to Mini-B Cable 60cm 24AWG
|
$3.50 | USB Type A | USB Mini-B | 600 mm |
USB-C to Mini-B Cable 60cm 28AWG
|
$5.00 | USB Type C | USB Mini-B | 600 mm |
USB-A to Mini-B Cable 83cm Right Angle
|
$4.50 | USB Type A | USB Mini-B (90 degree) | 830 mm |
USB-A to Mini-B Cable 120cm 24AWG
|
$4.00 | USB Type A | USB Mini-B | 1.2 m |
USB-A to Mini-B Cable 180cm 24AWG
|
$4.00 | USB Type A | USB Mini-B | 1.8 m |
USB-C to Mini-B Cable 180cm 28AWG
|
$6.00 | USB Type C | USB Mini-B | 1.8 m |
USB-A to Mini-B Cable 450cm 20AWG
|
$12.00 | USB Type A | USB Mini-B | 4.5 m |
Welcome to the 1047 user guide! In order to get started, make sure you have the following hardware on hand:
Next, you will need to connect the pieces:
Now that you have everything together, let's start using the 1047!
In order to demonstrate the functionality of the 1047, the Phidget Control Panel running on a Windows machine will be used.
The Phidget Control Panel is available for use on both macOS and Windows machines.
To open the Phidget Control Panel on Windows, find the icon in the taskbar. If it is not there, open up the start menu and search for Phidget Control Panel
To open the Phidget Control Panel on macOS, open Finder and navigate to the Phidget Control Panel in the Applications list. Double click on the icon to bring up the Phidget Control Panel.
For more information, take a look at the getting started guide for your operating system:
Linux users can follow the getting started with Linux guide and continue reading here for more information about the 1047.
After plugging the 1047 into your computer and opening the Phidget Control Panel, you will see something like this:
The Phidget Control Panel will list all connected Phidgets and associated objects, as well as the following information:
The Phidget Control Panel can also be used to test your device. Double-clicking on an object will open an example.
Double-click on the Encoder object, labelled Encoder Input, in order to run the example:
General information about the selected object will be displayed at the top of the window. You can also experiment with the following functionality:
Double-click on a Digital Input object in order to run the example:
General information about the selected object will be displayed at the top of the window. You can also experiment with the following functionality:
For more information about Digital Inputs, take a look at the Digital Input Primer
Before you can access the device in your own code, and from our examples, you'll need to take note of the addressing parameters for your Phidget. These will indicate how the Phidget is physically connected to your application. For simplicity, these parameters can be found by clicking the button at the top of the Control Panel example for that Phidget.
In the Addressing Information window, the section above the line displays information you will need to connect to your Phidget from any application. In particular, note the Channel Class field as this will be the API you will need to use with your Phidget, and the type of example you should use to get started with it. The section below the line provides information about the network the Phidget is connected on if it is attached remotely. Keep track of these parameters moving forward, as you will need them once you start running our examples or your own code.
You are now ready to start writing your own code for the device. The best way to do that is to start from our Code Samples.
Select your programming language of choice from the drop-down list to get an example for your device. You can use the options provided to further customize the example to best suit your needs.
Once you have your example, you will need to follow the instructions on the page for your programming language to get it running. To find these instructions, select your programming language from the Programming Languages page.
The 1047 can be used with a wide assortment of mechanical and optical encoders. The encoder should be of quadrature output type, indicating that there will be two quadrature output channels (usually labeled A and B) and a third output channel (only on some encoders) to signal when the index pin (a reference point for zero position or a complete revolution) has been reached.
The 1047 is able to read four encoders simultaneously. Encoders are not powered up until all initialization of the device is complete. It is possible to enable some or all encoders, depending on how many of the channels are being used. This can also be used to reduce power consumption when certain encoders are not needed.
The 1047 has the added ability to time the duration between a group of quadrature changes. The time is returned in microseconds. This time value can be used to calculate velocity and acceleration with very high precision.
If the number of quadrature counts per revolution is unknown for a particular encoder, this value can be determined by using the index signal. In addition, it is possible to monitor how many counts have occurred since the last index. The index signal is an output only on certain encoders. Refer to the encoder’s description to check if this third output channel exists or not. If the encoder does not have this signal, it is still possible to use it with the 1046, but an event for the index will never get triggered.
The maximum rate of the 1046 is specified at 250,000 quadrature cycles per second. Since this device counts pulses rather than cycles, you could also say that it counts a maximum of 1,000,000 pulses per second (since there are four pulses in a cycle). In your application, these numbers relate directly to the number of revolutions per second you wish to measure, and the number of counts per revolution specified for your encoder. If your encoder's wheel has 1000 counts per revolution, then the limit on measurable revolutions per second is 250, or 15,000 rpm (which, for the 1047, corresponds to 1000 position changes in software per second).
One of the most common problems encountered with connecting encoders to a 1047 is a strange jitter characterized by the encoder position appearing to switch back and forth between 0 and 1 or -1 and nothing else. This is usually indicative of a bad connection on either the A or B channel. You should check that the wiring is sound and try again.
The 1046 incorporates a 10 kOhm pull-up resistor on each line from the encoder input connector. If your encoder is mechanical, these pull-up resistors eliminate the requirement to add your own external pull-up resistors.
Some optical encoders will have a simple photo-transistor/open-collector output. The 10 kOhm pull-up resistor may have to be augmented with a stronger parallel resistor if your optical encoder datasheet calls for it. Some open-collector outputs will not be strong enough to pull this resistor to ground. These encoders are not compatible with the 1047, and may only work initially, or not at all. If you have any doubts, please contact us.
Most optical encoders have a push-pull output, and the pull-up resistor is irrelevant, but weak enough not cause problems.
We have reviewed the following encoders, and found that they can be used with the PhidgetEncoder Highspeed 4-Input. This is not meant to be a comprehensive list but should be used as examples of the type of encoders that can be used with the 1047.
Manufacturer | Web Page | Part Number |
Grayhill | www.Grayhill.com | Series 63R, Series 61R Series 63Q TTL Output |
US Digital (Recommended) | www.USDigital.com | S4, S5, E2, E3, E4, E4P, etc. |
Avago Technologies (Formerly Agilent) | www.avagotech.com | HEDS 5500 |
CUI Inc. | www.cui.com | AMT103-V |
Each Input uses a 5-pin, 0.100 inch pitch locking connector. The connectors are commonly available - refer to the Table below for manufacturer part numbers.
Manufacturer | Part Number | Description |
Molex | 50-57-9405 | 5 Position Cable Connector |
Molex | 16-02-0102 | Wire Crimp Insert for Cable Connector |
Molex | 70543-0004 | 5 Position Vertical PCB Connector |
Molex | 70553-0004 | 5 Position Right-Angle PCB Connector (Gold) |
Molex | 70553-0039 | 5 Position Right-Angle PCB Connector (Tin) |
Molex | 15-91-2055 | 5 Position Right-Angle PCB Connector - Surface Mount |
Note: Most of the above components can be bought at Digikey.
If you want to know more about encoders, check out the Encoder Guide. If you'd like to know more about the digital inputs on the 1047, visit the Digital Input Guide.
Board Properties | |
---|---|
Controlled By | USB (Mini-USB) |
USB Stack | PHIDUSB |
API Object Name | Encoder |
Encoder Interface | |
Number of Encoder Inputs | 4 |
Count Rate Max | 1E+06 pulses/s |
Encoder Interface Resolution | x4 |
Sampling Interval Min | 0.008 s/sample |
Sampling Interval Max | 60 s/sample |
Encoder Input Low Voltage Max | 1.1 V DC |
Encoder Input High Voltage Min | 2 V DC |
USB Speed | Full Speed |
Electrical Properties | |
Encoder Pull-up Resistance | 10 kΩ |
Current Consumption Max | 500 mA |
Current Consumption Max (per encoder) | 200 mA |
Current Consumption Min | 10 mA |
USB Voltage Min | 4.5 V DC |
USB Voltage Max | 5.3 V DC |
Physical Properties | |
Recommended Wire Size | 16 - 26 AWG |
Operating Temperature Min | -40 °C |
Operating Temperature Max | 85 °C |
Digital Inputs | |
Number of Digital Inputs | 4 |
Pull-up Resistance | 15 kΩ |
Low Voltage Max (True) | 1 V DC |
High Voltage Min (False) | 1.8 V DC |
Low Voltage Trigger Length Min | 4 ms |
High Voltage Trigger Length Min | 16 ms |
Digital Input Voltage Max | 5.3 V DC |
Customs Information | |
Canadian HS Export Code | 8471.80.00 |
American HTS Import Code | 8471.80.40.00 |
Country of Origin | CN (China) |
Date | Board Revision | Device Version | Packaging Revision | Comment |
---|---|---|---|---|
June 2010 | 0 | 100 | Product Release | |
May 2011 | 0 | 101 | getLabelString fixed for labels of length >7 | |
January 2012 | 0 | 102 | Fixed initial power state of channels 3 and 4 | |
June 2012 | 1 | 102 | Replaced power switches for added stability | |
March 2015 | 1 | 103 | Fixed a timing bug | |
September 2017 | 1 | 103 | B | Removed cables from packaging |
June 2021 | 2 | 200 | B | Updated obsolete components on board; no longer supports Phidget21 |
May 2023 | 2 | 301 | B | USB and timing fixes |
API | Detail | Language | OS | |
---|---|---|---|---|
Encoder | Visual Studio GUI | C# | Windows | Download |
Encoder | JavaScript | Browser | Download | |
Encoder | Objective-C | macOS | Download | |
Encoder | Swift | macOS | Download | |
Encoder | Swift | iOS | Download | |
Encoder | Visual Basic .NET | Windows | Download | |
Encoder | Max/MSP | Multiple | Download | |
DigitalInput | Visual Studio GUI | C# | Windows | Download |
DigitalInput | JavaScript | Browser | Download | |
DigitalInput | Multi-Channel Example | JavaScript | Browser | Download |
DigitalInput | Objective-C | macOS | Download | |
DigitalInput | Swift | macOS | Download | |
DigitalInput | Swift | iOS | Download | |
DigitalInput | Visual Basic .NET | Windows | Download | |
DigitalInput | Max/MSP | Multiple | Download |
Channel Name | API | Channel |
---|---|---|
Encoder Input | Encoder | 0 - 3 |
Digital Input | DigitalInput | 0 - 3 |
Product | Encoder Interface | ||
---|---|---|---|
Part Number | Price | Number of Encoder Inputs | Count Rate Max |
Quadrature Encoder Phidget
|
$15.00 | 1 | 1E+06 pulses/s |
4A DC Motor Phidget
|
$40.00 | 1 | 400000 pulses/s |
DC Motor Phidget
|
$75.00 | 1 | 400000 pulses/s |
PhidgetEncoder HighSpeed
|
$50.00 | 1 | 1E+06 pulses/s |
PhidgetEncoder HighSpeed 4-Input
|
$75.00 | 4 | 1E+06 pulses/s |
PhidgetEncoder HighSpeed
|
$40.00 | 1 | 2E+06 pulses/s |
PhidgetEncoder HighSpeed 4-Input
|
$65.00 | 4 | 1E+06 pulses/s |
PhidgetMotorControl 1-Motor
|
$75.00 | 1 | 500000 cycles/s |