Could you please shed any light on the following issue:
I am trying to run the attached code with Thommy and a pico:
The results I am getting depend on the Makerverse connections as follows:
(B= blue wire, O= orange wire, Y=yellow wire, G-green wire)
Test 1
Makerverse connections: A+=B, A-=O, B-=Y, B+=G
result: stepper motor only moves 50 steps clockwise and repeat of green run button produces no result.
Test 2
Makerverse connections: A+=B, A-=O, B-=G, B+=Y
result: stepper motor only moves 50 steps anticlockwise and repeat of green run button produces no result.
Test 3
Makerverse connections: A+=O, A-=B, B-=Y, B+=G
result: stepper motor only moves 50 steps anticlockwise and repeat of green run button produces no result.
Test 4
Makerverse connections: A+=O, A-=B, B-=G, B+=Y
result: stepper motor only moves 50 steps clockwise and repeat of green run button produces no result.
Sorry to trouble you but do you have any suggestions?
In your code if you change the ā-sā and ā+sā to -50 and 50 does that work in both directions? Python might be doing some behind the scenes typecasting making it behave unexpectedly.
Have you confirmed the stepper wire colour codes are correctly matched ??
You have Blue Orange as a pair and Yellow Green as a pair.
Some web sites show Blue Yellow as a pair and Orange/Red Green as a pair.
Using a multimeter you should be able to find the correct ones.
The stepper I tested measured 35 ohms for each coil.
It shouldnāt work if the pairs are incorrectly matched.
For the Stepper I think you are using; the datasheet does not say what colours are the pairs.
Anyway might not be the problem, but something I would want to know and check before using.
Iām still having problems making the Motor driver work using the Application Guide instructions.
Checked Pico Blink program works - OK.
Triple checked connections between Pico and MV driver.
Checked earth only connected between Pico and MV driver.
Triple checked connections between MV driver and motor.
Checked external +/- 12V power supply connected to MV driver.
Copy and pasted Makerverse_Motor_2ch.py into Pico
Copy and pasted demonstration code into Pico and saved as main.py.
Rechecked Pico is correctly connected to RPi as /dev/ttyACM2
But, on system start up and running the main.py code the motor rotates the 50 steps but neither the -180 angle rotation nor the Home rotation occur.
Running the code again doesnāt produce any results at all until the whole system is shut down and restarted which results in the 50 step rotation and nothing else as previously.
The programme is not stalling as I temporarily put in some print() statements which show it is running through the complete code.
Can anyone shed some light on what I am doing wrong or how to debug it.
Yes the green button retries produce the same āprintā results.
Static screen shot of this programme main.py included below.
Also static screen shot of the result of running your suggested code which failed. I tried to attach a MOV file but it was rejected with āutimeā isnāt defined message
Hi Toni
I donāt know anything much about Python or coding Python to drive steppers. I have been browsing rhis thread and one thing stands out.
The stepper rotates 50 steps then stops with no further action.
Immediately after the stepper.rotate(50) you have utime.sleep(1)
Then in your text you say
As I said I know nothing about Python but as this is the point where the motor stops is there not a clue here somewhere like the program doesnāt want to know about āutimeā.
Although it seems strange that the program itself does not appear to stall as indicated by the print statements.
Could there be something wrong with the line āstepper.rotate(angle=-180)ā. Should the ā=ā be there. To me that is telling the system the current position is equal to -180Āŗ not telling it to rotate -180Āŗ. Might be worth removing the ā=ā and try again.
Cheers Bob
Another easy experiment.
Change āstepper.rotate(angle=-180)ā to āstepper.rotate(-50)ā and if the stepper goes back to the starting position there will be definitely something wrong with that line of code causing it to be ignored.
another thought. Does the word āutimeā precede āsleepā? I would think āutimeā is where you are importing āsleepā from so you would just use "sleep(1).
Correct. Depending on how you import into python is how the commands work. @Liam120347 code is incorrect in this aspect.
import utime
utime.sleep(1)
from utime import sleep
sleep(1)
This example is shown in the guide. Using angle=-180 and is what the stepper.rotate function is expecting. The angle variable is set to None if not passed to the function.
def rotate(self, steps = 0, angle = None):
if angle is not None:
steps = round(angle/360.0*self.stepsPerRotation)
if steps < 0:
while steps < 0:
self.backwardStep()
steps += 1
time.sleep_ms(self.stepDelay_ms)
else:
while steps > 0:
self.forwardStep()
steps -= 1
time.sleep_ms(self.stepDelay_ms)
As the code @Toni135859 is using is from the guide it should work (assuming the guide has been checked), so there may be something else. I donāt have one of these Makerverse boards so I cannot check.
Did some extensive theoretical testing of the library. (donāt have a motor board to do real world tests)
Initially I thought the library was incorrect. I changed the pin assignments to variables to allow them to be printed at each step. The resulting table matches up with the motor driver chip datasheet and a NEMA-17 stepper motor datasheet.
I think the library is correct after this test.
(almost makes me want to buy a motor board to do real world tests, LOL)
Note: dirA dirB do not relate to motor A & B. The code changes A first then B.
The motor expects B first then A. Maybe this could be the problem, unsure.
Simply swapping the A & B sides on the motor driver board should fix it.
You should be able to get some useful clues by trying other commands.
If you change that value to -50 does it rotate 50 in the other direction?
If you change that to another value does the rotation angle change?
If you repeat that line after the delay, does it step another 50?
Your pic shows Green to B+, Yellow to B-, Blue to A+, Orange (Red) to A- on the Motor Driver.
It should be Yellow to A+, Blue to A-, Orange to B+, Green to B-, according to the datasheet.
The stepper is moving using both H-Bridges in the driver chip on both coils crossed.
I think the driver chip maybe going into shutdown or something.
The number of steps it is producing would be less than 50 because one coil will have the same voltage on both sides and the other not, for every alternate step.
I might be completely wrong here. Just going by what I found related to the stepper part number.
Thanks for the suggested changes which I have fully implemented - to no avail.
One extra thing I have noted is that when the motor does rotate (only on the first green Thonny button push, (post system shutdown/startup) it only moves 1/8 of a full rotation, ie 45deg or 25 steps. This does not relate to any of the steps (+/-50) nominated in the code.
Iāve even tried reloading the Makerverse_Motor_2ch.py code.
Sorry to be taking up your time but any suggestions or results from the Core guys would be greatly appreciated.
You can check that the driver is operating using the multimeter. You should be able to see the voltage on any of the pins flicker as the pulses are sent to the motor.
Does the software provide a speed setting? The motor will miss steps if the speed is set faster than it can handle.
I have used a hand held display to look at the motor pins waveforms when the green button is activated.
When initial system power is applied and the test code run, it doesnāt matter which channel is monitored, the signal appears and the motor rotates (by only 25 steps, not the 50 expected).
Subsequent runs of the code produce no rotation or waveform on either channel.
I have also double checked that the bridge on the rear of the PCB is open.