RandomStructured¶
- class torch.nn.utils.prune.RandomStructured(amount, dim=-1)[source][source]¶
隨機修剪張量中整個(當前未修剪的)通道。
- 引數
- classmethod apply(module, name, amount, dim=-1)[source][source]¶
動態新增修剪並重新引數化張量。
新增前向預鉤子,啟用動態修剪,並根據原始張量和修剪掩碼重新引數化張量。
- apply_mask(module)[source]¶
簡單處理被修剪引數與生成的掩碼之間的乘法。
從模組中獲取掩碼和原始張量,並返回張量的修剪版本。
- 引數
module (nn.Module) – 包含要修剪張量的模組
- 返回值
輸入張量的修剪版本
- 返回型別
pruned_tensor (torch.Tensor)
- compute_mask(t, default_mask)[source][source]¶
計算並返回輸入張量
t的掩碼。從基礎
default_mask開始(如果張量尚未修剪,則應為全一掩碼),透過隨機將張量沿指定維度上的通道歸零,生成一個隨機掩碼應用在default_mask之上。- 引數
t (torch.Tensor) – 表示要修剪引數的張量
default_mask (torch.Tensor) – 來自先前修剪迭代的基礎掩碼,應用新掩碼後仍需遵守。與
t具有相同的維度。
- 返回值
應用於
t的掩碼,與t維度相同- 返回型別
mask (torch.Tensor)
- 丟擲異常
IndexError – 如果
self.dim >= len(t.shape)
- prune(t, default_mask=None, importance_scores=None)[source]¶
計算並返回輸入張量
t的修剪版本。根據
compute_mask()中指定的修剪規則。- 引數
t (torch.Tensor) – 要修剪的張量(與
default_mask維度相同)。importance_scores (torch.Tensor) – 重要性分數張量(與
t形狀相同),用於計算修剪t的掩碼。此張量中的值表示待修剪的t中相應元素的重要性。如果未指定或為 None,則將使用張量t本身代替。default_mask (torch.Tensor,可選) – 來自先前修剪迭代的掩碼(如果存在)。確定修剪應作用於張量的哪一部分時應考慮此掩碼。如果為 None,則預設為全一掩碼。
- 返回值
張量
t的修剪版本。