Pompei (Production d'Orthophotos et de Mns à partir de Photos anciennEs de l'IGN) est une chaîne de traitement presque entièrement automatisée pour reconstruire des orthophotos et des MNS à partir des images argentiques acquises tout au long du XXème siècle et qui ont été scannées dernièrement. Jusqu’à présent, une première couverture de la France entière a été produite à partir d’images de 1950-1960, sous le nom de "BD Ortho historique". Cependant, cette production a nécessité de nombreuses opérations manuelles, principalement pour saisir les points d’appuis. Pompei permet de produire ces orthophotos avec un nombre d’opérations manuelles particulièrement réduit et pour des résultats tout aussi bons. L’enjeu est de taille car l’IGN possède plus de 3,5 millions d’images argentiques scannées, acquises au cours de plus de 26000 chantiers, que ce soit en France métropolitaine, dans les DOM-TOM ou dans les anciennes colonies. Les images sont disponibles sur Remonter le temps.
Pompei permet notamment de répondre à plusieurs défis techniques : recherche de repères de fond de chambre, construction d’orthophotos, recherche de points d’appuis et égalisation radiométrique. Pompei traite indifféremment les images en couleur (RVB ou IRC) ou bien les images à un seul canal (panchromatique ou infrarouge). Pompei utilise le logiciel de photogrammétrie MicMac, ainsi que des scripts Python et bash.
La documentation détaillée de Pompei se trouve dans pompei.pdf
Il sera peut-être nécessaire de récupérer le SRTM, suivant les chantiers. Pour cela, il est indispensable de créer dans pompei/scripts un fichier api_key.env qui aura un champ OpenTopo_key avec une clef de l'API https://www.opentopography.org/
Prérequis : Docker est déjà installé
Construction de l'image Docker :
docker build -t pompei --build-arg HTTP_PROXY=$HTTP_PROXY --build-arg HTTPS_PROXY=$HTTPS_PROXY --build-arg USER_ID=$(id --user) --build-arg CPU=12 .
Pour lancer le conteneur Docker (renseigner le répertoire de montage dans la machine hôte) :
docker run --name pompei -it -e DISPLAY -v [point de montage sur la machine hôte]:/home/pompei/pompei/pompei/chantiers -v /tmp/.X11-unix:/tmp/.X11-unix --user="$(id --user)" pompei /bin/bash
Ou bien (interne à l'IGN) : pour lancer le conteneur Docker après avoir monté store-ref en local (renseigner le répertoire de montage de store-ref) :
docker run --name pompei -it -e DISPLAY --mount type=bind,src=[chemin vers store-ref],dst=/media/store-ref,readonly -v [point de montage sur la machine hôte]:/home/pompei/pompei/pompei/chantiers -v /tmp/.X11-unix:/tmp/.X11-unix --user="$(id --user)" pompei /bin/bash
Activer l'environnement conda :
mamba activate pompei
Prérequis : Docker est déjà installé
Construction de l'image Docker :
docker build -t pompei --build-arg HTTP_PROXY=$HTTP_PROXY --build-arg HTTPS_PROXY=$HTTPS_PROXY --build-arg USER_ID=$(id -u) --build-arg CPU=12 .
Lancer le serveur X11 (installer XQuartz si nécessaire):
open -a XQuartz
Autorisez les connexions locales:
xhost +localhost
Lancer le conteneur Docker (renseigner le répertoire de montage dans la machine hôte):
docker run --name pompei -it --env="DISPLAY=host.docker.internal:0" -v [point de montage sur la machine hôte]:/home/pompei/pompei/pompei/chantiers -v /tmp/.X11-unix:/tmp/.X11-unix --user="$(id -u)" pompei /bin/bash
Ou bien (interne à l'IGN) : pour lancer le conteneur Docker après avoir monté store-ref en local (renseigner le répertoire de montage de store-ref) :
docker run --name pompei -it --env="DISPLAY=host.docker.internal:0" --mount type=bind,src=[chemin vers store-ref],dst=/media/store-ref,readonly -v [point de montage sur la machine hôte]:/home/pompei/pompei/pompei/chantiers -v /tmp/.X11-unix:/tmp/.X11-unix --user="$(id -u)" pompei /bin/bash
Activer l'environnement conda :
mamba activate pompei
Prérequis : WSL est déjà installé et Docker fonctionne sur WSL.
Dans ce cas, l'installation fonctionne en suivant toutes les étapes de l'installation avec Docker sur Linux. Il faut que le projet soit cloné dans WSL.
Ne fonctionne qu'avec Linux
-
Installer Micmac en suivant les consignes d'installation sur la page GitHub.
-
Installer l'environnement conda :
mamba env create -f environment.yml
- Activer l'environnement conda :
mamba activate pompei
Attention, les chantiers Pompei sont très volumineux ! Voici quelques ordres de grandeurs approximatifs :
- pour 6 images jp2 de 30 Mo et une emprise au sol de 184 km2, il faut compter 50 Go.
- pour 50 images jp2 de 30 Mo et une emprise au sol de 989 km2, il faut compter 306 Go.
- pour 84 images jp2 de 4 Mo et une emprise au sol de 494 km2, il faut compter 115 Go.
- pour 25 images jp2 de 45 Mo et une emprise au sol de 56 km2, il faut compter 152 Go.
Pour récupérer les chantiers disponibles sur Remonter le temps :
python scripts/get_data.py --outdir footprints
Un fichier [outdir]/footprints.geojson est créé. Il contient :
- les emprises (footprints) au sol
- la date de la mission (ne tenir compte que de l'année et pas du jour ni du mois)
- la résolution en mètres. Il s'agit d'une approximation calculée à partir de la hauteur de vol et de la focale définie dans les métadonnées de l'IGN
- la couleur. C : en RVB, P : panchromatique, IRC : infrarouge fausse couleur, IR : infrarouge
- le support. Nu : numérique, Ag : argentique
- prise de vue oblique. Pompei ne fonctionne pas avec les acquisitions en prise de vue oblique car il n'y a pas assez de recouvrement entre les images et les algorithmes de recherche de points d'appuis ne sont pas faits pour comparer images obliques et orthophoto acquises à la verticale.
- la taille de la focale en mm. Il s'agit d'une approximation issue des métadonnées, mais qui sert de valeur initiale lorsque Pompei déterminera la vraie valeur de la focale.
Note : seul le répertoire chantiers dispose d'un volume Docker. Donc si vous avez utilisé Docker pour l'installation, il faut que footprints soit de la forme chantiers/[...] pour que vous puissiez le visualiser ensuite dans Qgis.
Pour récupérer les emprises au sol d'un chantier :
python scripts/get_flight_plan.py --footprints_file fichier_emprises --id id_chantier --outdir outdir
Un fichier [outdir]/images.geojson est créé. Vous pouvez l'ouvrir dans Qgis. Ce fichier contient les emprises au sol de tous les clichés du chantier. Sélectionnez les clichés qui vous intéressent et sauvegardez-les dans un nouveau fichier shapefile.
Paramètres :
- fichier_footprints : chemin vers le fichier des chantiers disponibles, celui qui a été téléchargé avec le get_data.py
- id_chantier : l'identifiant du chantier souhaité : champ id du fichier footprints, sans le "dataset."
- outdir : répertoire où mettre les données pour le chantier
Pour récupérer les images et le TA d'un chantier :
python scripts/get_images.py --selection selection --id id_chantier --epsg epsg --outdir outdir
Avec :
- selection : chemin vers le fichier contenant les images sélectionnées
- id_chantier : l'identifiant du chantier souhaité : champ id du fichier footprints, sans le "dataset."
- epsg : epsg du chantier : il n'y a pas moyen de récupérer automatiquement l'EPSG du chantier, donc il faut le rentrer à la main ici
- outdir : répertoire où mettre les données pour le chantier
cd pompei
sh visualize_flight_plan.sh TA 0
sh pompei.sh TA nb_fiducial_marks targets Kugelhupf_image_filtree remove_artefacts ortho algo filter_GCP create_ortho_mns create_ortho_mnt cpu
La signification des paramètres est détaillée dans la documentation.
Le script pompei.sh ne fonctionne pas si les images ne se recouvrent pas suffisamment. En effet, il est alors impossible de reconstruire une orthophoto vraie et de la comparer avec l'ortho de référence. La variante se veut être plus robuste à ce cas de figure et plus rapide, mais moins précise. De plus, elle ne permet que la création d'une ortho sur MNT (donc pas de production de MNS). Il n'est pas possible de filtrer les points d'appuis. La variante ne fonctionne pas non plus pour le moment sur des images en couleur. Le principe est le suivant :
- Même processus de prétraitement des images et de recherche de repères de fond de chambre
- Recherche de points de liaisons
- Récupération de l'ortho de référence
- Pour chaque image, recherche de points d'appuis sur l'ortho de référence
- Aérotriangulation à partir des points de liaisons et des points d'appuis. Si une image est isolée du reste du chantier, elle devrait cependant être géoréférencée si elle a suffisamment de points d'appuis
- Construction d'une ortho sur le MNT actuel et égalisation radiométrique
cd pompei
sh visualize_flight_plan.sh TA
sh pompei_rapide.sh TA nb_fiducial_marks targets Kugelhupf_image_filtree remove_artefacts ortho nb_cpus
Contributeurs IGN : Célestin Huet, Arnaud Le Bris, Sébastien Giordano
- Aubry et al, Painting-to-3D Model Alignment Via Discriminative Visual Elements, 2014
- Giordano et al, Toward automatic georeferencing of archival aerial photogrammetric surveys, 2018
- Zhang et al, Feature matching for multi-epoch historical aerial images, 2021
Please cite Pompei and IGN if you use this software in your research or project. Proper citations help others find and reference this work and support its continued development.
To cite this software, please use the following reference:
@software{Pompei,
author = {IGN},
title = {Pompei},
version = {1},
year = {2024},
url = {https://github.com/IGNF/Pompei}
}