Skip to content

Latest commit

 

History

History
82 lines (55 loc) · 3.2 KB

File metadata and controls

82 lines (55 loc) · 3.2 KB

Overview

This set of scripts and configuration files are related to the thermal panel detection case. The detector is initially trained on data of the Aargau Kanton using swissimage from swisstopo and labels of the SolAI project of the FHNW.

Usage

This script uses the standard yaml configuration file of the object detector by reading its dedicated section.

The script is used in the following way :

$ python3 prepare_data.py --config [yaml_config] [--logger [logging_config]]

The section of the yaml configuration file is expected as follows :

prepare_data.py:
  srs: "EPSG:2056"
  tiling:
    csv: [TILE_CSV_FILE]
    split: 1
  label:
    shapefile: [LABEL_SHAPEFILE]
    redfact: 0.9
  output_folder: ../output

for tiles defined through CSV file and :

prepare_data.py:
  srs: "EPSG:2056"
  tiling:
    shapefile: [TILE_SHAPEFILE]
    split: 1
  label:
    shapefile: [LABEL_SHAPEFILE]
    redfact: 0.9
  output_folder: ../output

for tiles defined through a shapefile. The lables section can be missing, indicating that tiles are prepared for inference only.

The redfact key allows to specify the reduction factor of the label that is performed before removing empty tiles (tiles with empty intersection with all labels). Reducing the labels before removing empty tiles allows to force tiles with small overlap with labels to be removed. This allows not to consider tiles with a small portion of label at its edges.

In both case, the srs key provides the working geographical frame in order for all the input data to work together.

CSV Specified Tiles

The CSV file has to give the bounding box of each tile to consider. Each CSV are expected to contain at least the following values :

x_min, y_min, x_max, y_max

giving the tile bounding box coordinates. The CSV file is specified using the csv key in the tiling section.

The split key in the tiling section allows the script to divide the tiles into sub-tiles.

Shapefile Specified Tiles

In case a shapefile is used for tiles definition, it has to contain the tiles as simple polygons providing the shape of each tile.

The split key in the tiling section allows the script to divide the tiles into sub-tiles.

Ressources

Two files are provided along the prepare script :

  • config.yaml example
  • logging.conf example

The logging format file can be used as provided. The configuration YAML has to be adapted in terms of input and output location and files.

Training and Validation

As the data are prepared using the proposed script, the following procedure can be followed in the appropriate environment :

$ cd [process_directory]
$ python [detector_path]/scripts/generate_training_sets.py [yaml_config]
$ cd [output_directory]
$ tar -cvf images-256.tar COCO_{trn,val,tst}.json && \
  tar -rvf images-256.tar {trn,val,tst}-images-256 && \
  gzip < images-256.tar > images-256.tar.gz && \
  rm images-256.tar
$ cd -
$ python [detector_path]/scripts/train_model.py config_NE.yaml
$ python [detector_path]/scripts/make_prediction.py config_NE.yaml
$ python [detector_path]/scripts/assess_predictions.py config_NE.yaml