Dequantizzare il tensore 'input' in un tensore float o bfloat16.
[min_range, max_range] sono float scalari che specificano l'intervallo per l'output. L'attributo 'mode' controlla esattamente quali calcoli vengono utilizzati per convertire i valori float nei loro equivalenti quantizzati.
Nella modalità 'MIN_COMBINED', ciascun valore del tensore subirà quanto segue:
if T == qint8: in[i] += (range(T) + 1)/ 2.0
out[i] = min_range + (in[i]* (max_range - min_range) / range(T))
Esempio di modalità MIN_COMBINED
Se l'input proviene da un QuantizedRelu6, il tipo di output è quint8 (intervallo 0-255) ma il possibile intervallo di QuantizedRelu6 è 0-6. I valori min_range e max_range sono quindi 0,0 e 6,0. Dequantizza su quint8 prenderà ogni valore, lo convertirà in float e lo moltiplicherà per 6/255. Tieni presente che se quantizedtype è qint8, l'operazione aggiungerà inoltre ciascun valore per 128 prima dell'esecuzione del cast.
Se la modalità è "MIN_FIRST", viene utilizzato questo approccio:
num_discrete_values = 1 << (# of bits in T)
range_adjust = num_discrete_values / (num_discrete_values - 1)
range = (range_max - range_min) * range_adjust
range_scale = range / num_discrete_values
const double offset_input = static_cast<double>(input) - lowest_quantized;
result = range_min + ((input - numeric_limits<T>::min()) * range_scale)
Il fattore di scala è determinato da `min_range`, `max_range` e `narrow_range` in modo compatibile con `QuantizeAndDequantize{V2|V3}` e `QuantizeV2`, utilizzando il seguente algoritmo:
const int min_expected_T = std::numeric_limits<T>::min() +
(narrow_range ? 1 : 0);
const int max_expected_T = std::numeric_limits<T>::max();
const float max_expected_T = std::numeric_limits<float>::max();
const float scale_factor =
(std::numeric_limits<T>::min() == 0) ? (max_range / max_expected_T)
: std::max(min_range / min_expected_T,
max_range / max_expected_T);
Classi nidificate
classe | Dequantizza.Opzioni | Attributi facoltativi per Dequantize |
Costanti
Corda | OP_NAME | Il nome di questa operazione, come noto al motore principale di TensorFlow |
Metodi pubblici
Uscita <U> | comeuscita () Restituisce l'handle simbolico del tensore. |
Dequantize.Options statiche | asse (asse lungo) |
statico <U estende TNumber > Dequantizza <U> | |
Dequantizzazione statica < TFloat32 > | |
Dequantize.Options statiche | modalità (modalità stringa) |
Dequantize.Options statiche | narrowRange (Booleano narrowRange) |
Uscita <U> | produzione () |
Metodi ereditati
Costanti
Stringa finale statica pubblica OP_NAME
Il nome di questa operazione, come noto al motore principale di TensorFlow
Metodi pubblici
Uscita pubblica <U> asOutput ()
Restituisce l'handle simbolico del tensore.
Gli input per le operazioni TensorFlow sono output di un'altra operazione TensorFlow. Questo metodo viene utilizzato per ottenere un handle simbolico che rappresenta il calcolo dell'input.
public static Dequantize <U> create ( Scope scope, Operando <? estende TType > input, Operando < TFloat32 > minRange, Operando < TFloat32 > maxRange, Class<U> dtype, Opzioni... opzioni)
Metodo factory per creare una classe che racchiude una nuova operazione Dequantize.
Parametri
ambito | ambito attuale |
---|---|
minRange | Il valore scalare minimo eventualmente prodotto per l'input. |
maxRange | Il valore scalare massimo possibilmente prodotto per l'input. |
dtype | Tipo del tensore di uscita. Attualmente Dequantize supporta float e bfloat16. Se 'dtype' è 'bfloat16', supporta solo la modalità 'MIN_COMBINED'. |
opzioni | trasporta valori di attributi opzionali |
Ritorni
- una nuova istanza di Dequantize
public static Dequantize < TFloat32 > create ( Scope scope, Operando <? estende TType > input, Operando < TFloat32 > minRange, Operando < TFloat32 > maxRange, Opzioni... opzioni)
Metodo factory per creare una classe che racchiude una nuova operazione Dequantize utilizzando i tipi di output predefiniti.
Parametri
ambito | ambito attuale |
---|---|
minRange | Il valore scalare minimo eventualmente prodotto per l'input. |
maxRange | Il valore scalare massimo possibilmente prodotto per l'input. |
opzioni | trasporta valori di attributi opzionali |
Ritorni
- una nuova istanza di Dequantize