From a432102fc2354d991b72053d82e30ab7c6d790fa Mon Sep 17 00:00:00 2001 From: Ekaterina Aidova Date: Thu, 24 Oct 2024 12:01:53 +0400 Subject: [PATCH] restore original model_index.json after save_pretrained call (#961) --- optimum/intel/openvino/modeling_diffusion.py | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/optimum/intel/openvino/modeling_diffusion.py b/optimum/intel/openvino/modeling_diffusion.py index 68dc31bc90..22e8bf314f 100644 --- a/optimum/intel/openvino/modeling_diffusion.py +++ b/optimum/intel/openvino/modeling_diffusion.py @@ -259,6 +259,26 @@ def _save_pretrained(self, save_directory: Union[str, Path]): self._save_openvino_config(save_directory) + def _save_config(self, save_directory): + """ + Saves a model configuration into a directory, so that it can be re-loaded using the + [`from_pretrained`] class method. + """ + model_dir = ( + self.model_save_dir + if not isinstance(self.model_save_dir, TemporaryDirectory) + else self.model_save_dir.name + ) + save_dir = Path(save_directory) + original_config = Path(model_dir) / self.config_name + if original_config.exists(): + if not save_dir.exists(): + save_dir.mkdir(parents=True) + + shutil.copy(original_config, save_dir) + else: + self.config.save_pretrained(save_dir) + @classmethod def _from_pretrained( cls,