tilelang.carver.template.gemv module#

class tilelang.carver.template.gemv.GEMVTemplate(N: Optional[int] = None, K: Optional[int] = None, trans_B: bool = True, in_dtype: str = 'float16', out_dtype: str = 'float16', accum_dtype: str = 'float16', with_bias: bool = False)#

Bases: BaseTemplate

A template for Generalized Matrix-Vector Multiplication (GEMV).

This template defines the computation for a matrix-vector multiplication with configurable parameters such as transposition, data types, and bias addition.

K: int = None#
N: int = None#
accum_dtype: str = 'float16'#
property class_attributes#

Returns the class attributes in dictionary form.

Returns:

Dictionary of class attributes.

Return type:

dict

get_hardware_aware_configs(arch: Optional[TileDevice] = None, topk: int = 10) List[Hint]#

Retrieves optimized hardware-aware configurations.

Parameters:
  • arch (TileDevice, optional) – The target hardware architecture.

  • topk (int, optional) – Number of top configurations to consider.

Returns:

A list of optimization hints for hardware acceleration.

Return type:

List[Hint]

in_dtype: str = 'float16'#
initialize_function() None#

Defines and initializes the GEMV computation function.

This method sets up placeholders for input matrices, computes the matrix-vector multiplication using TVM’s compute API, and optionally applies bias and type casting.

out_dtype: str = 'float16'#
params_as_dict()#

Returns the template parameters as a dictionary.

Returns:

Dictionary containing template parameter values.

Return type:

dict

trans_B: bool = True#
with_bias: bool = False#