Skip to content

Latest commit

 

History

History
executable file
·
98 lines (77 loc) · 3.02 KB

README.md

File metadata and controls

executable file
·
98 lines (77 loc) · 3.02 KB

Introduction

Camera pose calibration uses vanishing point and horizon line detection. Both automatic and manual calibration approaches are provided.

Automatic calibration

We design a network to predict vanishing point and horizon line on a single image. The code is based on the implementations of CTRL-C: Camera calibration TRansformer with Line-Classification.

Demo

demo.mp4

Setup Environment

conda create -n ctrlc
conda activate ctrlc
conda install -c pytorch torchvision

pip install -r requirements.txt

Dataset

We annotated vanishing point and horizon line on KITTI dataset for training and testing. Please download it from the link below.

Link(链接): https://pan.baidu.com/s/1yBmJoPiGeRpEOCKo_hJEPA
Extraction code(提取码): 9u1b 

Train

  • Single GPU
python train.py --config-file config-files/ctrlc.yaml
  • Multi GPU
python -m torch.distributed.launch --nproc_per_node=4 --use_env train.py --config-file config-files/ctrlc.yaml

Pre-trained Model

Download the pre-trained model from Google Drive and put it under "logs/".

Evaluation

  • kitti dataset
python test_kitti.py --config-file config-files/ctrlc.yaml --opts MODE test
  • single image inference
python test_img.py --config-file config-files/ctrlc.yaml --opts MODE test DATASET_DIR ./pic/ OUTPUT_DIR ./output/

Calibrate

The simple process from vanishing point and horizon angle to the rotation matrix is implemented in the file "vphl2R.py".

Calibration using images:

python test_img_calib.py --config-file config-files/ctrlc.yaml --opts MODE test DATASET_DIR ./pic/

Notice:

  • It is needed to use straight driving scenes to produce reasonable result.
  • The intrinsic matrix in "test_img_calib.py" should be modified to your intrinsic.
  • The network may need to retrain to adapt other dataset.

Manual calibration

A manual tool to calibrate the rotation matrix from camera to car.

Prerequisites

  • opencv 3.4
  • eigen 3
  • PCL 1.9
  • Pangolin 0.6

Compile

# mkdir build
mkdir -p build && cd build
# build
cmake .. && make

Usage

./bin/run_camera2car <image_path> <intrinsic_json>
# example
./bin/run_camera2car data/0.png data/center_camera-intrinsic.json
  • image_path: image file from the Camera sensor
  • intrinsic_json: Camera intrinsic parameter JSON file

Calibration panel

sample

You can adjust x, y, z angle on the left control panel and the image will be reprojected. The target is:

  1. make the vanishing point locate in the center of the picture(the intersection of two reference lines).
  2. make the horizon line parallel to the horizon reference line. Once you think the adjustment is over, click the save button or just close the window to save the result. The parameter is saved in the form of rotation matrix.