Example: 50-OpenMV-Boards/99-Tests/selftest.py
import sensor
import pyb
def test_int_adc():
adc = pyb.ADCAll(12)
vbat = adc.read_core_vbat()
vbat_diff = abs(vbat - 3.3)
if vbat_diff > 0.1:
raise Exception("INTERNAL ADC TEST FAILED VBAT=%fv" % vbat)
vref = adc.read_core_vref()
vref_diff = abs(vref - 1.2)
if vref_diff > 0.1:
raise Exception("INTERNAL ADC TEST FAILED VREF=%fv" % vref)
adc = None
print("INTERNAL ADC TEST PASSED...")
def test_color_bars():
sensor.reset()
sensor.set_brightness(0)
sensor.set_saturation(3)
sensor.set_gainceiling(8)
sensor.set_contrast(2)
sensor.set_framesize(sensor.QVGA)
sensor.set_pixformat(sensor.RGB565)
sensor.set_colorbar(True)
for i in range(0, 100):
image = sensor.snapshot()
t = [
lambda r, g, b: r < 70 and g < 70 and b < 70,
lambda r, g, b: r < 70 and g < 70 and b > 200,
lambda r, g, b: r > 200 and g < 70 and b < 70,
lambda r, g, b: r > 200 and g < 70 and b > 200,
lambda r, g, b: r < 70 and g > 200 and b < 70,
lambda r, g, b: r < 70 and g > 200 and b > 200,
lambda r, g, b: r > 200 and g > 200 and b < 70,
lambda r, g, b: r > 200 and g > 200 and b > 200,
]
if sensor.get_id() == sensor.OV7725:
t = t[::-1]
for i in range(0, 8):
avg = (0, 0, 0)
idx = 40 * i + 20
for off in range(0, 10):
rgb = image.get_pixel(idx + off, 120)
avg = tuple(map(sum, zip(avg, rgb)))
if not t[i](avg[0] / 10, avg[1] / 10, avg[2] / 10):
raise Exception(
"COLOR BARS TEST FAILED."
"BAR#(%d): RGB(%d,%d,%d)"
% (i + 1, avg[0] / 10, avg[1] / 10, avg[2] / 10)
)
print("COLOR BARS TEST PASSED...")
if __name__ == "__main__":
print("")
test_int_adc()
test_color_bars()