han-xudong commited on
Commit
961dbc6
·
verified ·
1 Parent(s): 8fe82e6

Upload folder using huggingface_hub

Browse files
Files changed (5) hide show
  1. .gitattributes +34 -34
  2. README.md +5 -5
  3. config.json +16 -15
  4. modeling.py +54 -52
  5. modify_safetensors.py +32 -0
.gitattributes CHANGED
@@ -1,35 +1,35 @@
1
- *.7z filter=lfs diff=lfs merge=lfs -text
2
- *.arrow filter=lfs diff=lfs merge=lfs -text
3
- *.bin filter=lfs diff=lfs merge=lfs -text
4
- *.bz2 filter=lfs diff=lfs merge=lfs -text
5
- *.ckpt filter=lfs diff=lfs merge=lfs -text
6
- *.ftz filter=lfs diff=lfs merge=lfs -text
7
- *.gz filter=lfs diff=lfs merge=lfs -text
8
- *.h5 filter=lfs diff=lfs merge=lfs -text
9
- *.joblib filter=lfs diff=lfs merge=lfs -text
10
- *.lfs.* filter=lfs diff=lfs merge=lfs -text
11
- *.mlmodel filter=lfs diff=lfs merge=lfs -text
12
- *.model filter=lfs diff=lfs merge=lfs -text
13
- *.msgpack filter=lfs diff=lfs merge=lfs -text
14
- *.npy filter=lfs diff=lfs merge=lfs -text
15
- *.npz filter=lfs diff=lfs merge=lfs -text
16
- *.onnx filter=lfs diff=lfs merge=lfs -text
17
- *.ot filter=lfs diff=lfs merge=lfs -text
18
- *.parquet filter=lfs diff=lfs merge=lfs -text
19
- *.pb filter=lfs diff=lfs merge=lfs -text
20
- *.pickle filter=lfs diff=lfs merge=lfs -text
21
- *.pkl filter=lfs diff=lfs merge=lfs -text
22
- *.pt filter=lfs diff=lfs merge=lfs -text
23
- *.pth filter=lfs diff=lfs merge=lfs -text
24
- *.rar filter=lfs diff=lfs merge=lfs -text
25
- *.safetensors filter=lfs diff=lfs merge=lfs -text
26
- saved_model/**/* filter=lfs diff=lfs merge=lfs -text
27
- *.tar.* filter=lfs diff=lfs merge=lfs -text
28
- *.tar filter=lfs diff=lfs merge=lfs -text
29
- *.tflite filter=lfs diff=lfs merge=lfs -text
30
- *.tgz filter=lfs diff=lfs merge=lfs -text
31
- *.wasm filter=lfs diff=lfs merge=lfs -text
32
- *.xz filter=lfs diff=lfs merge=lfs -text
33
- *.zip filter=lfs diff=lfs merge=lfs -text
34
- *.zst filter=lfs diff=lfs merge=lfs -text
35
  *tfevents* filter=lfs diff=lfs merge=lfs -text
 
1
+ *.7z filter=lfs diff=lfs merge=lfs -text
2
+ *.arrow filter=lfs diff=lfs merge=lfs -text
3
+ *.bin filter=lfs diff=lfs merge=lfs -text
4
+ *.bz2 filter=lfs diff=lfs merge=lfs -text
5
+ *.ckpt filter=lfs diff=lfs merge=lfs -text
6
+ *.ftz filter=lfs diff=lfs merge=lfs -text
7
+ *.gz filter=lfs diff=lfs merge=lfs -text
8
+ *.h5 filter=lfs diff=lfs merge=lfs -text
9
+ *.joblib filter=lfs diff=lfs merge=lfs -text
10
+ *.lfs.* filter=lfs diff=lfs merge=lfs -text
11
+ *.mlmodel filter=lfs diff=lfs merge=lfs -text
12
+ *.model filter=lfs diff=lfs merge=lfs -text
13
+ *.msgpack filter=lfs diff=lfs merge=lfs -text
14
+ *.npy filter=lfs diff=lfs merge=lfs -text
15
+ *.npz filter=lfs diff=lfs merge=lfs -text
16
+ *.onnx filter=lfs diff=lfs merge=lfs -text
17
+ *.ot filter=lfs diff=lfs merge=lfs -text
18
+ *.parquet filter=lfs diff=lfs merge=lfs -text
19
+ *.pb filter=lfs diff=lfs merge=lfs -text
20
+ *.pickle filter=lfs diff=lfs merge=lfs -text
21
+ *.pkl filter=lfs diff=lfs merge=lfs -text
22
+ *.pt filter=lfs diff=lfs merge=lfs -text
23
+ *.pth filter=lfs diff=lfs merge=lfs -text
24
+ *.rar filter=lfs diff=lfs merge=lfs -text
25
+ *.safetensors filter=lfs diff=lfs merge=lfs -text
26
+ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
27
+ *.tar.* filter=lfs diff=lfs merge=lfs -text
28
+ *.tar filter=lfs diff=lfs merge=lfs -text
29
+ *.tflite filter=lfs diff=lfs merge=lfs -text
30
+ *.tgz filter=lfs diff=lfs merge=lfs -text
31
+ *.wasm filter=lfs diff=lfs merge=lfs -text
32
+ *.xz filter=lfs diff=lfs merge=lfs -text
33
+ *.zip filter=lfs diff=lfs merge=lfs -text
34
+ *.zst filter=lfs diff=lfs merge=lfs -text
35
  *tfevents* filter=lfs diff=lfs merge=lfs -text
README.md CHANGED
@@ -9,7 +9,7 @@ tags:
9
  - pytorch
10
  library_name: transformers
11
  datasets:
12
- - asRobotics/ballnet-100k
13
  ---
14
 
15
  # Model Card for BallNet
@@ -27,7 +27,7 @@ datasets:
27
 
28
  BallNet is an MLP model designed for the Metaball. It can predict both 6D force and 3D shape (mesh nodes) from the 6D motion of the ball.
29
 
30
- Try it out on the [Spaces demo](https://huggingface.co/spaces/asRobotics/ballnet-demo).
31
 
32
  - Developer: Xudong Han, Tianyu Wu, Fang Wan, and Chaoyang Song.
33
  - Model type: MLP
@@ -42,7 +42,7 @@ To load the model:
42
  ```python
43
  from transformers import AutoModel
44
 
45
- model = AutoModel.from_pretrained("asRobotics/ballnet", trust_remote_code=True)
46
  x = torch.zeros((1, 6)) # Example input: batch size of 1, 6D motion
47
  output = model(x)
48
  ```
@@ -55,7 +55,7 @@ import onnxruntime as ort
55
  import numpy as np
56
  from huggingface_hub import hf_hub_download
57
 
58
- onnx_model_path = hf_hub_download("asRobotics/ballnet", filename="model.onnx")
59
  ort_session = ort.InferenceSession(onnx_model_path)
60
 
61
  # Example input
@@ -65,7 +65,7 @@ output = ort_session.run(None, {"motion": x})
65
 
66
  ## Training Data
67
 
68
- The model was trained on the [BallNet-100K](https://huggingface.co/datasets/asRobotics/ballnet-100k) dataset, which includes a variety of motion, force, and shape data collected by finite element simulations.
69
 
70
  ## Citation
71
 
 
9
  - pytorch
10
  library_name: transformers
11
  datasets:
12
+ - han-xudong/ballnet-100k
13
  ---
14
 
15
  # Model Card for BallNet
 
27
 
28
  BallNet is an MLP model designed for the Metaball. It can predict both 6D force and 3D shape (mesh nodes) from the 6D motion of the ball.
29
 
30
+ Try it out on the [Spaces demo](https://huggingface.co/spaces/han-xudong/ballnet-demo).
31
 
32
  - Developer: Xudong Han, Tianyu Wu, Fang Wan, and Chaoyang Song.
33
  - Model type: MLP
 
42
  ```python
43
  from transformers import AutoModel
44
 
45
+ model = AutoModel.from_pretrained("han-xudong/ballnet", trust_remote_code=True)
46
  x = torch.zeros((1, 6)) # Example input: batch size of 1, 6D motion
47
  output = model(x)
48
  ```
 
55
  import numpy as np
56
  from huggingface_hub import hf_hub_download
57
 
58
+ onnx_model_path = hf_hub_download("han-xudong/ballnet", filename="model.onnx")
59
  ort_session = ort.InferenceSession(onnx_model_path)
60
 
61
  # Example input
 
65
 
66
  ## Training Data
67
 
68
+ The model was trained on the [BallNet-100K](https://huggingface.co/datasets/han-xudong/ballnet-100k) dataset, which includes a variety of motion, force, and shape data collected by finite element simulations.
69
 
70
  ## Citation
71
 
config.json CHANGED
@@ -1,15 +1,16 @@
1
- {
2
- "_name_or_path": "asRobotics/ballnet",
3
- "architectures": ["BallNet"],
4
- "model_type": "ballnet",
5
- "x_dim": [6],
6
- "y_dim": [6, 2931],
7
- "h1_dim": [100, 1000],
8
- "h2_dim": [100, 1000],
9
- "torch_dtype": "float32",
10
- "layer_norm": false,
11
- "use_activation": "relu",
12
- "auto_map": {
13
- "AutoModel": "modeling.FingerNet"
14
- }
15
- }
 
 
1
+ {
2
+ "_name_or_path": "asRobotics/ballnet",
3
+ "architectures": ["BallNet"],
4
+ "model_type": "ballnet",
5
+ "x_dim": [6],
6
+ "y_dim": [6, 2931],
7
+ "h1_dim": [100, 1000],
8
+ "h2_dim": [100, 1000],
9
+ "torch_dtype": "float32",
10
+ "layer_norm": false,
11
+ "use_activation": "relu",
12
+ "auto_map": {
13
+ "AutoConfig": "modeling.BallNetConfig",
14
+ "AutoModel": "modeling.BallNet"
15
+ }
16
+ }
modeling.py CHANGED
@@ -1,52 +1,54 @@
1
- import torch
2
- import torch.nn as nn
3
- from transformers import PreTrainedModel, PretrainedConfig
4
-
5
- class BallNetConfig(PretrainedConfig):
6
- model_type = "ballnet"
7
-
8
- def __init__(
9
- self,
10
- x_dim=[6],
11
- y_dim=[6, 1800],
12
- h1_dim=[100, 1000],
13
- h2_dim=[100, 1000],
14
- **kwargs,
15
- ):
16
- super().__init__(**kwargs)
17
- self.x_dim = x_dim
18
- self.y_dim = y_dim
19
- self.h1_dim = h1_dim
20
- self.h2_dim = h2_dim
21
-
22
-
23
- class BallNet(PreTrainedModel):
24
- config_class = BallNetConfig
25
-
26
- def __init__(self, config):
27
- super().__init__(config)
28
- self.x_dim = config.x_dim
29
- self.y_dim = config.y_dim
30
- self.h1_dim = config.h1_dim
31
- self.h2_dim = config.h2_dim
32
-
33
- # build sub-networks
34
- self.branches = nn.ModuleList()
35
- for i in range(len(self.y_dim)):
36
- net = nn.Sequential(
37
- nn.Linear(self.x_dim[0], self.h1_dim[i]),
38
- nn.ReLU(),
39
- nn.Linear(self.h1_dim[i], self.h2_dim[i]),
40
- nn.ReLU(),
41
- nn.Linear(self.h2_dim[i], self.y_dim[i]),
42
- )
43
- self.branches.append(net)
44
-
45
- # initialize weights
46
- self.post_init()
47
-
48
- def forward(self, x):
49
- if isinstance(x, (list, tuple)):
50
- x = torch.tensor(x, dtype=torch.float32)
51
- outputs = [branch(x) for branch in self.branches]
52
- return tuple(outputs)
 
 
 
1
+ import torch
2
+ import torch.nn as nn
3
+ from transformers import PreTrainedModel, PretrainedConfig
4
+
5
+ class BallNetConfig(PretrainedConfig):
6
+ model_type = "ballnet"
7
+
8
+ def __init__(
9
+ self,
10
+ x_dim=[6],
11
+ y_dim=[6, 1800],
12
+ h1_dim=[100, 1000],
13
+ h2_dim=[100, 1000],
14
+ **kwargs,
15
+ ):
16
+ super().__init__(**kwargs)
17
+ self.x_dim = x_dim
18
+ self.y_dim = y_dim
19
+ self.h1_dim = h1_dim
20
+ self.h2_dim = h2_dim
21
+
22
+
23
+ class BallNet(PreTrainedModel):
24
+ config_class = BallNetConfig
25
+
26
+ def __init__(self, config):
27
+ super().__init__(config)
28
+ self.x_dim = config.x_dim
29
+ self.y_dim = config.y_dim
30
+ self.h1_dim = config.h1_dim
31
+ self.h2_dim = config.h2_dim
32
+
33
+ self.model = nn.ModuleDict()
34
+ # Define the model architecture
35
+ for i in range(len(self.y_dim)):
36
+ self.model[f"estimator_{i}"] = nn.Sequential(
37
+ nn.Linear(self.x_dim[0], self.h1_dim[i]),
38
+ nn.ReLU(),
39
+ nn.Linear(self.h1_dim[i], self.h2_dim[i]),
40
+ nn.ReLU(),
41
+ nn.Linear(self.h2_dim[i], self.y_dim[i]),
42
+ )
43
+
44
+ # initialize weights
45
+ self.post_init()
46
+
47
+ def forward(self, x):
48
+ outputs = []
49
+ for i in range(len(self.y_dim)):
50
+ # Get the estimator for the i-th output
51
+ estimator = self.model[f"estimator_{i}"]
52
+ y = estimator(x)
53
+ outputs.append(y)
54
+ return outputs
modify_safetensors.py ADDED
@@ -0,0 +1,32 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from safetensors import safe_open
2
+ from safetensors.torch import save_file
3
+ import torch
4
+
5
+ # ==========================================================
6
+ # 1. Load original safetensors
7
+ # ==========================================================
8
+ input_path = "model.safetensors"
9
+ output_path = "model_fixed.safetensors"
10
+
11
+ new_state_dict = {}
12
+
13
+ with safe_open(input_path, framework="pt", device="cpu") as f:
14
+ for key in f.keys():
15
+ tensor = f.get_tensor(key)
16
+ # Add prefix "model." if not already
17
+ new_key = key if key.startswith("model.") else f"model.{key}"
18
+ new_state_dict[new_key] = tensor
19
+
20
+ metadata = {
21
+ "format": "pt",
22
+ }
23
+ # ==========================================================
24
+ # 2. Save to new safetensors file
25
+ # ==========================================================
26
+ save_file(new_state_dict, output_path, metadata=metadata)
27
+ print(f"✅ Saved updated safetensors to {output_path}")
28
+ print(f"✅ Total tensors: {len(new_state_dict)}")
29
+
30
+ # Optional: verify one sample
31
+ print("Example tensor key:", list(new_state_dict.keys())[0])
32
+ print("Shape:", new_state_dict[list(new_state_dict.keys())[0]].shape)