My Project
Public Member Functions | Static Public Member Functions | List of all members
mlir::quant::UniformQuantizedType Class Reference

#include <QuantTypes.h>

Inheritance diagram for mlir::quant::UniformQuantizedType:
Inheritance graph
[legend]
Collaboration diagram for mlir::quant::UniformQuantizedType:
Collaboration graph
[legend]

Public Member Functions

double getScale () const
 
int64_t getZeroPoint () const
 
bool isFixedPoint () const
 

Static Public Member Functions

static UniformQuantizedType get (unsigned flags, Type storageType, Type expressedType, double scale, int64_t zeroPoint, int64_t storageTypeMin, int64_t storageTypeMax)
 
static UniformQuantizedType getChecked (unsigned flags, Type storageType, Type expressedType, double scale, int64_t zeroPoint, int64_t storageTypeMin, int64_t storageTypeMax, Location location)
 
static LogicalResult verifyConstructionInvariants (Optional< Location > loc, MLIRContext *context, unsigned flags, Type storageType, Type expressedType, double scale, int64_t zeroPoint, int64_t storageTypeMin, int64_t storageTypeMax)
 Verifies construction invariants and issues errors/warnings. More...
 
static bool kindof (unsigned kind)
 Support method to enable LLVM-style type casting. More...
 
- Static Public Member Functions inherited from mlir::detail::StorageUserBase< ConcreteT, BaseT, StorageT, UniquerT >
static ClassIDgetClassID ()
 Return a unique identifier for the concrete type. More...
 
template<typename T >
static bool classof (T val)
 

Additional Inherited Members

- Public Types inherited from mlir::detail::StorageUserBase< ConcreteT, BaseT, StorageT, UniquerT >
using Base = StorageUserBase< ConcreteT, BaseT, StorageT, UniquerT >
 Utility declarations for the concrete attribute class. More...
 
using ImplType = StorageT
 
- Protected Member Functions inherited from mlir::detail::StorageUserBase< ConcreteT, BaseT, StorageT, UniquerT >
ImplTypegetImpl () const
 Utility for easy access to the storage instance. More...
 
- Static Protected Member Functions inherited from mlir::detail::StorageUserBase< ConcreteT, BaseT, StorageT, UniquerT >
template<typename... Args>
static ConcreteT get (MLIRContext *ctx, unsigned kind, Args... args)
 
template<typename... Args>
static ConcreteT getChecked (const Location &loc, MLIRContext *ctx, unsigned kind, Args... args)
 
template<typename... Args>
static LogicalResult verifyConstructionInvariants (Args... args)
 Default implementation that just returns success. More...
 

Detailed Description

Represents a family of uniform, quantized types.

Each instance of this type expresses a mapping between real values (most often expressed in floating point f32) and quantized values (either fixed point or affine).

The relationship is: real_value = scale * (quantized_value - zero_point)

It is used as part of high level graph transformations that have the goal of re-expressing parts of a computation in terms of this common form for more efficient execution at runtime. In addition, it is designed to be expressive enough to facilitate lowering to precise types and operations in target hardware.

As a high-level type, focused on intermediate passes, this type holds opinions consistent with high-level usage. If lowering math kernels below the high level arithmetic ops (i.e. to LLVM IR or hardware specific instruction sets), it is expected that the information expressed here will be used to drive low level codegen and target specific type selection, but this type will likely be erased in the process.

Syntax synopsis: Per-layer, all parameters expressed: !quant<uniform[StorageType:ExpressedType]{Scale:ZeroPoint}> Per-layer, optional parameters omitted: !quant<uniform[StorageType]{Scale}>

StorageType: 'i'|'u' NumBits ExpressedType: 'f16', 'f32', 'bf16', 'f64' Scale: A legal double value ZeroPoint: An integer value

Member Function Documentation

◆ get()

UniformQuantizedType UniformQuantizedType::get ( unsigned  flags,
Type  storageType,
Type  expressedType,
double  scale,
int64_t  zeroPoint,
int64_t  storageTypeMin,
int64_t  storageTypeMax 
)
static

Gets an instance of the type with all parameters specified but not checked.

◆ getChecked()

UniformQuantizedType UniformQuantizedType::getChecked ( unsigned  flags,
Type  storageType,
Type  expressedType,
double  scale,
int64_t  zeroPoint,
int64_t  storageTypeMin,
int64_t  storageTypeMax,
Location  location 
)
static

Gets an instance of the type with all specified parameters checked. Returns a nullptr convertible type on failure.

◆ getScale()

double UniformQuantizedType::getScale ( ) const

Gets the scale term. The scale designates the difference between the real values corresponding to consecutive quantized values differing by 1.

◆ getZeroPoint()

int64_t UniformQuantizedType::getZeroPoint ( ) const

Gets the storage value corresponding to the real value 0 in the affine equation.

◆ isFixedPoint()

bool mlir::quant::UniformQuantizedType::isFixedPoint ( ) const
inline

◆ kindof()

static bool mlir::quant::UniformQuantizedType::kindof ( unsigned  kind)
inlinestatic

Support method to enable LLVM-style type casting.

◆ verifyConstructionInvariants()

LogicalResult UniformQuantizedType::verifyConstructionInvariants ( Optional< Location loc,
MLIRContext context,
unsigned  flags,
Type  storageType,
Type  expressedType,
double  scale,
int64_t  zeroPoint,
int64_t  storageTypeMin,
int64_t  storageTypeMax 
)
static

Verifies construction invariants and issues errors/warnings.


The documentation for this class was generated from the following files: