H-Bridge Click Board
H-Bridge Click Board
Overview
The H-Bridge Click Board™ is a high-efficiency dual H-bridge driver capable of providing a reasonably high current while driving the connected load with up to 7V. Since the used driver IC has two full H-bridge channels, this Click Board™ is an ideal solution for driving smaller bipolar stepper motors.
The H-Bridge Click Board™ provides driving in both directions, with an addition of the brake mode, and the high impedance mode (Hi-Z). Overshoot current suppression algorithm protects the output stages from being damaged if both high-side and low-side MOSFETs on a single H-bridge channel become conductive.
The H-Bridge Click Board™ uses the MC34933, a dual H-bridge driver, from NXP. This IC is a highly integrated device, which requires a minimal number of external elements. Each of the H-bridge channels features two high-side and two low-side MOSFETs, used to control the current flow through the coils of the motor. The driver IC is produced by using Freescale's proprietary SMARTMOS process, which ensures high efficiency and low power consumption. The total resistance across the output stage drivers is only 0.8Ω, allowing peak currents up to 1.5A, and 1A for the normal operation at 25˚C.
Driving H-bridge channels (and the connected load) is implemented by using four control input lines, two per channel. The truth table below illustrates how the control inputs affect the output stages. H-Bridge click can be used to drive bipolar step motors in full step or half-step mode, offering full control over the motor driving functions. The H-Bridge click can also be used for driving DC brushed motors. Special cases are when both control inputs of a single H-bridge channel are set to a HIGH or to a LOW logic state. In the first case, the output stage will be set to a high impedance (Hi-Z) mode. In the second case, both outputs of the H-bridge click will be tied up to the GND, discharging the remaining coil current, performing so-called rheostatic (dynamic) braking. The Hi-Z mode is also activated as a protection measure when the temperature is too high, or when the power supply voltage drops under a certain threshold.
The control inputs are routed to the mikroBUS™ pins for an easy connection with the MCU. IN1A and IN1B control pins of the MC34933 driver IC used to control the first H-bridge channel, are routed to the PWM and CS pins of the mikroBUS™ respectively, while the IN2A and IN2B control pins are routed to the AN and RST pins of the mikroBUS™. These pins are labelled as I1A, I2A, I1B, I2B, on the Click board™.
The power supply for the logic section of the IC is provided by the mikroBUS™ power rails. The ability of the driver IC to work with logic levels in the range of 3.3V to 5V simplifies the interfacing to MCUs that work with both voltages: it is enough to move the onboard SMD jumper labelled as VCC SEL, and select the desired logic voltage level between 3.3V and 5V.
The motor coils are supplied with the power from either the external power supply or by the mikroBUS™ power rail, selected with the VCC SEL jumper. When working with motors that consume more power than available at the mikroBUS™ power rail, it is advisable to connect the external power supply and move the jumper labelled as VIN SEL to the VIN position. By default, this jumper is set to use the mikroBUS™ power supply (VCC position). The external DC power supply can be connected to the two-pole input screw terminal, with its inputs labelled as GND and VIN. The stepper motor coils can be connected to the four-pole screw terminal, with its inputs labelled as 1A, 1B, 2A, 2B. These labels correspond to the H-bridge outputs from the driver IC itself: 1A is routed to the OUT1A, 1B to the OUT1B, and so on.
The H-Bridge Click Board™ can be easily driven via the GPIO pins of the host MCU. However, MikroElektronika provides a library that contains functions compatible with the MikroElektronika compilers, which can be used for simplified control of the H-Bridge click. Library offers functions for setting the rotation speed with selectable acceleration and deceleration, direction, half and full step driving mode, setting the output stages, and more. The library also contains an example application, which demonstrates the use of these functions. This example application can be used as a reference for custom designs.
Truth table
I1A/I2A | I1B/I2B | 1A/2A | 1B/2B |
---|---|---|---|
H | L | H | L |
L | H | L | H |
H | H | HI-Z | HI-Z |
L | L | L | L |
Specifications
Type | Stepper |
Applications | Driving of light 3D printer elements, for precision actuators, for an accurate positioning of various moving elements by using stepper motors, and similar applications. |
On-board modules | MC34933, a dual H-bridge driver with 3V compatible logic inputs, from NXP. |
Key Features | Low power consumption, under-voltage protection, thermal protection, shoot-through current suppression, simple stepper motor driving with four control pins, 3.3V and 5V compatible logic. |
Interface | GPIO |
Compatibility | mikroBUS |
Click board size | M (42.9 x 25.4 mm) |
Input Voltage | 3.3V or 5V |
Pinout diagram
This table shows how the pinout on the H-Bridge Click Board™ corresponds to the pinout on the mikroBUS™ socket (the latter shown in the two middle columns).
Notes | Pin | Pin | Notes | ||||
---|---|---|---|---|---|---|---|
Logic input control 2A | IN2A | 1 | AN | PWM | 16 | IN1A | Logic input control 1A |
Logic input control 2B | IN2B | 2 | RST | INT | 15 | NC | |
Logic input control 1B | IN1B | 3 | CS | RX | 14 | NC | |
NC | 4 | SCK | TX | 13 | NC | ||
NC | 5 | MISO | SCL | 12 | NC | ||
NC | 6 | MOSI | SDA | 11 | NC | ||
Power Supply | +3V3 | 7 | 3.3V | 5V | 10 | +5V | Power Supply |
Ground | GND | 8 | GND | GND | 9 | GND | Ground |
Onboard settings and indicators
Label | Name | Default | Description |
---|---|---|---|
JP1 | VCC SEL | Left | Logic level voltage selection: left position 3.3V, right position 5V |
JP2 | VIN SEL | Right | Power supply source selection: left position VIN, right position VCC |
LD1 | PWR | - | Power LED indicator |
TB1 | 1A 1B | - | Terminal for connecting OUT1A and OUT1B |
TB2 | 2A 2B | - | Terminal for connecting OUT2A and OUT2B |
TB3 | VIN GND | - | Terminal for connecting input voltage VIN |
H-Bridge click electrical specifications
Description | Min | Typ | Max | Unit |
---|---|---|---|---|
Voltage at the VIN terminal | 2 | 3.3 | 7 | V |
Maximum load current (at 25°C) | - | 1 | - | A |
VCC under-voltage threshold | 2.0 | 2.2 | 2.4 | V |
Software Support
We provide a library for the H-Bridge Click Board™ on our Libstock page, as well as a demo application (example), developed using MikroElektronika compilers and mikroSDK. The provided click library is mikroSDK standard compliant. The demo application can run on all the main MikroElektronika development boards.
Library Description
The library carries everything needed for stepper motor control including speed and acceleration setup. The library is also adjustable so that it's possible to work on a different amount of ticks per second. Also, speed and acceleration can be provided in float format. The buffer used for the movement calculation is defined by the user, so this library can be adjusted for MCUs with very limited RAM resources. Check the documentation for more details on how to use it.
Key Functions
uint8_t hbridge_setSpeed( float minSpeed, float maxSpeed, float accelRatio, T_HBRIDGE_OBJ obj )
- Setup motor speed.
uint8_t hbridge_setRoute( const uint8_t direction, uint32_t steps, T_HBRIDGE_OBJ obj )
- Setup new route.
void hbridge_start( T_HBRIDGE_OBJ obj )
- Starts the motor movement.
void hbridge_setOutput( uint8_t state )
- Function puts all four outputs in the desired state.
Example Description
The application is composed of three sections:
- System Initialization - Initializes all GPIO pins found on H_Bridge Click and timer to 1ms interrupt.
- Application Initialization - The first segment initializes driver and stepper control. Second segment setup movement limits, maximum and minimum speed, and acceleration ratio. The third segment enables the motor and set up a new route which will be called from the application task.
- Application Task - (code snippet) - Sequentially moves the motor. The first part of the sequence executes movement until the end. The second part stops the motor movement after one second and continues the sequence after two seconds.
void applicationTask() { hbridge_start( (T_HBRIDGE_OBJ)&myStepper ); while( myStepper.status.running ) { hbridge_process( (T_HBRIDGE_OBJ)&myStepper ); } Delay_ms( 1000 ); }
The full application code, and ready to use projects can be found on our Libstock page.
Additional Notes and Information
Depending on the development board you are using, you may need a USB UART click, USB UART 2 click or RS232 click to connect to your PC, for development systems with no UART to USB interface available on the board. The terminal available in all MikroElektronika compilers, or any other terminal application of your choice, can be used to read the message.
mikroSDK
The H-Bridge Click Board™ is supported by mikroSDK - MikroElektronika Software Development Kit. To ensure proper operation of mikroSDK compliant Click board™ demo applications, mikroSDK should be downloaded from the LibStock and installed for the compiler you are using.
Software Support
We provide a library for the H-Bridge Click Board™ on our Libstock page, as well as a demo application (example), developed using MikroElektronika compilers and mikroSDK. The provided click library is mikroSDK standard compliant. The demo application can run on all the main MikroElektronika development boards.
Library Description
The library carries everything needed for stepper motor control including speed and acceleration setup. The library is also adjustable so that it's possible to work on a different amount of ticks per second. Also, speed and acceleration can be provided in float format. The buffer used for the movement calculation is defined by the user, so this library can be adjusted for MCUs with very limited RAM resources. Check the documentation for more details on how to use it.
Key Functions
uint8_t hbridge_setSpeed( float minSpeed, float maxSpeed, float accelRatio, T_HBRIDGE_OBJ obj )
- Setup motor speed.
uint8_t hbridge_setRoute( const uint8_t direction, uint32_t steps, T_HBRIDGE_OBJ obj )
- Setup new route.
void hbridge_start( T_HBRIDGE_OBJ obj )
- Starts the motor movement.
void hbridge_setOutput( uint8_t state )
- Function puts all four outputs in the desired state.
Example Description
The application is composed of three sections:
- System Initialization - Initializes all GPIO pins found on H_Bridge Click and timer to 1ms interrupt.
- Application Initialization - The first segment initializes driver and stepper control. Second segment setup movement limits, maximum and minimum speed, and acceleration ratio. The third segment enables the motor and set up a new route which will be called from the application task.
- Application Task - (code snippet) - Sequentially moves the motor. The first part of the sequence executes movement until the end. The second part stops the motor movement after one second and continues the sequence after two seconds.
void applicationTask() { hbridge_start( (T_HBRIDGE_OBJ)&myStepper ); while( myStepper.status.running ) { hbridge_process( (T_HBRIDGE_OBJ)&myStepper ); } Delay_ms( 1000 ); }
The full application code, and ready to use projects can be found on our Libstock page.
Additional Notes and Information
Depending on the development board you are using, you may need a USB UART click, USB UART 2 click or RS232 click to connect to your PC, for development systems with no UART to USB interface available on the board. The terminal available in all MikroElektronika compilers, or any other terminal application of your choice, can be used to read the message.
mikroSDK
The H-Bridge Click Board™ is supported by mikroSDK - MikroElektronika Software Development Kit. To ensure proper operation of mikroSDK compliant Click board™ demo applications, mikroSDK should be downloaded from the LibStock and installed for the compiler you are using.
Frequently Asked Questions
Have a Question?
Be the first to ask a question about this.