GithubHelp home page GithubHelp logo

golfbeta / yolov5_ncnn Goto Github PK

View Code? Open in Web Editor NEW

This project forked from cmdbug/yolov5_ncnn

0.0 0.0 0.0 235.52 MB

πŸ… Ncnn deployment on mobile,support:YOLOv5s,YOLOv4-tiny,MobileNetV2-YOLOv3-nano,Simple-Pose,Yolact,ChineseOCR-lite,ENet,Landmark106,DBFace,MBNv2-FCN and MBNv3-Seg-small on camera.

License: GNU General Public License v3.0

Java 1.03% CMake 0.05% C++ 93.57% C 4.62% Objective-C 0.42% Objective-C++ 0.30%

yolov5_ncnn's Introduction

δΈ­ζ–‡θ―΄ζ˜Ž

πŸš€ If it helps you, click a star! ⭐

Ncnn deployment on mobile,support:YOLOv5s,YOLOv4-tiny,MobileNetV2-YOLOv3-nano,Simple-Pose,Yolact,ChineseOCR-lite,ENet,Landmark106,DBFace,MBNv2-FCN and MBNv3-Seg-small on camera.

iOS:

  • Xcode 11.5
  • macOS 10.15.4
  • iPhone 6sp 13.5.1

Android:

  • Android Studio 4.0
  • Win10 1909
  • Meizu 16x 8.1.0 (CPU:Qualcomm 710 GPU:Adreno 616)

Android has added permission requests, but if it still crashes, please manually confirm whether the relevant permissions are allowed.

iOS

YOLOv5s:     Select the model to be tested directly on the interface.
YOLOv4-tiny: Select the model to be tested directly on the interface.
YOLOv3-nano: Select the model to be tested directly on the interface.

Android

Select the model to be tested directly on the interface.

Models

  • YOLOv5s: The input size is reduced, the decoding process uses a large number of for loops and NMS appears to be slower.
  • YOLOv4-tiny: Using the default size, the decoding process does not have a lot of for and NMS, so the speed will be faster.
  • YOLOv3-nano: Same as v4-tiny.
  • Simple-Pose: Only the Android version is written for the time being, and iOS has not been added yet. The internal principle is to first detect the person and then use the area of the person to perform posture detection again, that is, a 2-step process.
  • Yolact: Only the Android version is written for the time being, and iOS has not been added yet.
  • ChineseOCR_lite: Only the Android version is written for the time being, and iOS has not been added yet. (It should be noted that crashes occasionally occur, please fix it if you have time)
  • ENet: Only the Android version is written for the time being, and iOS has not been added yet. (Because the model is too small, the segmentation effect is relatively poor, you can replace the stronger network by yourself. But the effect is too poor, there may be problems)
  • Landmark106: Only the Android version is written for the time being, and iOS has not been added yet. The internal principle is to first detect the face and then use the area of the face to perform key point detection again, that is, a 2-step process.
  • DBFace: Only the Android version is written for the time being, and iOS has not been added yet.
  • MBNv2-FCN: Only the Android version is written for the time being, and iOS has not been added yet.(Thanks to the nick name Persistence for help)
  • MBNv3-Seg-small: Only the Android version is written for the time being, and iOS has not been added yet.

Note:

  • Due to factors such as mobile phone performance and image size, FPS varies greatly on different mobile phones. This project mainly tests the use of the NCNN framework. For the conversion of specific models, you can go to the NCNN official to view the conversion tutorial.
  • Because the opencv library is too large, only arm64-v8a/armeabi-v7a is reserved. If you need other versions, go to the official download.
  • ncnn temporarily uses the vulkan version, and acceleration needs to be turned on before loading, which is not turned on in this project. If you want to use the ncnn version, you need to modify the CMakeLists.txt configuration.
  • Different AS versions may have various problems with compilation. If the compilation error cannot be solved, it is recommended to use AS4.0 or higher to try.

🎨 Screenshot

Android

mbnv2-yolov3-nano yolov4-tiny yolov5s
simple_pose yolact chineseocr_lite_01
chineseocr_lite_02 ENet yoloface500k-landmark106
dbface mbnv2_fcn mbnv3_seg_small

iOS

mbnv2-yolov3-nano yolov4-tiny yolov5s

Thanks:

yolov5_ncnn's People

Contributors

cmdbug avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.