导航

    • 登录
    • 搜索
    • 版块
    • 产品
    • 教程
    • 论坛
    • 淘宝
    1. 主页
    2. e5lw
    E
    • 举报资料
    • 资料
    • 关注
    • 粉丝
    • 屏蔽
    • 帖子
    • 楼层
    • 最佳
    • 群组

    e5lw

    @e5lw

    0
    声望
    1
    楼层
    245
    资料浏览
    0
    粉丝
    0
    关注
    注册时间 最后登录

    e5lw 关注

    e5lw 发布的帖子

    • OpenMV4跑不了神经网络,模型和label文件都拷贝到TF卡,提示帧缓冲内存不足“,修改图像分辨率也不行!
      # TensorFlow Lite Mobilenet V1 Example
      #
      # Google's Mobilenet V1 detects 1000 classes of objects
      #
      # WARNING: Mobilenet is trained on ImageNet and isn't meant to classify anything
      # in the real world. It's just designed to score well on the ImageNet dataset.
      # This example just shows off running mobilenet on the OpenMV Cam. However, the
      # default model is not really usable for anything. You have to use transfer
      # learning to apply the model to a target problem by re-training the model.
      #
      # NOTE: This example only works on the OpenMV Cam H7 Pro (that has SDRAM) and better!
      # To get the models please see the CNN Network library in OpenMV IDE under
      # Tools -> Machine Vision. The labels are there too.
      # You should insert a microSD card into your camera and copy-paste the mobilenet_labels.txt
      # file and your chosen model into the root folder for ths script to work.
      #
      # In this example we slide the detector window over the image and get a list
      # of activations. Note that use a CNN with a sliding window is extremely compute
      # expensive so for an exhaustive search do not expect the CNN to be real-time.
      
      import sensor, image, time, os, tf
      
      sensor.reset()                         # Reset and initialize the sensor.
      sensor.set_pixformat(sensor.RGB565)    # Set pixel format to RGB565 (or GRAYSCALE)
      sensor.set_framesize(sensor.QVGA)      # Set frame size to QVGA (320x240)
      sensor.set_windowing((240, 240))       # Set 240x240 window.
      sensor.skip_frames(time=2000)          # Let the camera adjust.
      
      mobilenet_version = "1" # 1
      mobilenet_width = "0.5" # 1.0, 0.75, 0.50, 0.25
      mobilenet_resolution = "128" # 224, 192, 160, 128
      
      mobilenet = "mobilenet_v%s_%s_%s_quant.tflite" % (mobilenet_version, mobilenet_width, mobilenet_resolution)
      labels = [line.rstrip('\n') for line in open("mobilenet_labels.txt")]
      print(labels)
      clock = time.clock()
      while(True):
          clock.tick()
      
          img = sensor.snapshot()
      
          # net.classify() will run the network on an roi in the image (or on the whole image if the roi is not
          # specified). A classification score output vector will be generated for each location. At each scale the
          # detection window is moved around in the ROI using x_overlap (0-1) and y_overlap (0-1) as a guide.
          # If you set the overlap to 0.5 then each detection window will overlap the previous one by 50%. Note
          # the computational work load goes WAY up the more overlap. Finally, for multi-scale matching after
          # sliding the network around in the x/y dimensions the detection window will shrink by scale_mul (0-1)
          # down to min_scale (0-1). For example, if scale_mul is 0.5 the detection window will shrink by 50%.
          # Note that at a lower scale there's even more area to search if x_overlap and y_overlap are small...
      
          # Setting x_overlap=-1 forces the window to stay centered in the ROI in the x direction always. If
          # y_overlap is not -1 the method will search in all vertical positions.
      
          # Setting y_overlap=-1 forces the window to stay centered in the ROI in the y direction always. If
          # x_overlap is not -1 the method will serach in all horizontal positions.
      
          # default settings just do one detection... change them to search the image...
          for obj in tf.classify(mobilenet, img, min_scale=1.0, scale_mul=0.5, x_overlap=-1, y_overlap=-1):
              print("**********\nTop 5 Detections at [x=%d,y=%d,w=%d,h=%d]" % obj.rect())
              img.draw_rectangle(obj.rect())
              # This combines the labels and confidence values into a list of tuples
              # and then sorts that list by the confidence values.
              sorted_list = sorted(zip(labels, obj.output()), key = lambda x: x[1], reverse = True)
              for i in range(5):![0_1638240495420_微信截图_20211130104736.png](正在上传 100%) 
                  print("%s = %f" % (sorted_list[i][0], sorted_list[i][1]))
          print(clock.fps(), "fps")
      
      
      发布在 OpenMV Cam
      E
      e5lw