Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Diffusion Policy #53

Open
zxfever opened this issue Jun 26, 2024 · 10 comments
Open

Diffusion Policy #53

zxfever opened this issue Jun 26, 2024 · 10 comments

Comments

@zxfever
Copy link

zxfever commented Jun 26, 2024

I train the model with the --policy_class Diffusion parameters,but the error occurred:

Traceback (most recent call last):
  File "imitate_episodes.py", line 682, in <module>
    main(vars(parser.parse_args()))
  File "imitate_episodes.py", line 187, in main
    best_ckpt_info = train_bc(train_dataloader, val_dataloader, config)
  File "imitate_episodes.py", line 562, in train_bc
    policy = make_policy(policy_class, policy_config)
  File "imitate_episodes.py", line 203, in make_policy
    policy = DiffusionPolicy(policy_config)
  File "/home/lenovo/code_ws_python/act-plus-plus/policy.py", line 72, in __init__
    ema = EMAModel(model=nets, power=self.ema_power)
TypeError: __init__() missing 1 required positional argument: 'parameters'

Can you provide some help?

@barsm42
Copy link

barsm42 commented Jul 8, 2024

Hello,
When I changed the line as below

ema = EMAModel(parameters=nets, power=self.ema_power)

it started to train. However, during the inference I get another error. I will ask a question about it later.

@QueirosJustin
Copy link

@barsm42 have you found a solution to this? I am searching for one myself, I encountered the same problem

@barsm42
Copy link

barsm42 commented Jul 16, 2024

@barsm42 have you found a solution to this? I am searching for one myself, I encountered the same problem

Not yet, unfortunately.

@QueirosJustin
Copy link

QueirosJustin commented Jul 16, 2024

@barsm42 I found it, it works but the parameters need to be set differently. try this:

python3 imitate_episodes.py
--task_name aloha_mobile_wipe_wine
--ckpt_dir /scr/tonyzhao/train_logs/wipe_wine_diffusion_seed0
--policy_class Diffusion --chunk_size 32
--batch_size 32 --lr 1e-4 --seed 0
--num_steps 100000 --eval_every 100000 --validate_every 10000 --save_every 10000

The problem is that if it's evaluating the policy for every 500, 2000 or another small stepnumber, then diffusion policy isn't working well and the simulation crashed through invalid physics state. Therefore, it needs to be higher. I achieved the best result for the command above, if you use eval_every 6000 and onscreen_render you can directly see the improvements after 6000 steps instead of 100 000 steps

@barsm42
Copy link

barsm42 commented Jul 16, 2024

@QueirosJustin
Thank you for your reply.

In my code, I dont have --eval_every 100000 --validate_every 10000 --save_every 10000 args.

imitate_episodes.py gave error for those arguments.

@QueirosJustin
Copy link

can you post a screenshot? Those arguments are definitely part of the imitate_episode.py script, look at this section "def main(args):
set_seed(1)
# command line parameters
is_eval = args['eval']
ckpt_dir = args['ckpt_dir']
policy_class = args['policy_class']
onscreen_render = args['onscreen_render']
task_name = args['task_name']
batch_size_train = args['batch_size']
batch_size_val = args['batch_size']
num_steps = args['num_steps']
eval_every = args['eval_every']
validate_every = args['validate_every']
save_every = args['save_every']
resume_ckpt_path = args['resume_ckpt_path']"

@barsm42
Copy link

barsm42 commented Jul 16, 2024

I don't have these four arguments. I searched with Ctrl+F in the script, there are not any variables as eval_every and the rest.

eval_every = args['eval_every']
validate_every = args['validate_every']
save_every = args['save_every']
resume_ckpt_path = args['resume_ckpt_path']"

@barsm42
Copy link

barsm42 commented Jul 24, 2024

@QueirosJustin,
What should I do for that arguments?

@huyquoctrinh
Copy link

huyquoctrinh commented Dec 24, 2024

Hi guys, I fixed it by using the EMAModel class from Diffusion Policy, it will help you to solve this issue!

@junhui1997
Copy link

check the diffuser version, the correct version should be : pip install diffusers==0.11.1

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants