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,408 @@
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-g14",
17
- "embed_dim": 1536,
18
- "block_indices": [
19
- 9,
20
- 19,
21
- 29,
22
- 39
23
- ],
24
- "post_process_channels": [
25
  192,
26
  384,
27
  768,
28
  1536
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": 1536,
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": 24,
25
+ "num_channels": 3,
26
+ "num_hidden_layers": 40,
27
+ "num_register_tokens": 1,
28
+ "out_features": [
29
+ "stage10",
30
+ "stage20",
31
+ "stage30",
32
+ "stage40"
33
+ ],
34
+ "out_indices": [
35
+ 10,
36
+ 20,
37
+ 30,
38
+ 40
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
+ "stage25",
70
+ "stage26",
71
+ "stage27",
72
+ "stage28",
73
+ "stage29",
74
+ "stage30",
75
+ "stage31",
76
+ "stage32",
77
+ "stage33",
78
+ "stage34",
79
+ "stage35",
80
+ "stage36",
81
+ "stage37",
82
+ "stage38",
83
+ "stage39",
84
+ "stage40"
85
+ ],
86
+ "use_swiglu_ffn": true
87
+ },
88
+ "depth_decoder_activation": "relu",
89
+ "fusion_hidden_size": 256,
90
+ "id2label": {
91
+ "0": "wall",
92
+ "1": "building",
93
+ "10": "cabinet",
94
+ "100": "poster",
95
+ "101": "stage",
96
+ "102": "van",
97
+ "103": "ship",
98
+ "104": "fountain",
99
+ "105": "conveyer belt",
100
+ "106": "canopy",
101
+ "107": "washer",
102
+ "108": "plaything",
103
+ "109": "swimming pool",
104
+ "11": "sidewalk",
105
+ "110": "stool",
106
+ "111": "barrel",
107
+ "112": "basket",
108
+ "113": "waterfall",
109
+ "114": "tent",
110
+ "115": "bag",
111
+ "116": "minibike",
112
+ "117": "cradle",
113
+ "118": "oven",
114
+ "119": "ball",
115
+ "12": "person",
116
+ "120": "food",
117
+ "121": "step",
118
+ "122": "tank",
119
+ "123": "trade name",
120
+ "124": "microwave",
121
+ "125": "pot",
122
+ "126": "animal",
123
+ "127": "bicycle",
124
+ "128": "lake",
125
+ "129": "dishwasher",
126
+ "13": "earth",
127
+ "130": "screen",
128
+ "131": "blanket",
129
+ "132": "sculpture",
130
+ "133": "hood",
131
+ "134": "sconce",
132
+ "135": "vase",
133
+ "136": "traffic light",
134
+ "137": "tray",
135
+ "138": "ashcan",
136
+ "139": "fan",
137
+ "14": "door",
138
+ "140": "pier",
139
+ "141": "crt screen",
140
+ "142": "plate",
141
+ "143": "monitor",
142
+ "144": "bulletin board",
143
+ "145": "shower",
144
+ "146": "radiator",
145
+ "147": "glass",
146
+ "148": "clock",
147
+ "149": "flag",
148
+ "15": "table",
149
+ "16": "mountain",
150
+ "17": "plant",
151
+ "18": "curtain",
152
+ "19": "chair",
153
+ "2": "sky",
154
+ "20": "car",
155
+ "21": "water",
156
+ "22": "painting",
157
+ "23": "sofa",
158
+ "24": "shelf",
159
+ "25": "house",
160
+ "26": "sea",
161
+ "27": "mirror",
162
+ "28": "rug",
163
+ "29": "field",
164
+ "3": "floor",
165
+ "30": "armchair",
166
+ "31": "seat",
167
+ "32": "fence",
168
+ "33": "desk",
169
+ "34": "rock",
170
+ "35": "wardrobe",
171
+ "36": "lamp",
172
+ "37": "bathtub",
173
+ "38": "railing",
174
+ "39": "cushion",
175
+ "4": "tree",
176
+ "40": "base",
177
+ "41": "box",
178
+ "42": "column",
179
+ "43": "signboard",
180
+ "44": "chest of drawers",
181
+ "45": "counter",
182
+ "46": "sand",
183
+ "47": "sink",
184
+ "48": "skyscraper",
185
+ "49": "fireplace",
186
+ "5": "ceiling",
187
+ "50": "refrigerator",
188
+ "51": "grandstand",
189
+ "52": "path",
190
+ "53": "stairs",
191
+ "54": "runway",
192
+ "55": "case",
193
+ "56": "pool table",
194
+ "57": "pillow",
195
+ "58": "screen door",
196
+ "59": "stairway",
197
+ "6": "road",
198
+ "60": "river",
199
+ "61": "bridge",
200
+ "62": "bookcase",
201
+ "63": "blind",
202
+ "64": "coffee table",
203
+ "65": "toilet",
204
+ "66": "flower",
205
+ "67": "book",
206
+ "68": "hill",
207
+ "69": "bench",
208
+ "7": "bed ",
209
+ "70": "countertop",
210
+ "71": "stove",
211
+ "72": "palm",
212
+ "73": "kitchen island",
213
+ "74": "computer",
214
+ "75": "swivel chair",
215
+ "76": "boat",
216
+ "77": "bar",
217
+ "78": "arcade machine",
218
+ "79": "hovel",
219
+ "8": "windowpane",
220
+ "80": "bus",
221
+ "81": "towel",
222
+ "82": "light",
223
+ "83": "truck",
224
+ "84": "tower",
225
+ "85": "chandelier",
226
+ "86": "awning",
227
+ "87": "streetlight",
228
+ "88": "booth",
229
+ "89": "television receiver",
230
+ "9": "grass",
231
+ "90": "airplane",
232
+ "91": "dirt track",
233
+ "92": "apparel",
234
+ "93": "pole",
235
+ "94": "land",
236
+ "95": "bannister",
237
+ "96": "escalator",
238
+ "97": "ottoman",
239
+ "98": "bottle",
240
+ "99": "buffet"
241
+ },
242
+ "label2id": {
243
+ "airplane": 90,
244
+ "animal": 126,
245
+ "apparel": 92,
246
+ "arcade machine": 78,
247
+ "armchair": 30,
248
+ "ashcan": 138,
249
+ "awning": 86,
250
+ "bag": 115,
251
+ "ball": 119,
252
+ "bannister": 95,
253
+ "bar": 77,
254
+ "barrel": 111,
255
+ "base": 40,
256
+ "basket": 112,
257
+ "bathtub": 37,
258
+ "bed ": 7,
259
+ "bench": 69,
260
+ "bicycle": 127,
261
+ "blanket": 131,
262
+ "blind": 63,
263
+ "boat": 76,
264
+ "book": 67,
265
+ "bookcase": 62,
266
+ "booth": 88,
267
+ "bottle": 98,
268
+ "box": 41,
269
+ "bridge": 61,
270
+ "buffet": 99,
271
+ "building": 1,
272
+ "bulletin board": 144,
273
+ "bus": 80,
274
+ "cabinet": 10,
275
+ "canopy": 106,
276
+ "car": 20,
277
+ "case": 55,
278
+ "ceiling": 5,
279
+ "chair": 19,
280
+ "chandelier": 85,
281
+ "chest of drawers": 44,
282
+ "clock": 148,
283
+ "coffee table": 64,
284
+ "column": 42,
285
+ "computer": 74,
286
+ "conveyer belt": 105,
287
+ "counter": 45,
288
+ "countertop": 70,
289
+ "cradle": 117,
290
+ "crt screen": 141,
291
+ "curtain": 18,
292
+ "cushion": 39,
293
+ "desk": 33,
294
+ "dirt track": 91,
295
+ "dishwasher": 129,
296
+ "door": 14,
297
+ "earth": 13,
298
+ "escalator": 96,
299
+ "fan": 139,
300
+ "fence": 32,
301
+ "field": 29,
302
+ "fireplace": 49,
303
+ "flag": 149,
304
+ "floor": 3,
305
+ "flower": 66,
306
+ "food": 120,
307
+ "fountain": 104,
308
+ "glass": 147,
309
+ "grandstand": 51,
310
+ "grass": 9,
311
+ "hill": 68,
312
+ "hood": 133,
313
+ "house": 25,
314
+ "hovel": 79,
315
+ "kitchen island": 73,
316
+ "lake": 128,
317
+ "lamp": 36,
318
+ "land": 94,
319
+ "light": 82,
320
+ "microwave": 124,
321
+ "minibike": 116,
322
+ "mirror": 27,
323
+ "monitor": 143,
324
+ "mountain": 16,
325
+ "ottoman": 97,
326
+ "oven": 118,
327
+ "painting": 22,
328
+ "palm": 72,
329
+ "path": 52,
330
+ "person": 12,
331
+ "pier": 140,
332
+ "pillow": 57,
333
+ "plant": 17,
334
+ "plate": 142,
335
+ "plaything": 108,
336
+ "pole": 93,
337
+ "pool table": 56,
338
+ "poster": 100,
339
+ "pot": 125,
340
+ "radiator": 146,
341
+ "railing": 38,
342
+ "refrigerator": 50,
343
+ "river": 60,
344
+ "road": 6,
345
+ "rock": 34,
346
+ "rug": 28,
347
+ "runway": 54,
348
+ "sand": 46,
349
+ "sconce": 134,
350
+ "screen": 130,
351
+ "screen door": 58,
352
+ "sculpture": 132,
353
+ "sea": 26,
354
+ "seat": 31,
355
+ "shelf": 24,
356
+ "ship": 103,
357
+ "shower": 145,
358
+ "sidewalk": 11,
359
+ "signboard": 43,
360
+ "sink": 47,
361
+ "sky": 2,
362
+ "skyscraper": 48,
363
+ "sofa": 23,
364
+ "stage": 101,
365
+ "stairs": 53,
366
+ "stairway": 59,
367
+ "step": 121,
368
+ "stool": 110,
369
+ "stove": 71,
370
+ "streetlight": 87,
371
+ "swimming pool": 109,
372
+ "swivel chair": 75,
373
+ "table": 15,
374
+ "tank": 122,
375
+ "television receiver": 89,
376
+ "tent": 114,
377
+ "toilet": 65,
378
+ "towel": 81,
379
+ "tower": 84,
380
+ "trade name": 123,
381
+ "traffic light": 136,
382
+ "tray": 137,
383
+ "tree": 4,
384
+ "truck": 83,
385
+ "van": 102,
386
+ "vase": 135,
387
+ "wall": 0,
388
+ "wardrobe": 35,
389
+ "washer": 107,
390
+ "water": 21,
391
+ "waterfall": 113,
392
+ "windowpane": 8
393
+ },
394
  "max_depth": 10.0,
395
+ "min_depth": 0.001,
396
+ "model_type": "tipsv2_dpt",
397
+ "neck_hidden_sizes": [
 
 
 
 
 
 
 
398
  192,
399
  384,
400
  768,
401
  1536
402
+ ],
403
+ "num_depth_bins": 256,
404
+ "readout_act": "gelu_pytorch_tanh",
405
+ "reassemble_factors": [
406
+ 4,
407
+ 2,
408
+ 1,
409
+ 0.5
410
+ ],
411
+ "semantic_loss_ignore_index": 255,
412
+ "transformers_version": "5.10.0.dev0"
413
+ }
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:637e1095c02ef28d35a516ad5d8e56d7b6fee3570bd58fd93986fbec20f4d1c8
3
- size 738064900
 
1
  version https://git-lfs.github.com/spec/v1
2
+ oid sha256:8ad9e99d69b6bc3a6c046f3b34532ddf04373adb56e71dd1ebb572f52075dc5e
3
+ size 5281937548
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
+ }