• 瑞芯微:基于RK3568的深度估计模型部署


           根据单张图像估计深度信息是计算机视觉领域的经典问题,也是一项具有挑战的难题。由于单目图像的尺度不确定,传统方法无法计算深度值。

           随着深度学习技术的发展,该范式已经成为了估计单目图像的深度信息的一种解决方案。早期的深度估计方法大多是有监督的,即要求数据集包含单目图像和对应的深度真值支撑网络模型训练。

            要想让图像含深度真值非常困难,一般需要精密的深度测量设备和移动平台“捕获”。因此,高昂的成本导致数据集的数据量较小,也意味着有监督学习的深度估计方式不适用于大规模的工业场景。

            对于距离的计算,常用的算法就是单目测距,但传统算法有时候并不是很准确,因此需要深度学习去进行深度估计。

    下面我们基于RK3568进行相应的部署:

    量化:

    1. import cv2
    2. import numpy as np
    3. from rknn.api import RKNN
    4. import os
    5. if __name__ == '__main__':
    6. platform = 'rk3566'
    7. exp = 'SHENDU'
    8. Width = 512
    9. Height = 256
    10. MODEL_PATH = './onnx_models/SHENDU.onnx'
    11. NEED_BUILD_MODEL = True
    12. # NEED_BUILD_MODEL = False
    13. im_file = './dog_bike_car_640x640.jpg'
    14. # Create RKNN object
    15. rknn = RKNN()
    16. OUT_DIR = "rknn_models"
    17. RKNN_MODEL_PATH = './{}/{}_rm_transpose.rknn'.format(OUT_DIR,exp+'-'+str(Width)+'-'+str(Height))
    18. if NEED_BUILD_MODEL:
    19. DATASET = './dataset.txt'
    20. rknn.config(mean_values=[[124, 116, 104]], std_values=[[58, 57, 57]], target_platform="rk3568")
    21. # Load model
    22. print('--> Loading model')
    23. ret = rknn.load_onnx(MODEL_PATH)
    24. if ret != 0:
    25. print('load model failed!')
    26. exit(ret)
    27. print('done')
    28. # Build model
    29. print('--> Building model')
    30. ret = rknn.build(do_quantization=True, dataset=DATASET)
    31. if ret != 0:
    32. print('build model failed.')
    33. exit(ret)
    34. print('done')
    35. # Export rknn model
    36. if not os.path.exists(OUT_DIR):
    37. os.mkdir(OUT_DIR)
    38. print('--> Export RKNN model: {}'.format(RKNN_MODEL_PATH))
    39. ret = rknn.export_rknn(RKNN_MODEL_PATH)
    40. if ret != 0:
    41. print('Export rknn model failed.')
    42. exit(ret)
    43. print('done')
    44. else:
    45. ret = rknn.load_rknn(RKNN_MODEL_PATH)
    46. rknn.release()

  • 相关阅读:
    MySQL案例详解 二:MHA高可用配置及故障切换
    VMware vSphere 8 发布(含下载)
    Matlab:确定数值类
    冥想第四百八十四天
    AIDL for HALs实战
    TensorFlow.NET--数据类型与张量详解
    人工智能理论介绍
    一篇文章带你搞懂什么是幂等性问题?如何解决幂等性问题?
    lottie 动画在 vue 中的使用
    http升级为https
  • 原文地址:https://blog.csdn.net/zhangdaoliang1/article/details/134329214