例程讲解99-Tests->selftest自检
import sensor, time, 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()
星瞳科技OpenMV官方中文文档函数讲解: