A project in mind : force feedback wheel

Hi all,
I have recently bought a DJI Mavic Mini, played with the SDK, created my own App, interfaced a Microsoft Sidewinder force feedback joystick to it…
And finally jumped to the idea to create a force feedback steering wheel to play with…

So today I acquired an old hoverboard and extracted the motor, which is really nice !

I have found many topics using this kind of motor for forceFeedback wheels. But currently none are using SimpleFoc Library…

I love this one fully 3D printed ! https://www.xsimulator.net/community/threads/3d-printed-hoverboard-motor-wheel.14454/

I know that this is not a simple project… Il will have to find a way to implement a Forcefeedback controller (PC side) and then to decode the “force commands” sent by the PC to feed them to SimpleFoc library to implement “force effects”. I do believe that starting by Foc torque control would be fine ?

I still have a lot of questions regarding the hardware side:

  • what kind of driver should I use ? Vesc ? B-G431B-ESC ? (many DIY ffb Wheels use these devices)
  • a custom made board (how hard is it to build one for this kind of motor ?)

Any advice or guideline would be apreciated !
Thanks
JP

Hey, I’m building a force feedback joystick with hoverboard motors.
For the driver I had a odrive that let the magic smoke out. Now I’m in the process off building a custom board. Probably with this igbt https://www.mouser.de/datasheet/2/308/1/FNB43060T2_D-2313697.pdf it’s a bit overkill but whatever it’s only 15$.

For the ffb interface I’m using a Arduino Leonardo with this on it GitHub - jmriego/Fino: An Arduino Joystick Library With Force Feedback Feature, the guy over there is pretty responsive, already has a issue opened to support wheels, if you reply to him in there, and tell him that you are interested in support for steering wheels he probably will implement it.

Hoverboard motors with voltage/torque controll are pretty good for ffb because the seam to have very low cogging torque and are about 10Nm of torque.

If you have more questions or are interested in my driver board development, just ask me.

2 Likes

Hi, cool project and cool idea!

There’s another implementation of a force feedback steering wheel that has been mentioned in the forum:
https://community.simplefoc.com/t/direct-drive-force-feedback-wheel/701
https://community.simplefoc.com/t/vesc4-20-ac-servo-1-3kw/930
Maybe you guys @AdilRepas97 and @freedom2000 should talk?

Many people have used the B-G431B-ESC, the price is good :slight_smile: - but it is very compact and can be hard to use…

Making your own board is certainly possible, and a cool project - personally, I certainly like designing these boards - but it does take some time and effort, so it would be more like its own project, I think… I would not see it as being on the direct path to making a steering wheel - more like a major detour… :wink:

1 Like

I also used the g431b-esc and a good solution I found for the small solder pads, was to use some molex 2510 PCB mount connectors and bend the outer pins to the inside and solder them in a 45° angel to the solder pads. Unfortunately I don’t have a picture of it at the moment.

Thank you for your answer !

I will have a look at the Arduino Leonardo controler. Curently I am struggling with a a PIC 18F4550 driver… almost working but not properly recognized by “forcetest.exe” : PIC18F4550

I am definitively interested in your IGBT driver. If I can help it will be with pleasure. I can easily make single sided PCBs. Don’t hesitate !

JP

For the force feedback we had quite some problems with the USB vid, it’s in the closed issues in the fino GitHub.

As you mentionned his setup is quite impressive !

I have sent a question regarding wheels at fino’s github !

BTW, do you think this board would be ok with fino ?

They seem to be 5V boards… would need some level shifting to interface with ESP32 if I use it to drive the motor…

There are Arduino pro micro boards with 3.3v if the IO is enough for you I think it should work.

Lol The guy over at GitHub is fast

Yes he is really fast !

BTW, I am currently waiting for Arduino pro micro so I started to look at how to mount the encoder.

I found this clever setup :slight_smile:

A rubber roller is “rolling” on the motor hub. Seems very easy to reproduce, the roller can even be printed using TPU for a good smoothness and adhesion to the wheel.

The question that I have is if simplefoc will cope with multiple rotations of the encoder for a single turn of the motor shaft ?

I mean that if I use a 4096 values magnetic encoder, and as it is an absolute encoder, I will get N zero resets after each turn. Does simplefoc handle this ?

Thanks
JP

No it currently doesn’t handle this. On the one hand I don’t think the adaptation would be such a problem because SimpleFOC cares about electrical angle primarily for the commutation, and there are many electrical revolutions per full turn.
However I think you gave a different problem. For the electrical revolutions the physical Setup of how a motor works guarantees that there is always an integer number of electrical revolutions per full turn. For your setup, what guarantees this? Even if the rubber wheel size is chosen to be an integer multiple of the shaft circumference, it won’t be that precise, and you‘ll have small amounts of slip, meaning you’d lose the motors electrical zero… over Time the errors will add up and the commutation will become increasingly inefficient and eventually stop working.
There was another thread recently discussing a similar idea, and the consensus there was also that it’s not a good idea to separate the FOC sensor from the motor shaft…

I think it would work if you just multiply the reduction ratio with the 4096, so if you have a reduction of 1 to 6.6 you just multiply 4096 times 6.6.

In this setup I would worry about the rubber wheel slipping. I disassembled the motor and in the housing with the magnets I drilled a hole trough the middle off the housing where the bearing is, now you can mount a magnet to the shaft and attach the encoder to the housing.

yes attaching the encoder to the housing is an idea. The drawback is that the I2C wires may tangle if you make several turns with the wheel.

Another idea would be to put the encoder into the hub (on the shaft) and glue the magnet on the rotating hub

see this : https://www.youtube.com/watch?v=T5yhM_fGfm0

JP

yes you are right the roller disalignement is an issue…

Although I had in mind that a calibration could be done when starting the wheel.

Another option could be to add a timing belt. But this wouldn’t correct the other issue (Nx turns per shaft revolution)…

BTW, this video alone is useless… Here is the full article.

I do enjoy the last video with the tractor sound : awesome !

However I do not understand how the magnets ere fixed in front of the encoder ??? Any idea ?

Ok it’s a clever use of a magnetic ring !

magnetic ring
The encoder is fixed on the shaft part and the small magnetic ring is glued on the rotating hub.

Seems so nice !

Well accuracy will probably be an issue with these magnetic rings…

What he is talking about on the odrive Forum isn’t about accuracy, it’s about the index pulses, Wich aren’t really that important if you calibrate the wheel on startup.

I don’t exactly understand how these “magnetic rings” work.
Are they equivalent to a diametrically magnetized magnet ?
If so what are the indexes ?