Introduction
This application shows a demo of auto valet parking application which runs 5 deep learning algorithms such as parking spot detection, vehicle detection, semantic segmentation, motion segmentation and depth estimation on multiple input channels such as front, right and left cameras. The demo takes as input a sequence of nv12 images of resolution 1280x720 pixels coming from different input channels. The input is resized using a multi-scalar hardware (MSC) to 768x384 resolution which is provided to a multi-category object-detection network for doing parking spot detection and vehicle detection. The same resized input is provided provided to a multi-task network which does semantic segmentation, motion segmentation and depth estimation. The multi-task network also takes in Dense Optical Flow (DOF) output to help in motion segmentation task. The inputs are pre-processed on C66 DSP before providing to TIDL running on C7x DSP. The output of TIDL is then post-processed on another C66 DSP which draws rectangles around objects and blends semantic segmentation output. User can select a sub-set of outputs for display which is rendered using DSS driver.
Supported plaforms
Platform | Linux x86_64 | Linux+RTOS mode | QNX+RTOS mode | SoC |
Support | YES | YES | YES | J721e / J721S2 / J784S4 |
Data flow
Steps to run the application on J7 EVM (Linux + RTOS mode)
- Build the application and related libraries as mentioned in Build Instructions for Linux+RTOS mode
- A sample config file "app_avp3.cfg" is provided under "/opt/vision_apps/" folder on the rootfs partition.
- Edit config file to modify the fields as required
- Run the app as shown below
cd /opt/vision_apps
source ./vision_apps_init.sh
./run_app_tidl_avp3.sh
Steps to run the application on J7 EVM (QNX + RTOS mode)
- Build the application and related libraries as mentioned in Build Instructions for QNX+RTOS mode
- A sample config file "app_avp3.cfg" is provided under "/ti_fs/vision_apps/" folder on the boot partition.
- Edit config file to modify the fields as required
- Run the app as shown below
cd /ti_fs/vision_apps
. ./vision_apps_init.sh
./run_app_tidl_avp3.sh
Steps to run the application on Linux x86_64
- Build the application and related libraries as mentioned in Build Instructions for PC emulation mode
- A sample config file "app_avp3.cfg" is provided under "${PSDKR_PATH}/vision_apps/apps/dl_demos/app_tidl_avp3/config" folder
- Edit config file to modify the fields as required
- Create an output directory
- Run the app as shown below
./vx_app_tidl_avp3 --cfg ${PSDKR_PATH}/vision_apps/apps/dl_demos/app_tidl_avp3/config/app_avp3.cfg
- The output will be written in "app_tidl_avp3_out" folder in nv12 format.
- Use open source tools like YUView to see the output.
Sample Output
Shown below is a example input and its corresponding output
Semantic Segmentation - Parking Spot Detection - Vehicle Detection
Dense Optical Flow - Motion Segmentation - Depth Estimation