Coverage for hyper_parallel / core / checkpoint / saver.py: 91%
11 statements
« prev ^ index » next coverage.py v7.13.1, created at 2026-03-01 07:33 +0800
« prev ^ index » next coverage.py v7.13.1, created at 2026-03-01 07:33 +0800
1# Copyright 2026 Huawei Technologies Co., Ltd
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14# ============================================================================
15"""Save checkpoint to safetensors."""
16from pathlib import Path
17from typing import Union
19from hyper_parallel.core.checkpoint.util import check_path, has_valid_filename
20from hyper_parallel.platform import get_platform
22platform = get_platform()
25def save_checkpoint(save_obj, file_path: Union[Path, str]) -> None:
26 """
27 Save model checkpoint parameters to a file using safetensors format.
29 Args:
30 save_obj (Any): Net instance containing parameters to save. Can be a Cell or a Module.
31 file_path (Union[Path, str]): The path or file to save checkpoint parameters. Path must contain the file name
32 with extension.
33 """
34 file_path_obj = Path(file_path) if isinstance(file_path, str) else file_path
35 if not has_valid_filename(file_path_obj):
36 raise ValueError(f"Saver file_path should contains valid filename but get: {file_path}")
38 # Create parent directory
39 check_path(file_path_obj.parent)
40 platform.save_checkpoint(save_obj, str(file_path_obj))