diff options
author | Dmitrii Agibov <dmitrii.agibov@arm.com> | 2022-11-18 17:21:09 +0000 |
---|---|---|
committer | Dmitrii Agibov <dmitrii.agibov@arm.com> | 2022-11-29 14:44:13 +0000 |
commit | 6a88ee5315b4ce5b023370c1e55e48bf9f2b6f67 (patch) | |
tree | 88edabf90228724f4fe2944b0ab23859d824a880 /tests/test_target_cortex_a_operators.py | |
parent | a34163c9d9a5cc0416bcaea2ebf8383bda9d505c (diff) | |
download | mlia-6a88ee5315b4ce5b023370c1e55e48bf9f2b6f67.tar.gz |
Rename modules
- Rename module "mlia.devices" into "mlia.target"
- Rename module "mlia.target.ethosu" into "mlia.target.ethos_u"
- Rename module "mlia.target.cortexa" into "mlia.target.cortex_a"
- Rename and update tests
Change-Id: I6dca7c8646d881f739fb6b5914d1cc7e45e63dc2
Diffstat (limited to 'tests/test_target_cortex_a_operators.py')
-rw-r--r-- | tests/test_target_cortex_a_operators.py | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/tests/test_target_cortex_a_operators.py b/tests/test_target_cortex_a_operators.py new file mode 100644 index 0000000..94eb890 --- /dev/null +++ b/tests/test_target_cortex_a_operators.py @@ -0,0 +1,73 @@ +# SPDX-FileCopyrightText: Copyright 2022, Arm Limited and/or its affiliates. +# SPDX-License-Identifier: Apache-2.0 +"""Tests for Cortex-A operator compatibility.""" +from pathlib import Path + +import pytest +import tensorflow as tf + +from mlia.nn.tensorflow.tflite_graph import TFL_OP +from mlia.nn.tensorflow.utils import convert_to_tflite +from mlia.target.cortex_a import operator_compatibility as op_compat +from mlia.target.cortex_a.operators import CortexACompatibilityInfo +from mlia.target.cortex_a.operators import get_cortex_a_compatibility_info +from mlia.target.cortex_a.operators import Operator + + +def test_op_compat_data() -> None: + """Make sure all data contains the necessary items.""" + builtin_tfl_ops = {op.name for op in TFL_OP} + for data in [op_compat.ARMNN_TFLITE_DELEGATE]: + assert "metadata" in data + assert "backend" in data["metadata"] + assert "version" in data["metadata"] + assert "builtin_ops" in data + for comp in data["builtin_ops"]: + assert comp in builtin_tfl_ops + assert "custom_ops" in data + + +def check_get_cortex_a_compatibility_info( + model_path: Path, + expected_success: bool, +) -> None: + """Check the function 'get_cortex_a_compatibility_info'.""" + compat_info = get_cortex_a_compatibility_info(model_path) + assert isinstance(compat_info, CortexACompatibilityInfo) + assert expected_success == compat_info.cortex_a_compatible + assert compat_info.operators + for oper in compat_info.operators: + assert oper.name + assert oper.location + assert oper.support_type in Operator.SupportType + + +def test_get_cortex_a_compatibility_info_compatible( + test_tflite_model: Path, +) -> None: + """Test a fully compatible TensorFlow Lite model.""" + check_get_cortex_a_compatibility_info(test_tflite_model, expected_success=True) + + +def test_get_cortex_a_compatibility_info_not_compatible( + monkeypatch: pytest.MonkeyPatch, +) -> None: + """Construct and test a NOT fully compatible TensorFlow Lite model.""" + keras_model = tf.keras.Sequential( + [ + tf.keras.Input(shape=(28, 28, 1), batch_size=1, name="input"), + tf.keras.layers.Conv2D( + filters=12, kernel_size=(3, 3), activation="softmax", name="conv1" + ), + tf.keras.layers.LeakyReLU(), + ] + ) + keras_model.compile(optimizer="sgd", loss="mean_squared_error") + tflite_model = convert_to_tflite(keras_model, quantized=False) + + monkeypatch.setattr( + "mlia.nn.tensorflow.tflite_graph.load_tflite", lambda _p: tflite_model + ) + check_get_cortex_a_compatibility_info( + Path("NOT_USED_BECAUSE_OF_MOCKING"), expected_success=False + ) |