2023-01-19 15:47:43 -05:00
|
|
|
import argparse
|
|
|
|
import os
|
|
|
|
import torch
|
|
|
|
from safetensors.torch import load_file
|
|
|
|
|
|
|
|
|
|
|
|
def main(file):
|
|
|
|
print(f"loading: {file}")
|
|
|
|
if os.path.splitext(file)[1] == '.safetensors':
|
|
|
|
sd = load_file(file)
|
|
|
|
else:
|
|
|
|
sd = torch.load(file, map_location='cpu')
|
|
|
|
|
|
|
|
values = []
|
|
|
|
|
|
|
|
keys = list(sd.keys())
|
|
|
|
for key in keys:
|
2023-01-22 10:18:00 -05:00
|
|
|
if 'lora_up' in key or 'lora_down' in key:
|
2023-01-19 15:47:43 -05:00
|
|
|
values.append((key, sd[key]))
|
2023-01-22 10:18:00 -05:00
|
|
|
print(f"number of LoRA modules: {len(values)}")
|
2023-01-19 15:47:43 -05:00
|
|
|
|
|
|
|
for key, value in values:
|
2023-01-22 10:18:00 -05:00
|
|
|
value = value.to(torch.float32)
|
2023-03-09 11:06:59 -05:00
|
|
|
print(f"{key},{str(tuple(value.size())).replace(', ', '-')},{torch.mean(torch.abs(value))},{torch.min(torch.abs(value))}")
|
2023-01-19 15:47:43 -05:00
|
|
|
|
|
|
|
|
2023-03-21 20:20:57 -04:00
|
|
|
def setup_parser() -> argparse.ArgumentParser:
|
2023-01-19 15:47:43 -05:00
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument("file", type=str, help="model file to check / 重みを確認するモデルファイル")
|
2023-03-21 20:20:57 -04:00
|
|
|
|
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
parser = setup_parser()
|
|
|
|
|
2023-01-19 15:47:43 -05:00
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
main(args.file)
|