Kart/stepper motor controller

From FSI
Revision as of 11:31, 4 July 2022 by Axel.amand (Talk | contribs)
Jump to: navigation, search


The kart's stepper motor controller module generates 4 coil driving signals and receives a stepper end input.

stepper motor module

Stepper motor


The stepper motor is a Nanotec SP3575M0906-A.

It has a step angle of 7.5°, and as such 48 steps per turn. It is attached to a 100:1 reductor, which leads to an output axis with 4800 steps per turn.

The DC/stepper control board hosts a dual full H-bridge to control the 4 coils of the stepper motor.

The end switch is connected between one of the FPGAs I/O with an internal pull-up enabled and the GND. The logic is internally reverted (i.e. a '1' is read when the switch is closed).


The cables are connected as follows:

Signal Color
phase 1 white
phase 2 blue
phase 3 red
phase 4 yellow
GND brown, black

FPGA design

stepper motor module

The stepper motor controller has to generate the 4 phases to turn the kart's steering wheels to the desired angle. The target angle is set in the desired steering angle register.

To begin with, the design environment has to be downloaded. It comprises the stepperMotorController block which contains the registers and events manager and an empty angleControl block which is to be completed.


The block receives a targetAngle unsigned number and has to step the coils at each occurrence of the stepEn signal until the desired angle is reached.

The coils are controlled through the 4 outputs coil1 to coil4. When a '1' is applied, the corresponding coil is magnetized.


To control the stepper, one coil at a time should be magnetized, known as wave drive.

The switching frequency should also be chosen carefully. A frequency of 285 Hz is near the slip limit of the motor. The frequency is given by the formula : f = 100k / prescaler. A prescaler (clockDivider) of 400 (i.e. a frequency of 250 Hz) is a great first approach.

The steering angle, actual, is estimated with the help of a counter which increments or decrements each time the coils change.

It is joined with a logic signal, reached, telling if the desired angle has been reached. This information is sent back to the controlling smartphone.

Zero position

A switch contact, providing the signal stepperEnd, has to be mechanically fitted on the kart in order set one end of the wheels' direction movement. As soon as stepperEnd is '1', the stepper motor is stopped and the actual angle is reset.

With this, the steering motor will not try to turn further than what the kart's mechanical structure allows it to do in one of the directions. In the other direction, it is the programmer's task not to request a too large target angle. This also means that the angles are always considered as positive numbers, the zero position being given by the stepperEnd switch.


  • In order to limit the current consumption, turn off the current in all the coils when the stepper motor is not turning any more.
  • Make sure that both the first and the last pulse of the coil control signals have the same duration as all the others.


Draw the schematics of the angleControl block.

Hardware orientation

stepper hardware orientation controls

The mechanical design allows for the following variations:

  • the stepperEnd switch can be placed such as to detect the maximal steering angle either on the left or on the right side
  • switching the coil controls in the sequence 1 - 2 - 3 - 4 - 1 - 2 - … can result in the kart to turn either to the left or to the right

In order to cope with all possibilities, 2 setup signals are provided to the block:

  • sensorLeft being '1' means that the stepperEnd switch has been placed such as to react when the wheels are oriented to the maximal steering angle on the left side
  • clockwise being '1' means that the sequence 1 - 2 - 3 - 4 - 1 - 2 - … lets the steering turn to the right

The corresponding setup bits are configured in the hardware control register.


Update the schematics of the angleControl block in order to cope for the different mechanical design possibilities.

Initial position

The hardware control register also contains the bit restart allowing to let the stepper motor turn all the way to the angle where the stepperEnd switch is pressed.

This has to be sent by the remote control smartphone after a successful Bluetooth pairing, together with the appropriate sensorLeft and clockwise setup bits, in order for the FPGA hardware to discover the zero angle position. Obviously, this should only be done after the Stepper motor period register has been set to a proper value.

Restarting to the zero position can also be a help if too much current has been drawn from the batteries and the FPGAs' power has sunk in a way that they have performed a reset.


Update the schematics of the angleControl block in order to turn all the way to the stepperEnd position once the input restart has been set.

The stepper motor should wait for the restart signal to be released before acting normally.

It should not turn while a first restart has not been performed, at choice either directly on startup or once requested from the smartphone.


The Stepper motor functionality can be tested through the StepperMotor_test -> stepperMotorController_tb block.

Stepper motor tester

The corresponding simulation layout file for Modelsim is available under $SIMULATION_DIR/Stepper/stepperMotorController.do. It will automatically run the simulation if it has not been modified.

Stepper motor tester
  • The blue header shows which test is performed
  • The yellow signals are those generated by the tester
  • The purple signals are the one generated by your implementation
  • The green signals are internal ones
  • You can add and remove signals at will, they will not interfere with the tests


The following tests are performed :

  • The prescaler is set, outputting pulses on stepEn
  • A target of 250 is set, expecting the coils to stay at '0'
  • The restart signal pulses (both one pulse or constant '1' are valid), expecting the coils to turn as 4-3-2-1-4...
  • The endSwitch pulses, which should reset actual to 0 and begin moving coils to target 250 in order 1-2-3-4-1...
  • The reached signal should be '1' when 250 pulses have been made
  • A target of 500 is set, expecting same behavior as before
  • A target of 1000 is set, expecting same behavior as before
  • A target of 0 is set, expecting same behavior as before but the coils sequencing as 4-3-2-1-4...
  • The endSwitch creates a pulse a bit after the actual signal reaches 0, ensuring coils stop moving when target 0 is reached
  • A target of 500 is set, expecting same behavior as before
  • The restart signal pulses, while the sensorLeft is invertedm expecting the coils to turn as 1-2-3-4-1...
  • stepperEnd pulses, coils should stop and reached should rise

The transcript window gives you details on if tests passed or not:

  • For the Coil1...4 signals, you get Coil direction OK or Coil direction error.
  • For the reached signal, you get Reached flag OK or Reached flag error.
  • For the actual signal, you get Position readback OK or Position readback error.
Personal tools
Modules / Projects