IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MATLAB Discussion :

Intersection shapefile et grille régulière


Sujet :

MATLAB

  1. #1
    Membre confirmé
    Homme Profil pro
    Éternel universitaire
    Inscrit en
    Avril 2012
    Messages
    421
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Éternel universitaire

    Informations forums :
    Inscription : Avril 2012
    Messages : 421
    Points : 639
    Points
    639
    Par défaut Intersection shapefile et grille régulière
    Bonjour à tous,

    Je cherche à identifier les points d'une grille qui chevauchent un polygone défini dans un shapefile. Plus précisément, je voudrais pouvoir retourner les indices des vecteurs contenant les longitudes et les latitudes qui sont compris à l'intérieur de ce polygone. Ou encore mieux, pouvoir définir une distance à partir de laquelle un point est considéré comme à l'intérieur du polygone.

    J'ai produit le shapefile à l'aide d'arcGIS. Il contient un polygone "déprojeté", c'est à dire que la position des points est exprimée en degrés. Les grilles sont issues de centres de prévisions météo et stockées dans des fichiers NetCDF. Il peut s'agir de grilles régulières (cas de ECMWF dans le code dessous), ou correspondant à une projection (projection Lambert pour NOAA).

    Une petite figure pour illustrer le problème. Nom : 023402_grid.png
Affichages : 372
Taille : 38,5 Ko
    La ligne bleue représente les limites de mon polygone, les points noirs les nœuds de la grille ECMWF, les points rouge les noeuds de la grille NOAA.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    % Import shape file
    [S,A]=shaperead('./023402_shp/023402.shp');
     
    % Import NetCDF NOAA
    ncid = netcdf.open('./NetCDF_files/noaa.nc','NOWRITE');
    lat0noaa = netcdf.getVar(ncid, netcdf.inqVarID(ncid,'g3_lat_0'));
    lon0noaa = netcdf.getVar(ncid, netcdf.inqVarID(ncid,'g3_lon_1'));
    netcdf.close(ncid)
     
    % Import NetCDF ECMWF
    ncid = netcdf.open('./NetCDF_files/ecmwf.nc','NOWRITE');
    lat0ecmwf = netcdf.getVar(ncid, netcdf.inqVarID(ncid,'lat_0'));
    lon0ecmwf = netcdf.getVar(ncid, netcdf.inqVarID(ncid,'lon_0'));
    netcdf.close(ncid)
     
    % Plots
    plot(S.X,S.Y,'b'); hold on
    plot(lon0noaa,lat0noaa,'LineStyle','none','Marker','.','Color','r')
    plot(repmat(lon0ecmwf-360, [1, size(lat0ecmwf,1)])',...
        repmat(lat0ecmwf, [1, size(lon0ecmwf,1)]),...
        'LineStyle','none','Marker','.','Color','k')
    set(gca,'XLim',[-72 -70],'YLim',[45 47])
    Je mets en pièce jointe des données pour faire tourner le code (seulement la grille rouge et le shapefile, sinon la pièce jointe est trop lourde).

    Merci pour vos suggestions !
    Fichiers attachés Fichiers attachés

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 882
    Points
    52 882
    Par défaut
    Regarde la fonction inpolygon ou ses alternatives sur le File Exchange
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  3. #3
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    1 882
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 882
    Points : 3 432
    Points
    3 432
    Par défaut
    salut

    as tu essayer la fonction inpolygon ?

    Fabien

  4. #4
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 882
    Points
    52 882
    Par défaut
    J'ai oublié de préciser que dans ce genre de problème, tu peux initialement réduire le domaine de recherche en excluant les points qui sont en dehors du rectangle englobant le polygone :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    idx = x<min(S.X(:)) | x>max(S.X(:)) | y<min(S.Y(:)) | y>max(S.Y(:));
     
    x(idx) = [];
    y(idx) = [];
    Tu peux aussi remplacer le rectangle par le polygone convexe englobant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    k = convhull(xpolygon, ypolygon);
     
    in = inpolygon(x, y, x(k), y(k);
     
    x(~in) = [];
    y(~in) = [];
    C'est l'idée…
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  5. #5
    Membre confirmé
    Homme Profil pro
    Éternel universitaire
    Inscrit en
    Avril 2012
    Messages
    421
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Éternel universitaire

    Informations forums :
    Inscription : Avril 2012
    Messages : 421
    Points : 639
    Points
    639
    Par défaut
    Merci, je suis passé à côté de cette fonction lors de mes recherches ! C'était ça qu'il me fallait.
    Par contre pas d'option pour spécifier une distance à partir de laquelle un point est "attrapé"

  6. #6
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    1 882
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 882
    Points : 3 432
    Points
    3 432
    Par défaut
    bein en fait soit le point est dedans, soit il ne l'est pas
    du coup pour attraper des points qui ne son pas dedans mis qui sont pas loin, il faut tricher
    par exemple en faisant l'union de plusieurs inpolygone ou l'on décale les grilles X,Y dans les 4 directions

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 30/07/2015, 20h37
  2. Extrapolation d'un grille régulière
    Par oodini dans le forum Mathématiques
    Réponses: 19
    Dernier message: 11/07/2011, 11h56
  3. Calculer une intersection sur une grille
    Par Greg L. dans le forum Mathématiques
    Réponses: 8
    Dernier message: 26/06/2008, 15h51
  4. Classer des rectangles dans une grille régulière
    Par Rodrigue dans le forum Algorithmes et structures de données
    Réponses: 3
    Dernier message: 16/09/2006, 13h38
  5. Réponses: 5
    Dernier message: 11/06/2002, 15h21

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo