Yolo Vision Shenzhen
Shenzhen
Rejoindre maintenant
Glossaire

Réseau neuronal graphique (GNN)

Découvrez comment les réseaux neuronaux graphiques (GNN) révolutionnent l'IA avec des données structurées en graphes pour la découverte de médicaments, les réseaux sociaux, la prédiction du trafic, et bien plus encore !

Un réseau neuronal graphique (GNN) est une architecture spécialisée dans le domaine de l'apprentissage profond (DL). l'apprentissage profond (DL), conçue pour traiter et analyser des données représentées sous forme de graphiques. Alors que les modèles d'apprentissage machine (ML) standard exigent généralement que les données soient structurées en grilles régulières (comme les images) ou en tableaux séquentiels (comme le texte), les GNN excellent dans l'interprétation des données définies par les nœuds et les arêtes qui les séparent. définies par des nœuds et les arêtes qui les relient. Cette capacité unique leur permet de capturer des relations complexes relations complexes et les interdépendances entre les entités, ce qui les rend indispensables pour les tâches où la structure de connexion est tout aussi importante que les points de données eux-mêmes. que les points de données eux-mêmes.

Fonctionnement des réseaux neuronaux graphiques

Le mécanisme de base d'un GNN est un processus connu sous le nom de transmission de messages ou d'agrégation de voisinage. Dans ce cadre, chaque nœud du graphe met à jour sa propre représentation en recueillant des informations auprès de ses voisins immédiats. Au cours de formation, le réseau apprend des embeddings (représentations vectorielles denses) qui encodent àla fois les caractéristiques et la structure de l'image. représentations vectorielles denses qui encodent à la fois les caractéristiques du nœud lui-même et les informations structurelles du réseau qui l'entoure. réseau.

Grâce à plusieurs couches de traitement, un nœud peut finalement intégrer des informations provenant de parties éloignées du graphe, voir" le contexte plus large. Cela contraste avec les modèles traditionnels de régression linéaire ou de classification simple. régression linéaire traditionnelle ou les modèles de classification simples qui traitent souvent les points de données comme des entités indépendantes. Des cadres tels que PyTorch Geometric facilitent ce calcul complexe, permettant aux développeurs de créer des applications sophistiquées basées sur les graphes. complexes, permettant aux développeurs de créer des applications sophistiquées basées sur les graphes.

Distinguer les GNN des autres architectures

Pour comprendre l'utilité des GNN, il est utile de les différencier d'autres types de réseaux types de réseaux neuronaux (NN) que l'on trouve dans l'IA moderne :

  • Réseaux neuronaux convolutifs (CNN): Les réseaux neuronaux convolutifs sont optimisés pour les données structurées en grille telles que les images. Ils utilisent des noyaux de taille fixe pour detect motifs. Alors que les modèles comme Ultralytics YOLO11 représentent l'état l'état de l'art en matière de détection d'objets visuels, ils ne sont pas conçus pour gérer la structure irrégulière et non euclidienne des données graphiques.
  • Réseaux neuronaux récurrents (RNN): Les RNN sont conçus pour les données séquentielles, traitant les entrées dans un ordre spécifique pour l'analyse de séries temporelles ou les tâches linguistiques. pour l'analyse de séries temporelles ou les tâches linguistiques. Les réseaux neuronaux récurrents, à l'inverse, traitent des données dont les relations sont spatiales ou relationnelles plutôt que temporelles.
  • Graphique de connaissances: Un graphe de connaissances est une base de données structurée de faits (entités et relations), tandis qu'un GNN est le modèle informatique utilisé pour apprendre à partir de ces structures. pour apprendre à partir de ces structures. Les GNN sont souvent utilisés pour effectuer des raisonnements ou des prédictions de liens sur les graphes de connaissances.

Applications concrètes

La capacité à modéliser les relations rend les GNN puissants dans diverses industries à fort impact :

  1. Découverte de médicaments et chimie : Dans l'industrie pharmaceutique, les molécules peuvent être représentées naturellement comme des graphes où les atomes sont des nœuds et les liaisons chimiques des arêtes. représenter les molécules comme des graphes où les atomes sont des nœuds et les liaisons chimiques des arêtes. Les GNN contribuent à l'utilisation de l'IA dans le domaine de la santé en prédisant les molécules et les liaisons chimiques. l 'IA dans les soins de santé en prédisant les propriétés moléculaires, en simulant les interactions entre les protéines et en identifiant les candidats médicaments potentiels plus rapidement que les simulations traditionnelles. traditionnelles. Des initiatives de recherche majeures, telles que celles de DeepMind, s'appuient fortement sur les concepts d'apprentissage profond géométrique.
  2. Analyse des réseaux sociaux : Les plateformes utilisent les réseaux sociaux pour analyser les vastes réseaux d'interactions des utilisateurs. En modélisant les utilisateurs comme des nœuds et les interactions comme des arêtes, ces réseaux en modélisant les utilisateurs comme des nœuds et les interactions comme des arêtes, ces réseaux alimentent les systèmes de recommandation. systèmes de recommandation qui suggèrent d'amis, de contenus ou de produits. Ils sont également essentiels pour la détection des fraudes, en identifiant les groupes d'activités suspectes que les systèmes traditionnels ne parviennent pas à détecter. d'activités suspectes que les méthodes que les méthodes traditionnelles de détection des anomalies pourraient manquer.

Mise en œuvre des concepts graphiques

Bien que des bibliothèques spécialisées se chargent de la transmission des messages, la première étape consiste à comprendre comment structurer les données des graphes. est la première étape. Voici un exemple simple utilisant PyTorch pour définir les connexions des arêtes (topologie) d'un graphe, qui sert d'entrée à un GNN.

import torch

# Define a simple graph with 3 nodes and 2 edges
# 'edge_index' represents connections: Node 0->1 and Node 1->2
edge_index = torch.tensor([[0, 1], [1, 2]], dtype=torch.long)

# Define features for each node (e.g., x, y coordinates or attributes)
# 3 nodes, each with 2 feature values
x = torch.tensor([[-1, 0], [0, 0], [1, 0]], dtype=torch.float)

print(f"Graph defined with {x.size(0)} nodes and {edge_index.size(1)} edges.")

Les GNN sont de plus en plus souvent intégrés dans des pipelines plus importants. Par exemple, un système peut utiliser segmentation d'images pour identifier des objets dans une scène, puis utiliser un GNN pour raisonner sur les relations spatiales entre ces objets, comblant ainsi le fossé entre la perception visuelle et le raisonnement logique. entre la perception visuelle et le raisonnement logique. Comme des outils tels que TensorFlow GNN et Deep Graph Library (DGL), la barrière à l'entrée pour le déploiement de ces modèles complexes continue de diminuer, élargissant ainsi leur portée. modèles complexes continue de baisser, élargissant ainsi leur dans les villes intelligentes et au-delà.

Rejoindre la communauté Ultralytics

Rejoignez le futur de l'IA. Connectez-vous, collaborez et évoluez avec des innovateurs mondiaux.

Rejoindre maintenant