From 66d5d9cc726efc0d5a1f0afd5e0ad9f6dd0e8ab6 Mon Sep 17 00:00:00 2001 From: Alexander Date: Wed, 27 Nov 2024 12:01:51 +0400 Subject: [PATCH 1/2] Expand activation scaling to other submodels --- optimum/exporters/openvino/convert.py | 5 +++-- tests/openvino/test_export.py | 12 ++++++++++++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/optimum/exporters/openvino/convert.py b/optimum/exporters/openvino/convert.py index 18f2efa7a5..e0c4fe8bca 100644 --- a/optimum/exporters/openvino/convert.py +++ b/optimum/exporters/openvino/convert.py @@ -98,10 +98,11 @@ def _set_runtime_options( Tuple[Union["PreTrainedModel", "TFPreTrainedModel", "ModelMixin", "DiffusionPipeline"], "OnnxConfig"], ], task: str, + library_name: str, ): for model_name in models_and_export_configs.keys(): _, sub_export_config = models_and_export_configs[model_name] - if "vae_" in model_name or "text-generation" in task: + if "diffusers" in library_name or "text-generation" in task: sub_export_config.runtime_options = {"ACTIVATIONS_SCALE_FACTOR": "8.0"} @@ -754,7 +755,7 @@ def export_from_model( model.save_config(output) - _set_runtime_options(models_and_export_configs, task) + _set_runtime_options(models_and_export_configs, task, library_name) export_models( models_and_export_configs=models_and_export_configs, diff --git a/tests/openvino/test_export.py b/tests/openvino/test_export.py index 4c42f8a337..b2fb9a7b72 100644 --- a/tests/openvino/test_export.py +++ b/tests/openvino/test_export.py @@ -140,6 +140,18 @@ def _openvino_export( self.assertTrue( ov_model.vae_decoder.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"]) ) + if hasattr(ov_model, "text_encoder") and ov_model.text_encoder: + self.assertTrue( + ov_model.text_encoder.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"]) + ) + if hasattr(ov_model, "unet") and ov_model.unet: + self.assertTrue( + ov_model.unet.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"]) + ) + if hasattr(ov_model, "transformer") and ov_model.transformer: + self.assertTrue( + ov_model.transformer.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"]) + ) @parameterized.expand(SUPPORTED_ARCHITECTURES) def test_export(self, model_type: str): From adb4a16aca1dcb2d013070e34e533feb642d0ca4 Mon Sep 17 00:00:00 2001 From: Alexander Date: Wed, 27 Nov 2024 16:28:30 +0400 Subject: [PATCH 2/2] Applied comments --- tests/openvino/test_export.py | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/tests/openvino/test_export.py b/tests/openvino/test_export.py index b2fb9a7b72..80a45cab6e 100644 --- a/tests/openvino/test_export.py +++ b/tests/openvino/test_export.py @@ -144,6 +144,14 @@ def _openvino_export( self.assertTrue( ov_model.text_encoder.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"]) ) + if hasattr(ov_model, "text_encoder_2") and ov_model.text_encoder_2: + self.assertTrue( + ov_model.text_encoder_2.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"]) + ) + if hasattr(ov_model, "text_encoder_3") and ov_model.text_encoder_3: + self.assertTrue( + ov_model.text_encoder_3.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"]) + ) if hasattr(ov_model, "unet") and ov_model.unet: self.assertTrue( ov_model.unet.model.has_rt_info(["runtime_options", "ACTIVATIONS_SCALE_FACTOR"])