| # Copyright 2020 Google LLC |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # https://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| # Test coverage across backends for e2e tests is defined directly in the BUILD |
| # files. A coverage table generated from this file can be viewed here: |
| # https://google.github.io/iree/tf-e2e-coverage |
| # Updates made to test suite names should also be reflected here: |
| # https://github.com/google/iree/blob/main/scripts/update_e2e_coverage.py |
| |
| load( |
| "//bindings/python:build_defs.oss.bzl", |
| "INTREE_TENSORFLOW_PY_DEPS", |
| "NUMPY_DEPS", |
| "iree_py_binary", |
| ) |
| load( |
| "//integrations/tensorflow/e2e:iree_e2e_cartesian_product_test_suite.bzl", |
| "iree_e2e_cartesian_product_test_suite", |
| ) |
| load( |
| "//integrations/tensorflow/e2e:iree_e2e_test_suite.bzl", |
| "iree_e2e_test_suite", |
| ) |
| |
| package( |
| default_visibility = ["//visibility:public"], |
| features = ["layering_check"], |
| licenses = ["notice"], # Apache 2.0 |
| ) |
| |
| # @unused |
| DOC = """ |
| vision_model_test_manual is for manual testing of all keras vision models. |
| Test will run only manually with all parameters specified manually, for example: |
| bazel run -c opt integrations/tensorflow/e2e/keras:vision_model_test_manual -- \ |
| --target_backends=tf,iree_vmla,iree_llvmjit \ |
| --data=imagenet \ |
| --url=https://storage.googleapis.com/iree_models/ \ |
| --model=ResNet50 |
| |
| Command arguments description: |
| --target_backends: can be combination of these: tf,iree_vmla,iree_llvmjit |
| --data: can be 'imagenet' or 'cifar10'. |
| imagenet - input image size (1, 224, 224, 3) |
| cifar10 - input image size (1, 32, 32, 3) - it is used for quick tests |
| and needs pretrained weights, we pretrained models: ResNet50, MobileNet, MobileNetV2 |
| --include_top: Whether or not to include the final (top) layers of the model. |
| --url: we need it only for cifar10 models to load weights from https://storage.googleapis.com/iree_models/ |
| imagenet pretrained weights url is specified by keras |
| --model: supports ResNet50, MobileNet, MobileNetV2, ResNet101, ResNet152, |
| ResNet50V2, ResNet101V2, ResNet152V2, VGG16, VGG19, Xception, |
| InceptionV3, InceptionResNetV2, DenseNet121, DenseNet169, |
| DenseNet201, NASNetMobile, NASNetLarge |
| All above models works with 'imagenet' data sets. |
| ResNet50, MobileNet, MobileNetV2 work with both 'imagenet' and 'cifar10' data sets. |
| """ |
| |
| [ |
| iree_py_binary( |
| name = src.replace(".py", "_manual"), |
| srcs = [src], |
| main = src, |
| python_version = "PY3", |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| for src in glob( |
| ["*_test.py"], |
| exclude = ["keyword_spotting_streaming_test.py"], |
| ) |
| ] |
| |
| SPECIAL_CASES = [ |
| "keyword_spotting_streaming_test.py", |
| "vision_model_test.py", |
| ] |
| |
| TFLITE_FAILING = [] |
| |
| VMLA_FAILING = [] |
| |
| LLVM_FAILING = [] |
| |
| VULKAN_FAILING = [] |
| |
| TF_PASSING = glob( |
| ["*_test.py"], |
| exclude = SPECIAL_CASES, |
| ) |
| |
| TFLITE_PASSING = glob( |
| ["*_test.py"], |
| exclude = TFLITE_FAILING + SPECIAL_CASES, |
| ) |
| |
| VMLA_PASSING = glob( |
| ["*_test.py"], |
| exclude = VMLA_FAILING + SPECIAL_CASES, |
| ) |
| |
| LLVM_PASSING = glob( |
| ["*_test.py"], |
| exclude = LLVM_FAILING + SPECIAL_CASES, |
| ) |
| |
| VULKAN_PASSING = glob( |
| ["*_test.py"], |
| exclude = VULKAN_FAILING + SPECIAL_CASES, |
| ) |
| |
| iree_e2e_test_suite( |
| name = "keras_tests", |
| backends_to_srcs = { |
| "tf": TF_PASSING, |
| "tflite": TFLITE_PASSING, |
| "iree_vmla": VMLA_PASSING, |
| "iree_llvmjit": LLVM_PASSING, |
| "iree_vulkan": VULKAN_PASSING, |
| }, |
| reference_backend = "tf", |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| |
| iree_e2e_test_suite( |
| name = "keras_tests_failing", |
| backends_to_srcs = { |
| "tflite": TFLITE_FAILING, |
| "iree_vmla": VMLA_FAILING, |
| "iree_llvmjit": LLVM_FAILING, |
| "iree_vulkan": VULKAN_FAILING, |
| }, |
| reference_backend = "tf", |
| tags = [ |
| "failing", |
| "manual", |
| "nokokoro", |
| "notap", |
| ], |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| |
| iree_e2e_cartesian_product_test_suite( |
| name = "large_cifar10_tests", |
| size = "large", |
| srcs = ["vision_model_test.py"], |
| flags_to_values = { |
| "reference_backend": "tf", |
| "data": "cifar10", |
| "model": [ |
| # All models with runtime shorter than ResNet50. |
| "MobileNet", # Max: Vulkan 61.0s |
| "MobileNetV2", # Max: LLVM 96.3s |
| "ResNet50", # Max: LLVM 145.6s |
| "VGG16", # Max: LLVM 89.5s |
| "VGG19", # Max: LLVM 94.7s |
| ], |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| main = "vision_model_test.py", |
| tags = ["manual"], |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| |
| iree_e2e_cartesian_product_test_suite( |
| name = "enormous_cifar10_tests", |
| size = "enormous", |
| srcs = ["vision_model_test.py"], |
| failing_configurations = [ |
| { |
| # Failing on vmla with negative inputs. |
| "model": [ |
| "NASNetLarge", |
| "NASNetMobile", |
| ], |
| "target_backends": "iree_vmla", |
| }, |
| { |
| # Failing on llvm and vulkan: |
| "model": [ |
| "NASNetLarge", |
| "NASNetMobile", |
| "ResNet50V2", |
| "ResNet101V2", |
| "ResNet152V2", |
| ], |
| "target_backends": [ |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| ], |
| flags_to_values = { |
| "reference_backend": "tf", |
| "data": "cifar10", |
| "model": [ |
| "DenseNet121", |
| "DenseNet169", |
| "DenseNet201", |
| "NASNetLarge", |
| "NASNetMobile", |
| "ResNet50V2", |
| "ResNet101", |
| "ResNet101V2", |
| "ResNet152", |
| "ResNet152V2", |
| ], |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| main = "vision_model_test.py", |
| tags = [ |
| "guitar", |
| "manual", |
| "nokokoro", |
| "notap", |
| ], |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| |
| # 'non_hermetic' tests use real model weights to test numerical correctness. |
| iree_e2e_cartesian_product_test_suite( |
| name = "cifar10_non_hermetic_tests", |
| size = "large", |
| srcs = ["vision_model_test.py"], |
| flags_to_values = { |
| "reference_backend": "tf", |
| "data": "cifar10", |
| "url": "https://storage.googleapis.com/iree_models/", |
| "use_external_weights": True, |
| "model": [ |
| "MobileNet", |
| "MobileNetV2", |
| "ResNet50", |
| ], |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| main = "vision_model_test.py", |
| tags = [ |
| "external", |
| "guitar", |
| "manual", |
| "no-remote", |
| "nokokoro", |
| "notap", |
| ], |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| |
| # 'non_hermetic' tests use real model weights to test numerical correctness. |
| iree_e2e_cartesian_product_test_suite( |
| name = "imagenet_non_hermetic_tests", |
| size = "enormous", |
| srcs = ["vision_model_test.py"], |
| failing_configurations = [ |
| { |
| # Failing on vmla with negative inputs. |
| "model": [ |
| "NASNetLarge", |
| "NASNetMobile", |
| ], |
| "target_backends": "iree_vmla", |
| }, |
| { |
| # Failing vulkan: |
| "model": [ |
| "InceptionResNetV2", |
| "InceptionV3", |
| ], |
| "target_backends": [ |
| "iree_vulkan", |
| ], |
| }, |
| { |
| # Failing llvm and vulkan: |
| "model": [ |
| "NASNetLarge", |
| "NASNetMobile", |
| "ResNet50V2", |
| "ResNet101V2", |
| "ResNet152V2", |
| "Xception", |
| ], |
| "target_backends": [ |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| ], |
| flags_to_values = { |
| "reference_backend": "tf", |
| "data": "imagenet", |
| "use_external_weights": True, |
| "model": [ |
| "DenseNet121", |
| "DenseNet169", |
| "DenseNet201", |
| "InceptionResNetV2", |
| "InceptionV3", |
| "MobileNet", |
| "MobileNetV2", |
| "NASNetLarge", |
| "NASNetMobile", |
| "ResNet50", |
| "ResNet50V2", |
| "ResNet101", |
| "ResNet101V2", |
| "ResNet152", |
| "ResNet152V2", |
| "VGG16", |
| "VGG19", |
| "Xception", |
| ], |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| main = "vision_model_test.py", |
| tags = [ |
| "external", |
| "guitar", |
| "manual", |
| "nokokoro", |
| "notap", |
| ], |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| |
| # It is used to produce weights for keras vision models with input image size |
| # 32x32. These models are not optimized for accuracy or latency (they are for |
| # debugging only). They have the same neural net topology with keras vision |
| # models trained on imagenet data sets |
| iree_py_binary( |
| name = "train_vision_models_on_cifar", |
| srcs = ["train_vision_models_on_cifar.py"], |
| python_version = "PY3", |
| srcs_version = "PY2AND3", |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| ], |
| ) |
| |
| # Keyword Spotting Tests: |
| KEYWORD_SPOTTING_MODELS = [ |
| "svdf", |
| "svdf_resnet", |
| "ds_cnn", |
| "gru", |
| "lstm", |
| "cnn_stride", |
| "cnn", |
| "tc_resnet", |
| "crnn", |
| "dnn", |
| "att_rnn", |
| "att_mh_rnn", |
| "mobilenet", |
| "mobilenet_v2", |
| "xception", |
| "inception", |
| "inception_resnet", |
| "ds_tc_resnet", |
| ] |
| |
| NON_STREAMING_KEYWORD_SPOTTING_MODELS = [ |
| "att_mh_rnn", |
| "att_rnn", |
| "ds_cnn", |
| "inception", |
| "inception_resnet", |
| "mobilenet", |
| "mobilenet_v2", |
| "svdf_resnet", |
| "tc_resnet", |
| "xception", |
| ] |
| |
| iree_e2e_cartesian_product_test_suite( |
| name = "keyword_spotting_tests", |
| srcs = ["keyword_spotting_streaming_test.py"], |
| failing_configurations = [ |
| { |
| # Failing on IREE: |
| "model": [ |
| "att_mh_rnn", # b/147824465 |
| "att_rnn", # b/147824465 |
| "crnn", # b/162067867 |
| "ds_tc_resnet", |
| "gru", # b/162067867 |
| "lstm", # b/162067867 |
| ], |
| "target_backends": [ |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| ], |
| flags_to_values = { |
| "reference_backend": "tf", |
| "mode": "non_streaming", |
| "model": KEYWORD_SPOTTING_MODELS, |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| main = "keyword_spotting_streaming_test.py", |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| "@kws_streaming//:models_lib", |
| "@kws_streaming//:train_lib", |
| ], |
| ) |
| |
| iree_e2e_cartesian_product_test_suite( |
| name = "keyword_spotting_internal_streaming_tests", |
| srcs = ["keyword_spotting_streaming_test.py"], |
| failing_configurations = [ |
| { |
| # TFLite cannot compile variables. |
| "target_backends": "tflite", |
| }, |
| { |
| # These models do not currently support streaming. |
| "model": NON_STREAMING_KEYWORD_SPOTTING_MODELS, |
| }, |
| { |
| # Failing on IREE: |
| "model": "ds_tc_resnet", |
| "target_backends": [ |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| ], |
| flags_to_values = { |
| "reference_backend": "tf", |
| "mode": "internal_streaming", |
| "model": KEYWORD_SPOTTING_MODELS, |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| main = "keyword_spotting_streaming_test.py", |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| "@kws_streaming//:models_lib", |
| "@kws_streaming//:train_lib", |
| ], |
| ) |
| |
| iree_e2e_cartesian_product_test_suite( |
| name = "keyword_spotting_external_streaming_tests", |
| srcs = ["keyword_spotting_streaming_test.py"], |
| failing_configurations = [ |
| { |
| # A bug in keras causes the external steraming conversion to fail |
| # when TensorFlow 2.x is used. |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| { |
| # These models do not currently support streaming. |
| "model": NON_STREAMING_KEYWORD_SPOTTING_MODELS, |
| }, |
| ], |
| flags_to_values = { |
| "reference_backend": "tf", |
| "mode": "external_streaming", |
| "model": KEYWORD_SPOTTING_MODELS, |
| "target_backends": [ |
| "tf", |
| "tflite", |
| "iree_vmla", |
| "iree_llvmjit", |
| "iree_vulkan", |
| ], |
| }, |
| main = "keyword_spotting_streaming_test.py", |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| "@kws_streaming//:models_lib", |
| "@kws_streaming//:train_lib", |
| ], |
| ) |
| |
| iree_py_binary( |
| name = "keyword_spotting_streaming_test_manual", |
| srcs = ["keyword_spotting_streaming_test.py"], |
| main = "keyword_spotting_streaming_test.py", |
| python_version = "PY3", |
| deps = INTREE_TENSORFLOW_PY_DEPS + NUMPY_DEPS + [ |
| "//integrations/tensorflow/bindings/python/pyiree/tf/support", |
| "@kws_streaming//:models_lib", |
| "@kws_streaming//:train_lib", |
| ], |
| ) |