RuntimeError: Placeholder storage has not been allocated on MPS device!

I am trying to run the basic fine-tuning a pretrained model code from the huggingface page (Fine-tune a pretrained model) and am getting a runtime error:

RuntimeError: Placeholder storage has not been allocated on MPS device!

I know this is something to do with the device Pytorch is running on but I have no idea how to solve it.

Any help is appreciated!

1 Like

training_args = TrainingArguments(output_dir="test_trainer", use_mps_device=True)

Fixed the problem for me.

6 Likes

I have tried this before, but the model outputs a bunch of errors.

Any help on this?

Thanks! this worked for me as well. I think it has an issue with the pytorch nightly build for apple silicon

This worked for me, too. I was finishing the tutorial series to work out the development environment for tomorrow’s work and hit that MPS issue. @pmoraes solution solved it.

Context:
Apple M1 MBP
PyTorch in a conda (MiniForge3) environment

It took nearly 9 minutes over three epochs, and I used the small training and test datasets. The eval loss dropped each epoch, and accuracy increased. It worked.

Where this goes?

2 Likes

I’m having exact same problem but - while running ControlNet via Automatic11111, I wish I knew where to add this line

Would also really love some help resolving the same issue

using :

Automatic 1111 + ControlNet v1.1.410 + Lineart feature.

I have some understanding of editing code but not a programmer ( so please tell us where to paste the code a) which file - which directory etc - or is it a command via terminal?


The error appears when trying to generate an image from lineart __ ( ControlNet ) on a pertained model -

Mac: RuntimeError: Placeholder storage has not been allocated on MPS device __

Please explain in lamen terms - what piece of code needs to be replaced and where. I’ve seen other posts but they all relate to M1 Macs. If this issue has been resolved elsewhere for an Intel based Mac please share the link.

Thanks in Advance

1 Like

try edit COMMANDLINE_ARGS=“–skip-torch-cuda-test --no-half --use-cpu all” to COMMANDLINE_ARGS=“–skip-torch-cuda-test --no-half”

fixed it with: device=“mps”

Can someone please do a YouTube video on this? I’m using Pinokio controllnet is saying the same thing. “placeholder storage has not been allocated on mps device!”

this is worked for me

if torch.backends.mps.is_built():
    device = torch.device("mps")  # for mac use

#test prediction

text='//module 2 to 1 mux'

input_ids = tokenizer(text, return_tensors="pt").input_ids.to(device)

generated_ids = model.generate(input_ids, max_length=128).to(device)

print(tokenizer.decode(generated_ids[0], skip_special_tokens=True))

I am still facing the issue and nothing seems to work. My device is apple M1 chip.
Is this the problem with all apple m1chips devices?

this is my error.
…

[2262]no_grad_embedding_renorm(weight, input, max_norm, norm_type) → 2264 return torch.embedding(weight, input, padding_idx, scale_grad_by_freq, sparse) RuntimeError: Placeholder storage has not been allocated on MPS device!

Can u share the posts where it worked for apple M1, cant seem to find one and i am facing the same error

@pdevanshi

Also faced the same issue, for endless hours

Got it to work by passing in no_cuda=true

believe it has something to do with how Trainer handles the models and tensors
Because my model reverts back to cpu after initialising the Trainer class though being preded by model.to(torch.device(“mps”))

By passing in the the no_cuda, it uses cpu in all scenarios & avoids the mps saga

training_args = TrainingArguments(
        output_dir='results',
        overwrite_output_dir=True,
        num_train_epochs=1,
        per_device_train_batch_size=1,
        save_steps=10_000,
        save_total_limit=2,
        no_cuda=True
    )
4 Likes

Thank you very much, I will try this

it’s a bug,
line 2157 training_args.py
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu" )
it changed to CPU even though it was mps

3 Likes

Thank you that solved the issue for me, and enabled me to train using the apple sillicone GPU by changing the last part of the line to “mps” (instead of “cpu”)

1 Like