# CLRerNet **Repository Path**: sa_ka_na/CLRerNet ## Basic Information - **Project Name**: CLRerNet - **Description**: No description available - **Primary Language**: Python - **License**: Apache-2.0 - **Default Branch**: feature/curvelanes - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2024-12-05 - **Last Updated**: 2024-12-05 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README [![PWC](https://img.shields.io/endpoint.svg?url=https://paperswithcode.com/badge/clrernet-improving-confidence-of-lane/lane-detection-on-culane)](https://paperswithcode.com/sota/lane-detection-on-culane?p=clrernet-improving-confidence-of-lane) # CLRerNet Official Implementation The official implementation of [our paper](https://arxiv.org/abs/2305.08366) "CLRerNet: Improving Confidence of Lane Detection with LaneIoU", by Hiroto Honda and Yusuke Uchida. ## What's New - **Code for training is available !** (Dec. 1, 2023) - **Our CLRerNet paper has been accepted to WACV2024 !** (Oct. 25, 2023) - LaneIoU loss and cost are published. ([PR#17](https://github.com/hirotomusiker/CLRerNet/pull/17), Oct.22, 2023) ## Method CLRerNet features LaneIoU for the target assignment cost and loss functions aiming at the improved quality of confidence scores.
LaneIoU takes the local lane angles into consideration to better correlate with the segmentation-based IoU metric.

## Performance CLRerNet achieves the state-of-the-art performance on CULane benchmark significantly surpassing the baseline. Model | Backbone | F1 score | GFLOPs --- | --- | --- | --- CLRNet | DLA34 | 80.47 | 18.4 [CLRerNet](https://github.com/hirotomusiker/CLRerNet/releases/download/v0.1.0/clrernet_culane_dla34.pth) | DLA34 | 81.12±0.04 *| 18.4 [CLRerNet⋆](https://github.com/hirotomusiker/CLRerNet/releases/download/v0.1.0/clrernet_culane_dla34_ema.pth) | DLA34 | 81.43±0.14 * | 18.4 \* F1 score stats of five models reported in our paper. The release models' scores are 81.11 (CLRerNet) and 81.55 (CLRerNet⋆, EMA model) respectively. ## Install Docker environment is recommended for installation: ```bash docker-compose build --build-arg UID="`id -u`" dev docker-compose run --rm dev ``` See [Installation Tips](docs/INSTALL.md) for more details. ## Inference Run the following command to detect the lanes from the image and visualize them: ```bash python demo/image_demo.py demo/demo.jpg configs/clrernet/culane/clrernet_culane_dla34_ema.py clrernet_culane_dla34_ema.pth --out-file=result.png ``` ## Test Run the following command to evaluate the model on CULane dataset: ```bash python tools/test.py configs/clrernet/culane/clrernet_culane_dla34_ema.py clrernet_culane_dla34_ema.pth ``` For dataset preparation, please refer to [Dataset Preparation](docs/DATASETS.md). ## Frame Difference Calculation Filtering out redundant frames during training helps the model avoid overfitting to them. We provide a simple calculator that outputs an npz file containing frame difference values. ```bash python tools/calculate_frame_diff.py [culane_root_path] ``` Also you can find the npz file [[here]](https://github.com/hirotomusiker/CLRerNet/releases/download/v0.2.0/train_diffs.npz). ## Train Make sure that the frame difference npz file is prepared as `dataset/culane/list/train_diffs.npz`.
Run the following command to train a model on CULane dataset: ```bash python tools/train.py configs/clrernet/culane/clrernet_culane_dla34.py ``` ### Train on CurveLanes Draw segmentation images for CurveLanes for auxiliary loss. ```bash python tools/make_seg.py configs/clrernet/curvelanes/clrernet_curvelanes_dla34.py ``` Run the following command to train a model on CurveLanes dataset: ```bash python tools/train.py configs/clrernet/curvelanes/clrernet_curvelanes_dla34.py ``` ## Citation ```BibTeX @article{honda2023clrernet, title={CLRerNet: Improving Confidence of Lane Detection with LaneIoU}, author={Hiroto Honda and Yusuke Uchida}, journal={arXiv preprint arXiv:2305.08366}, year={2023}, } ``` ## References * [Turoad/CLRNet](https://github.com/Turoad/CLRNet/) * [lucastabelini/LaneATT](https://github.com/lucastabelini/LaneATT) * [aliyun/conditional-lane-detection](https://github.com/aliyun/conditional-lane-detection) * [CULane Dataset](https://xingangpan.github.io/projects/CULane.html) * [open-mmlab/mmdetection](https://github.com/open-mmlab/mmdetection) * [optn-mmlab/mmcv](https://github.com/open-mmlab/mmcv)