From d613ad0a125284a159b199567a81e60b3c0f5f9a Mon Sep 17 00:00:00 2001 From: Luca Colagrande Date: Fri, 23 Aug 2024 13:07:01 +0200 Subject: [PATCH] sw: Uniformize `data_utils` import --- sw/apps/atax/scripts/datagen.py | 18 ++++++++---------- sw/apps/correlation/scripts/datagen.py | 19 +++++++++---------- sw/apps/covariance/scripts/datagen.py | 10 ++++------ sw/apps/doitgen/scripts/datagen.py | 9 ++++----- sw/blas/axpy/scripts/datagen.py | 19 ++++++++----------- sw/blas/dot/scripts/datagen.py | 22 ++++++++++------------ sw/blas/gemm/scripts/datagen.py | 22 ++++++++++------------ sw/blas/syrk/scripts/datagen.py | 9 ++++----- 8 files changed, 57 insertions(+), 71 deletions(-) diff --git a/sw/apps/atax/scripts/datagen.py b/sw/apps/atax/scripts/datagen.py index c73ae70a29..0008bea261 100755 --- a/sw/apps/atax/scripts/datagen.py +++ b/sw/apps/atax/scripts/datagen.py @@ -9,8 +9,6 @@ import numpy as np import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import format_scalar_definition, format_array_definition, \ - format_array_declaration, format_ifdef_wrapper, DataGen # AXI splits bursts crossing 4KB address boundaries. To minimize @@ -18,7 +16,7 @@ BURST_ALIGNMENT = 4096 -class AtaxDataGen(DataGen): +class AtaxDataGen(du.DataGen): def golden_model(self, A, x): return np.matmul(A.transpose(), np.matmul(A, x)) @@ -38,13 +36,13 @@ def emit_header(self, **kwargs): x = x.flatten() y = y.flatten() - header += [format_scalar_definition('uint32_t', 'M', M)] - header += [format_scalar_definition('uint32_t', 'N', N)] - header += [format_array_definition('double', 'A', A, alignment=BURST_ALIGNMENT)] - header += [format_array_definition('double', 'x', x, alignment=BURST_ALIGNMENT)] - header += [format_array_declaration('double', 'y', y.shape, alignment=BURST_ALIGNMENT)] - result_def = format_array_definition('double', 'golden', y, alignment=BURST_ALIGNMENT) - header += [format_ifdef_wrapper('BIST', result_def)] + header += [du.format_scalar_definition('uint32_t', 'M', M)] + header += [du.format_scalar_definition('uint32_t', 'N', N)] + header += [du.format_array_definition('double', 'A', A, alignment=BURST_ALIGNMENT)] + header += [du.format_array_definition('double', 'x', x, alignment=BURST_ALIGNMENT)] + header += [du.format_array_declaration('double', 'y', y.shape, alignment=BURST_ALIGNMENT)] + result_def = du.format_array_definition('double', 'golden', y, alignment=BURST_ALIGNMENT) + header += [du.format_ifdef_wrapper('BIST', result_def)] header = '\n\n'.join(header) return header diff --git a/sw/apps/correlation/scripts/datagen.py b/sw/apps/correlation/scripts/datagen.py index 7880c16934..d60f527d1c 100755 --- a/sw/apps/correlation/scripts/datagen.py +++ b/sw/apps/correlation/scripts/datagen.py @@ -9,8 +9,6 @@ import numpy as np import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import format_scalar_definition, format_array_definition, \ - format_array_declaration, format_ifdef_wrapper, DataGen # AXI splits bursts crossing 4KB address boundaries. To minimize @@ -18,7 +16,7 @@ BURST_ALIGNMENT = 4096 -class CorrelationDataGen(DataGen): +class CorrelationDataGen(du.DataGen): def golden_model(self, data): return np.corrcoef(data, rowvar=False) @@ -33,13 +31,14 @@ def emit_header(self, **kwargs): data = data.flatten() corr = corr.flatten() - header += [format_scalar_definition('uint32_t', 'M', M)] - header += [format_scalar_definition('uint32_t', 'N', N)] - header += [format_array_definition('double', 'data', data, alignment=BURST_ALIGNMENT)] - header += [format_array_declaration('double', 'corr', corr.shape, - alignment=BURST_ALIGNMENT)] - result_def = format_array_definition('double', 'golden', corr, alignment=BURST_ALIGNMENT) - header += [format_ifdef_wrapper('BIST', result_def)] + header += [du.format_scalar_definition('uint32_t', 'M', M)] + header += [du.format_scalar_definition('uint32_t', 'N', N)] + header += [du.format_array_definition('double', 'data', data, alignment=BURST_ALIGNMENT)] + header += [du.format_array_declaration('double', 'corr', corr.shape, + alignment=BURST_ALIGNMENT)] + result_def = du.format_array_definition('double', 'golden', corr, + alignment=BURST_ALIGNMENT) + header += [du.format_ifdef_wrapper('BIST', result_def)] header = '\n\n'.join(header) return header diff --git a/sw/apps/covariance/scripts/datagen.py b/sw/apps/covariance/scripts/datagen.py index 07bb92d0a3..7beb2c6713 100755 --- a/sw/apps/covariance/scripts/datagen.py +++ b/sw/apps/covariance/scripts/datagen.py @@ -9,15 +9,13 @@ import numpy as np import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import format_array_definition, \ - format_array_declaration, format_struct_definition, DataGen np.random.seed(42) DOUBLE_BUFFER = True -class CovarianceDataGen(DataGen): +class CovarianceDataGen(du.DataGen): # Function pointers to alternative implementations FUNCPTRS = ["covariance_naive", "covariance_baseline", "covariance_opt"] @@ -69,9 +67,9 @@ def emit_header(self, **kwargs): 'funcptr': kwargs['funcptr'] } - header += [format_array_definition('double', data_uid, data)] - header += [format_array_declaration('double', cov_uid, cov.shape)] - header += [format_struct_definition('covariance_args_t', 'args', cfg)] + header += [du.format_array_definition('double', data_uid, data)] + header += [du.format_array_declaration('double', cov_uid, cov.shape)] + header += [du.format_struct_definition('covariance_args_t', 'args', cfg)] header = '\n\n'.join(header) return header diff --git a/sw/apps/doitgen/scripts/datagen.py b/sw/apps/doitgen/scripts/datagen.py index 5f14ec86dd..d1a9c3b46f 100755 --- a/sw/apps/doitgen/scripts/datagen.py +++ b/sw/apps/doitgen/scripts/datagen.py @@ -8,14 +8,13 @@ import numpy as np import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import format_array_definition, format_struct_definition, DataGen np.random.seed(42) DOUBLE_BUFFER = True -class DoitgenDataGen(DataGen): +class DoitgenDataGen(du.DataGen): # Function pointers to alternative implementations FUNCPTRS = ["doitgen_naive", "doitgen_baseline", "doitgen_opt"] @@ -78,9 +77,9 @@ def emit_header(self, **kwargs): 'funcptr': kwargs['funcptr'] } - header += [format_array_definition('double', A_uid, A)] - header += [format_array_definition('double', x_uid, x)] - header += [format_struct_definition('doitgen_args_t', 'args', cfg)] + header += [du.format_array_definition('double', A_uid, A)] + header += [du.format_array_definition('double', x_uid, x)] + header += [du.format_struct_definition('doitgen_args_t', 'args', cfg)] header = '\n\n'.join(header) return header diff --git a/sw/blas/axpy/scripts/datagen.py b/sw/blas/axpy/scripts/datagen.py index ec00a4c880..38634dd5ee 100755 --- a/sw/blas/axpy/scripts/datagen.py +++ b/sw/blas/axpy/scripts/datagen.py @@ -5,15 +5,12 @@ # # Author: Luca Colagrande -import numpy as np import sys import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import format_scalar_definition, format_array_definition, \ - format_array_declaration, format_ifdef_wrapper, format_struct_definition, DataGen -class AxpyDataGen(DataGen): +class AxpyDataGen(du.DataGen): # AXI splits bursts crossing 4KB address boundaries. To minimize # the occurrence of these splits the data should be aligned to 4KB @@ -60,16 +57,16 @@ def emit_header(self, **kwargs): 'funcptr': kwargs['funcptr'] } - header += [format_scalar_definition('const double', 'a', a)] - header += [format_array_definition('double', x_uid, x, + header += [du.format_scalar_definition('const double', 'a', a)] + header += [du.format_array_definition('double', x_uid, x, alignment=self.BURST_ALIGNMENT, section=kwargs['section'])] - header += [format_array_definition('double', y_uid, y, + header += [du.format_array_definition('double', y_uid, y, alignment=self.BURST_ALIGNMENT, section=kwargs['section'])] - header += [format_array_declaration('double', z_uid, x.shape, + header += [du.format_array_declaration('double', z_uid, x.shape, alignment=self.BURST_ALIGNMENT, section=kwargs['section'])] - header += [format_struct_definition('axpy_args_t', 'args', cfg)] - result_def = format_array_definition('double', 'g', g) - header += [format_ifdef_wrapper('BIST', result_def)] + header += [du.format_struct_definition('axpy_args_t', 'args', cfg)] + result_def = du.format_array_definition('double', 'g', g) + header += [du.format_ifdef_wrapper('BIST', result_def)] header = '\n\n'.join(header) return header diff --git a/sw/blas/dot/scripts/datagen.py b/sw/blas/dot/scripts/datagen.py index d11b53ff86..8a8631a6a2 100755 --- a/sw/blas/dot/scripts/datagen.py +++ b/sw/blas/dot/scripts/datagen.py @@ -7,11 +7,9 @@ import sys import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import format_scalar_definition, format_array_definition, \ - format_scalar_declaration, format_ifdef_wrapper, DataGen -class DotDataGen(DataGen): +class DotDataGen(du.DataGen): # AXI splits bursts crossing 4KB address boundaries. To minimize # the occurrence of these splits the data should be aligned to 4KB @@ -31,15 +29,15 @@ def emit_header(self, **kwargs): assert (n % (8 * 4)) == 0, "n must be an integer multiple of the number of cores times " \ "the unrolling factor" - header += [format_scalar_definition('const uint32_t', 'n', n)] - header += [format_array_definition('double', 'x', x, alignment=self.BURST_ALIGNMENT, - section=kwargs['section'])] - header += [format_array_definition('double', 'y', y, alignment=self.BURST_ALIGNMENT, - section=kwargs['section'])] - header += [format_scalar_declaration('double', 'result', alignment=self.BURST_ALIGNMENT, - section=kwargs['section'])] - result_def = format_scalar_definition('double', 'g', g) - header += [format_ifdef_wrapper('BIST', result_def)] + header += [du.format_scalar_definition('const uint32_t', 'n', n)] + header += [du.format_array_definition('double', 'x', x, alignment=self.BURST_ALIGNMENT, + section=kwargs['section'])] + header += [du.format_array_definition('double', 'y', y, alignment=self.BURST_ALIGNMENT, + section=kwargs['section'])] + header += [du.format_scalar_declaration('double', 'result', alignment=self.BURST_ALIGNMENT, + section=kwargs['section'])] + result_def = du.format_scalar_definition('double', 'g', g) + header += [du.format_ifdef_wrapper('BIST', result_def)] header = '\n\n'.join(header) return header diff --git a/sw/blas/gemm/scripts/datagen.py b/sw/blas/gemm/scripts/datagen.py index 6361756040..4d6274aa2b 100755 --- a/sw/blas/gemm/scripts/datagen.py +++ b/sw/blas/gemm/scripts/datagen.py @@ -13,14 +13,12 @@ import sys import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import DataGen, format_array_declaration, \ - format_struct_definition, format_array_definition, format_ifdef_wrapper np.random.seed(42) -class GemmDataGen(DataGen): +class GemmDataGen(du.DataGen): # AXI splits bursts crossing 4KB address boundaries. To minimize # the occurrence of these splits the data should be aligned to 4KB @@ -125,18 +123,18 @@ def emit_header(self, **kwargs): b = b.flatten() c = c.flatten() - header += [format_array_declaration(ctype, a_uid, a.shape)] - header += [format_array_declaration(ctype, b_uid, b.shape)] - header += [format_array_declaration(ctype, c_uid, c.shape)] - header += [format_struct_definition('gemm_args_t', 'args', cfg)] - header += [format_array_definition(ctype, a_uid, a, + header += [du.format_array_declaration(ctype, a_uid, a.shape)] + header += [du.format_array_declaration(ctype, b_uid, b.shape)] + header += [du.format_array_declaration(ctype, c_uid, c.shape)] + header += [du.format_struct_definition('gemm_args_t', 'args', cfg)] + header += [du.format_array_definition(ctype, a_uid, a, section=kwargs['section'])] - header += [format_array_definition(ctype, b_uid, b, + header += [du.format_array_definition(ctype, b_uid, b, section=kwargs['section'])] - header += [format_array_definition(ctype, c_uid, c, + header += [du.format_array_definition(ctype, c_uid, c, section=kwargs['section'])] - result_def = format_array_definition(ctype, 'result', result.flatten()) - header += [format_ifdef_wrapper('BIST', result_def)] + result_def = du.format_array_definition(ctype, 'result', result.flatten()) + header += [du.format_ifdef_wrapper('BIST', result_def)] header = '\n\n'.join(header) return header diff --git a/sw/blas/syrk/scripts/datagen.py b/sw/blas/syrk/scripts/datagen.py index ad15222f36..3fb86644f3 100755 --- a/sw/blas/syrk/scripts/datagen.py +++ b/sw/blas/syrk/scripts/datagen.py @@ -8,13 +8,12 @@ import numpy as np import snitch.util.sim.data_utils as du -from snitch.util.sim.data_utils import format_array_definition, format_struct_definition, DataGen DOUBLE_BUFFER = True -class SyrkDataGen(DataGen): +class SyrkDataGen(du.DataGen): # Function pointers to alternative implementations FUNCPTRS = ["syrk_naive", "syrk_baseline", "syrk_opt"] @@ -73,9 +72,9 @@ def emit_header(self, **kwargs): 'funcptr': kwargs['funcptr'] } - header += [format_array_definition('double', A_uid, A)] - header += [format_array_definition('double', C_uid, C_in)] - header += [format_struct_definition('syrk_args_t', 'args', cfg)] + header += [du.format_array_definition('double', A_uid, A)] + header += [du.format_array_definition('double', C_uid, C_in)] + header += [du.format_struct_definition('syrk_args_t', 'args', cfg)] header = '\n\n'.join(header) return header