Use GPU for loading safetensors, disable export

This commit is contained in:
Tim Patton 2022-11-21 16:40:18 -05:00
parent e134b74ce9
commit 210cb4c128
2 changed files with 5 additions and 3 deletions

View file

@ -147,8 +147,9 @@ def torch_load(model_filename, model_info, map_override=None):
map_override=shared.weight_load_location if not map_override else map_override map_override=shared.weight_load_location if not map_override else map_override
if(checkpoint_types[model_info.exttype] == 'safetensors'): if(checkpoint_types[model_info.exttype] == 'safetensors'):
# safely load weights # safely load weights
# TODO: safetensors supports zero copy fast load to gpu, see issue #684 # TODO: safetensors supports zero copy fast load to gpu, see issue #684.
return load_file(model_filename, device=map_override) # GPU only for now, see https://github.com/huggingface/safetensors/issues/95
return load_file(model_filename, device='cuda')
else: else:
return torch.load(model_filename, map_location=map_override) return torch.load(model_filename, map_location=map_override)

View file

@ -1187,7 +1187,8 @@ def create_ui(wrap_gradio_gpu_call):
interp_amount = gr.Slider(minimum=0.0, maximum=1.0, step=0.05, label='Multiplier (M) - set to 0 to get model A', value=0.3) interp_amount = gr.Slider(minimum=0.0, maximum=1.0, step=0.05, label='Multiplier (M) - set to 0 to get model A', value=0.3)
interp_method = gr.Radio(choices=["Weighted sum", "Add difference"], value="Weighted sum", label="Interpolation Method") interp_method = gr.Radio(choices=["Weighted sum", "Add difference"], value="Weighted sum", label="Interpolation Method")
save_as_half = gr.Checkbox(value=False, label="Save as float16") save_as_half = gr.Checkbox(value=False, label="Save as float16")
save_as_safetensors = gr.Checkbox(value=False, label="Save as safetensors format") # invisible until feature can be verified
save_as_safetensors = gr.Checkbox(value=False, label="Save as safetensors format", visible=False)
modelmerger_merge = gr.Button(elem_id="modelmerger_merge", label="Merge", variant='primary') modelmerger_merge = gr.Button(elem_id="modelmerger_merge", label="Merge", variant='primary')
with gr.Column(variant='panel'): with gr.Column(variant='panel'):