fort images jpg
This commit is contained in:
52
Readme.md
52
Readme.md
@@ -1,13 +1,11 @@
|
||||
# LidarTo3DPrint
|
||||
|
||||
Procédure de conversion d'un fichier de points LIDAR en une impression 3D
|
||||
|
||||
# Contexte
|
||||
|
||||
Tenter de pouvoir observer et caractériser le relief d'un territoire au moyen des relevés 3D réalisés par l'état. Le territoire français est en cours de cartographie au Lidar avec une résolution de 10 points par mètre carré : [https://geoservices.ign.fr/lidarhd](https://geoservices.ign.fr/lidarhd)
|
||||
|
||||
Ces données seront utilisées et transformées dans ce projet en une surface imprimable en 3D.
|
||||
|
||||
# Réalisation
|
||||
|
||||
Les grandes étapes de la réalisation sont :
|
||||
@@ -24,7 +22,7 @@ Se rendre sur la page web de téléchargement des données brutes : [https://ca
|
||||
|
||||
Sélectionner une zone et télécharger les données, ici nous sélectionnons une zone couvrant le centre ville de Plomelin
|
||||
|
||||

|
||||

|
||||
## Rassembler les points
|
||||
|
||||
Afin de traiter les données LIDAR, nous allons utiliser l'outil QGIS et LAStools. Ces outils vont permettre :
|
||||
@@ -34,39 +32,39 @@ Afin de traiter les données LIDAR, nous allons utiliser l'outil QGIS et LAStool
|
||||
|
||||
Ouvrir QGIS et installer le plugin LAStools depuis QGIS, cela va intégrer les outils dans l'IHM de QGIS mais les executables sont à télécharger à part. Pour installer les outils dans QGIS commencer par dérouler le menu Plugins puis cliquer sur Manager et Installer des Plugins
|
||||
|
||||

|
||||

|
||||
|
||||
Trouver le paquet LAStools et cliquer sur installer, cela va intégrer les outils dans QGIS.
|
||||
|
||||

|
||||

|
||||
|
||||
Se rendre sur [la page de LASTools](https://rapidlasso.de/downloads/) et télécharger les outils compilés pour votre OS.
|
||||
|
||||

|
||||

|
||||
|
||||
Décompresser le zip et copier le fichier LASTools dans le disque C:\LAStools puis redémarrer QGIS
|
||||
|
||||

|
||||

|
||||
|
||||
Maintenant que les outils de traitement LIDAR sont installés on peut Importer un fichier LIDAR (ou plusieurs). Les fichiers sont importés comme des "Couches" dans le projet.
|
||||
|
||||

|
||||

|
||||
|
||||
Dans QGIS, il est possible d’avoir un aperçu des fichiers en ouvrant une nouvelle vue 3D avec le menu View => 3D Map View => New 3D Map View
|
||||
|
||||

|
||||

|
||||
|
||||
Sur ce zoom on peut apercevoir un château d’eau ainsi que des maisons et de la végétation. Les couleurs affichées dépendent des catégories. En effet lors du post-traitement effectué sur ces données LIDAR, un algorithme de catégorisation va identifier parmi les points : le sol, les bâtiments, la végétation, les lignes électriques... ou alors si rien n'est identifié placer les points dans Uncategorized.
|
||||
|
||||

|
||||

|
||||
|
||||
Pour ne pas imprimer tout le village, nous allons sélectionner une plus petite zone. Pour cela commencer par créer une nouvelle couche temporaire, cette couche va servir à dessiner un polygone, qui sera utilisé pour découper le fichier de points.
|
||||
|
||||

|
||||

|
||||
|
||||
Sélectionner une géométrie de type polygon (pour faire la sélection) et choisir la même géodésique que celle du nuage de points (vérifier qu'il n'y ait pas de logo de type point d'exclamation à côté du menu déroulant).
|
||||
|
||||

|
||||

|
||||
|
||||
Une nouvelle couche apparaît maintenant en bas a gauche, nous allons y dessiner un polygone qui contiendra uniquement les points à garder.
|
||||
|
||||
@@ -74,37 +72,37 @@ Cliquer sur "Add Polygon" pour ajouter un polygone et sélectionner une région
|
||||
|
||||
Utiliser l’outil d’ajout de polygone (click gauche pour les points du polygone, click droit pour terminer)
|
||||
|
||||

|
||||

|
||||
|
||||
Chercher l’outil de processing « Point Cloud Clip »
|
||||

|
||||

|
||||
|
||||
Sélectionner la couche de points source ainsi que le polygone
|
||||

|
||||

|
||||
|
||||
Cela va sélectionner les points contenus dans le polygone et créer une nouvelle couche. Ne cocher que la couche « Clipped » pour retenir les points sélectionnés.
|
||||

|
||||

|
||||
|
||||
|
||||
Si au contraire on souhaite assembler plusieurs fichiers de points pour représenter une grande surface, cela reste possible avec la fonction Point cloud data management ==> Merge
|
||||
|
||||

|
||||

|
||||
|
||||
### Désélectionner les catégories non souhaitées
|
||||
|
||||
Il est possible maintenant d’utiliser les classes de ces données lidar pour retirer ce que l’on ne va pas imprimer. Ici je ne garde que le sol et les bâtiments
|
||||
|
||||

|
||||

|
||||
|
||||
En cochant / décochant des cases, il n’est possible que d’afficher ou de masquer des points. Cependant pour les étapes suivantes nous souhaitons les retirer du jeu de données avant de transférer le fichier dans un autre logiciel
|
||||
|
||||
Faire un click droit sur la couche et cliquer sur Filter… créer un filtre en ne gardant que les classifications 2 et 6
|
||||
|
||||

|
||||

|
||||
|
||||
Faire un click droit sur la couche, Export => Save As et enregistrer dans un fichier LAS
|
||||
|
||||

|
||||

|
||||
|
||||
Vous n’aurez que les points associés aux catégories filtrées dans ce fichier
|
||||
|
||||
@@ -115,7 +113,7 @@ Afin de combler les trous un utilisateur à créer un programme en C# permettant
|
||||
|
||||
L'idée est de l'utiliser afin de combler les vides, par exemple ici à gauche, le nuage de points originel, et à droite le nuage "corrigé"
|
||||
|
||||

|
||||

|
||||
|
||||
On peut voir que sur le nuage originel, pris par avion, certaines facades de bâtiments sont vides de points. Cela rend la reconstruction compliquée...
|
||||
|
||||
@@ -155,25 +153,25 @@ Maintenant que le nuage de points est corrigé, on cherche à en créer la surfa
|
||||
|
||||
En regardant en haut a droite on peut observer que nous avons beaucoup de points mais aucune face. Il faut reconstruire les faces d’après tous les points en utilisant le bon filtre et potentiellement des corrections manuelles.
|
||||
|
||||

|
||||

|
||||
|
||||
Ces points ont été relevés par avion et ont un certain bruit de mesure. Partir de ce nuage pour reconstruire le modèle va créer des incohérences étranges dues a une mauvaise interprétation des normales (qu'est ce qui est "dedans" et ce qui est "dehors"). Sur l'image ci-dessous une partie du toit du building de gauche à été inversée comme "dehors"
|
||||
|
||||

|
||||

|
||||
|
||||
Pour réduire ces effets, on peut moyenner les points. Cela va induire une perte de "résolution" et de détails sur le modèle, mais permet d'éviter les formes incohérentes.
|
||||
|
||||
Pour cela on va simplifier le nuage de points en regroupant les points, je trouve que de garder 0,1% sur ces relevés donne de bons résultats. Avec 0,09% j'ai toujours des problèmes donc 0,1 est peut être le minimum pour ne pas avoir de défauts sans tout autant perdre trop de résolution.
|
||||
|
||||

|
||||

|
||||
|
||||
Il faut ensuite lancer une estimation des normales. Cet algorithmes va tenter d'identifier ce qui est dedans et ce qui est dehors, ainsi que le vecteur orthogonal aux points. Je trouve qu'une valeur qui fonctionne bien est d'utiliser une quantité de 40 points par normale.
|
||||
|
||||

|
||||

|
||||
|
||||
Finalement on peut utiliser la reconstruction de Poisson pour identifier la surface qui correspond le mieux a tous ces points, toutes ces normales et leur orientation. Ici je trouve qu'une valeu qui fonctionne bien est d'utiliser les paramètres suivants:
|
||||
|
||||

|
||||

|
||||
|
||||
Enregistrer maintenant la surface au format STL en utilisant le menu File => Export As et l’appeler "mesh.stl"
|
||||
## Découper la surface
|
||||
@@ -208,4 +206,4 @@ Cela va créer un modèle STL importable dans Bambu Studio
|
||||
|
||||
Ouvrir Bambu Studio et importer le STL, le redimensionner et lancer l'impression.
|
||||
|
||||

|
||||

|
||||
|
||||
Reference in New Issue
Block a user