Salut, Xiaozhuang ! Ravi de vous rencontrer! Puis-je faire quelque chose pour vous aider ?
J'ai partagé du contenu sur l'apprentissage profond au cours des derniers jours.
De plus, il existe certaines fonctions de traitement de données courantes similaires à numpy et pandas dans Pytorch, qui sont tout aussi importantes et intéressantes !
De même, PyTorch fournit également de nombreuses fonctions de traitement et de transformation des données.
Jetons maintenant un coup d’œil aux fonctions nécessaires les plus importantes.
Dans PyTorch, torch.Tensor est une structure de données de base utilisée pour représenter des tenseurs. Un tenseur est un tableau multidimensionnel pouvant contenir différents types de données telles que des nombres et des valeurs booléennes. Vous pouvez utiliser le constructeur de torch.Tensor pour créer un tenseur, ou vous pouvez utiliser d'autres fonctions pour le créer.
1 |
|
est utilisé pour convertir les tableaux NumPy en tenseurs PyTorch.
1 |
|
est utilisé pour extraire les valeurs numériques Python d'un tenseur ne contenant qu'un seul élément. S'applique aux tenseurs scalaires.
1 |
|
est utilisé pour changer la forme du tenseur.
1 |
|
est utilisé pour convertir un tenseur en un périphérique spécifié (tel qu'un CPU ou un GPU).
1 |
|
Convertissez un tenseur en tableau NumPy.
1 |
|
est utilisé pour l'encodage à chaud de tenseurs entiers.
1 |
|
sont utilisés pour charger et traiter des ensembles de données. Ces deux classes sont généralement utilisées avec des classes d'ensembles de données personnalisées.
1 |
|
Ci-dessus sont quelques fonctions de conversion de données importantes dans PyTorch, qui sont simplement utilisées.
Ils sont très, très utiles pour traiter et préparer les données dans les tâches d'apprentissage en profondeur.
Ensuite, nous réalisons un cas de segmentation d'images.
Dans ce cas, nous utiliserons les bibliothèques PyTorch et torchvision pour la segmentation d'images, en utilisant le modèle DeepLabV3 pré-entraîné et l'ensemble de données PASCAL VOC.
L'ensemble du code implique ce que nous avons appris ci-dessus, comme le redimensionnement, le recadrage, la standardisation, etc.
1 |
|
Dans ce cas, nous définissons d'abord une série de fonctions de transformation d'image, notamment le redimensionnement, la conversion en tenseur et la normalisation. Ces transformations garantissent que l'image d'entrée répond aux besoins du modèle.
Ensuite, un exemple d'image a été chargé et ces transformations ont été appliquées.
Ensuite, nous avons utilisé le modèle DeepLabV3 pré-entraîné dans torchvision pour la segmentation d'images. Pour la sortie, nous avons extrait l'indice maximum des résultats de prédiction pour obtenir la classe prédite pour chaque pixel.
Enfin, nous convertissons les résultats de prédiction en images couleur et visualisons les images originales et les résultats de segmentation.
Ce cas met en évidence le rôle important de la fonction de conversion d'image dans la tâche de segmentation d'image, garantissant que l'image d'entrée répond aux exigences d'entrée du modèle et que les résultats de sortie sont faciles à visualiser.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!