程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
您现在的位置: 程式師世界 >> 編程語言 >  >> 更多編程語言 >> Python

python label 與 one-hot 之間的互相轉換

編輯:Python

文章目錄

  • 前言
  • label 轉 one-hot
  • one-hot 轉label

前言

有時候需要label,比如強化學習的離散動作空間,輸出動作索引;有時候需要one-hot,比如訓練數據或者輸入上一個狀態的動作,簡單的互相轉換還是重要的。

label 轉 one-hot

通過 np.eye(action_dims)[actions] 快速生成:

>>> import numpy as np
>>> label = [1,2,2,3]
>>> np.eye(4)[label]
array([[0., 1., 0., 0.],
[0., 0., 1., 0.],
[0., 0., 1., 0.],
[0., 0., 0., 1.]])

one-hot 轉label

numpy可以通過 np.argmax(onehot, 1) 實現,pytorch 可以通過 torch.topk(one_hot, 1)[1].squeeze(1) 實現:

>>> import torch
>>> onehot
array([[0., 1., 0., 0.],
[0., 0., 1., 0.],
[0., 0., 1., 0.],
[0., 0., 0., 1.]])
>>> np.argmax(onehot,1)
array([1, 2, 2, 3], dtype=int64)
>>> torch.topk(torch.tensor(onehot), 1)[1].squeeze(1)
tensor([1, 2, 2, 3])

  1. 上一篇文章:
  2. 下一篇文章:
Copyright © 程式師世界 All Rights Reserved