-
The "Twitchy Leg Syndrome" and the Op-Amp Solution
8 hours ago • 0 commentsWhen I started designing the TNY-360, I knew I wanted closed-loop control. "Blind" PWM servos just don't cut it if you want to do real robotics (calculating inverse kinematics, detecting terrain, auto-calibration). But spending $50+ per smart servo for a 12-DOF quadruped wasn't an option.
So, I did what every budget-conscious maker does: I bought a bunch of $5 digital MG996R servos and decided to hack them to read their internal potentiometers.
The internet makes it sound so easy: "Just solder a 4th wire to the middle pin of the servo's potentiometer and plug it into your ESP32's ADC!"
So I did exactly that. I wired up all 12 legs, powered up the robot, and... it was a disaster. The limbs were shaking uncontrollably, the robot looked like it was having a seizure, and the position readings were clearly unusable.
What went wrong? Physics.
After pulling my hair out, I realized the problem wasn't my code, it was the electrical reality of a fully assembled robot:
- The Voltage Drop: The ESP32's ADC draws a tiny bit of current when it reads a pin. Because the servo's internal potentiometer has a high impedance, drawing that current causes a sudden voltage drop. The servo's internal PID controller panics because it thinks the motor just moved, and tries to correct it. Hence, the twitching.
- The Antenna Effect: Inside the chassis, my 12 analog wires were routed right next to the high-current power lines and the brushed DC motors. Those wires acted as perfect antennas, picking up massive electromagnetic interference (EMI).
I realized I couldn't just read the potentiometer directly. I needed an intermediary. Enter the Operational Amplifier (Op-Amp)!
Instead of a simple RC filter (which wouldn't solve the current-draw issue), I designed a tiny custom PCB that fits completely inside the MG996R's casing. On this board, I put an Op-Amp configured as a voltage follower (buffer).
The Result
Combined with a software low-pass filter on my ESP32's "Reflex Core", I can now poll the exact position of all 12 motors at a blistering 200Hz, with zero twitching and buttery smooth movements.
We turned a $5 dumb servo into a high-speed, closed-loop actuator!
If you want to see the exact schematic of this micro-PCB, or if you want to mod your own servos for your projects, I’ve documented the entire step-by-step process on the project's website:
See the servo mod
Paul LOISIL