1. Do not share user accounts! Any account that is shared by another person will be blocked and closed. This means: we will close not only the account that is shared, but also the main account of the user who uses another person's account. We have the ability to detect account sharing, so please do not try to cheat the system. This action will take place on 04/18/2023. Read all forum rules.
    Dismiss Notice
  2. For downloading SimTools plugins you need a Download Package. Get it with virtual coins that you receive for forum activity or Buy Download Package - We have a zero Spam tolerance so read our forum rules first.

    Buy Now a Download Plan!
  3. Do not try to cheat our system and do not post an unnecessary amount of useless posts only to earn credits here. We have a zero spam tolerance policy and this will cause a ban of your user account. Otherwise we wish you a pleasant stay here! Read the forum rules
  4. We have a few rules which you need to read and accept before posting anything here! Following these rules will keep the forum clean and your stay pleasant. Do not follow these rules can lead to permanent exclusion from this website: Read the forum rules.
    Are you a company? Read our company rules

Tutorial SMC3 Arduino 3DOF Motor Driver and Windows Utilities

Discussion in 'SimTools compatible interfaces' started by RufusDufus, Dec 1, 2013.

  1. prophet.id

    prophet.id BOSeTAMPER's Rotary Servo 6dof Build

    Joined:
    Mar 11, 2024
    Messages:
    53
    Balance:
    205Coins
    Ratings:
    +16 / 0 / -0
    My Motion Simulator:
    DC motor, Arduino, Motion platform, 6DOF
    Y

    But I was still confused why Roll always on Axis 1, Pitch on Axis 2, Yaw on Axis 3, etc. Is this relate with the 'Generic 3D rotating' I am using? Sort of a template that is specific for 6DOF, maybe?
    [​IMG]

    Perhaps, I need to use "Generic 2D advance" Axis plugin, so I can follow your approach?
  2. noorbeast

    noorbeast VR Tassie Devil Staff Member Moderator Race Director

    Joined:
    Jul 13, 2014
    Messages:
    21,439
    Occupation:
    Innovative tech specialist for NGOs
    Location:
    St Helens, Tasmania, Australia
    Balance:
    150,279Coins
    Ratings:
    +11,001 / 55 / -2
    My Motion Simulator:
    3DOF, DC motor, JRK
    May I suggest you start by mapping USB controller allocations, please see the FAQs here: https://www.xsimulator.net/community/faq/simtools-usb-issues-can-cause-crashes.313/
  3. Pietbrok85

    Pietbrok85 New Member

    Joined:
    Jan 16, 2025
    Messages:
    9
    Occupation:
    Retired
    Location:
    Venlo
    Balance:
    35Coins
    Ratings:
    +1 / 0 / -0
    My Motion Simulator:
    DC motor, Arduino, 6DOF
    With the command:
    //#define REVERSE_MOTOR1 I can reverse the direction of motor1, How can i change motor direction for Motor 2 or Motor3 (motor output and hall sensor input) without do any rewiring.
    Arduino Uno R3, SMC Utils V1.0
    Thanks for any help! Kind regards, Piet

    p.s. I found that the change in motor direction is automatically corrected in SimTools (V3) so no need to change it in SMC3
    Last edited: Mar 9, 2025
  4. Jodino

    Jodino New Member

    Joined:
    Dec 9, 2024
    Messages:
    21
    Location:
    The Netherlands
    Balance:
    87Coins
    Ratings:
    +3 / 0 / -0
    My Motion Simulator:
    2DOF, 3DOF, DC motor, Arduino
    I am curious. I have uploaded the smc3 sketch to my Arduino. Then I tuned the motors with smc3ultility. How does this affect the sketch on the Arduino? I think not?
    Do I need to changes the values from smc3utility in the sketch myself?

    anyway I did change the sketch manual. But I could not find every value setting from smc3ultily in my smc3 sketch. Because of other names? Is there a conversion list so I don’t make mistakes?

    whatever I did, it is working.. but I want to tweak my settings and am not sure this above.
  5. prophet.id

    prophet.id BOSeTAMPER's Rotary Servo 6dof Build

    Joined:
    Mar 11, 2024
    Messages:
    53
    Balance:
    205Coins
    Ratings:
    +16 / 0 / -0
    My Motion Simulator:
    DC motor, Arduino, Motion platform, 6DOF
    I believe those 'saved values on the Utility' are stored in the ROM memory in the Arduino board.
    Any tweaking of the SMC3 firmware (as motor's parameters) is only possible on the Utility app.
  6. Jodino

    Jodino New Member

    Joined:
    Dec 9, 2024
    Messages:
    21
    Location:
    The Netherlands
    Balance:
    87Coins
    Ratings:
    +3 / 0 / -0
    My Motion Simulator:
    2DOF, 3DOF, DC motor, Arduino
    I did not read about this.
    Ok, So they might overrule the sketch settings?
  7. noorbeast

    noorbeast VR Tassie Devil Staff Member Moderator Race Director

    Joined:
    Jul 13, 2014
    Messages:
    21,439
    Occupation:
    Innovative tech specialist for NGOs
    Location:
    St Helens, Tasmania, Australia
    Balance:
    150,279Coins
    Ratings:
    +11,001 / 55 / -2
    My Motion Simulator:
    3DOF, DC motor, JRK
  8. Attyla.pl

    Attyla.pl Active Member

    Joined:
    Oct 1, 2023
    Messages:
    254
    Location:
    Polska
    Balance:
    1,116Coins
    Ratings:
    +72 / 0 / -0
    My Motion Simulator:
    2DOF, DC motor, Arduino
    SMC3Utils automatically saves the engine settings in Arduino memory, sketch .smc3.ino you upload only once and you do all the settings in SMC3Utils which saves them autmatically
  9. prophet.id

    prophet.id BOSeTAMPER's Rotary Servo 6dof Build

    Joined:
    Mar 11, 2024
    Messages:
    53
    Balance:
    205Coins
    Ratings:
    +16 / 0 / -0
    My Motion Simulator:
    DC motor, Arduino, Motion platform, 6DOF

    Attached Files:

    • Like Like x 1
    • Useful Useful x 1
  10. noorbeast

    noorbeast VR Tassie Devil Staff Member Moderator Race Director

    Joined:
    Jul 13, 2014
    Messages:
    21,439
    Occupation:
    Innovative tech specialist for NGOs
    Location:
    St Helens, Tasmania, Australia
    Balance:
    150,279Coins
    Ratings:
    +11,001 / 55 / -2
    My Motion Simulator:
    3DOF, DC motor, JRK
    Thanks so much for sharing your work :thumbs

    I have added it to the SMC3 section of the FAQs, with credit to yourself: https://www.xsimulator.net/community/faq/arduino-code-for-use-with-various-hardware-and-simtools.31/
    • Like Like x 1
  11. prophet.id

    prophet.id BOSeTAMPER's Rotary Servo 6dof Build

    Joined:
    Mar 11, 2024
    Messages:
    53
    Balance:
    205Coins
    Ratings:
    +16 / 0 / -0
    My Motion Simulator:
    DC motor, Arduino, Motion platform, 6DOF
    • Like Like x 1
  12. Sebastian2

    Sebastian2 Member Gold Contributor

    Joined:
    Dec 17, 2023
    Messages:
    90
    Balance:
    345Coins
    Ratings:
    +53 / 1 / -0
    Hi,

    I noticed that the I and D component of the PID regulator of SMC3 are not really working and implemented a fix.

    The attached picture "I_not_working.png" shows the step response after configuring SMC3 v1.0 as a pure I regulator (Kp=0 and Kd=0). The I regulator doesn't do a thing, it just plays dead - even though I ramped Ki up to max. It's also not working at all on lower levels of Ki.
    I expected the PWM signal to gradually change. The attached picture "I_fixed.png" shows the desired behavior.

    The attached picture "D_not_working.png" shows the response of SMC3 v1.0 configured as a pure D regulator (Kp=0 and Ki=0) to a sine curve. The regulator hardly does anything, there's just some noise visible. Checking the code, I found a rather odd implementation of a D regulator. It's response is calculated based on the change in position, while it's usually based on change in error. So the noise we see in the regulator's output is just the noise it's getting on it's input.
    I expected the regulator's answer to a sine wave to be the same wave but 180° degree phase shifted. The attached picture "D_fixed.png" shows the desired behavior.

    I also attached a zip file containing arduino code with the I and D fixes I wrote. There are 2 versions.
    1) Based of off vanilla SMC3 v1.0 as found on page 1 of this thread
    2) Based of off Blame73's version of SMC3, for use with Cytron MD30C motor drivers

    My changes are all within the 3 PID functions CalcMotor1PID(), CalcMotor2PID(), CalcMotor3PID() so they can be easily transferred to other SMC3 versions.
    The current filtering/smoothing implementation for the D component via Ks could use some more sophistication. I was too lazy to do it, as I think I won't use the D component at all. In my experience, a PI regulator usually gets the job done pretty well. Really using the D component in addition to PI requires lots of tweaking while offering very little improvement in return.

    Have I reinvented the wheel here? Is this a known issue thats already solved by other people? I wonder how the broken I regulator got overlooked for so long. I'm curious to read how you guys view the situation.

    Attached Files:

    • Like Like x 1
  13. prophet.id

    prophet.id BOSeTAMPER's Rotary Servo 6dof Build

    Joined:
    Mar 11, 2024
    Messages:
    53
    Balance:
    205Coins
    Ratings:
    +16 / 0 / -0
    My Motion Simulator:
    DC motor, Arduino, Motion platform, 6DOF
    I have been working on the PID as well. My rig feels jittery when move in slow velocity during manual test move on the Utility software.
    How does your rig feel when you use the original code? and what the different feel when you have the 'fixed code'? I am interested to learn.
  14. Joe Cortexian

    Joe Cortexian Active Member Gold Contributor

    Joined:
    Sep 8, 2021
    Messages:
    138
    Balance:
    827Coins
    Ratings:
    +30 / 0 / -0
    My Motion Simulator:
    3DOF
    I view it as a snafu. I have always thought that they were useless aka leave them at zero. On the other hand for cars its good enough. For planes its a bit jumpy. I have never seen a "sloped" line on PWM outside of your image but its always jumping all around.

    I will do some testing and get back to this thread. My brain works better over a cup of morning coffee.

    BTW: I did a diff from SMC3 v1.0 and found expected diffs in the CalcPID routines and that the version was set to 1.01.
    • Like Like x 1
  15. noorbeast

    noorbeast VR Tassie Devil Staff Member Moderator Race Director

    Joined:
    Jul 13, 2014
    Messages:
    21,439
    Occupation:
    Innovative tech specialist for NGOs
    Location:
    St Helens, Tasmania, Australia
    Balance:
    150,279Coins
    Ratings:
    +11,001 / 55 / -2
    My Motion Simulator:
    3DOF, DC motor, JRK
    Added to the SMC3 section of the FAQs, with credit to yourself: https://www.xsimulator.net/community/faq/arduino-code-for-use-with-various-hardware-and-simtools.31/
  16. prophet.id

    prophet.id BOSeTAMPER's Rotary Servo 6dof Build

    Joined:
    Mar 11, 2024
    Messages:
    53
    Balance:
    205Coins
    Ratings:
    +16 / 0 / -0
    My Motion Simulator:
    DC motor, Arduino, Motion platform, 6DOF
    Great! Looking forward to your testing report :cheers
  17. Sebastian2

    Sebastian2 Member Gold Contributor

    Joined:
    Dec 17, 2023
    Messages:
    90
    Balance:
    345Coins
    Ratings:
    +53 / 1 / -0
    Thanks for your replies.

    I also used to drive my rig with SMC3 set as a pure P regulator (Ki=0 and Kd=0). If I increased Ki above 2 I got a lot of erratic movement on the motors that didn't make any sense. Similar with Kd.

    Check out the attached picture "UnModdedPID_PureP_Motion.png". It was recorded using the vanilla SMC3 PID implementation with Ki=0 and Kd=0. To me it looks ok.
    I also attached the picture "UnmoddedPID_PureP_StepResponse.png". Both the "pure" step response at the beginning as well as the manually softended step at the end show a permanent control deviation on the downward slope of the diagram (which shows my rig going up). The deviation remains constant at the end, where the desired position remains constant. This is typical for pure P regulators. Working against gravity, the motors would need more power to get to their desired position, but the pure P regulator is "too stupid" to realize that.

    Now lets check out how my fixed regulator code works out. Instead of Kp=200, Ki=0 and Kd=0, I used Kp=150, Ki=50 and Kd=0. The attached picture "ModdedPID_PI_Motion.png" looks quite similar to the first version. If you take a closer look at the long down-slopes in the middle of the picture (where the rig is going up), you see that the deviation gets smaller the longer the movement lasts.
    Finally, the attached picture "ModdedPID_PI_StepResponse" shows that there is no permanent control deviation anymore. This is expected of a (working) PI regulator.

    But how does it feel?
    I think my modded PID feels better than the original implementation. Doing slow up/downwards movement I used to feel a distinct torque ripple. It wasn't one smooth motion but like a fast series of mini-bumps that moved me around. I thought this was caused by imperfections on the motor gearing or cogging torque from the motor magnets. But I think this torque ripple is noticably reduced now that the regulator has a actually working I component. This makes sense as the I component of the regulator provides torque that doesn't change as wildly as the P component.
    I don't want to oversell it, though. Maybe it's all just in my head. I'd be happy if other people gave it a try and reported their findings.

    Attached Files:

  18. noorbeast

    noorbeast VR Tassie Devil Staff Member Moderator Race Director

    Joined:
    Jul 13, 2014
    Messages:
    21,439
    Occupation:
    Innovative tech specialist for NGOs
    Location:
    St Helens, Tasmania, Australia
    Balance:
    150,279Coins
    Ratings:
    +11,001 / 55 / -2
    My Motion Simulator:
    3DOF, DC motor, JRK
    Independent of the code discussion, I just wanted point out there are under and, in particular, overshoots, with these setting that indicate further refinement is possible, and ask why Max Limits is set to zero, given its intended function: https://www.xsimulator.net/communit...driver-and-windows-utilities.4957/#post-48121

    Max Limits Used to create a band at either limit of the feedback range beyond which if the motors move (typically through inertia) the SMC3 will automatically shutdown the drivers and keep them disabled until reset. This is essentially a safety mechanism if something goes wrong. The value can be between 0-255 (however can’t be greater than the current clip setting).
  19. Thick8

    Thick8 Just some random guy

    Joined:
    Jan 1, 2025
    Messages:
    29
    Location:
    South Carolina USA
    Balance:
    158Coins
    Ratings:
    +8 / 0 / -0
    My Motion Simulator:
    3DOF, DC motor
    I was going to ask you if you have any cogging issue as slow speeds. It's a condition that seems to be an issue with PMDC motors. Let us know if you are able to eliminate it.
  20. Joe Cortexian

    Joe Cortexian Active Member Gold Contributor

    Joined:
    Sep 8, 2021
    Messages:
    138
    Balance:
    827Coins
    Ratings:
    +30 / 0 / -0
    My Motion Simulator:
    3DOF
    For my testing, I hooked up a laptop between my game computer and my rig. This process is loosely described in the general description on page 1 or 2. SMCUtils runs on the laptop and passes data from the game system to the Arduino. SimTools sends the data via UDP via an interface I set up for this purpose.

    Using the built-in waveforms in SMCUtils is not the same as what happens in agame. I tried those first and everything looked fine. With this setup, I can observe the same displays but driven by the game instead. I’ve confirmed in my own mind that the integral term (Ki) is working appropriately. I can pull the motor into the correct position with low gain and a low PWMmin value. The Kd term is harder to test.

    My first test was with Richard Burns Rally (RBR). This game is harsh and sharp so much so that with high gain, it tends to become unstable. Using the Ki term can provide a very stable result, even when set to relatively high values. So, if you want games like RBR to feel harsher than they already are, these two terms can accomplish that without instability.This is driving off the road. Kp = 300 Ki = 50 Kd = 10. Its not that sensitive to values.
    RBRHarsh.jpg

    The next test was with Microsoft Flight Simulator 2024. This is a very tough application to tune for. I use a sport plane Extra 330 LT which is very sensitive.

    I don’t know what the issue is. If you watch the data coming out of the game, it’s smooth as silk possibly because I have filters applied.
    MSFSOut.jpg
    Still, the position term needs to be set to a minimal value, like 200, to get reasonable performance. In this case, even minimal values (less than 10) for the integral or derivative terms cause undesirable results.
    MSFSNonzero.jpg

    This should be smooth slow motion. The "ringing" s NOT comfortable like hit the estop uncomfortable.

    The smoothest motion I can achieve is with the position term set to 200 and the other terms at 0.

    MSFSZeros.jpg
    You can see it is quite laggy but also very comforable ride unlike RBR.

    So, unfortunately I don't see a net functional gain on the MSFS side.