|  | # 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 \ | 
|  | --data=imagenet \ | 
|  | --url=https://storage.googleapis.com/iree_models/ \ | 
|  | --model=ResNet50 | 
|  |  | 
|  | Command arguments description: | 
|  | --target_backends: can be combination of these: tf,iree_vmla | 
|  | --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", | 
|  | ], | 
|  | ) |