Pages: 1
- Sujet précédent - Postgresql :Découpage couche batiments avec couche d'occupation du sol - Sujet suivant
#1 Mon 20 February 2017 10:17
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour à tous,
Je travail sous postgresql 9.4, postgis 2.1.8, PG Admin III-1.20 et je souhaite découper une couche de polygones représentant le bâti d'un département avec une couche de polygones représentant l'occupation du sol.
Je voudrais affecter le type d'occupation du sol à chaque batiment là où il se situe.
- Première solution : requête de jointure du centroïde du bâtiment avec la géométrie du polygone d'occupation du sol...pas très pro ni précis car quid des bâtiments à cheval sur plusieurs polygones d'occupation du sol?
- Deuxième solution : je découpe mon bâtiment avec les objets de la couche d'occupation du sol, je calcule la superficie de chaque nouveaux petits bouts de bâtiments obtenus et je prends le type d'occupation du sol là où la superficie du petit bout de bâtiment est la plus importante par identifiant de bâtiment :
Code:
WITH tempa AS (SELECT id_bati,max(surf_decoup) as s_max FROM bati_decoup GROUP BY id_bati) SELECT id_bati,id_ocs FROM bati_decoup,tempa WHERE bati_decoup.id_bati=tempa.id_bati AND bati_decoup.surf_decoup=tempa.s_max
Cette requête suppose qu'un bâtiment n'est jamais à cheval exactement à 50%/50% sur deux polygones pour ne pas avoir de doublons d'identifiants id_bati.
Bon, le seul problème, c'est que je ne bloque pas sur cette requête que j'ai déjà effectué pour un autre travail mais sur la requête de découpage...
Voici ma requête :
Code:
DROP TABLE IF EXISTS bati_decoup; CREATE TABLE bati_decoup AS SELECT bati.id as id_bati,ocs.id as id_ocs,st_intersection(bati.geom,ocs.geom) as geom_inter FROM bati_decoup as bati,ocs WHERE st_intersects(bati.geom,ocs.geom);
Le problème avec cette requête, c'est qu'après 4 jours, elle ne s'est toujours pas exécutée (je précise que ma couche d'OCS est uniquement sur l'agglo de Lyon tandis que mes bâtiments sont sur l'intégralité du département 69).
J'ai essayé la requête suivante:
Code:
DROP TABLE IF EXISTS bati_decoup; CREATE TABLE bati_decoup AS SELECT bati.id as id_bati,ocs.id as id_ocs,st_intersection(bati.geom,ocs.geom) as geom_inter FROM bati_decoup as bati INNER JOIN ocs ON st_intersects(bati.geom,ocs.geom) AND Not ST_IsEmpty(ST_Intersection(bati.geom,ocs.geom));
mais elle tourne elle aussi "dans le vide".
Bon, beaucoup me disent qu'il faut que je soit patiente mais le problème c'est que cette requête doit être reproductible sur l'ensemble du territoire nationale et je ne peux pas livrer une requête qui met une semaine à s'exécuter (surtout que ce découpage est loin d'être la seule requête de mon fichier .sql!Il s'agit en fait d'une étude complète sur le bâti).
Je précise que mes couches ont bien tous les index géo et attributaires nécessaires...
Avez-vous une idée pour optimiser ma requête?
Merci!!!
Lucie D.
Hors ligne
#2 Mon 20 February 2017 10:51
- Nicolas Ribot
- Membre
- Lieu: Toulouse
- Date d'inscription: 9 Sep 2005
- Messages: 1554
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
Il faut regarder le plan de la requete pour savoir ce qu'elle fait et notamment si les index sont utilisés:
explain select...
Autre chose très importante pour ces cas d'intersection:
Il faut que les pg a intersecter soient petits par rapport à la zone totale, sinon l'index n'est pas très sélectif et un gros PG occ sol va se retrouver dans pleins d'intersections avec des petits batiments => long.
Avant, une solution consistait à créer une grille et à découper la couche avec de gros pg par rapport à cette grille. Maintenant, st_subdivide(geom) fait ca tout seul et TRES vite !
Si les PG occupation du sol sont gros, il faut créer une autre table occsol_cut en appliquant subdivide, puis index et utiliser cette couche.
Le gain de perf peut etre énorme.
Nicolas
Hors ligne
#3 Mon 20 February 2017 11:23
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Merci pour l'info!
Je vais tester comme ça, mais c'est vrai qu'il me semblait que les PG de cette couche d'occupation du sol étaient relativement petits (il s'agit de urban areas de l'agence européenne de l'environnement).
Mais en fait quand je regarde en zone périurbaine, les PG deviennent plus gros!
Je reviens sur le forum pour vous tenir au courant!
Merci!
Lucie D.
Hors ligne
#4 Mon 20 February 2017 11:52
- ChristopheV
- Membre
- Lieu: Ajaccio
- Date d'inscription: 7 Sep 2005
- Messages: 3197
- Site web
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
Je vais peut-être dire une bêtise mais j'avais remarqué pour un sujet similaire qu'il est plus rapide de calculer l'intersection de deux multi-polygones.
L'utilisation de st_clusterwithin vous offrirait deux avantages :
Création d'un multi-polygone et possibilité en fonction de la distance de savoir si vous êtes dans du bâti dense (urbain) ou non (peri-urbain).
Comme on peut aussi récupérer le nombre de bâtiments dans une grappe on peut aussi gérer le bâti isolé.
L'idée est la suivante :
Je crée des grappes bâties (st_clusterwithin) avec une distance de 10 m, ie zone urbaine, je récupère la BBox de la grappe, dans une CTE je récupère l'occupation du sol de cette BBox et je calcule l'intersection des deux couches.
Christophe
L'avantage d'être une île c'est d'être une terre topologiquement close
Hors ligne
#5 Mon 20 February 2017 13:27
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour ChristopheV,
Merci pour ce message qui tombe à pic car je suis justement en train de tester votre approche de la tache urbaine (https://georezo.net/forum/viewtopic.php?id=102129) qui est très intéressante! Je suis en phase test et du coup j'ai effectivement eu l'occasion d'utiliser ce fameux st_clusterwithin() pour la première fois! Bon le seul hic c'est que je travaille de plus en plus avec des fonctions qui nécessitent postgis 2.2 et je travaille sur un serveur distant avec un postgis 2.1.8...Donc j'ai installé un serveur postgresql sur mon propre PC avec une version 2.3.2 de postgis et comme ça je pourrai utiliser st_clusterwithin ET st_subdivide(geom) que je ne connaissais pas non plus mais qui ne fonctionne également qu'à partir de la 2.2...
Je vous tiens au courant!
Lucie D.
Dernière modification par Lucie D. (Mon 20 February 2017 14:10)
Hors ligne
#6 Mon 20 February 2017 14:48
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Nicolas,
Je suis en train de lancer la requête de découp du bati avec une couche d'occupation du sol sous_découpée avec st_subdivide(geom) [qui, au passage, s'exécute effectivement très rapidement].
Toutefois, comme vous me l'avez proposé, j'ai jeté un coup d’œil au plan de ma requête et en fait postgresql prend bien en compte mon index géographique sur ma couche bati, mais pas sur ma couche d'occupation du sol alors qu'elle a bien un index sur sa géométrie...?!
Est-ce normal? Je me suis demandé si ce n'était pas du au inner join. J'ai essayé de le remplacer avec un where mais le résultat est le même, seul l'index de ma couche bati est pris en compte... En revanche, quand je passe la souris sur la couche d'occupation du sol dans le plan de la requête, ça me dit : "seq scan" (voir pièce jointe).
Je ne sais pas ce que ça signifie (je ne maitrise pas les plans de requête ^^")?
Encore merci pour votre aide!
Bien cordialement,
Lucie D.
Dernière modification par Lucie D. (Mon 20 February 2017 14:48)
Hors ligne
#7 Mon 20 February 2017 16:04
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Et bien ma foi, le découpage grâce au st_subdivide(geom) de ma couche d'occupation du sol m'a effectivement permis de passer de plus de trois jours de requête à quelques minutes pour le découpage du bâti!
Je suis vraiment impressionnée! o_O
Merci beaucoup, du coup je dois légèrement adapter les requêtes qui suivent mais c'est parfait comme ça!
A bientôt pour de nouvelles aventures SQL!
Bien cordialement,
Lucie D.
Hors ligne
#8 Mon 20 February 2017 17:14
- Nicolas Ribot
- Membre
- Lieu: Toulouse
- Date d'inscription: 9 Sep 2005
- Messages: 1554
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Ah cool, mieux en effet
Je suis vraiment impressionnée! o_O
Moi aussi: c'est vraiment un bel outil ce Postgis !
Hors ligne
#9 Tue 30 May 2017 18:07
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
Je reviens sur ce post car je me pose une question un peu bête.
J'avais lancé un st_subdivide(geom) sans préciser le nombre de sommets maxi...
Savez-vous quel est le nombre de sommets par défaut de la fonction quand on ne précise rien?
Merci par avance pour votre aide!
Bien cordialement,
Lucie D.
Hors ligne
#10 Tue 30 May 2017 18:36
- Nicolas Ribot
- Membre
- Lieu: Toulouse
- Date d'inscription: 9 Sep 2005
- Messages: 1554
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
http://postgis.net/docs/ST_Subdivide.html
(je vous invite à lire cette doc si vous utilisez postgis !)
NIcolas
Hors ligne
#11 Wed 31 May 2017 09:20
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
Merci.
Je m'attendais à cette réponse et c'est de ma faute, j'aurais du préciser que, bien évidemment j'ai lu et relu cette page postgis, mais soit je suis aveugle, soit mon niveau en anglais est trop bas, mais je ne trouve pas la réponse exacte à ma question.
Ok, le nombre minimum de sommets que l'on peut indiquer dans cette fonction est 8 sinon ça plante, mais ça ne me dit pas si c'est bien la valeur par défaut utilisée par st_subdivide quand on ne lui précise rien?
J'ai peut-être pas tout compris...?? =P
Merci beaucoup!
Lucie
Hors ligne
#12 Wed 31 May 2017 09:53
- ChristopheV
- Membre
- Lieu: Ajaccio
- Date d'inscription: 7 Sep 2005
- Messages: 3197
- Site web
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
integer max_vertices=256
Cela signifie que la valeur par défaut de max_vertices est 256.
Christophe
L'avantage d'être une île c'est d'être une terre topologiquement close
Hors ligne
#13 Wed 31 May 2017 10:01
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
Merci, c'est super, je ne l'avais pas du tout compris comme ça mais c'est super, merci beaucoup!
Bonne journée!
Lucie D.
Hors ligne
#14 Wed 31 May 2017 10:19
- ppluvinet
- Participant assidu
- Lieu: VALENCE
- Date d'inscription: 6 Aug 2007
- Messages: 617
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
ravi de voir que ST_Subdivide a pu permettre une exécution plus rapide. C'est effectivement un réflexe qu'il faut avoir pour ce type de traitement !
Toutefois, je me suis interrogé sur ce croisement :
1. As-t-on besoin de faire un st_intersection : cela suppose qu'on peut avoir un même bâtiment dans plusieurs occupation différentes ? ca me semble conceptuellement peu approprié ?
2. Ne faut-il pas retirer les routes ? Ce sont souvent des polygones tentaculaires qui ne permettent pas d'utiliser les index correctement et un bâtiment ne peut pas appartenir à une route (à priori).
Bien sûr, je ne connais pas le sujet exact de travail de Lucie.
Bonne journée,
Dernière modification par ppluvinet (Wed 31 May 2017 10:22)
Pascal PLUVINET
Hors ligne
#15 Thu 01 June 2017 10:52
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour Pascal,
Effectivement, il aurait été possible de retirer certains items de l'occupation du sol quand on est sûr que les bâtiments ne peuvent pas en faire partie...Et ça aurait été effectivement plus juste car je me retrouve malgré tout, avec ma méthode, avec quelques bâtiments dans l'eau (pas beaucoup heureusement)=> problèmes de précision géométrique? problème de méthode? Mais ça n'impacte pas vraiment mon travail.
En fait, je cherchais un moyen de récupérer le type d'occupation du sol dont la superficie de recouvrement par le bâti est la plus importante pour pouvoir affirmer que le bâtiment se trouve prioritairement sur telle ou telle occupation du sol (en cas de chevauchement sur plusieurs type d'OCS). J'ai donc fait des sommes de superficie de bouts de bâtiments par item OCS en prenant bien en compte le fait que ma couche d'OCS a été sous découpée par st_subdivide pour obtenir des objets avec moins de sommets (et donc doublons d'identifiants OCS).
Le résultat que j'ai obtenu avec ça est tout à fait cohérent, mais pour ce que je souhaitais faire, le simple croisement avec le centroide du bâtiment ne change quasiment pas les résultats à l'échelle d'un département et aurait suffit (j'ai fait le test).
Bonne journée!
Bien cordialement,
Lucie D.
Hors ligne
#16 Thu 01 June 2017 12:31
- ppluvinet
- Participant assidu
- Lieu: VALENCE
- Date d'inscription: 6 Aug 2007
- Messages: 617
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Oui, j'aurais fait un simple update avec une condition d’intersection avec le centroïde de chaque bâtiment.
Attention tout de même avec l'urban areas de l'agence européenne de l'environnement. Elle est à prendre avec des pincettes sur certains postes de la nomenclature. Je me souviens d'avoir vu une carte de l'agglomération de Lyon qui était un peu surprenante ! Des zones commerciales un peu surreprésentées de souvenir...?
Bon courage,
Pascal PLUVINET
Hors ligne
#17 Thu 01 June 2017 14:28
- ChristopheV
- Membre
- Lieu: Ajaccio
- Date d'inscription: 7 Sep 2005
- Messages: 3197
- Site web
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Bonjour,
Nous ne sommes plus dans postgis mais il y a une chose qui me choque c'est cette notion
affirmer que le bâtiment se trouve prioritairement sur telle ou telle occupation du sol
Pour moi un bâtiment EST une occupation du sol. Il me semble que l'IGN considère que tout bâtiment est a minima une surface de 200 m² pour son ocs à grande échelle.
Avoir un bâtiment qui est situé sur plusieurs zone ocs c'est que ce bâtiment a été construit après l'OCS ou que l'OCS a été réalisée avec des données obsolètes.
Et nous nous retrouvons dans le cadre habituel, la problématique de la mise à jour des données à grande échelle ... bon il y a un organisme qui sait faire depuis 200 ans mais c'est pas à lui que l'on demande et c'est pas lui que l'on écoute, bon il faut dire que sa tutelle n'a pas vraiment envie.
Christophe
L'avantage d'être une île c'est d'être une terre topologiquement close
Hors ligne
#18 Thu 01 June 2017 16:04
- Lucie D.
- Participant actif
- Date d'inscription: 21 Oct 2013
- Messages: 137
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Pour moi un bâtiment EST une occupation du sol.
J'en conviens totalement mais ça dépend quelle niveau de précision on souhaite. Urban areas a une nomenclature qui mélange occupation et usage des sols et avoir un bâtiment en zone agricole et un bâtiment dans une zone d'activités commerciales est pour moi différent.
Pour tout vous avouer :
1°/ je manipule des données que, il est vrai, je ne maitrise pas vraiment malgré mes recherches mais manque de temps et on fait tous un jour les braves exécutants ;-)
2°/ on ne sait pas si ces données vont être utilisées
3°/ Nous sommes en plein test alors merci pour vos conseils qui pourront peut-être faire pencher la balance...qui sait?
Lucie D.
Hors ligne
#19 Thu 01 June 2017 16:05
- ppluvinet
- Participant assidu
- Lieu: VALENCE
- Date d'inscription: 6 Aug 2007
- Messages: 617
Re: Postgresql :Découpage couche batiments avec couche d'occupation du sol
Il y a différente définition/école et de règle appliquée à la production de cartographie d'occupation du sol. Le bureau d'études dans lequel je suis, travaille sur toutes ces notions. Selon les nomenclatures, un bâtiment peut être considéré à lui seul comme une occupation du sol, parfois ce sont les bâtiments et les espaces autour associés . Dans le second cas, on peut distinguer aisément par exemple les centres-ville et les zones pavillonnaires. D'ailleurs dans les zones pavillonnaires on a rarement des bâtiments de plus de 200m2, non ?
Par contre, un bâtiment est rarement à cheval sur 2 occupations du sol (quoique on a déjà vu des terrains de tennis sur des centre-commerciaux! )
Bon, on s'éloigne du sujet...
Pascal PLUVINET
Hors ligne
Pages: 1
- Sujet précédent - Postgresql :Découpage couche batiments avec couche d'occupation du sol - Sujet suivant