wsagi commited on
Commit
186b5a1
·
verified ·
1 Parent(s): 11787e1

Add files using upload-large-folder tool

Browse files
README.md ADDED
@@ -0,0 +1,111 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ license: apache-2.0
3
+ library_name: lerobot
4
+ pipeline_tag: robotics
5
+ tags:
6
+ - smolvla
7
+ - lerobot
8
+ - so101
9
+ - leisaac
10
+ - pick-orange
11
+ - isaac-sim
12
+ datasets:
13
+ - LightwheelAI/leisaac-pick-orange
14
+ language:
15
+ - en
16
+ base_model: lerobot/smolvla_base
17
+ ---
18
+
19
+ # SmolVLA2-PickOrange
20
+
21
+ 针对 [LeIsaac SO-101 PickOrange](https://github.com/LightwheelAI/leisaac) 任务 LoRA-free 微调的 [SmolVLA](https://huggingface.co/lerobot/smolvla_base) 策略 — 自训 30k step。
22
+ _A fine-tuned [SmolVLA](https://huggingface.co/lerobot/smolvla_base) policy on the [LeIsaac SO-101 PickOrange](https://github.com/LightwheelAI/leisaac) task, 30k steps full-parameter from `lerobot/smolvla_base`._
23
+
24
+ **🔗 项目仓库 / Project repos**:
25
+ - [vitorcen/isaaclab-experience](https://github.com/vitorcen/isaaclab-experience) — Isaac Lab + LeIsaac 多策略横评(parent project)— 含 7-baseline benchmark
26
+ - [vitorcen/LeIsaac-Training](https://github.com/vitorcen/LeIsaac-Training) — LeIsaac fork(训练脚本 + 设计文档 / training scripts + design docs)
27
+
28
+ > **命名注意 / Naming note**:仓库名是 `SmolVLA2-PickOrange` 但 `config.type=smolvla`(v1,SmolVLM2-500M-Video-Instruct backbone + Action Expert)。LeRobot 当时没把 `smolvla2`(带 LoRA on)merge 到 main,所以这里仍是 v1。命名是 dir 命名误称延续。
29
+ > _Despite the repo name, `config.type=smolvla` (v1). LeRobot's smolvla2 (with LoRA enabled) hadn't merged to main at training time; the "2" is carried over from the local output directory naming._
30
+
31
+ ## TL;DR
32
+
33
+ - **任务 / Task**:`Pick up the orange and place it on the plate` — SO-101 单臂依次夹起 3 颗橙子并放盘子。
34
+ - **数据集 / Dataset**:[`LightwheelAI/leisaac-pick-orange`](https://huggingface.co/datasets/LightwheelAI/leisaac-pick-orange) — 60 episode 遥操示范,30 fps,dual-cam 480×640。
35
+ - **架构 / Architecture**:SmolVLA v1(450M),SmolVLM2-500M-Video-Instruct backbone + Action Expert,`chunk_size=50`。
36
+ - **训练 / Training**:full-param 微调(无 LoRA),batch=8 / lr=1e-4 / 30k step / pyav video backend,~14h on RTX 4090。
37
+ - **评测 / Eval**(Isaac Sim 5.1,3 round × 3 颗 = 9 颗):
38
+ - **strict 1/3 rounds,5/9 oranges**(partial credit by sticky `put_orange_to_plate`)
39
+ - 详见 [`vitorcen/isaaclab-experience`](https://github.com/vitorcen/isaaclab-experience) 的 `LeIsaac/README.md` benchmark section
40
+ - **⚠️ 推理 inference 配置**:
41
+ - `policy_action_horizon=50`(= chunk_size,全 chunk receding window)
42
+ - LeRobot async server 端 `--policy_checkpoint_path=wsagi/SmolVLA2-PickOrange`
43
+ - `step_hz=30` 匹配 dataset
44
+
45
+ ## 模型亮点
46
+ _Highlights_
47
+
48
+ - SmolVLA 全参微调在 60 ep 小数据上**部分能学到**,1/3 round 自然 success(3/3 oranges in 158s)— 比第三方 [`edge-inference/smolvla-so101-pick-orange`](https://huggingface.co/edge-inference/smolvla-so101-pick-orange) 的 0/3 强。
49
+ - 但 round 间方差大(episode 2 = 0/3,episode 3 = 2/3)— **60 ep × 30k step 仍欠拟合**。
50
+ - 大参数 VLM-based policy 在低数据 regime 下不如专精 visuomotor (ACT 80M) — 与原 SmolVLA 论文低数据 finding 一致。
51
+
52
+ ## 训练配方
53
+ _Training recipe_
54
+
55
+ | 项 / Item | 值 / Value |
56
+ |---|---|
57
+ | Dataset | `LightwheelAI/leisaac-pick-orange` (60 ep, dual-cam 480×640 RGB + 6 DOF state, 30 Hz) |
58
+ | Policy | `smolvla` (LeRobot 实现) |
59
+ | Backbone | `HuggingFaceTB/SmolVLM2-500M-Video-Instruct` + Action Expert |
60
+ | `chunk_size` / `n_action_steps` | 50 / 50 |
61
+ | Batch size | 8 (full-param, no LoRA) |
62
+ | Optimizer | AdamW, lr=1e-4 |
63
+ | Steps | 30000 (~14h on 4090) |
64
+ | `video_backend` | `pyav`(torchcodec 长跑 segfault) |
65
+ | Image augmentation | 无 |
66
+ | Train expert only | False(全参数) |
67
+
68
+ > **🚨 schema-free base 关键 fix**:训练前必须用 [`prepare_base.sh`](https://github.com/vitorcen/LeIsaac-Training/blob/main/scripts/training/smolvla/prepare_base.sh) 剥光 `lerobot/smolvla_base` 自带的 `input_features` / `empty_cameras`(默认 `camera1/2/3 @ 256×256` 会污染微调路径),否则训练时 schema 不对齐 → forward 报 KeyError 或 silent 训坏。详见 [`smolvla2_finetune_pick_orange.html`](https://github.com/vitorcen/LeIsaac-Training/blob/main/docs/finetune/smolvla2_finetune_pick_orange.html)。
69
+
70
+ ## 推理 inference
71
+
72
+ ### 通过 LeIsaac eval harness 跑(推荐 / recommended)
73
+
74
+ ```bash
75
+ # 1. 启 LeRobot async policy server
76
+ bash server/start_server.sh --lerobot-only
77
+
78
+ # 2. 跑 LeIsaac PickOrange eval
79
+ DISPLAY=:0 python -u LeIsaac/scripts/evaluation/policy_inference.py \
80
+ --task=LeIsaac-SO101-PickOrange-v0 \
81
+ --eval_rounds=3 --episode_length_s=120 --step_hz=30 \
82
+ --policy_type=lerobot-smolvla \
83
+ --policy_host=127.0.0.1 --policy_port=8080 \
84
+ --policy_action_horizon=50 \
85
+ --policy_checkpoint_path=wsagi/SmolVLA2-PickOrange \
86
+ --policy_language_instruction='Pick up the orange and place it on the plate' \
87
+ --device=cuda --enable_cameras
88
+ ```
89
+
90
+ ### 直接用 LeRobot
91
+
92
+ ```python
93
+ from lerobot.policies.smolvla.modeling_smolvla import SmolVLAPolicy
94
+ policy = SmolVLAPolicy.from_pretrained("wsagi/SmolVLA2-PickOrange")
95
+ # 见 LeRobot 文档
96
+ ```
97
+
98
+ ## 评测细节(Isaac Sim 5.1,2026-05-18 snapshot)
99
+ _Evaluation details_
100
+
101
+ | Round | 🍊 placed | duration | mode | notes |
102
+ |---|---|---|---|---|
103
+ | 1 | 3/3 ✅ | 158.2 s | env-success | 自然完成 |
104
+ | 2 | 0/3 | 551.7 s | key-R skip | 抓不中颤抖 |
105
+ | 3 | 2/3 | 355.0 s | manual-hang | lerobot server 中断;2 是 viewport 观察 |
106
+
107
+ **round-by-round detail + 1Hz GPU sample + 7-baseline 横评对比** 见 [`vitorcen/isaaclab-experience`](https://github.com/vitorcen/isaaclab-experience) 的 `results/benchmark/snapshots/`。
108
+
109
+ ## License
110
+
111
+ Apache-2.0(继承自 `lerobot/smolvla_base` 和 LeIsaac)。
config.json ADDED
@@ -0,0 +1,93 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "type": "smolvla",
3
+ "n_obs_steps": 1,
4
+ "input_features": {
5
+ "observation.state": {
6
+ "type": "STATE",
7
+ "shape": [
8
+ 6
9
+ ]
10
+ },
11
+ "observation.images.front": {
12
+ "type": "VISUAL",
13
+ "shape": [
14
+ 3,
15
+ 480,
16
+ 640
17
+ ]
18
+ },
19
+ "observation.images.wrist": {
20
+ "type": "VISUAL",
21
+ "shape": [
22
+ 3,
23
+ 480,
24
+ 640
25
+ ]
26
+ }
27
+ },
28
+ "output_features": {
29
+ "action": {
30
+ "type": "ACTION",
31
+ "shape": [
32
+ 6
33
+ ]
34
+ }
35
+ },
36
+ "device": "cuda",
37
+ "use_amp": false,
38
+ "use_peft": false,
39
+ "push_to_hub": false,
40
+ "repo_id": null,
41
+ "private": null,
42
+ "tags": null,
43
+ "license": null,
44
+ "pretrained_path": "/home/david/work/LeIsaac/outputs/.bases/smolvla_base_no_features",
45
+ "chunk_size": 50,
46
+ "n_action_steps": 50,
47
+ "normalization_mapping": {
48
+ "VISUAL": "IDENTITY",
49
+ "STATE": "MEAN_STD",
50
+ "ACTION": "MEAN_STD"
51
+ },
52
+ "max_state_dim": 32,
53
+ "max_action_dim": 32,
54
+ "resize_imgs_with_padding": [
55
+ 512,
56
+ 512
57
+ ],
58
+ "empty_cameras": 0,
59
+ "adapt_to_pi_aloha": false,
60
+ "use_delta_joint_actions_aloha": false,
61
+ "tokenizer_max_length": 48,
62
+ "num_steps": 10,
63
+ "use_cache": true,
64
+ "freeze_vision_encoder": true,
65
+ "train_expert_only": true,
66
+ "train_state_proj": true,
67
+ "optimizer_lr": 0.0001,
68
+ "optimizer_betas": [
69
+ 0.9,
70
+ 0.95
71
+ ],
72
+ "optimizer_eps": 1e-08,
73
+ "optimizer_weight_decay": 1e-10,
74
+ "optimizer_grad_clip_norm": 10.0,
75
+ "scheduler_warmup_steps": 1000,
76
+ "scheduler_decay_steps": 30000,
77
+ "scheduler_decay_lr": 2.5e-06,
78
+ "vlm_model_name": "HuggingFaceTB/SmolVLM2-500M-Video-Instruct",
79
+ "load_vlm_weights": true,
80
+ "add_image_special_tokens": false,
81
+ "attention_mode": "cross_attn",
82
+ "prefix_length": 0,
83
+ "pad_language_to": "max_length",
84
+ "num_expert_layers": 0,
85
+ "num_vlm_layers": 16,
86
+ "self_attn_every_n_layers": 2,
87
+ "expert_width_multiplier": 0.75,
88
+ "min_period": 0.004,
89
+ "max_period": 4.0,
90
+ "rtc_config": null,
91
+ "compile_model": false,
92
+ "compile_mode": "max-autotune"
93
+ }
model.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:5180ce422a593d2e65c668782aa23069e4bbf6151758e08ccb6d0e0a16a3c587
3
+ size 906712520
policy_postprocessor.json ADDED
@@ -0,0 +1,32 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "policy_postprocessor",
3
+ "steps": [
4
+ {
5
+ "registry_name": "unnormalizer_processor",
6
+ "config": {
7
+ "eps": 1e-08,
8
+ "features": {
9
+ "action": {
10
+ "type": "ACTION",
11
+ "shape": [
12
+ 6
13
+ ]
14
+ }
15
+ },
16
+ "norm_map": {
17
+ "VISUAL": "IDENTITY",
18
+ "STATE": "MEAN_STD",
19
+ "ACTION": "MEAN_STD"
20
+ }
21
+ },
22
+ "state_file": "policy_postprocessor_step_0_unnormalizer_processor.safetensors"
23
+ },
24
+ {
25
+ "registry_name": "device_processor",
26
+ "config": {
27
+ "device": "cpu",
28
+ "float_dtype": null
29
+ }
30
+ }
31
+ ]
32
+ }
policy_postprocessor_step_0_unnormalizer_processor.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:0b9214914398156f17ddf08a5082c20b24efb70a7ba7677e8bc3d3ff68a722db
3
+ size 3756
policy_preprocessor.json ADDED
@@ -0,0 +1,79 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "policy_preprocessor",
3
+ "steps": [
4
+ {
5
+ "registry_name": "rename_observations_processor",
6
+ "config": {
7
+ "rename_map": {}
8
+ }
9
+ },
10
+ {
11
+ "registry_name": "to_batch_processor",
12
+ "config": {}
13
+ },
14
+ {
15
+ "registry_name": "smolvla_new_line_processor",
16
+ "config": {}
17
+ },
18
+ {
19
+ "registry_name": "tokenizer_processor",
20
+ "config": {
21
+ "max_length": 48,
22
+ "task_key": "task",
23
+ "padding_side": "right",
24
+ "padding": "max_length",
25
+ "truncation": true,
26
+ "tokenizer_name": "HuggingFaceTB/SmolVLM2-500M-Video-Instruct"
27
+ }
28
+ },
29
+ {
30
+ "registry_name": "device_processor",
31
+ "config": {
32
+ "device": "cuda",
33
+ "float_dtype": null
34
+ }
35
+ },
36
+ {
37
+ "registry_name": "normalizer_processor",
38
+ "config": {
39
+ "eps": 1e-08,
40
+ "features": {
41
+ "observation.state": {
42
+ "type": "STATE",
43
+ "shape": [
44
+ 6
45
+ ]
46
+ },
47
+ "observation.images.front": {
48
+ "type": "VISUAL",
49
+ "shape": [
50
+ 3,
51
+ 480,
52
+ 640
53
+ ]
54
+ },
55
+ "observation.images.wrist": {
56
+ "type": "VISUAL",
57
+ "shape": [
58
+ 3,
59
+ 480,
60
+ 640
61
+ ]
62
+ },
63
+ "action": {
64
+ "type": "ACTION",
65
+ "shape": [
66
+ 6
67
+ ]
68
+ }
69
+ },
70
+ "norm_map": {
71
+ "VISUAL": "IDENTITY",
72
+ "STATE": "MEAN_STD",
73
+ "ACTION": "MEAN_STD"
74
+ }
75
+ },
76
+ "state_file": "policy_preprocessor_step_5_normalizer_processor.safetensors"
77
+ }
78
+ ]
79
+ }
policy_preprocessor_step_5_normalizer_processor.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:0b9214914398156f17ddf08a5082c20b24efb70a7ba7677e8bc3d3ff68a722db
3
+ size 3756
train_config.json ADDED
@@ -0,0 +1,234 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "dataset": {
3
+ "repo_id": "LightwheelAI/leisaac-pick-orange",
4
+ "root": "/home/david/work/LeIsaac/datasets/raw/leisaac-pick-orange",
5
+ "episodes": null,
6
+ "image_transforms": {
7
+ "enable": false,
8
+ "max_num_transforms": 3,
9
+ "random_order": false,
10
+ "tfs": {
11
+ "brightness": {
12
+ "weight": 1.0,
13
+ "type": "ColorJitter",
14
+ "kwargs": {
15
+ "brightness": [
16
+ 0.8,
17
+ 1.2
18
+ ]
19
+ }
20
+ },
21
+ "contrast": {
22
+ "weight": 1.0,
23
+ "type": "ColorJitter",
24
+ "kwargs": {
25
+ "contrast": [
26
+ 0.8,
27
+ 1.2
28
+ ]
29
+ }
30
+ },
31
+ "saturation": {
32
+ "weight": 1.0,
33
+ "type": "ColorJitter",
34
+ "kwargs": {
35
+ "saturation": [
36
+ 0.5,
37
+ 1.5
38
+ ]
39
+ }
40
+ },
41
+ "hue": {
42
+ "weight": 1.0,
43
+ "type": "ColorJitter",
44
+ "kwargs": {
45
+ "hue": [
46
+ -0.05,
47
+ 0.05
48
+ ]
49
+ }
50
+ },
51
+ "sharpness": {
52
+ "weight": 1.0,
53
+ "type": "SharpnessJitter",
54
+ "kwargs": {
55
+ "sharpness": [
56
+ 0.5,
57
+ 1.5
58
+ ]
59
+ }
60
+ },
61
+ "affine": {
62
+ "weight": 1.0,
63
+ "type": "RandomAffine",
64
+ "kwargs": {
65
+ "degrees": [
66
+ -5.0,
67
+ 5.0
68
+ ],
69
+ "translate": [
70
+ 0.05,
71
+ 0.05
72
+ ]
73
+ }
74
+ }
75
+ }
76
+ },
77
+ "revision": null,
78
+ "use_imagenet_stats": true,
79
+ "video_backend": "pyav",
80
+ "return_uint8": false,
81
+ "streaming": false
82
+ },
83
+ "env": null,
84
+ "policy": {
85
+ "type": "smolvla",
86
+ "n_obs_steps": 1,
87
+ "input_features": {
88
+ "observation.state": {
89
+ "type": "STATE",
90
+ "shape": [
91
+ 6
92
+ ]
93
+ },
94
+ "observation.images.front": {
95
+ "type": "VISUAL",
96
+ "shape": [
97
+ 3,
98
+ 480,
99
+ 640
100
+ ]
101
+ },
102
+ "observation.images.wrist": {
103
+ "type": "VISUAL",
104
+ "shape": [
105
+ 3,
106
+ 480,
107
+ 640
108
+ ]
109
+ }
110
+ },
111
+ "output_features": {
112
+ "action": {
113
+ "type": "ACTION",
114
+ "shape": [
115
+ 6
116
+ ]
117
+ }
118
+ },
119
+ "device": "cuda",
120
+ "use_amp": false,
121
+ "use_peft": false,
122
+ "push_to_hub": false,
123
+ "repo_id": null,
124
+ "private": null,
125
+ "tags": null,
126
+ "license": null,
127
+ "pretrained_path": "/home/david/work/LeIsaac/outputs/.bases/smolvla_base_no_features",
128
+ "chunk_size": 50,
129
+ "n_action_steps": 50,
130
+ "normalization_mapping": {
131
+ "VISUAL": "IDENTITY",
132
+ "STATE": "MEAN_STD",
133
+ "ACTION": "MEAN_STD"
134
+ },
135
+ "max_state_dim": 32,
136
+ "max_action_dim": 32,
137
+ "resize_imgs_with_padding": [
138
+ 512,
139
+ 512
140
+ ],
141
+ "empty_cameras": 0,
142
+ "adapt_to_pi_aloha": false,
143
+ "use_delta_joint_actions_aloha": false,
144
+ "tokenizer_max_length": 48,
145
+ "num_steps": 10,
146
+ "use_cache": true,
147
+ "freeze_vision_encoder": true,
148
+ "train_expert_only": true,
149
+ "train_state_proj": true,
150
+ "optimizer_lr": 0.0001,
151
+ "optimizer_betas": [
152
+ 0.9,
153
+ 0.95
154
+ ],
155
+ "optimizer_eps": 1e-08,
156
+ "optimizer_weight_decay": 1e-10,
157
+ "optimizer_grad_clip_norm": 10.0,
158
+ "scheduler_warmup_steps": 1000,
159
+ "scheduler_decay_steps": 30000,
160
+ "scheduler_decay_lr": 2.5e-06,
161
+ "vlm_model_name": "HuggingFaceTB/SmolVLM2-500M-Video-Instruct",
162
+ "load_vlm_weights": true,
163
+ "add_image_special_tokens": false,
164
+ "attention_mode": "cross_attn",
165
+ "prefix_length": 0,
166
+ "pad_language_to": "max_length",
167
+ "num_expert_layers": 0,
168
+ "num_vlm_layers": 16,
169
+ "self_attn_every_n_layers": 2,
170
+ "expert_width_multiplier": 0.75,
171
+ "min_period": 0.004,
172
+ "max_period": 4.0,
173
+ "rtc_config": null,
174
+ "compile_model": false,
175
+ "compile_mode": "max-autotune"
176
+ },
177
+ "output_dir": "/home/david/work/LeIsaac/outputs/smolvla2-leisaac-pick-orange",
178
+ "job_name": "smolvla",
179
+ "resume": false,
180
+ "seed": 1000,
181
+ "cudnn_deterministic": false,
182
+ "num_workers": 2,
183
+ "batch_size": 8,
184
+ "prefetch_factor": 4,
185
+ "persistent_workers": true,
186
+ "steps": 30000,
187
+ "eval_freq": 20000,
188
+ "log_freq": 200,
189
+ "tolerance_s": 0.0001,
190
+ "save_checkpoint": true,
191
+ "save_freq": 5000,
192
+ "use_policy_training_preset": true,
193
+ "optimizer": {
194
+ "type": "adamw",
195
+ "lr": 0.0001,
196
+ "weight_decay": 1e-10,
197
+ "grad_clip_norm": 10.0,
198
+ "betas": [
199
+ 0.9,
200
+ 0.95
201
+ ],
202
+ "eps": 1e-08
203
+ },
204
+ "scheduler": {
205
+ "type": "cosine_decay_with_warmup",
206
+ "num_warmup_steps": 1000,
207
+ "num_decay_steps": 30000,
208
+ "peak_lr": 0.0001,
209
+ "decay_lr": 2.5e-06
210
+ },
211
+ "eval": {
212
+ "n_episodes": 50,
213
+ "batch_size": 22,
214
+ "use_async_envs": true
215
+ },
216
+ "wandb": {
217
+ "enable": false,
218
+ "disable_artifact": false,
219
+ "project": "lerobot",
220
+ "entity": null,
221
+ "notes": null,
222
+ "run_id": null,
223
+ "mode": null,
224
+ "add_tags": true
225
+ },
226
+ "peft": null,
227
+ "use_rabc": false,
228
+ "rabc_progress_path": null,
229
+ "rabc_kappa": 0.01,
230
+ "rabc_epsilon": 1e-06,
231
+ "rabc_head_mode": "sparse",
232
+ "rename_map": {},
233
+ "checkpoint_path": null
234
+ }