import os
import numpy as np
from utils import NumExt
np.random.seed(19)
def gen_golden_data_tcolsum(case_name, param):
dtype = param.dtype
srcRow, srcCols = [param.tile_row, param.tile_col]
dstRow, dstCols = [1, param.tile_col]
row_valid, col_valid = [min(dstRow, param.valid_row), min(dstCols, param.valid_col)]
input1 = NumExt.astype(np.random.randint(low=-16, high=16, size=[srcRow, srcCols]), dtype)
golden = NumExt.astype(np.sum(input1, axis=0, dtype=np.float32).reshape(1, col_valid), dtype)
NumExt.write_array("input.bin", input1, dtype)
NumExt.write_array("golden.bin", golden, dtype)
return input1, golden
class TColsumParams:
def __init__(self, dtype, global_row, global_col, tile_row, tile_col, valid_row, valid_col):
self.dtype = dtype
self.global_row = global_row
self.global_col = global_col
self.tile_row = tile_row
self.tile_col = tile_col
self.valid_row = valid_row
self.valid_col = valid_col
def generate_case_name(param):
dtype_str = NumExt.get_short_type_name(param.dtype)
name = f"TCOLSUMTest.case_{dtype_str}"
name += f"_{param.global_row}x{param.global_col}"
name += f"_{param.tile_row}x{param.tile_col}"
name += f"_{param.valid_row}x{param.valid_col}"
return name
if __name__ == "__main__":
script_dir = os.path.dirname(os.path.abspath(__file__))
testcases_dir = os.path.join(script_dir, "testcases")
if not os.path.exists(testcases_dir):
os.makedirs(testcases_dir)
case_params_list = [
TColsumParams(np.float32, 64, 64, 64, 64, 64, 64),
TColsumParams(np.float16, 16, 256, 16, 256, 16, 256),
]
if os.getenv("PTO_CPU_SIM_ENABLE_BF16") == "1":
case_params_list.append(TColsumParams(NumExt.bf16, 16, 256, 16, 256, 16, 256))
for i, param in enumerate(case_params_list):
case_name = generate_case_name(param)
if not os.path.exists(case_name):
os.makedirs(case_name)
original_dir = os.getcwd()
os.chdir(case_name)
gen_golden_data_tcolsum(case_name, param)
os.chdir(original_dir)