Skip to content

Latest commit

 

History

History
64 lines (45 loc) · 3.89 KB

README.md

File metadata and controls

64 lines (45 loc) · 3.89 KB

DIY Para-Para controller with Time of Flight sensors and Arduino

This is a short guide on building your own Para-Para Paradise controller using an Arduino and ToF sensors.

para-controller

Notes on materials and project limitations

Disclaimer: this controller has poor range and field of view, see notes below.

Why these sensors?

I used this distance sensor guide to compare the characteristics of different sensors. I had four requirements:

  1. Range over 150 cm
  2. High update frequency, to work reasonably with timing windows
  3. A narrow-ish field of view, so that movement is only detected above the sensor
  4. $15 or so a piece (which ruled out all the cool lidars)

The VL53L1X have 400 cm range, 50 Hz update rate, and are $20 a piece. Points (1) and (2), however, turned out to be moot.

  • Although the sensor range is 4 metres, it cannot reliably detect small targets (like hands) at this distance. In practice, detection stopped working at 120 cm. Larger targets, such as a magazine, worked a little further, but nowhere close to 4 metres. This is why the sensors are lifted onto boxes in the picture.
  • Para-Para timing windows are huge. Parastar uses 300 ms windows for all judgments, so picking a sensor with 10 Hz update rate would have been sufficient.

Which Arduino?

Any board that can act as a USB controller. Other than Teensy, that could be an Arduino Leonardo, or an Arduino Micro, or any other board built on an atmega32u4 controller. There are ways to make other controllers work as USB, but they looked too involved to me.

Why the mux?

This was an easy way to connect multiple sensors to the same I2C bus. TL;DR all sensors of the same type have the same address on the bus, changing it is either a pain or impossible depending on the library, I tinkered and decided I'd rather throw $10 at it.

Assembly

para-assembly

  1. Connect the Arduino to the main port on the mux
    • Find a cable with qwiic connector on one side, and 4 pins on the other
    • Plug the qwiic end into the MAIN port on the mux
    • Find the following pins on your Arduino: GND, 3.3V, SDA, SCL
    • Connect the 4 pins on the cable to the Arduino as follows:
      • Black = GND
      • Red = 3.3V
      • Blue = SDA
      • Yellow = SCL
  2. Connect the sensors to ports 0-4 on the mux. Use a qwiic-qwiic cable if they are long enough. Otherwise you may need to use two qwiic to 4 pin cables and connect them with jumper wires in between. When doing so, trace the wire color to make sure the wires do not get mixed up from end to end.
  3. Plug the Arduino into your PC with a USB cable

Code

To program the controller, you will need the Arduino IDE, and the Teensyduino if using a Teensy.

The sketch uses a simple algorithm:

  1. In a loop, poll each sensor for a reading
  2. If the reading is lower than a set threshold, send a joystick button press
  3. Else, send an off event to the button

Upload the sketch to your board. Stepmania should now recognize the controller as a joystick, and allow you to map the buttons in the usual way.