Skip to content

m-yahya-khattak/PDSA

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pedestrian Detection Sensitivity Analysis : An experiment to explore the potential of synthetic data for evaluating pedestrian detection

I Introduction

Real Data Synthetic Data (SCDG)
Parc in Paris Snapshot-2023-06-01_094139-29494254.png
Bercy parc in Paris. Photo from Wikipedia. A synthetic scene of a Parc in SCDG. Unreal Engine 5 offer a photorealistic rendering of urban sceene, allowing to explore the use of AI detection algorithms.
Real Data Synthetic Data
Aquisition Low cost N (aquisition cost + 0.1$ per bbox) Y
Rare real-life scenarios N (or very few and costly to aquire) Y
Law No legal issue N Y
Utility Flexible N Y
No biases N (very hard to have a totally unbiased dataset) N (due to synthetic-reality gap), but to what extent ?

I.1 Context

This work is part of the Entrepreneur d'Interet General (EIG) program, at the SDITN of the French Ministry of Interior.

Keywords : AI, Game-Engine, Synthetic Data, Pedestrian Detection, Object Detection, Sensitivity Analysis, Evaluation.

I.2 Motivation

  • Low luminosity, adverse weather conditions, occlusion or camera angle are factors that can affect the performance of pedestrian detection methods. To what extent ?
  • How fast an AI-system would detect a crowd accident ?
  • Is an AI discriminative ?

These are the types of questions that arise at the Datalab of the SDTIN french Ministry of Interior, as the use of AI-systems for public safety has just been authorized by the french law, and is currently discussed at the European level, with the European Artificial Intelligence Act.

In the SCDG project, we intend to provide first insights on these issues by :

  • taking a step back and leverage synthetic data generated via a game engine (Unreal Engine)
    • by analogy with the Autonomous Driving field, where it is widely used for training and evaluation.
    • because recent progress of these engines lead to convincing photorealistic images and videos.
  • focusing on the pedestrian detection task, as
    • it is well studied in the litterature (especially autonomous driving), numerous datasets are available,
    • it is no different from any other Object Detection (OD) task.
    • annotations are more granular with bounding boxes (e.g. more than crowd counting with a point per person) allowing finer analysis (e.g. study the influence of occlusion, height, etc.)
    • it is relevant for the Ministry of Interior use-cases.

To this end we first reduce the scope the project to answer the following question :

Can we use synthetic data to evaluate pedestrian detection methods ?
which we split in two sub-questions :

    1. Using SoTA Synthetic Dataset : is it doable in theory ?
    1. Using a custom synthetic dataset : is it doable in practice ?

Why do we intend to answer the feasability and usefullness of building a custom synthetic dataset ?
Because if successfull :

  • It would allow us to build datasets that are tailored to our needs (e.g. for the Ministry of Interior use-cases, such as image blurring), which is often hard to find in real datasets publicly available when working on niche applications.
  • It would allow us to control the characteristics of the data (e.g. occlusion, weather, camera angle, etc.)
  • It would allow to centralize on a common dataset the evaluation of pedestrian detection methods . It is very hard to find a publicly available dataset that correspond both to the desired use-case, as well as having the needed level of exhaustivity. For example EuroCityPerson and NightOwls aim at exhaustivity on day/night as well As weather conditions, but the camera angle is always the same due to their Autonomous Driving application.
  • Compared to real data, it is easier to generate (e.g. no need to label the data, no need to find a location, etc.), and do not require any privacy concern (e.g. blurring faces, license plates, etc.).
  • It allows to anticipate and better target the acquisition of real data (e.g. by focusing on the most challenging scenarios), by nature sensitive, and costly to acquire and annotate.

In addition, there are other potential benefits :

  • Possible synergies for comptuter vision dataset building (especially in 3D assets)
  • A fully controlled dataset could be used to exhibit potential biases of AI solutions, such as discriminations that are explicitely pointed out in the EU AI White Paper as well as in the JO 2024 Project of Law.

To test the hypothesis of questions 1. and 2., we perform a benchmark of baseline pedestrian detection methods on specific datasets and scenarios, detailed in the Benchmark section. In short, we propose a sensitivity analysis, by correlating metrics of performance with characteristics of the data (e.g. occlusion rate, weather, etc.). We then look at what parameter influence the most the performance, in what cases.

Day Night
CCTV view 0_Clear Sky_-30.0_GT.png 1_Clear Sky_-30.0_GT.png
Bird's eye view 0_Clear Sky_-70.0_GT.png 1_Clear Sky_-70.0_GT.png

Example of randomization of a given scenario (luminosity, camera angle). Each pedestrian is described by a bounding box (x1,y1,x2,y2), shown in green in each plot.

I.3 The Task of Pedestrian Detection

I.3.1 Task description

The task of Pedestrian Detection (PD) is a specific case of Object Detection (OD) where the object of interest is a pedestrian.

From an image or a video (e.g. 1920x1080), the goal is to detect all pedestrians, and localize each pedestrian $i$ with a bounding box $B_i=(x1, y1, x2, y2)$.

Model typically output a score $p_i$ (between 0 and 1) for each bounding box $B_i$ that is a measure of confidence that the bounding box $B_i$ contains a pedestrian.

Therefore, from a model output, we can define a threshold $t$ (between 0 and 1) that will be used to filter out bounding boxes with a score $p_i$ below $t$.

Pedestrian detection in SCDG Day Night
CCTV view 0_Clear Sky_-30.0_Preds.png 1_Clear Sky_-30.0_Preds.png
Bird's eye view 0_Clear Sky_-70.0_Preds.png 1_Clear Sky_-70.0_Preds.png

Prediction for a given pedestrian detection model on the generated synthetic data. Predictions for each pedestrian are bounding boxes, shown in blue. Each bounding box has an associated score of confidence between 0 and 1. We can see that in Bird's eye view the model misses most of the pedestrians.

I.3.2 Metrics for the Task of Pedestrian Detection

Matching the Bounding Boxes

  • IoU : Intersection over Union, is a measure of the overlap between two bounding boxes (typically, a threshold of 0.5 is used to consider a prediction as a true positive).
IoU
IoU.png
Union = (Red+Blue-Green)
Intersection = Green
IoU = Intersection/Union = 2/(9+6-2) ~ 0.154

Typically a threshold of 0.5 is chosen to match a predicted bounding box (blue) with a groud truth bounding box (here in red).

Computing Metrics over matched Bounding Boxes

  • Missing Rate (MR) : the proportion of pedestrians that are not detected (i.e. not matched with a prediction).

  • False Positive Per Image (FPPI) : the average number of false positives per image (i.e. the average number of bounding boxes that are not matched with a ground truth). This is especially important as there would always be agents monitoring AI solutions, and too many false positives decribilize the solution.

schema_fppi_mr.png

For various thresholds, of predicted box confidence, we can compute the number of false positives, as well as the missing rate (number of missed boundig boxes divided by the number of ground truth bounding boxes). On the top left, the threshold is set at 0.9, meaning that only the box with a score equal or above 0.9 are considered. The central box is matched to a prediction with a score of 0.99. However, a prediction with score 0.9 does not match any ground truth on the bottom right. Other predicted boxes are not considered. Overall, we have 1 false positive (bounding box on the right) and a missing rate of 2/3, as the 2 other ground truths bounding boxes on the left are not matched. On the bottom left, the threshold is set at 0.8, and the bottom left bounding box is matched as well. The missing rate (MR) is 1/3 and the FPPI is 1. On the bottom right, the threshold is 0.5, and we have one additional false positive on the bottom left, overlapping a matched bounding box.

Metrics of detection in SCDG Day Night
CCTV view 0_Clear Sky_-30.0_Preds+GT.png 1_Clear Sky_-30.0_Preds+GT.png
Bird's eye view 0_Clear Sky_-70.0_Preds+GT.png 1_Clear Sky_-70.0_Preds+GT.png

Predictions shown versus ground truth bounding boxes. The blue bounding boxes are model prediction. Ground truth bounding boxes are either green to indicate true positive (matched to a model prediction), red to indicate a false negative (pedestrian that have not been matched) or yellow to indicate cases that are ignored (considered too hard, or not interesting, such as an strong occlusion).

I.3.3 Papers and datasets of reference for Pedestrian Detection

Real datasets :

  • Pedestrian detection: A benchmark (2009) : perform an exhaustive evaluation of pedestrian detection (PD) SoTA methods on a common dataset : the Caltech Dataset.

  • EuroCityPerson (2018) : perform evaluation of PD SoTA methods on the Autonomous Driving (AD) EuroCityPerson dataset that focus on detection in various European urban environments, with both day and night, as well as multiple weather conditions. They also provide a benchmark in the fashion of Pedestrian detection: A benchmark (2009) that exhibit significative differences in performance between day and night, city location, and between weather conditions.

Synthetic datasets :

  • MoTSynth (2020) : perform evaluation of PD SoTA methods on the MoTSynth dataset that focus on detection and tracking in GTAV (Grand Theft Auto V) game engine. It includes various weather conditions, day and night, cameras angle, and various occlusion levels. In the 2020 paper the focus is of leveraging MoTSynth for pre-training. In this work, we explore the use of MoTSynth for evaluating PD methods.

Additional datasets : (not used in this work)

  • KITTI & Virtual KITTI (Virtual Worlds as Proxy for Multi-Object Tracking Analysis 2016) : perform evaluation of PD SoTA methods on the Autonomous Driving (AD) KITTI dataset that focus on detection in urban environments, with both day and night, as well as multiple weather conditions. Virtual KITTI is designed to be a synthetic version of KITTI, all other things being equal. They "provide quantitative experimental evidence suggesting that

(i) modern deep learning algorithms pre-trained on real data behave similarly in real and virtual worlds, and (ii) pre-training on virtual data improves performance. As the gap between real and virtual worlds is small, virtual worlds enable measuring the impact of various weather and imaging conditions on recognition performance, all other things being equal. We show these factors may affect drastically otherwise high-performing deep models for tracking."

  • NightOwls (2020) : perform evaluation of PD SoTA methods on the Autonompus Driving (AD) NightOwls dataset that focus on detection at night. Detection at night is a challenging task because of the low light conditions and saturation.

  • https://github.com/aasharma90/NightTime_Datasets : list of datasets for night time detection.

  • CARLA (2017): is "an open-source simulator for autonomous driving research. CARLA has been developed from the ground up to support development, training, and validation of autonomous urban driving systems".

II. Benchmark

We perform a benchmark in the spirit of Pedestrian detection: A benchmark (2009), but with a focus on the use of synthetic data. We use MoTSynth, SoTA on synthetic data for pedestrian detection, as well as our custom SCDG dataset and compare it to real data via the EurocityPerson dataset.

II.1 Dataset description

Small version of dataset named as : ($name_small_$max samples) indicate a subsampling of the full dataset for faster prototyping, but shall eventually be replaced by the full dataset.

characteristics SCDG-Unreal-v9_20 ecp_small_30 motsynth_small_30
sequences (day/night) 9/9 31/7 24/10
images (day/night) 180/180 285/53 237/100
person (day/night) 3735/4286 1963/359 6966/3138
weather clear, snow, rain clear, rain thunder, clear, smog, sunny, foggy, clouds, snow, rain, overcast
weather categories clear, reduced visibility, rain clear, rain rain, clear, reduced visibility
height 113 +- (56) 96 +- (57) 146 +- (91)
occlusion rate 0.00 +- (0.00) 0.14 +- (0.15) 0.46 +- (0.21)
aspect ratio inf +- (nan) 0.38 +- (0.07) 0.45 +- (0.14)

II.2 Experimental protocol

We take 2 baseline models from the MMDET model zoo :

We use the same experimental protocol as Pedestrian detection: A benchmark (2009) and compute the MR (Miss Rate) vs FPPI (False Positive Per Image) for each method and each dataset. We also compute the MR difference between specific scenario and average. We use the same metrics as Pedestrian detection: A benchmark (2009) :

  • MR (Miss Rate) : the percentage of pedestrians that are not detected
  • FPPI (False Positive Per Image) : the number of false positives per image

We compare different scenarios, and for each compute the MR (Miss Rate) vs FPPI (False Positive Per Image) curves according to

  • Bounding Box parameters (as in Pedestrian detection: A benchmark (2009)) : aspect ratio, height, occlusion rate.
  • Image parameters : day vs night, camera angle, weather.

TODO : give parameters of filtering for the study !! e;g. occlusion ...

II.3 Results

SCDG (Ours, Synthetic) MoTSynth (Synthetic) EuroCityPerson (Real)
Boundig Box parameter sensitivity : MR vs FPPI for bbox aspect ratio (line 1), height (line 2) and occlusion rate (line 3). gtbbox_cofactor_fppi_mr.png gtbbox_cofactor_fppi_mr.png gtbbox_cofactor_fppi_mr.png
Frame parameter sensitivity : MR vs FPPI for Day vs Night (line 2) and Camera Angle (line 3). Image 1 frame_cofactor_fppi_mr.png frame_cofactor_fppi_mr.png

To read the plots, the lower the curve the better. The x-axis is the FPPI (False Positive Per Image) and the y-axis is the MR (Miss Rate). The curves are the MR vs FPPI for each scenario. The orange curve is the average MR vs FPPI for the Mask-RCNN trained on COCO. The blue curve is the average MR vs FPPI for the Faster-RCNN trained on Cityscapes.

For example, for the plot of MoTSynth and its bounding box parameters (central column, first row of the overall table) we can see on the top left (all bounding boxes) that the Mask RCNN trained on Coco (orange) perform better than the Faster-RCNN trained on Cityscapes (blue). This difference in performance is all the more important that the aspect ratios of bounding boxes are typical (second and third plots of the first line of the plot), that the bounding boxes are small (second line of the plot) and that the occlusion rate is high (third line of the plot).

First focusing on MoTSynth vs EurocityPerson :

  • Performance appear consistent between the 2 datasets for Bounding Box parameters (Aspect ratio, height, occlusion rate).
  • Night is harder than Day for the faster-RCNN trained on Cityscapes in both datasets.
  • Night and Day are similar for the Mask-RCNN trained on COCO in both datasets.
  • On MoTSynth, pitch angle affects the performance of the Faster-RCNN and Mask-RCNN. Performances are best for higher pitch, probably due to occlusions at the ground level.

And looking at our custom SCDG Dataset :

  • Night is harder than Day
  • Camera Angle impact results : bird's eye view miss most of the pedestrian, while frontal view suffer from occlusions. The more classical CCTV angle show the best performances.

Note that the annotation in SCDG is for now different than those of other datasets. The available bounding boxes are extracted from an instance segmentation of the image, and therefore do not capture the occlusion information, which explains the lower performance overall. (On other datasets, a threshold on occlusion is typically set at e.g. 50% to study the other factors).

III Conclusion

  • Overall comparison between MoTSynth and EuroCityPerson show that model behaviours are consistent between Synthetic and Real datasets (provided datasets are similar enough modulo their synthetic or real nature, which seems to be the case for MOTSynth and EuroCityPerson). While the effect of weather is less clear, this is especially the case for
    • Bounding Box parameters
    • Night and Day
    • Camera Angle
  • There are still significative performance difference between SCDG and the 2 other datasets. We explain this difference via the yet different annotations, and hope to adapt it in the future to make it more consistent. Modulo this difference in performance, the behaviours of methods in SCDG seem consistent to those in the other 2 datasets. In the future, we hope to adress the annotation issue, and add bounding box and occlusion information for each pedestrian in SCDG.

Limitations

  • The comparison is qualitative and rely on comparing visually the MR vs FPPI curves. In order to perform a more quantitative comparison, we could analyse more datasets and methods, and perform statistical tests to compare the behaviors in the different scenarios. (e.g. same ranking of methods in either real of synthetic version of the same scenario).

  • We reduced the metrics to MR and FPPI, but other could be explored, such as the mAP or LMAR, which can be considered as summary statistics of the MR vs FPPI curves.

  • We did not, but could analyze the effect of datasets and models independently, in order to disentangle effects due to the model and effects due to the dataset.

    • Add more datasets (KITTI, Cityscapes, etc.).
    • Add more models
    • Add models/datasets setups with known biases (e.g. trained only at night or at day, etc.) and see if our approach can detect them.

Further Work

Take Home Message

Synthetic datasets are a good alternative to real datasets for object detection, provided the synthetic-gap is small (which may have to be quantified), and that all biases other than their synthetic-real nature are as small as possible (e.g. scenarios, camera angle, annotations, etc.).

The use of synthetic dataset allowed to go further than the best real dataset we found (EuroCityPerson) by incorporating parameters not found in real datasets (e.g. camera angle in MoTSynth). and possibly by exploring specific use-cases (e.g. fall detection, weapon detection, pedestrian flux estimation, etc.) via our custom dataset SCDG.

Performances are linked to both the model used and its training data. Our approach is agnostic to both these factors, and is generic in the sense that it considers the model as a black box, and only requires the model to be able to output bounding boxes and associated probability scores.

FAQ

  • Q : Why not focus only on real datasets ? (As there can be a gap between synthetic and real datasets) A : Real datasets are hard to collect, and therefore are often small. This makes it hard to compare methods, as the performance of a method on a dataset is highly dependent on the dataset itself. Thus there are non-negligeable biases between real datasets themselves. In addition, for specific use-cases, real datasets are often not available at all (e.g. in urban environment : fall detection, drowning detection, weapon detection, pedestrian flux estimation, etc.).

  • Q : Why not leverage generative models ?
    A : This is due to time constraints. Generative models are also viable ways to generate synthetic data ad/or alterate real data in order to simulate scenarios (e.g. sunny to rainy).

About

Pedestrian Detection Analysis

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages