From c3e163c77fe75faf27ace7153bd9507d7c1ac6da Mon Sep 17 00:00:00 2001 From: Yaman Umuroglu <maltanar@gmail.com> Date: Wed, 20 May 2020 00:44:35 +0100 Subject: [PATCH] [Core] add canonical data layouts in own file --- src/finn/core/data_layout.py | 34 +++++++++++++++++++++++++++++++++ tests/core/test_modelwrapper.py | 3 ++- 2 files changed, 36 insertions(+), 1 deletion(-) create mode 100644 src/finn/core/data_layout.py diff --git a/src/finn/core/data_layout.py b/src/finn/core/data_layout.py new file mode 100644 index 000000000..75751fcc7 --- /dev/null +++ b/src/finn/core/data_layout.py @@ -0,0 +1,34 @@ +# Copyright (c) 2020, Xilinx +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are met: +# +# * Redistributions of source code must retain the above copyright notice, this +# list of conditions and the following disclaimer. +# +# * Redistributions in binary form must reproduce the above copyright notice, +# this list of conditions and the following disclaimer in the documentation +# and/or other materials provided with the distribution. +# +# * Neither the name of FINN nor the names of its +# contributors may be used to endorse or promote products derived from +# this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +# predefined lists of strings to have a cannonical way of expresing data layout +# annotations + +NHWC = ["N", "H", "W", "C"] +NCHW = ["N", "C", "H", "W"] +NC = ["N", "C"] diff --git a/tests/core/test_modelwrapper.py b/tests/core/test_modelwrapper.py index 66e1ff43d..c04deb616 100644 --- a/tests/core/test_modelwrapper.py +++ b/tests/core/test_modelwrapper.py @@ -31,6 +31,7 @@ import onnx from collections import Counter import brevitas.onnx as bo import numpy as np +import finn.core.data_layout as data_layout from finn.core.modelwrapper import ModelWrapper from finn.util.test import get_test_model_trained @@ -69,7 +70,7 @@ def test_modelwrapper(): assert out_prod.op_type == "MultiThreshold" inp_layout = model.get_tensor_layout(inp_name) assert inp_layout is None - inp_layout = ["N", "C", "H", "W"] + inp_layout = data_layout.NCHW model.set_tensor_layout(inp_name, inp_layout) assert model.get_tensor_layout(inp_name) == inp_layout os.remove(export_onnx_path) -- GitLab