DML_ELEMENT_WISE_BIT_XOR_OPERATOR_DESC結構 (directml.h)
計算輸入張量之每個對應元素之間的位 XOR (eXclusive OR) ,並將結果寫入輸出張量。
位運算會以其原生編碼方式套用至張量數據。 因此,除了判斷每個元素的寬度之外,會忽略 tensor 數據類型。
這個運算符支援就地執行,這表示輸出張量可以在系結期間將一或多個輸入張量別名化。
語法
struct DML_ELEMENT_WISE_BIT_XOR_OPERATOR_DESC {
const DML_TENSOR_DESC *ATensor;
const DML_TENSOR_DESC *BTensor;
const DML_TENSOR_DESC *OutputTensor;
};
成員
ATensor
類型: const DML_TENSOR_DESC*
包含左側輸入的張量。
BTensor
類型: const DML_TENSOR_DESC*
包含右側輸入的張量。
OutputTensor
類型: const DML_TENSOR_DESC*
要寫入結果的輸出張量。
範例
InputTensor: (Sizes:{2,2}, DataType:UINT8)
[[0, 128], // 0b00000000, 0b10000000
[42, 255]] // 0b00101010, 0b11111111
OutputTensor: (Sizes:{2,2}, DataType:UINT8)
[[255, 127], // 0b11111111, 0b01111111
[213, 0 ]] // 0b11010101, 0b00000000
可用性
這個運算子是在 中 DML_FEATURE_LEVEL_3_0
引進。
Tensor 條件約束
ATensor、 BTensor 和 OutputTensor 必須具有相同 的 DataType、 DimensionCount 和 Sizes。
Tensor 支援
DML_FEATURE_LEVEL_4_1和更新版本
張 | 種類 | 支援的維度計數 | 支援的資料類型 |
---|---|---|---|
ATensor | 輸入 | 1 到 8 | FLOAT64、FLOAT32、FLOAT16、INT64、INT32、INT16、INT8、UINT64、UINT32、UINT16、UINT8 |
BTensor | 輸入 | 1 到 8 | FLOAT64、FLOAT32、FLOAT16、INT64、INT32、INT16、INT8、UINT64、UINT32、UINT16、UINT8 |
OutputTensor | 輸出 | 1 到 8 | FLOAT64、FLOAT32、FLOAT16、INT64、INT32、INT16、INT8、UINT64、UINT32、UINT16、UINT8 |
DML_FEATURE_LEVEL_3_0和更新版本
張 | 種類 | 支援的維度計數 | 支援的資料類型 |
---|---|---|---|
ATensor | 輸入 | 1 到 8 | UINT32、UINT16、UINT8 |
BTensor | 輸入 | 1 到 8 | UINT32、UINT16、UINT8 |
OutputTensor | 輸出 | 1 到 8 | UINT32、UINT16、UINT8 |
規格需求
需求 | 值 |
---|---|
最低支援的用戶端 | Windows 10 組建 20348 |
最低支援的伺服器 | Windows 10 組建 20348 |
標頭 | directml.h |