This repository contains code to test the latency of PWM and I2C ESCs. Latency refers to the time between sending a command to change RPM of a motor and reading the desired RPM using a tachometer.
- Connect motor to ESC, and ESC to Power Supply/LiPo
- For PWM:
- connect ESC signal and ground to Adafruit Driver
- Connect Adafruit Driver VCC, SDA, SCL, and GND pins to Arduino
- For I2C:
- Connect ESC SDA and SCL to respective pins on Arduino (20 and 21 on Mega)
- NOTE: you may need pull up resistors for SDA and SCL
- Wire the Digital Tachometer to a digital pin on Arduino (https://www.aliexpress.com/i/2251832549134134.html?gatewayAdapt=4itemAdapt).
- Attach an encoder wheel (or black wheel with spokes) to the motor shaft.
- Place tachometer so that wheel passes through IR sensor of the tachometer.
- Using Adafruit 16-channel 12-bit PWM Driver to convert I2C to PWM signal (https://www.adafruit.com/product/815).
- Use adafruit_pwm_lat.ino and esc_latency.py. When viewing the terminal output of the python script, there will be two latency values from the arduino (values greater than 8000) which are printed around the time of the increase in motor speed. These are the beginning and end times of the arduino's latency calculation, and their difference is the latency in milliseconds.
- adafruit_pwm.ino only includes the python latency value, not the arduino one (which is more precise).
- ESC Used: Multistar BLHeli-S 20A 2-4s V3.0
- Information about i2c-to-pwm:
- Function: pwm.setPWM(0, low_tick, high_tick)
- low_tick is the beginning of pwm duty cycle, and high_tick is the end of the pwm duty cycle. Values can range between 0-4095.
- For ESCs, motors arm when the difference betwewen high_tick-low_tick = 700
- Lowest speed is when difference between high_tick-low_tick = 810
- see https://learn.adafruit.com/16-channel-pwm-servo-driver?view=all for additional details
- Use i2c_lat.ino and i2c_esc_latency.py. When viewing the terminal output of the python script, there will be two latency values from the arduino (values greater than 8000) which are printed around the time of the increase in motor speed. These are the beginning and end times of the arduino's latency calculation, and their difference is the latency in milliseconds.
- i2c.ino only includes the python latency value, not the arduino one (which is more precise).
- ESC Used: MikroKopter Bl-Ctrl 2.0 controller
- change pulseCount variable depending on number of spokes on encoder wheel (.ino)
- For I2C: change I2C address (.ino)
- change serial port (.py)
- adjust command variable (.py)
- change RPM threshold (.py, .ino)
- change digitalPinToInterrupt to correct pin (.ino)
- For PWM escs, when arming, you must first send a pwm signal of 700 followed by a signal of 810+ to the esc (see PWM section above). If the esc doesn't receive the second signal while it beeps HIGH, it will beep LOW and won't begin spinning. If the esc receives the the second signal before it beeps, it will not spin.
- When restarting a test, press reset on arduino board.