Update files for transformers integration

#1
by guarin HF Staff - opened
config.json CHANGED
@@ -1,5 +1,4 @@
1
  {
2
- "model_type": "tipsv2_dpt",
3
  "architectures": [
4
  "TIPSv2DPTModel"
5
  ],
@@ -7,24 +6,392 @@
7
  "AutoConfig": "configuration_dpt.TIPSv2DPTConfig",
8
  "AutoModel": "modeling_dpt.TIPSv2DPTModel"
9
  },
10
- "channels": 256,
11
- "readout_type": "project",
12
- "num_depth_bins": 256,
13
- "min_depth": 0.001,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
14
  "max_depth": 10.0,
15
- "num_seg_classes": 150,
16
- "backbone_repo": "google/tipsv2-l14",
17
- "embed_dim": 1024,
18
- "block_indices": [
19
- 5,
20
- 11,
21
- 17,
22
- 23
23
- ],
24
- "post_process_channels": [
25
  128,
26
  256,
27
  512,
28
  1024
29
- ]
30
- }
 
 
 
 
 
 
 
 
 
 
 
1
  {
 
2
  "architectures": [
3
  "TIPSv2DPTModel"
4
  ],
 
6
  "AutoConfig": "configuration_dpt.TIPSv2DPTConfig",
7
  "AutoModel": "modeling_dpt.TIPSv2DPTModel"
8
  },
9
+ "backbone_config": {
10
+ "apply_layernorm": true,
11
+ "attention_probs_dropout_prob": 0.0,
12
+ "drop_path_rate": 0.0,
13
+ "hidden_act": "gelu",
14
+ "hidden_dropout_prob": 0.0,
15
+ "hidden_size": 1024,
16
+ "image_size": 448,
17
+ "initializer_range": 0.02,
18
+ "interpolate_antialias": true,
19
+ "interpolate_offset": 0.0,
20
+ "layer_norm_eps": 1e-06,
21
+ "layerscale_value": 1.0,
22
+ "mlp_ratio": 4,
23
+ "model_type": "tipsv2_vision_model",
24
+ "num_attention_heads": 16,
25
+ "num_channels": 3,
26
+ "num_hidden_layers": 24,
27
+ "num_register_tokens": 1,
28
+ "out_features": [
29
+ "stage6",
30
+ "stage12",
31
+ "stage18",
32
+ "stage24"
33
+ ],
34
+ "out_indices": [
35
+ 6,
36
+ 12,
37
+ 18,
38
+ 24
39
+ ],
40
+ "patch_size": 14,
41
+ "qkv_bias": true,
42
+ "reshape_hidden_states": false,
43
+ "stage_names": [
44
+ "stem",
45
+ "stage1",
46
+ "stage2",
47
+ "stage3",
48
+ "stage4",
49
+ "stage5",
50
+ "stage6",
51
+ "stage7",
52
+ "stage8",
53
+ "stage9",
54
+ "stage10",
55
+ "stage11",
56
+ "stage12",
57
+ "stage13",
58
+ "stage14",
59
+ "stage15",
60
+ "stage16",
61
+ "stage17",
62
+ "stage18",
63
+ "stage19",
64
+ "stage20",
65
+ "stage21",
66
+ "stage22",
67
+ "stage23",
68
+ "stage24"
69
+ ],
70
+ "use_swiglu_ffn": false
71
+ },
72
+ "depth_decoder_activation": "relu",
73
+ "fusion_hidden_size": 256,
74
+ "id2label": {
75
+ "0": "wall",
76
+ "1": "building",
77
+ "10": "cabinet",
78
+ "100": "poster",
79
+ "101": "stage",
80
+ "102": "van",
81
+ "103": "ship",
82
+ "104": "fountain",
83
+ "105": "conveyer belt",
84
+ "106": "canopy",
85
+ "107": "washer",
86
+ "108": "plaything",
87
+ "109": "swimming pool",
88
+ "11": "sidewalk",
89
+ "110": "stool",
90
+ "111": "barrel",
91
+ "112": "basket",
92
+ "113": "waterfall",
93
+ "114": "tent",
94
+ "115": "bag",
95
+ "116": "minibike",
96
+ "117": "cradle",
97
+ "118": "oven",
98
+ "119": "ball",
99
+ "12": "person",
100
+ "120": "food",
101
+ "121": "step",
102
+ "122": "tank",
103
+ "123": "trade name",
104
+ "124": "microwave",
105
+ "125": "pot",
106
+ "126": "animal",
107
+ "127": "bicycle",
108
+ "128": "lake",
109
+ "129": "dishwasher",
110
+ "13": "earth",
111
+ "130": "screen",
112
+ "131": "blanket",
113
+ "132": "sculpture",
114
+ "133": "hood",
115
+ "134": "sconce",
116
+ "135": "vase",
117
+ "136": "traffic light",
118
+ "137": "tray",
119
+ "138": "ashcan",
120
+ "139": "fan",
121
+ "14": "door",
122
+ "140": "pier",
123
+ "141": "crt screen",
124
+ "142": "plate",
125
+ "143": "monitor",
126
+ "144": "bulletin board",
127
+ "145": "shower",
128
+ "146": "radiator",
129
+ "147": "glass",
130
+ "148": "clock",
131
+ "149": "flag",
132
+ "15": "table",
133
+ "16": "mountain",
134
+ "17": "plant",
135
+ "18": "curtain",
136
+ "19": "chair",
137
+ "2": "sky",
138
+ "20": "car",
139
+ "21": "water",
140
+ "22": "painting",
141
+ "23": "sofa",
142
+ "24": "shelf",
143
+ "25": "house",
144
+ "26": "sea",
145
+ "27": "mirror",
146
+ "28": "rug",
147
+ "29": "field",
148
+ "3": "floor",
149
+ "30": "armchair",
150
+ "31": "seat",
151
+ "32": "fence",
152
+ "33": "desk",
153
+ "34": "rock",
154
+ "35": "wardrobe",
155
+ "36": "lamp",
156
+ "37": "bathtub",
157
+ "38": "railing",
158
+ "39": "cushion",
159
+ "4": "tree",
160
+ "40": "base",
161
+ "41": "box",
162
+ "42": "column",
163
+ "43": "signboard",
164
+ "44": "chest of drawers",
165
+ "45": "counter",
166
+ "46": "sand",
167
+ "47": "sink",
168
+ "48": "skyscraper",
169
+ "49": "fireplace",
170
+ "5": "ceiling",
171
+ "50": "refrigerator",
172
+ "51": "grandstand",
173
+ "52": "path",
174
+ "53": "stairs",
175
+ "54": "runway",
176
+ "55": "case",
177
+ "56": "pool table",
178
+ "57": "pillow",
179
+ "58": "screen door",
180
+ "59": "stairway",
181
+ "6": "road",
182
+ "60": "river",
183
+ "61": "bridge",
184
+ "62": "bookcase",
185
+ "63": "blind",
186
+ "64": "coffee table",
187
+ "65": "toilet",
188
+ "66": "flower",
189
+ "67": "book",
190
+ "68": "hill",
191
+ "69": "bench",
192
+ "7": "bed ",
193
+ "70": "countertop",
194
+ "71": "stove",
195
+ "72": "palm",
196
+ "73": "kitchen island",
197
+ "74": "computer",
198
+ "75": "swivel chair",
199
+ "76": "boat",
200
+ "77": "bar",
201
+ "78": "arcade machine",
202
+ "79": "hovel",
203
+ "8": "windowpane",
204
+ "80": "bus",
205
+ "81": "towel",
206
+ "82": "light",
207
+ "83": "truck",
208
+ "84": "tower",
209
+ "85": "chandelier",
210
+ "86": "awning",
211
+ "87": "streetlight",
212
+ "88": "booth",
213
+ "89": "television receiver",
214
+ "9": "grass",
215
+ "90": "airplane",
216
+ "91": "dirt track",
217
+ "92": "apparel",
218
+ "93": "pole",
219
+ "94": "land",
220
+ "95": "bannister",
221
+ "96": "escalator",
222
+ "97": "ottoman",
223
+ "98": "bottle",
224
+ "99": "buffet"
225
+ },
226
+ "label2id": {
227
+ "airplane": 90,
228
+ "animal": 126,
229
+ "apparel": 92,
230
+ "arcade machine": 78,
231
+ "armchair": 30,
232
+ "ashcan": 138,
233
+ "awning": 86,
234
+ "bag": 115,
235
+ "ball": 119,
236
+ "bannister": 95,
237
+ "bar": 77,
238
+ "barrel": 111,
239
+ "base": 40,
240
+ "basket": 112,
241
+ "bathtub": 37,
242
+ "bed ": 7,
243
+ "bench": 69,
244
+ "bicycle": 127,
245
+ "blanket": 131,
246
+ "blind": 63,
247
+ "boat": 76,
248
+ "book": 67,
249
+ "bookcase": 62,
250
+ "booth": 88,
251
+ "bottle": 98,
252
+ "box": 41,
253
+ "bridge": 61,
254
+ "buffet": 99,
255
+ "building": 1,
256
+ "bulletin board": 144,
257
+ "bus": 80,
258
+ "cabinet": 10,
259
+ "canopy": 106,
260
+ "car": 20,
261
+ "case": 55,
262
+ "ceiling": 5,
263
+ "chair": 19,
264
+ "chandelier": 85,
265
+ "chest of drawers": 44,
266
+ "clock": 148,
267
+ "coffee table": 64,
268
+ "column": 42,
269
+ "computer": 74,
270
+ "conveyer belt": 105,
271
+ "counter": 45,
272
+ "countertop": 70,
273
+ "cradle": 117,
274
+ "crt screen": 141,
275
+ "curtain": 18,
276
+ "cushion": 39,
277
+ "desk": 33,
278
+ "dirt track": 91,
279
+ "dishwasher": 129,
280
+ "door": 14,
281
+ "earth": 13,
282
+ "escalator": 96,
283
+ "fan": 139,
284
+ "fence": 32,
285
+ "field": 29,
286
+ "fireplace": 49,
287
+ "flag": 149,
288
+ "floor": 3,
289
+ "flower": 66,
290
+ "food": 120,
291
+ "fountain": 104,
292
+ "glass": 147,
293
+ "grandstand": 51,
294
+ "grass": 9,
295
+ "hill": 68,
296
+ "hood": 133,
297
+ "house": 25,
298
+ "hovel": 79,
299
+ "kitchen island": 73,
300
+ "lake": 128,
301
+ "lamp": 36,
302
+ "land": 94,
303
+ "light": 82,
304
+ "microwave": 124,
305
+ "minibike": 116,
306
+ "mirror": 27,
307
+ "monitor": 143,
308
+ "mountain": 16,
309
+ "ottoman": 97,
310
+ "oven": 118,
311
+ "painting": 22,
312
+ "palm": 72,
313
+ "path": 52,
314
+ "person": 12,
315
+ "pier": 140,
316
+ "pillow": 57,
317
+ "plant": 17,
318
+ "plate": 142,
319
+ "plaything": 108,
320
+ "pole": 93,
321
+ "pool table": 56,
322
+ "poster": 100,
323
+ "pot": 125,
324
+ "radiator": 146,
325
+ "railing": 38,
326
+ "refrigerator": 50,
327
+ "river": 60,
328
+ "road": 6,
329
+ "rock": 34,
330
+ "rug": 28,
331
+ "runway": 54,
332
+ "sand": 46,
333
+ "sconce": 134,
334
+ "screen": 130,
335
+ "screen door": 58,
336
+ "sculpture": 132,
337
+ "sea": 26,
338
+ "seat": 31,
339
+ "shelf": 24,
340
+ "ship": 103,
341
+ "shower": 145,
342
+ "sidewalk": 11,
343
+ "signboard": 43,
344
+ "sink": 47,
345
+ "sky": 2,
346
+ "skyscraper": 48,
347
+ "sofa": 23,
348
+ "stage": 101,
349
+ "stairs": 53,
350
+ "stairway": 59,
351
+ "step": 121,
352
+ "stool": 110,
353
+ "stove": 71,
354
+ "streetlight": 87,
355
+ "swimming pool": 109,
356
+ "swivel chair": 75,
357
+ "table": 15,
358
+ "tank": 122,
359
+ "television receiver": 89,
360
+ "tent": 114,
361
+ "toilet": 65,
362
+ "towel": 81,
363
+ "tower": 84,
364
+ "trade name": 123,
365
+ "traffic light": 136,
366
+ "tray": 137,
367
+ "tree": 4,
368
+ "truck": 83,
369
+ "van": 102,
370
+ "vase": 135,
371
+ "wall": 0,
372
+ "wardrobe": 35,
373
+ "washer": 107,
374
+ "water": 21,
375
+ "waterfall": 113,
376
+ "windowpane": 8
377
+ },
378
  "max_depth": 10.0,
379
+ "min_depth": 0.001,
380
+ "model_type": "tipsv2_dpt",
381
+ "neck_hidden_sizes": [
 
 
 
 
 
 
 
382
  128,
383
  256,
384
  512,
385
  1024
386
+ ],
387
+ "num_depth_bins": 256,
388
+ "readout_act": "gelu_pytorch_tanh",
389
+ "reassemble_factors": [
390
+ 4,
391
+ 2,
392
+ 1,
393
+ 0.5
394
+ ],
395
+ "semantic_loss_ignore_index": 255,
396
+ "transformers_version": "5.10.0.dev0"
397
+ }
configuration_dpt.py CHANGED
@@ -3,6 +3,14 @@
3
  from transformers import PretrainedConfig
4
 
5
 
 
 
 
 
 
 
 
 
6
  class TIPSv2DPTConfig(PretrainedConfig):
7
  """Configuration for TIPSv2 DPT dense prediction heads."""
8
 
@@ -10,26 +18,27 @@ class TIPSv2DPTConfig(PretrainedConfig):
10
 
11
  def __init__(
12
  self,
13
- backbone_repo="google/tipsv2-l14",
14
- embed_dim=1024,
15
- channels=256,
16
- post_process_channels=(128, 256, 512, 1024),
17
- block_indices=(5, 11, 17, 23),
18
  readout_type="project",
19
  num_depth_bins=256,
20
  min_depth=1e-3,
21
  max_depth=10.0,
22
- num_seg_classes=150,
23
  **kwargs,
24
  ):
25
  super().__init__(**kwargs)
26
- self.backbone_repo = backbone_repo
27
- self.embed_dim = embed_dim
28
- self.channels = channels
29
- self.post_process_channels = list(post_process_channels)
30
- self.block_indices = list(block_indices)
 
 
 
31
  self.readout_type = readout_type
32
  self.num_depth_bins = num_depth_bins
33
  self.min_depth = min_depth
34
  self.max_depth = max_depth
35
- self.num_seg_classes = num_seg_classes
 
3
  from transformers import PretrainedConfig
4
 
5
 
6
+ _BACKBONE_REPO_BY_HIDDEN_SIZE = {
7
+ 768: "google/tipsv2-b14",
8
+ 1024: "google/tipsv2-l14",
9
+ 1152: "google/tipsv2-so400m14",
10
+ 1536: "google/tipsv2-g14",
11
+ }
12
+
13
+
14
  class TIPSv2DPTConfig(PretrainedConfig):
15
  """Configuration for TIPSv2 DPT dense prediction heads."""
16
 
 
18
 
19
  def __init__(
20
  self,
21
+ backbone_config=None,
22
+ neck_hidden_sizes=(96, 192, 384, 768),
23
+ fusion_hidden_size=256,
24
+ reassemble_factors=(4, 2, 1, 0.5),
 
25
  readout_type="project",
26
  num_depth_bins=256,
27
  min_depth=1e-3,
28
  max_depth=10.0,
 
29
  **kwargs,
30
  ):
31
  super().__init__(**kwargs)
32
+ backbone_config = backbone_config or {}
33
+ hidden_size = backbone_config.get("hidden_size", 768)
34
+ out_indices = backbone_config.get("out_indices", (3, 6, 9, 12))
35
+ self.backbone_repo = _BACKBONE_REPO_BY_HIDDEN_SIZE[hidden_size]
36
+ self.embed_dim = hidden_size
37
+ self.channels = fusion_hidden_size
38
+ self.post_process_channels = list(neck_hidden_sizes)
39
+ self.block_indices = [out_index - 1 for out_index in out_indices]
40
  self.readout_type = readout_type
41
  self.num_depth_bins = num_depth_bins
42
  self.min_depth = min_depth
43
  self.max_depth = max_depth
44
+ self.num_seg_classes = self.num_labels
model.safetensors CHANGED
@@ -1,3 +1,3 @@
1
  version https://git-lfs.github.com/spec/v1
2
- oid sha256:a7610f79d02ea314818402eec5437361cf046a88d69bd170c43ae90ed36e33e6
3
- size 406735852
 
1
  version https://git-lfs.github.com/spec/v1
2
+ oid sha256:38362aae91092ca0a6f2fe7f7ed29ec2e7042e3b920b7217d9317ad4c13abdfa
3
+ size 1622839292
modeling_dpt.py CHANGED
@@ -8,7 +8,7 @@ from typing import Optional
8
 
9
  import torch
10
  from huggingface_hub import hf_hub_download
11
- from transformers import AutoModel, PreTrainedModel
12
 
13
  from .configuration_dpt import TIPSv2DPTConfig
14
 
@@ -74,6 +74,10 @@ class TIPSv2DPTModel(PreTrainedModel):
74
 
75
  ppc = tuple(config.post_process_channels)
76
 
 
 
 
 
77
  self.depth_head = dpt_mod.DPTDepthHead(
78
  input_embed_dim=config.embed_dim, channels=config.channels,
79
  post_process_channels=ppc, readout_type=config.readout_type,
@@ -89,17 +93,9 @@ class TIPSv2DPTModel(PreTrainedModel):
89
  post_process_channels=ppc, readout_type=config.readout_type,
90
  num_classes=config.num_seg_classes,
91
  )
92
- self._backbone = None
93
-
94
- def _get_backbone(self):
95
- if self._backbone is None:
96
- self._backbone = AutoModel.from_pretrained(self.config.backbone_repo, trust_remote_code=True)
97
- self._backbone.to(self.device).eval()
98
- return self._backbone.vision_encoder
99
 
100
  def _extract_intermediate(self, pixel_values):
101
- backbone = self._get_backbone()
102
- intermediate = backbone.get_intermediate_layers(
103
  pixel_values, n=self.config.block_indices,
104
  reshape=True, return_class_token=True, norm=True,
105
  )
 
8
 
9
  import torch
10
  from huggingface_hub import hf_hub_download
11
+ from transformers import AutoConfig, AutoModel, PreTrainedModel
12
 
13
  from .configuration_dpt import TIPSv2DPTConfig
14
 
 
74
 
75
  ppc = tuple(config.post_process_channels)
76
 
77
+ backbone_config = AutoConfig.from_pretrained(config.backbone_repo, trust_remote_code=True)
78
+ backbone = AutoModel.from_config(backbone_config, trust_remote_code=True)
79
+ self.vision_encoder = backbone.vision_encoder
80
+
81
  self.depth_head = dpt_mod.DPTDepthHead(
82
  input_embed_dim=config.embed_dim, channels=config.channels,
83
  post_process_channels=ppc, readout_type=config.readout_type,
 
93
  post_process_channels=ppc, readout_type=config.readout_type,
94
  num_classes=config.num_seg_classes,
95
  )
 
 
 
 
 
 
 
96
 
97
  def _extract_intermediate(self, pixel_values):
98
+ intermediate = self.vision_encoder.get_intermediate_layers(
 
99
  pixel_values, n=self.config.block_indices,
100
  reshape=True, return_class_token=True, norm=True,
101
  )
preprocessor_config.json ADDED
@@ -0,0 +1,13 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "do_convert_rgb": true,
3
+ "do_normalize": false,
4
+ "do_rescale": true,
5
+ "do_resize": true,
6
+ "image_processor_type": "Tipsv2DptImageProcessor",
7
+ "resample": 2,
8
+ "rescale_factor": 0.00392156862745098,
9
+ "size": {
10
+ "height": 448,
11
+ "width": 448
12
+ }
13
+ }