From bc88e4285496bbbb974d389d7e1080269cb5e315 Mon Sep 17 00:00:00 2001 From: eaidova Date: Wed, 23 Oct 2024 18:31:15 +0400 Subject: [PATCH] restore original model_index.json after save_pretrained call --- 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..d219459b38 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_directory) + else: + self.config.save_pretrained(save_directory) + @classmethod def _from_pretrained( cls,