久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 3799|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

基于openmv的單個(gè)色環(huán)閾值分割python代碼

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
基于openmv閾值分割的代碼

  1. import sensor, image, time, lcd, math,ujson, pyb ,json

  2. from pyb import UART
  3. from pyb import LED
  4. obj = [[12,0],[10,12],[22,10],[99,11]]   #json

  5. threshold_index = 0 # 0 for red, 1 for green, 2 for blue

  6. objthresholds = [(51, 76, 8, 77, 7, 23), # generic_red_thresholds
  7.            (37, 60, -32, 33, 0, 67), # generic_green_thresholds
  8.            (37, 60, -5, 33, -60, 67)] # generic_blue_thresholds

  9. graythreshold=[(100,255)]

  10. red_led = LED(1)
  11. green_led = LED(2)
  12. blue_led = LED(3)

  13. sensor.reset()
  14. sensor.set_pixformat(sensor.RGB565)
  15. sensor.set_framesize(sensor.QVGA)
  16. sensor.skip_frames(time = 2000)

  17. uart = UART(3, 115200)

  18. red_led.off()
  19. green_led.off()
  20. blue_led.off()

  21. def compareBlob(blob1, blob2):
  22.    tmp = blob1.pixels() - blob2.pixels()
  23.    if tmp == 0:
  24.        return 0;
  25.    elif tmp > 0:
  26.        return 1;
  27.    else:
  28.        return -1;

  29. A=6

  30. while(True):
  31.     img = sensor.snapshot()
  32.     #img.lens_corr(1.0)
  33.                                                                         #accepet
  34.     if(uart.any()):
  35.         r = uart.readline()

  36.         if r == b'R':
  37.             A=6
  38.         elif r == b'G' :
  39.             A=7
  40.         elif r == b'B':
  41.             A=8
  42.         else:
  43.             A=0

  44.     if(A==6):
  45.         img.binary([objthresholds[0]])
  46.         img.dilate(2)

  47.         blobs=img.find_blobs(graythreshold, pixels_threshold=2025, area_threshold=1600, merge=True)
  48.         if len(blobs) == 0:
  49.             continue
  50.             bigBlob = blobs[0]
  51.             for blob in blobs:
  52.                 if compareBlob(bigBlob, blob) == -1:
  53.                     bigBlob = blob
  54.                 img.draw_rectangle(bigBlob.rect())
  55.                 print(bigBlob.cx(), bigBlob.cy())
  56.                 #output_str=json.dumps([bigBlob.cx(),bigBlob.cy()])
  57.                 data_out = 'O'
  58.             red_led.on()
  59.             green_led.off()
  60.             blue_led.off()
  61.             uart.write(data_out)
  62.             print(data_out)

  63.     if(A==7):
  64.         img.binary([objthresholds[1]])
  65.         img.dilate(4)
  66.         blobs=img.find_blobs(graythreshold, pixels_threshold=2025, area_threshold=1600, merge=True)
  67.         if len(blobs) == 0:
  68.            continue
  69.         bigBlob = blobs[0]
  70.         for blob in blobs:
  71.             if compareBlob(bigBlob, blob) == -1:
  72.                 bigBlob = blob
  73.                 img.draw_rectangle(bigBlob.rect())
  74.                 print(bigBlob.cx(), bigBlob.cy())
  75.                 #output_str=json.dumps([bigBlob.cx(),bigBlob.cy()])
  76.                 data_out ='P'
  77.             red_led.off()
  78.             green_led.on()
  79.             blue_led.off()
  80.             uart.write(data_out)
  81.             print(data_out)

  82.     if(A==8):
  83.         img.binary([objthresholds[2]])
  84.         img.dilate(4)

  85.         blobs=img.find_blobs(graythreshold, pixels_threshold=900, area_threshold=900, merge=True)
  86.         if len(blobs) == 0:
  87.             continue
  88.             bigBlob = blobs[0]
  89.             for blob in blobs:
  90.                 if compareBlob(bigBlob, blob) == -1:
  91.                     bigBlob = blob
  92.                 img.draw_rectangle(bigBlob.rect())
  93.                 print(bigBlob.cx(), bigBlob.cy())

  94.                 data_out ='Q'
  95.             red_led.off()
  96.             green_led.off()
  97.             blue_led.on()
  98.             uart.write(data_out)
  99.             print(data_out)

  100.     if(A==0):
  101.         red_led.on()
  102.         time.sleep(50)
  103.         red_led.off()
復(fù)制代碼

下載: 單個(gè)色環(huán)識(shí)別uart.zip (1.05 KB, 下載次數(shù): 23)
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:362900 發(fā)表于 2019-7-13 22:51 | 只看該作者
深度學(xué)習(xí),謝謝樓主!!
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 日本不卡一区二区三区 | 99精品久久 | 婷婷99 | 亚洲一区二区在线播放 | 精品国产18久久久久久二百 | 中文字幕在线视频免费观看 | 国产精品永久免费视频 | 天天看天天摸天天操 | 国产精品国产精品国产专区不卡 | 欧美大片久久久 | 久久免费精品视频 | 免费一级黄 | 国产精品欧美一区二区三区不卡 | 欧美日韩高清在线一区 | 久久国产精品视频 | 精品欧美乱码久久久久久1区2区 | 亚洲视频免费在线观看 | 国产精品色 | 最新国产精品视频 | 精品久久国产老人久久综合 | 国产精品久久久久久影院8一贰佰 | 午夜专区 | 亚洲品质自拍视频网站 | 免费视频二区 | 99久久精品免费看国产小宝寻花 | 成年人在线视频 | 日韩精品视频一区二区三区 | 久久里面有精品 | 一区二区三区在线电影 | 亚洲精品一区中文字幕乱码 | 亚洲美女天堂网 | 久久精品国产久精国产 | 午夜ww | 国产精品一区久久久 | 亚洲欧洲一区二区 | 国产精品黄视频 | 精品一区av | 久久久www成人免费无遮挡大片 | 久久精彩视频 | 国产高清在线观看 | 爱爱视频在线观看 |