The 1063 – PhidgetStepper Bipolar 1-Motor allows you to control the position, velocity, and acceleration of one bipolar stepper motor.
The 1063 can be used in applications that require very precise positioning. Four digital inputs have been included on the board for reading limit switches or user input.
Make sure the power supply is unplugged before attaching or removing wires from the terminal blocks. Failure to do so could cause permanent damage to the PhidgetStepper board. |
Controller Properties | |
---|---|
API Object Name | Stepper |
Motor Type | Bipolar Stepper |
Number of Motor Ports | 1 |
Motor Position Resolution | 1⁄16 Step (40-Bit Signed) |
Position Max | ± 5.49756E+11 1⁄16 steps |
Stepper Velocity Resolution | 8 1⁄16 steps/sec |
Stepper Velocity Max | 32768 1⁄16 steps/sec |
Stepper Acceleration Resolution | 4000 1⁄16 steps/sec² |
Stepper Acceleration Min | 4000 1⁄16 steps/sec² |
Stepper Acceleration Max | 1.02E+06 1⁄16 steps/sec² |
Electrical Properties | |
Available Current per Coil Max | 1.5 A |
Supply Voltage Min | 9 V DC |
Supply Voltage Max | 30 V DC |
Current Consumption Min | 32 mA |
Current Consumption Max | 100 mA |
USB Speed | Full Speed |
Physical Properties | |
Power Jack Hole Diameter | 5.5 mm |
Power Jack Pin Diameter | 2.1 mm |
Power Jack Polarity | Center Positive |
Recommended Wire Size (Power Terminal) | 12 - 24 AWG |
Recommended Wire Size (Motor Terminal) | 12 - 24 AWG |
Operating Temperature Min | 0 °C |
Operating Temperature Max | 70 °C |
Digital Inputs | |
Number of Digital Inputs | 4 |
Digital Input Update Rate | 125 samples/s |
High Voltage Min (False) | 2.1 V DC |
Low Voltage Max (True) | 800 mV DC |
High Voltage Trigger Length Min | 16 ms |
Low Voltage Trigger Length Min | 4 ms |
Pull-up Resistance | 15 kΩ |
Recommended Wire Size | 16 - 26 AWG |
Customs Information | |
Canadian HS Export Code | 8471.80.00 |
American HTS Import Code | 8471.80.40.00 |
Country of Origin | CN (China) |
Device | Object Name | Channel |
---|---|---|
Stepper Motor Output | Stepper | 0 |
Motor Current Sense | CurrentInput | 0 |
Digital Inputs | DigitalInput | 0 - 3 |
If you need a stepper controller that can handle larger motors, try the 1067 – PhidgetStepper Bipolar HC. With a higher current limit, higher maximum velocity and acceleration, surge protection and constant micro-stepping, the 1067 is a step up from the 1063.
We do not carry enclosures for the 1063_1, because motor controllers are prone to overheating when kept in enclosed spaces for extended periods of time with no airflow.
API | Detail | Language | OS | |
---|---|---|---|---|
Stepper | Visual Studio GUI | C# | Windows | Download |
Stepper | JavaScript | Browser | Download | |
Stepper | Objective-C | macOS | Download | |
Stepper | Swift | macOS | Download | |
Stepper | Swift | iOS | Download | |
Stepper | Visual Basic .NET | Windows | Download | |
Stepper | 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 | |
CurrentInput | Visual Studio GUI | C# | Windows | Download |
CurrentInput | JavaScript | Browser | Download | |
CurrentInput | Objective-C | macOS | Download | |
CurrentInput | Swift | macOS | Download | |
CurrentInput | Swift | iOS | Download | |
CurrentInput | Visual Basic .NET | Windows | Download | |
CurrentInput | Max/MSP | Multiple | Download |
Date | Board Revision | Device Version | Comment |
---|---|---|---|
January 2009 | 0 | 100 | Product Release |
February 2011 | 1 | 100 | Mini-USB connector, added more capacitance to the board, Digital Input terminal block exposes +5V, 12-24 AWG terminal blocks |
May 2011 | 1 | 101 | getLabelString fixed for labels longer than 7 characters |
November 2013 | Product Discontinued. Succeeded by the 1067 - PhidgetStepper HC. For information on differences between the 1063 and 1067, see below. |
Welcome to the 1063 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 1063!
In order to demonstrate the functionality of the 1063, 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 1063.
After plugging the 1063 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 Stepper object, labelled Bipolar Stepper Controller, 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
Double-click on the Current Input object , labelled Bipolar Stepper Current Sensor, 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:
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 1063 can be used to control 4, 6, or 8 wire bipolar stepper motors.
The PhidgetStepper Bipolar is most effective when used with stepper motors designed to be driven with a chopper drive stepper controller. These motors are often large, with a rectangular industrial appearance. The specifications of these motors are often confusing and may seem contradictory. Our users are often confused attempting to relate the specifications of their motor to the capabilities of the 1063. If you are in doubt if your motor will work with the 1063, call us.
When the steppers are first engaged from software, the stepper motor likely will not be at the same state as the default output state of the controller. This will cause the stepper to ‘snap’ to the position asserted by the controller - potentially moving by 2 full steps.
At low speeds, less than 1024 1/16th steps per second, the 1063 uses a microstepping scheme to allow precise control of the current to each coil, and therefore the position of the stepper. It’s important to note that many steppers are not designed to be microstepped precisely, and will not accurately produce the expected angle.
At higher speeds, the 1063 switches to a full stepping mode. The 1063 will automatically switch back to microstepping when approaching the target position.
To avoid the use of floating point in the APIs, the position, velocity and acceleration parameters are expressed in microsteps (1/16th steps), instead of full steps. If your application wants to move the motor by 1 full step, you change the position by 16.
Because stepper motors do not have the inherent ability to sense their actual shaft position, they are considered open loop systems.
This means that the value contained in the current position property is merely a count of the number of steps that have occurred towards the target value; it can not be relied upon as a measure of the actual shaft angle, as external forces may also be affecting the motor.
There are several ways of overcoming this drawback. The simplest is to allow the motor load to depress a limit switch located at a known position. This can be used to fire an event in software to recalibrate the shaft position values. A more elegant solution might involve the mounting of an optical encoder on the shaft and the development of a control system.
Bipolar Steppers motors are available in 4, 6 or 8 wire configurations. Driving a motor in the Bipolar Configuration produces maximum torque. The word Bipolar means that the controlling electronics have to be able to produce a current flow in either direction in each coil, to produce magnetic fields in opposite directions.
A 4 wire Stepper motor can only be controlled as a bipolar. There are two coils, with the ends of each coil brought out. By applying current to the two coils in sequence, and changing the direction of current flow, the motor can be made to rotate. Determining how to connect a 4 wire stepper to the 1063 can be done by following this procedure. Suppose we have four wires: red, green, yellow and blue. Start by measuring the resistance between all the wires. Below is a sample table of resistance data, in ohms. This table contains example values, your readings may be different but should still produce a similar pattern. |
||
Wire Color | Green | Blue | Yellow | Red |
---|---|---|---|---|
Green | 30 | ∞ | ∞ | |
Blue | ∞ | ∞ | ||
Yellow | 30 | |||
Red |
Looking at the table, you see that there are two pairs of wires (Green-Blue, and Yellow-Red), with roughly the same resistance measured between the wires in each pair. Pick one of the four wires and wire it to the A terminal. The other wire in this pair is connected to the B terminal. At random, wire the other pair to C and D. The motor will turn in clockwise or counter-clockwise rotation. Swapping the A and B wires or the C and D wires will change whether the motor considers “forward” to mean clockwise or counter-clockwise rotation (Remember, steppers can be run in forward or reverse by choosing a target position greater than or less than the current position).
In a 6 – wire bipolar motor, there is two + wires, one for each coil, which are the center taps for each coil. You will need to isolate which are the center tap wires and the corresponding wires for their coil. These center taps are left unconnected to operate as a bipolar. Let’s assume our six wire stepper motor wires are colored as follows: red, green, blue, white, purple, and yellow. We measure the resistance between all wires and are presented with the following values in ohms (these are simply example values):
|
||
Wire Color | Red | White | Yellow | Purple | Green | Blue |
---|---|---|---|---|---|---|
Red | ∞ | ∞ | ∞ | 10 | 10 | |
White | 10 | 10 | ∞ | ∞ | ||
Yellow | 20 | ∞ | ∞ | |||
Purple | ∞ | ∞ | ||||
Green | 20 | |||||
Blue |
Looking at our table, we can see our pattern. The red wire has the same resistance to the green and blue wires. The white wire has the same resistance to the yellow and purple wire. Red, green, and blue are for one pole, and white, yellow, and purple are the other pole. The red and white wires are the center of their coils. Leave the red/white wires unconnected, and follow the instructions for connecting a 4-Wire Bipolar Motor as described earlier in this section.
There are in fact two valid combinations, one that will produce a clockwise rotation in the stepper motor for increasing position and one that will produce counter-clockwise rotation. Swapping the A and B wires or the C and D wires will change whether the motor considers “forward” to mean clockwise or counter-clockwise rotation.
8 Wire Motors are very difficult to wire up if you do not have a schematic showing how the wires are connected to the internal coils. Only follow these instructions if you are really desperate. In an 8 wire motor, the coils are split, and we have to reconnect the coils, to reduce them to a 4 wire. Assume our eight wire stepper motor wires are colored as follows: red, yellow, purple, orange, blue, green, brown, and white. In an 8-wire stepper motor, these wires would be part of 4 coils, 2 wires per coil. We need to determine the cable pairings. We measure the resistance between each wire and are presented with the following values in ohms (these are simply example values):
|
||
Wire Color | Orange | Red | Yellow | Purple | Blue | Green | Brown | White |
---|---|---|---|---|---|---|---|---|
Orange | ∞ | ∞ | ∞ | 1 | ∞ | ∞ | ∞ | |
Red | ∞ | ∞ | ∞ | 1 | ∞ | ∞ | ||
Yellow | ∞ | ∞ | ∞ | 1 | ∞ | |||
Purple | ∞ | ∞ | ∞ | 1 | ||||
Blue | ∞ | ∞ | ∞ | |||||
Green | ∞ | ∞ | ||||||
Brown | ∞ | |||||||
White |
This table tells us which wires are parts of a coil. From the table we can tell that red/green, yellow/brown, purple/white, and orange/blue are the coils.
We are now left with the following situation; we need to determine the proper orientation of the wires to determine our connections. Of each pair, one of the wires will be assigned to A, B, C, or D, and the other wire will be connected to another pair. The number of combinations to be tried to see if they produce rotation is large, but can be reduced to a maximum of 96 possibilities by following these steps:
If you attempt to use this algorithm, build a table of permutations beforehand and proceed in a systematic way.
There are a total of 96 wiring combinations, of which there are 2 valid combinations where one will cause a clockwise motor rotation and the other will cause a counter-clockwise rotation.
If you are not using a Phidget stepper, we suggest consulting any manuals or data sheets that are associated with your particular motor in order to determine the proper wiring for your motor.
When looking at a stepper motor's specifications, you may come across a "Rated Voltage" value. This value is usually equal to the rated current multiplied by the resistance of the coils of the motor, making it somewhat of a redundant specification. As mentioned earlier, you can increase your controller's supply voltage in order to allow the motor to reach higher speeds at a lower current (because high current causes high inductance which puts a hard limit on how much speed and torque a motor can produce). The motor will also produce more heat as you increase the supply voltage, so it's a good idea to choose a supply voltage based on the performance you need for the motor. Some motors will have a "Recommended Voltage" for a particular controller, which is the amount of voltage needed to reach the optimal speed and torque of the motor with minimal heating.
For more information about how supply voltage affects your motor's maximum speed and torque, check the Stepper Motor Guide.
The 1063 allows the current applied to the motor to be programmatically set. This is important - if the current limit is set too high, the motor’s internal resistance will cause the sine-wave approximations used to implement microstepping to clip at the maximum current possible, given your motor/supply voltage. This clipping will cause rough operation, or prevent the motor from turning. If the limit is set too low, the motor may not be able to handle it’s load, by missing steps, or not turning at all at high accelerations.
This is your current limit. If you do not need so much torque, you can reduce the current limit to save power and reduce heating. If you need more current than the 1063 is specified to provide, you'll need to add some form of heat dissipation to the driver chip (A3979), in the form of a heatsink, air circulation, or both. The only problem with artificially increasing this limit through cooling is that you have no way of knowing how much further you can push the controller without some sort of temperature monitoring.
For more information about setting the current limit, check the Stepper Motor Guide.
A stepper motor can be caused to rotate continuously by simply setting the motor position property to an extremely large number of steps. The valid range of values for the motor position property is large enough to be able to cause the motor to continuously turn at maximum velocity for 194 days.
Holding torque is the amount of torque required to rotate the motor ‘against it’s will’ when the full rated current is flowing through the coils. If current consumption / heating is a problem, and full holding torque is not required, the Current Limit can be decreased in software when the motor is not moving. Holding torque will decrease linearly with the Current Limit.
There is also a small resistance to movement within the motor even when there is no current, called Detent Torque. This may be sufficient to prevent rotation in your application, particularly if the stepper has a gearbox on it.
If the motor is not supporting a load or is not required to maintain a specific angle, it is recommended to set the Enable property to false. This will allow the motor shaft to rotate freely, but the present angle may be lost if forces on the motor-shaft are greater than can be resisted by the detent torque of the unpowered motor.
Stepper motor precision is limited by the manufacturing process used to build them. Errors in the rotor and coils will cause some degree of inaccuracy. In our experience, inexpensive stepper motors will often have positioning errors approaching a half-step. Gearing a stepper motor down with a gearbox will reduce this error proportional to the reduction ratio of the gearbox.
Many applications call for several steppers motors operating in unison - for example, operating a CNC table, or a robot arm. Highly precise synchronization of steppers using the PhidgetStepper is not possible, as the sequencing will be affected by the real-time performance of your operating system. Each stepper is controlled as a independent unit, so there is no way of arranging for a particular action to happen to all motors at the same time. Typical jitter can be 10-30mS.
When looking for a motor that will be compatible with the 1063, check the motor's data sheet and make sure it meets the following specifications.
If your stepper motor is not behaving correctly, you can use a multimeter to determine whether it is the controller or the motor that is at fault.
Disconnect the motor and set the current limit to 0. Set the target position to 7 and measure the voltage difference between the A and B terminals it should be either -12, or +12V assuming you are using a 12V power supply (just depending on which terminal you have the positive multimeter lead connected to). Then set the target position to 8, the voltage should drop to 0, and it will go to the opposite at 9 (-12 or +12). This pattern will repeat for 39,40,41 and 71,72,73 and 103,104,105 etc... in increments of 32. If this is behaving as expected then the problem is probably with how you have connected your motor, or your code.
For more information about the digital inputs on the 1063, check the Digital Input Guide.
For more information about stepper motors, check the Stepper Motor and Controller Guide.
Channel Name | API | Channel |
---|---|---|
Bipolar Stepper Controller | Stepper | 0 |
Digital Input | DigitalInput | 0 - 3 |
Bipolar Stepper Current Sensor | CurrentInput | 0 |