backbone.py 47 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222
  1. # Copyright 2021-2022 The Alibaba DAMO NLP Team Authors.
  2. # Copyright 2020 Microsoft and the Hugging Face Inc. team.
  3. #
  4. # Licensed under the Apache License, Version 2.0 (the "License");
  5. # you may not use this file except in compliance with the License.
  6. # You may obtain a copy of the License at
  7. #
  8. # http://www.apache.org/licenses/LICENSE-2.0
  9. #
  10. # Unless required by applicable law or agreed to in writing, software
  11. # distributed under the License is distributed on an "AS IS" BASIS,
  12. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. # See the License for the specific language governing permissions and
  14. # limitations under the License.
  15. """ PyTorch DeBERTa-v2 model."""
  16. from collections.abc import Sequence
  17. from typing import Optional, Tuple, Union
  18. import torch
  19. import torch.utils.checkpoint
  20. from torch import nn
  21. from torch.nn import LayerNorm
  22. from transformers.activations import ACT2FN
  23. from transformers.modeling_utils import PreTrainedModel
  24. from transformers.pytorch_utils import softmax_backward_data
  25. from modelscope.metainfo import Models
  26. from modelscope.models import Model, TorchModel
  27. from modelscope.models.builder import MODELS
  28. from modelscope.outputs import AttentionBackboneModelOutput
  29. from modelscope.utils import logger as logging
  30. from modelscope.utils.constant import Tasks
  31. from .configuration import DebertaV2Config
  32. logger = logging.get_logger()
  33. # Copied from transformers.models.deberta.modeling_deberta.ContextPooler
  34. class ContextPooler(nn.Module):
  35. def __init__(self, config):
  36. super().__init__()
  37. self.dense = nn.Linear(config.pooler_hidden_size,
  38. config.pooler_hidden_size)
  39. self.dropout = StableDropout(config.pooler_dropout)
  40. self.config = config
  41. def forward(self, hidden_states):
  42. # We "pool" the model by simply taking the hidden state corresponding
  43. # to the first token.
  44. context_token = hidden_states[:, 0]
  45. context_token = self.dropout(context_token)
  46. pooled_output = self.dense(context_token)
  47. pooled_output = ACT2FN[self.config.pooler_hidden_act](pooled_output)
  48. return pooled_output
  49. @property
  50. def output_dim(self):
  51. return self.config.hidden_size
  52. # Copied from transformers.models.deberta.modeling_deberta.XSoftmax with deberta->deberta_v2
  53. class XSoftmax(torch.autograd.Function):
  54. """
  55. Masked Softmax which is optimized for saving memory
  56. Args:
  57. input (`torch.tensor`): The input tensor that will apply softmax.
  58. mask (`torch.IntTensor`):
  59. The mask matrix where 0 indicate that element will be ignored in the softmax calculation.
  60. dim (int): The dimension that will apply softmax
  61. Example:
  62. >>> import torch
  63. >>> from transformers.models.deberta_v2.modeling_deberta_v2 import XSoftmax
  64. >>> # Make a tensor
  65. >>> x = torch.randn([4, 20, 100])
  66. >>> # Create a mask
  67. >>> mask = (x > 0).int()
  68. >>> # Specify the dimension to apply softmax
  69. >>> dim = -1
  70. >>> y = XSoftmax.apply(x, mask, dim)
  71. """
  72. @staticmethod
  73. def forward(self, input, mask, dim):
  74. self.dim = dim
  75. rmask = ~(mask.to(torch.bool))
  76. output = input.masked_fill(rmask,
  77. torch.tensor(torch.finfo(input.dtype).min))
  78. output = torch.softmax(output, self.dim)
  79. output.masked_fill_(rmask, 0)
  80. self.save_for_backward(output)
  81. return output
  82. @staticmethod
  83. def backward(self, grad_output):
  84. (output, ) = self.saved_tensors
  85. inputGrad = softmax_backward_data(self, grad_output, output, self.dim,
  86. output)
  87. return inputGrad, None, None
  88. @staticmethod
  89. def symbolic(g, self, mask, dim):
  90. import torch.onnx.symbolic_helper as sym_help
  91. from torch.onnx.symbolic_opset9 import masked_fill, softmax
  92. mask_cast_value = g.op(
  93. 'Cast', mask, to_i=sym_help.cast_pytorch_to_onnx['Long'])
  94. r_mask = g.op(
  95. 'Cast',
  96. g.op('Sub',
  97. g.op('Constant', value_t=torch.tensor(1, dtype=torch.int64)),
  98. mask_cast_value),
  99. to_i=sym_help.cast_pytorch_to_onnx['Byte'],
  100. )
  101. output = masked_fill(
  102. g, self, r_mask,
  103. g.op(
  104. 'Constant',
  105. value_t=torch.tensor(torch.finfo(self.type().dtype()).min)))
  106. output = softmax(g, output, dim)
  107. return masked_fill(
  108. g, output, r_mask,
  109. g.op('Constant', value_t=torch.tensor(0, dtype=torch.uint8)))
  110. # Copied from transformers.models.deberta.modeling_deberta.DropoutContext
  111. class DropoutContext(object):
  112. def __init__(self):
  113. self.dropout = 0
  114. self.mask = None
  115. self.scale = 1
  116. self.reuse_mask = True
  117. # Copied from transformers.models.deberta.modeling_deberta.get_mask
  118. def get_mask(input, local_context):
  119. if not isinstance(local_context, DropoutContext):
  120. dropout = local_context
  121. mask = None
  122. else:
  123. dropout = local_context.dropout
  124. dropout *= local_context.scale
  125. mask = local_context.mask if local_context.reuse_mask else None
  126. if dropout > 0 and mask is None:
  127. mask = (1 - torch.empty_like(input).bernoulli_(1 - dropout)).to(
  128. torch.bool)
  129. if isinstance(local_context, DropoutContext):
  130. if local_context.mask is None:
  131. local_context.mask = mask
  132. return mask, dropout
  133. # Copied from transformers.models.deberta.modeling_deberta.XDropout
  134. class XDropout(torch.autograd.Function):
  135. """Optimized dropout function to save computation and memory by using mask operation instead of multiplication."""
  136. @staticmethod
  137. def forward(ctx, input, local_ctx):
  138. mask, dropout = get_mask(input, local_ctx)
  139. ctx.scale = 1.0 / (1 - dropout)
  140. if dropout > 0:
  141. ctx.save_for_backward(mask)
  142. return input.masked_fill(mask, 0) * ctx.scale
  143. else:
  144. return input
  145. @staticmethod
  146. def backward(ctx, grad_output):
  147. if ctx.scale > 1:
  148. (mask, ) = ctx.saved_tensors
  149. return grad_output.masked_fill(mask, 0) * ctx.scale, None
  150. else:
  151. return grad_output, None
  152. @staticmethod
  153. def symbolic(g: torch._C.Graph, input: torch._C.Value,
  154. local_ctx: Union[float, DropoutContext]) -> torch._C.Value:
  155. from torch.onnx import symbolic_opset12
  156. dropout_p = local_ctx
  157. if isinstance(local_ctx, DropoutContext):
  158. dropout_p = local_ctx.dropout
  159. # StableDropout only calls this function when training.
  160. train = True
  161. # TODO: We should check if the opset_version being used to export
  162. # is > 12 here, but there's no good way to do that. As-is, if the
  163. # opset_version < 12, export will fail with a CheckerError.
  164. # Once https://github.com/pytorch/pytorch/issues/78391 is fixed, do something like:
  165. # if opset_version < 12:
  166. # return torch.onnx.symbolic_opset9.dropout(g, input, dropout_p, train)
  167. return symbolic_opset12.dropout(g, input, dropout_p, train)
  168. # Copied from transformers.models.deberta.modeling_deberta.StableDropout
  169. class StableDropout(nn.Module):
  170. """
  171. Optimized dropout module for stabilizing the training
  172. Args:
  173. drop_prob (float): the dropout probabilities
  174. """
  175. def __init__(self, drop_prob):
  176. super().__init__()
  177. self.drop_prob = drop_prob
  178. self.count = 0
  179. self.context_stack = None
  180. def forward(self, x):
  181. """
  182. Call the module
  183. Args:
  184. x (`torch.tensor`): The input tensor to apply dropout
  185. """
  186. if self.training and self.drop_prob > 0:
  187. return XDropout.apply(x, self.get_context())
  188. return x
  189. def clear_context(self):
  190. self.count = 0
  191. self.context_stack = None
  192. def init_context(self, reuse_mask=True, scale=1):
  193. if self.context_stack is None:
  194. self.context_stack = []
  195. self.count = 0
  196. for c in self.context_stack:
  197. c.reuse_mask = reuse_mask
  198. c.scale = scale
  199. def get_context(self):
  200. if self.context_stack is not None:
  201. if self.count >= len(self.context_stack):
  202. self.context_stack.append(DropoutContext())
  203. ctx = self.context_stack[self.count]
  204. ctx.dropout = self.drop_prob
  205. self.count += 1
  206. return ctx
  207. else:
  208. return self.drop_prob
  209. # Copied from transformers.models.deberta.modeling_deberta.DebertaSelfOutput with DebertaLayerNorm->LayerNorm
  210. class DebertaV2SelfOutput(nn.Module):
  211. def __init__(self, config):
  212. super().__init__()
  213. self.dense = nn.Linear(config.hidden_size, config.hidden_size)
  214. self.LayerNorm = LayerNorm(config.hidden_size, config.layer_norm_eps)
  215. self.dropout = StableDropout(config.hidden_dropout_prob)
  216. def forward(self, hidden_states, input_tensor):
  217. hidden_states = self.dense(hidden_states)
  218. hidden_states = self.dropout(hidden_states)
  219. hidden_states = self.LayerNorm(hidden_states + input_tensor)
  220. return hidden_states
  221. # Copied from transformers.models.deberta.modeling_deberta.DebertaAttention with Deberta->DebertaV2
  222. class DebertaV2Attention(nn.Module):
  223. def __init__(self, config):
  224. super().__init__()
  225. self.self = DisentangledSelfAttention(config)
  226. self.output = DebertaV2SelfOutput(config)
  227. self.config = config
  228. def forward(
  229. self,
  230. hidden_states,
  231. attention_mask,
  232. output_attentions=False,
  233. query_states=None,
  234. relative_pos=None,
  235. rel_embeddings=None,
  236. ):
  237. self_output = self.self(
  238. hidden_states,
  239. attention_mask,
  240. output_attentions,
  241. query_states=query_states,
  242. relative_pos=relative_pos,
  243. rel_embeddings=rel_embeddings,
  244. )
  245. if output_attentions:
  246. self_output, att_matrix = self_output
  247. if query_states is None:
  248. query_states = hidden_states
  249. attention_output = self.output(self_output, query_states)
  250. if output_attentions:
  251. return (attention_output, att_matrix)
  252. else:
  253. return attention_output
  254. # Copied from transformers.models.bert.modeling_bert.BertIntermediate with Bert->DebertaV2
  255. class DebertaV2Intermediate(nn.Module):
  256. def __init__(self, config):
  257. super().__init__()
  258. self.dense = nn.Linear(config.hidden_size, config.intermediate_size)
  259. if isinstance(config.hidden_act, str):
  260. self.intermediate_act_fn = ACT2FN[config.hidden_act]
  261. else:
  262. self.intermediate_act_fn = config.hidden_act
  263. def forward(self, hidden_states: torch.Tensor) -> torch.Tensor:
  264. hidden_states = self.dense(hidden_states)
  265. hidden_states = self.intermediate_act_fn(hidden_states)
  266. return hidden_states
  267. # Copied from transformers.models.deberta.modeling_deberta.DebertaOutput with DebertaLayerNorm->LayerNorm
  268. class DebertaV2Output(nn.Module):
  269. def __init__(self, config):
  270. super().__init__()
  271. self.dense = nn.Linear(config.intermediate_size, config.hidden_size)
  272. self.LayerNorm = LayerNorm(config.hidden_size, config.layer_norm_eps)
  273. self.dropout = StableDropout(config.hidden_dropout_prob)
  274. self.config = config
  275. def forward(self, hidden_states, input_tensor):
  276. hidden_states = self.dense(hidden_states)
  277. hidden_states = self.dropout(hidden_states)
  278. hidden_states = self.LayerNorm(hidden_states + input_tensor)
  279. return hidden_states
  280. # Copied from transformers.models.deberta.modeling_deberta.DebertaLayer with Deberta->DebertaV2
  281. class DebertaV2Layer(nn.Module):
  282. def __init__(self, config):
  283. super().__init__()
  284. self.attention = DebertaV2Attention(config)
  285. self.intermediate = DebertaV2Intermediate(config)
  286. self.output = DebertaV2Output(config)
  287. def forward(
  288. self,
  289. hidden_states,
  290. attention_mask,
  291. query_states=None,
  292. relative_pos=None,
  293. rel_embeddings=None,
  294. output_attentions=False,
  295. ):
  296. attention_output = self.attention(
  297. hidden_states,
  298. attention_mask,
  299. output_attentions=output_attentions,
  300. query_states=query_states,
  301. relative_pos=relative_pos,
  302. rel_embeddings=rel_embeddings,
  303. )
  304. if output_attentions:
  305. attention_output, att_matrix = attention_output
  306. intermediate_output = self.intermediate(attention_output)
  307. layer_output = self.output(intermediate_output, attention_output)
  308. if output_attentions:
  309. return (layer_output, att_matrix)
  310. else:
  311. return layer_output
  312. class ConvLayer(nn.Module):
  313. def __init__(self, config):
  314. super().__init__()
  315. kernel_size = getattr(config, 'conv_kernel_size', 3)
  316. groups = getattr(config, 'conv_groups', 1)
  317. self.conv_act = getattr(config, 'conv_act', 'tanh')
  318. self.conv = nn.Conv1d(
  319. config.hidden_size,
  320. config.hidden_size,
  321. kernel_size,
  322. padding=(kernel_size - 1) // 2,
  323. groups=groups)
  324. self.LayerNorm = LayerNorm(config.hidden_size, config.layer_norm_eps)
  325. self.dropout = StableDropout(config.hidden_dropout_prob)
  326. self.config = config
  327. def forward(self, hidden_states, residual_states, input_mask):
  328. out = self.conv(hidden_states.permute(0, 2, 1).contiguous()).permute(
  329. 0, 2, 1).contiguous()
  330. rmask = (1 - input_mask).bool()
  331. out.masked_fill_(rmask.unsqueeze(-1).expand(out.size()), 0)
  332. out = ACT2FN[self.conv_act](self.dropout(out))
  333. layer_norm_input = residual_states + out
  334. output = self.LayerNorm(layer_norm_input).to(layer_norm_input)
  335. if input_mask is None:
  336. output_states = output
  337. else:
  338. if input_mask.dim() != layer_norm_input.dim():
  339. if input_mask.dim() == 4:
  340. input_mask = input_mask.squeeze(1).squeeze(1)
  341. input_mask = input_mask.unsqueeze(2)
  342. input_mask = input_mask.to(output.dtype)
  343. output_states = output * input_mask
  344. return output_states
  345. class DebertaV2Encoder(nn.Module):
  346. """Modified BertEncoder with relative position bias support"""
  347. def __init__(self, config):
  348. super().__init__()
  349. self.layer = nn.ModuleList(
  350. [DebertaV2Layer(config) for _ in range(config.num_hidden_layers)])
  351. self.relative_attention = getattr(config, 'relative_attention', False)
  352. if self.relative_attention:
  353. self.max_relative_positions = getattr(config,
  354. 'max_relative_positions', -1)
  355. if self.max_relative_positions < 1:
  356. self.max_relative_positions = config.max_position_embeddings
  357. self.position_buckets = getattr(config, 'position_buckets', -1)
  358. pos_ebd_size = self.max_relative_positions * 2
  359. if self.position_buckets > 0:
  360. pos_ebd_size = self.position_buckets * 2
  361. self.rel_embeddings = nn.Embedding(pos_ebd_size,
  362. config.hidden_size)
  363. self.norm_rel_ebd = [
  364. x.strip()
  365. for x in getattr(config, 'norm_rel_ebd', 'none').lower().split('|')
  366. ]
  367. if 'layer_norm' in self.norm_rel_ebd:
  368. self.LayerNorm = LayerNorm(
  369. config.hidden_size,
  370. config.layer_norm_eps,
  371. elementwise_affine=True)
  372. self.conv = ConvLayer(config) if getattr(config, 'conv_kernel_size',
  373. 0) > 0 else None
  374. self.gradient_checkpointing = False
  375. def get_rel_embedding(self):
  376. rel_embeddings = self.rel_embeddings.weight if self.relative_attention else None
  377. if rel_embeddings is not None and ('layer_norm' in self.norm_rel_ebd):
  378. rel_embeddings = self.LayerNorm(rel_embeddings)
  379. return rel_embeddings
  380. def get_attention_mask(self, attention_mask):
  381. if attention_mask.dim() <= 2:
  382. extended_attention_mask = attention_mask.unsqueeze(1).unsqueeze(2)
  383. attention_mask = extended_attention_mask * extended_attention_mask.squeeze(
  384. -2).unsqueeze(-1)
  385. attention_mask = attention_mask.byte()
  386. elif attention_mask.dim() == 3:
  387. attention_mask = attention_mask.unsqueeze(1)
  388. return attention_mask
  389. def get_rel_pos(self, hidden_states, query_states=None, relative_pos=None):
  390. if self.relative_attention and relative_pos is None:
  391. q = query_states.size(
  392. -2) if query_states is not None else hidden_states.size(-2)
  393. relative_pos = build_relative_position(
  394. q,
  395. hidden_states.size(-2),
  396. bucket_size=self.position_buckets,
  397. max_position=self.max_relative_positions)
  398. return relative_pos
  399. def forward(
  400. self,
  401. hidden_states,
  402. attention_mask,
  403. output_hidden_states=True,
  404. output_attentions=False,
  405. query_states=None,
  406. relative_pos=None,
  407. return_dict=True,
  408. ):
  409. if attention_mask.dim() <= 2:
  410. input_mask = attention_mask
  411. else:
  412. input_mask = (attention_mask.sum(-2) > 0).byte()
  413. attention_mask = self.get_attention_mask(attention_mask)
  414. relative_pos = self.get_rel_pos(hidden_states, query_states,
  415. relative_pos)
  416. all_hidden_states = () if output_hidden_states else None
  417. all_attentions = () if output_attentions else None
  418. if isinstance(hidden_states, Sequence):
  419. next_kv = hidden_states[0]
  420. else:
  421. next_kv = hidden_states
  422. rel_embeddings = self.get_rel_embedding()
  423. output_states = next_kv
  424. for i, layer_module in enumerate(self.layer):
  425. if output_hidden_states:
  426. all_hidden_states = all_hidden_states + (output_states, )
  427. if self.gradient_checkpointing and self.training:
  428. def create_custom_forward(module):
  429. def custom_forward(*inputs):
  430. return module(*inputs, output_attentions)
  431. return custom_forward
  432. output_states = torch.utils.checkpoint.checkpoint(
  433. create_custom_forward(layer_module),
  434. next_kv,
  435. attention_mask,
  436. query_states,
  437. relative_pos,
  438. rel_embeddings,
  439. )
  440. else:
  441. output_states = layer_module(
  442. next_kv,
  443. attention_mask,
  444. query_states=query_states,
  445. relative_pos=relative_pos,
  446. rel_embeddings=rel_embeddings,
  447. output_attentions=output_attentions,
  448. )
  449. if output_attentions:
  450. output_states, att_m = output_states
  451. if i == 0 and self.conv is not None:
  452. output_states = self.conv(hidden_states, output_states,
  453. input_mask)
  454. if query_states is not None:
  455. query_states = output_states
  456. if isinstance(hidden_states, Sequence):
  457. next_kv = hidden_states[i + 1] if i + 1 < len(
  458. self.layer) else None
  459. else:
  460. next_kv = output_states
  461. if output_attentions:
  462. all_attentions = all_attentions + (att_m, )
  463. if output_hidden_states:
  464. all_hidden_states = all_hidden_states + (output_states, )
  465. if not return_dict:
  466. return tuple(
  467. v for v in [output_states, all_hidden_states, all_attentions]
  468. if v is not None)
  469. return AttentionBackboneModelOutput(
  470. last_hidden_state=output_states,
  471. hidden_states=all_hidden_states,
  472. attentions=all_attentions)
  473. def make_log_bucket_position(relative_pos, bucket_size, max_position):
  474. sign = torch.sign(relative_pos)
  475. mid = bucket_size // 2
  476. abs_pos = torch.where(
  477. (relative_pos < mid) & (relative_pos > -mid),
  478. torch.tensor(mid - 1).type_as(relative_pos),
  479. torch.abs(relative_pos),
  480. )
  481. log_pos = (
  482. torch.ceil(
  483. torch.log(abs_pos / mid)
  484. / torch.log(torch.tensor(
  485. (max_position - 1) / mid)) * (mid - 1)) + mid)
  486. bucket_pos = torch.where(abs_pos <= mid, relative_pos.type_as(log_pos),
  487. log_pos * sign)
  488. return bucket_pos
  489. def build_relative_position(query_size,
  490. key_size,
  491. bucket_size=-1,
  492. max_position=-1):
  493. """
  494. Build relative position according to the query and key
  495. We assume the absolute position of query \\(P_q\\) is range from (0, query_size) and the absolute position of key
  496. \\(P_k\\) is range from (0, key_size), The relative positions from query to key is \\(R_{q \\rightarrow k} = P_q -
  497. P_k\\)
  498. Args:
  499. query_size (int): the length of query
  500. key_size (int): the length of key
  501. bucket_size (int): the size of position bucket
  502. max_position (int): the maximum allowed absolute position
  503. Return:
  504. `torch.LongTensor`: A tensor with shape [1, query_size, key_size]
  505. """
  506. q_ids = torch.arange(0, query_size)
  507. k_ids = torch.arange(0, key_size)
  508. rel_pos_ids = q_ids[:, None] - k_ids[None, :]
  509. if bucket_size > 0 and max_position > 0:
  510. rel_pos_ids = make_log_bucket_position(rel_pos_ids, bucket_size,
  511. max_position)
  512. rel_pos_ids = rel_pos_ids.to(torch.long)
  513. rel_pos_ids = rel_pos_ids[:query_size, :]
  514. rel_pos_ids = rel_pos_ids.unsqueeze(0)
  515. return rel_pos_ids
  516. @torch.jit.script
  517. # Copied from transformers.models.deberta.modeling_deberta.c2p_dynamic_expand
  518. def c2p_dynamic_expand(c2p_pos, query_layer, relative_pos):
  519. return c2p_pos.expand([
  520. query_layer.size(0),
  521. query_layer.size(1),
  522. query_layer.size(2),
  523. relative_pos.size(-1)
  524. ])
  525. @torch.jit.script
  526. # Copied from transformers.models.deberta.modeling_deberta.p2c_dynamic_expand
  527. def p2c_dynamic_expand(c2p_pos, query_layer, key_layer):
  528. return c2p_pos.expand([
  529. query_layer.size(0),
  530. query_layer.size(1),
  531. key_layer.size(-2),
  532. key_layer.size(-2)
  533. ])
  534. @torch.jit.script
  535. # Copied from transformers.models.deberta.modeling_deberta.pos_dynamic_expand
  536. def pos_dynamic_expand(pos_index, p2c_att, key_layer):
  537. return pos_index.expand(p2c_att.size()[:2]
  538. + (pos_index.size(-2), key_layer.size(-2)))
  539. class DisentangledSelfAttention(nn.Module):
  540. """
  541. Disentangled self-attention module
  542. Parameters:
  543. config (`DebertaV2Config`):
  544. A model config class instance with the configuration to build a new model. The schema is similar to
  545. *BertConfig*, for more details, please refer [`DebertaV2Config`]
  546. """
  547. def __init__(self, config):
  548. super().__init__()
  549. if config.hidden_size % config.num_attention_heads != 0:
  550. raise ValueError(
  551. f'The hidden size ({config.hidden_size}) is not a multiple of the number of attention '
  552. f'heads ({config.num_attention_heads})')
  553. self.num_attention_heads = config.num_attention_heads
  554. _attention_head_size = config.hidden_size // config.num_attention_heads
  555. self.attention_head_size = getattr(config, 'attention_head_size',
  556. _attention_head_size)
  557. self.all_head_size = self.num_attention_heads * self.attention_head_size
  558. self.query_proj = nn.Linear(
  559. config.hidden_size, self.all_head_size, bias=True)
  560. self.key_proj = nn.Linear(
  561. config.hidden_size, self.all_head_size, bias=True)
  562. self.value_proj = nn.Linear(
  563. config.hidden_size, self.all_head_size, bias=True)
  564. self.share_att_key = getattr(config, 'share_att_key', False)
  565. self.pos_att_type = config.pos_att_type if config.pos_att_type is not None else []
  566. self.relative_attention = getattr(config, 'relative_attention', False)
  567. if self.relative_attention:
  568. self.position_buckets = getattr(config, 'position_buckets', -1)
  569. self.max_relative_positions = getattr(config,
  570. 'max_relative_positions', -1)
  571. if self.max_relative_positions < 1:
  572. self.max_relative_positions = config.max_position_embeddings
  573. self.pos_ebd_size = self.max_relative_positions
  574. if self.position_buckets > 0:
  575. self.pos_ebd_size = self.position_buckets
  576. self.pos_dropout = StableDropout(config.hidden_dropout_prob)
  577. if not self.share_att_key:
  578. if 'c2p' in self.pos_att_type:
  579. self.pos_key_proj = nn.Linear(
  580. config.hidden_size, self.all_head_size, bias=True)
  581. if 'p2c' in self.pos_att_type:
  582. self.pos_query_proj = nn.Linear(config.hidden_size,
  583. self.all_head_size)
  584. self.dropout = StableDropout(config.attention_probs_dropout_prob)
  585. def transpose_for_scores(self, x, attention_heads):
  586. new_x_shape = x.size()[:-1] + (attention_heads, -1)
  587. x = x.view(new_x_shape)
  588. return x.permute(0, 2, 1, 3).contiguous().view(-1, x.size(1),
  589. x.size(-1))
  590. def forward(
  591. self,
  592. hidden_states,
  593. attention_mask,
  594. output_attentions=False,
  595. query_states=None,
  596. relative_pos=None,
  597. rel_embeddings=None,
  598. ):
  599. """
  600. Call the module
  601. Args:
  602. hidden_states (`torch.FloatTensor`):
  603. Input states to the module usually the output from previous layer, it will be the Q,K and V in
  604. *Attention(Q,K,V)*
  605. attention_mask (`torch.ByteTensor`):
  606. An attention mask matrix of shape [*B*, *N*, *N*] where *B* is the batch size, *N* is the maximum
  607. sequence length in which element [i,j] = *1* means the *i* th token in the input can attend to the *j*
  608. th token.
  609. output_attentions (`bool`, optional):
  610. Whether return the attention matrix.
  611. query_states (`torch.FloatTensor`, optional):
  612. The *Q* state in *Attention(Q,K,V)*.
  613. relative_pos (`torch.LongTensor`):
  614. The relative position encoding between the tokens in the sequence. It's of shape [*B*, *N*, *N*] with
  615. values ranging in [*-max_relative_positions*, *max_relative_positions*].
  616. rel_embeddings (`torch.FloatTensor`):
  617. The embedding of relative distances. It's a tensor of shape [\\(2 \\times
  618. \\text{max_relative_positions}\\), *hidden_size*].
  619. """
  620. if query_states is None:
  621. query_states = hidden_states
  622. query_layer = self.transpose_for_scores(
  623. self.query_proj(query_states), self.num_attention_heads)
  624. key_layer = self.transpose_for_scores(
  625. self.key_proj(hidden_states), self.num_attention_heads)
  626. value_layer = self.transpose_for_scores(
  627. self.value_proj(hidden_states), self.num_attention_heads)
  628. rel_att = None
  629. # Take the dot product between "query" and "key" to get the raw attention scores.
  630. scale_factor = 1
  631. if 'c2p' in self.pos_att_type:
  632. scale_factor += 1
  633. if 'p2c' in self.pos_att_type:
  634. scale_factor += 1
  635. scale = torch.sqrt(
  636. torch.tensor(query_layer.size(-1), dtype=torch.float)
  637. * scale_factor)
  638. attention_scores = torch.bmm(query_layer, key_layer.transpose(
  639. -1, -2)) / torch.tensor(
  640. scale, dtype=query_layer.dtype)
  641. if self.relative_attention:
  642. rel_embeddings = self.pos_dropout(rel_embeddings)
  643. rel_att = self.disentangled_attention_bias(query_layer, key_layer,
  644. relative_pos,
  645. rel_embeddings,
  646. scale_factor)
  647. if rel_att is not None:
  648. attention_scores = attention_scores + rel_att
  649. attention_scores = attention_scores
  650. attention_scores = attention_scores.view(-1, self.num_attention_heads,
  651. attention_scores.size(-2),
  652. attention_scores.size(-1))
  653. # bsz x height x length x dimension
  654. attention_probs = XSoftmax.apply(attention_scores, attention_mask, -1)
  655. attention_probs = self.dropout(attention_probs)
  656. context_layer = torch.bmm(
  657. attention_probs.view(-1, attention_probs.size(-2),
  658. attention_probs.size(-1)), value_layer)
  659. context_layer = (
  660. context_layer.view(-1, self.num_attention_heads,
  661. context_layer.size(-2),
  662. context_layer.size(-1)).permute(0, 2, 1,
  663. 3).contiguous())
  664. new_context_layer_shape = context_layer.size()[:-2] + (-1, )
  665. context_layer = context_layer.view(new_context_layer_shape)
  666. if output_attentions:
  667. return (context_layer, attention_probs)
  668. else:
  669. return context_layer
  670. def disentangled_attention_bias(self, query_layer, key_layer, relative_pos,
  671. rel_embeddings, scale_factor):
  672. if relative_pos is None:
  673. q = query_layer.size(-2)
  674. relative_pos = build_relative_position(
  675. q,
  676. key_layer.size(-2),
  677. bucket_size=self.position_buckets,
  678. max_position=self.max_relative_positions)
  679. if relative_pos.dim() == 2:
  680. relative_pos = relative_pos.unsqueeze(0).unsqueeze(0)
  681. elif relative_pos.dim() == 3:
  682. relative_pos = relative_pos.unsqueeze(1)
  683. # bsz x height x query x key
  684. elif relative_pos.dim() != 4:
  685. raise ValueError(
  686. f'Relative position ids must be of dim 2 or 3 or 4. {relative_pos.dim()}'
  687. )
  688. att_span = self.pos_ebd_size
  689. relative_pos = relative_pos.long().to(query_layer.device)
  690. rel_embeddings = rel_embeddings[0:att_span * 2, :].unsqueeze(0)
  691. if self.share_att_key:
  692. pos_query_layer = self.transpose_for_scores(
  693. self.query_proj(rel_embeddings),
  694. self.num_attention_heads).repeat(
  695. query_layer.size(0) // self.num_attention_heads, 1, 1)
  696. pos_key_layer = self.transpose_for_scores(
  697. self.key_proj(rel_embeddings),
  698. self.num_attention_heads).repeat(
  699. query_layer.size(0) // self.num_attention_heads, 1, 1)
  700. else:
  701. if 'c2p' in self.pos_att_type:
  702. pos_key_layer = self.transpose_for_scores(
  703. self.pos_key_proj(rel_embeddings),
  704. self.num_attention_heads).repeat(
  705. query_layer.size(0) // self.num_attention_heads, 1,
  706. 1) # .split(self.all_head_size, dim=-1)
  707. if 'p2c' in self.pos_att_type:
  708. pos_query_layer = self.transpose_for_scores(
  709. self.pos_query_proj(rel_embeddings),
  710. self.num_attention_heads).repeat(
  711. query_layer.size(0) // self.num_attention_heads, 1,
  712. 1) # .split(self.all_head_size, dim=-1)
  713. score = 0
  714. # content->position
  715. if 'c2p' in self.pos_att_type:
  716. scale = torch.sqrt(
  717. torch.tensor(pos_key_layer.size(-1), dtype=torch.float)
  718. * scale_factor)
  719. c2p_att = torch.bmm(query_layer, pos_key_layer.transpose(-1, -2))
  720. c2p_pos = torch.clamp(relative_pos + att_span, 0, att_span * 2 - 1)
  721. c2p_att = torch.gather(
  722. c2p_att,
  723. dim=-1,
  724. index=c2p_pos.squeeze(0).expand([
  725. query_layer.size(0),
  726. query_layer.size(1),
  727. relative_pos.size(-1)
  728. ]),
  729. )
  730. score += c2p_att / torch.tensor(scale, dtype=c2p_att.dtype)
  731. # position->content
  732. if 'p2c' in self.pos_att_type:
  733. scale = torch.sqrt(
  734. torch.tensor(pos_query_layer.size(-1), dtype=torch.float)
  735. * scale_factor)
  736. if key_layer.size(-2) != query_layer.size(-2):
  737. r_pos = build_relative_position(
  738. key_layer.size(-2),
  739. key_layer.size(-2),
  740. bucket_size=self.position_buckets,
  741. max_position=self.max_relative_positions,
  742. ).to(query_layer.device)
  743. r_pos = r_pos.unsqueeze(0)
  744. else:
  745. r_pos = relative_pos
  746. p2c_pos = torch.clamp(-r_pos + att_span, 0, att_span * 2 - 1)
  747. p2c_att = torch.bmm(key_layer, pos_query_layer.transpose(-1, -2))
  748. p2c_att = torch.gather(
  749. p2c_att,
  750. dim=-1,
  751. index=p2c_pos.squeeze(0).expand([
  752. query_layer.size(0),
  753. key_layer.size(-2),
  754. key_layer.size(-2)
  755. ]),
  756. ).transpose(-1, -2)
  757. score += p2c_att / torch.tensor(scale, dtype=p2c_att.dtype)
  758. return score
  759. # Copied from transformers.models.deberta.modeling_deberta.DebertaEmbeddings with DebertaLayerNorm->LayerNorm
  760. class DebertaV2Embeddings(nn.Module):
  761. """Construct the embeddings from word, position and token_type embeddings."""
  762. def __init__(self, config):
  763. super().__init__()
  764. pad_token_id = getattr(config, 'pad_token_id', 0)
  765. self.embedding_size = getattr(config, 'embedding_size',
  766. config.hidden_size)
  767. self.word_embeddings = nn.Embedding(
  768. config.vocab_size, self.embedding_size, padding_idx=pad_token_id)
  769. self.position_biased_input = getattr(config, 'position_biased_input',
  770. True)
  771. if not self.position_biased_input:
  772. self.position_embeddings = None
  773. else:
  774. self.position_embeddings = nn.Embedding(
  775. config.max_position_embeddings, self.embedding_size)
  776. if config.type_vocab_size > 0:
  777. self.token_type_embeddings = nn.Embedding(config.type_vocab_size,
  778. self.embedding_size)
  779. if self.embedding_size != config.hidden_size:
  780. self.embed_proj = nn.Linear(
  781. self.embedding_size, config.hidden_size, bias=False)
  782. self.LayerNorm = LayerNorm(config.hidden_size, config.layer_norm_eps)
  783. self.dropout = StableDropout(config.hidden_dropout_prob)
  784. self.config = config
  785. # position_ids (1, len position emb) is contiguous in memory and exported when serialized
  786. self.register_buffer(
  787. 'position_ids',
  788. torch.arange(config.max_position_embeddings).expand((1, -1)))
  789. def forward(self,
  790. input_ids=None,
  791. token_type_ids=None,
  792. position_ids=None,
  793. mask=None,
  794. inputs_embeds=None):
  795. if input_ids is not None:
  796. input_shape = input_ids.size()
  797. else:
  798. input_shape = inputs_embeds.size()[:-1]
  799. seq_length = input_shape[1]
  800. if position_ids is None:
  801. position_ids = self.position_ids[:, :seq_length]
  802. if token_type_ids is None:
  803. token_type_ids = torch.zeros(
  804. input_shape, dtype=torch.long, device=self.position_ids.device)
  805. if inputs_embeds is None:
  806. inputs_embeds = self.word_embeddings(input_ids)
  807. if self.position_embeddings is not None:
  808. position_embeddings = self.position_embeddings(position_ids.long())
  809. else:
  810. position_embeddings = torch.zeros_like(inputs_embeds)
  811. embeddings = inputs_embeds
  812. if self.position_biased_input:
  813. embeddings += position_embeddings
  814. if self.config.type_vocab_size > 0:
  815. token_type_embeddings = self.token_type_embeddings(token_type_ids)
  816. embeddings += token_type_embeddings
  817. if self.embedding_size != self.config.hidden_size:
  818. embeddings = self.embed_proj(embeddings)
  819. embeddings = self.LayerNorm(embeddings)
  820. if mask is not None:
  821. if mask.dim() != embeddings.dim():
  822. if mask.dim() == 4:
  823. mask = mask.squeeze(1).squeeze(1)
  824. mask = mask.unsqueeze(2)
  825. mask = mask.to(embeddings.dtype)
  826. embeddings = embeddings * mask
  827. embeddings = self.dropout(embeddings)
  828. return embeddings
  829. # Copied from transformers.models.deberta.modeling_deberta.DebertaPreTrainedModel with Deberta->DebertaV2
  830. class DebertaV2PreTrainedModel(TorchModel, PreTrainedModel):
  831. """
  832. An abstract class to handle weights initialization and a simple interface for downloading and loading pretrained
  833. models.
  834. """
  835. config_class = DebertaV2Config
  836. base_model_prefix = 'deberta'
  837. _keys_to_ignore_on_load_missing = ['position_ids']
  838. _keys_to_ignore_on_load_unexpected = ['position_embeddings']
  839. supports_gradient_checkpointing = True
  840. def __init__(self, config, **kwargs):
  841. super().__init__(config.name_or_path, **kwargs)
  842. super(Model, self).__init__(config)
  843. def _init_weights(self, module):
  844. """Initialize the weights."""
  845. if isinstance(module, nn.Linear):
  846. # Slightly different from the TF version which uses truncated_normal for initialization
  847. # cf https://github.com/pytorch/pytorch/pull/5617
  848. module.weight.data.normal_(
  849. mean=0.0, std=self.config.initializer_range)
  850. if module.bias is not None:
  851. module.bias.data.zero_()
  852. elif isinstance(module, nn.Embedding):
  853. module.weight.data.normal_(
  854. mean=0.0, std=self.config.initializer_range)
  855. if module.padding_idx is not None:
  856. module.weight.data[module.padding_idx].zero_()
  857. def _set_gradient_checkpointing(self, module, value=False):
  858. if isinstance(module, DebertaV2Encoder):
  859. module.gradient_checkpointing = value
  860. @classmethod
  861. def _instantiate(cls, **kwargs):
  862. model_dir = kwargs.pop('model_dir', None)
  863. if model_dir is None:
  864. ponet_config = DebertaV2Config(**kwargs)
  865. model = cls(ponet_config)
  866. else:
  867. model = super(
  868. Model,
  869. cls).from_pretrained(pretrained_model_name_or_path=model_dir)
  870. return model
  871. @MODELS.register_module(Tasks.backbone, module_name=Models.deberta_v2)
  872. # Copied from transformers.models.deberta.modeling_deberta.DebertaModel with Deberta->DebertaV2
  873. class DebertaV2Model(DebertaV2PreTrainedModel):
  874. """The bare DeBERTa_v2 Model transformer outputting raw hidden-states without any specific head on top.
  875. The DeBERTa model was proposed in [DeBERTa: Decoding-enhanced BERT with Disentangled
  876. Attention](https://arxiv.org/abs/2006.03654) by Pengcheng He, Xiaodong Liu, Jianfeng Gao, Weizhu Chen. It's build
  877. on top of BERT/RoBERTa with two improvements, i.e. disentangled attention and enhanced mask decoder. With those two
  878. improvements, it out perform BERT/RoBERTa on a majority of tasks with 80GB pretraining data.
  879. This model is also a PyTorch [torch.nn.Module](https://pytorch.org/docs/stable/nn.html#torch.nn.Module) subclass.
  880. Use it as a regular PyTorch Module and refer to the PyTorch documentation for all matter related to general usage
  881. and behavior.
  882. Parameters:
  883. config (`DebertaV2Config`): Model configuration class with all the parameters of the model.
  884. Initializing with a config file does not load the weights associated with the model, only the
  885. configuration.
  886. """
  887. def __init__(self, config, **kwargs):
  888. super().__init__(config)
  889. self.embeddings = DebertaV2Embeddings(config)
  890. self.encoder = DebertaV2Encoder(config)
  891. self.z_steps = 0
  892. self.config = config
  893. # Initialize weights and apply final processing
  894. self.post_init()
  895. def get_input_embeddings(self):
  896. return self.embeddings.word_embeddings
  897. def set_input_embeddings(self, new_embeddings):
  898. self.embeddings.word_embeddings = new_embeddings
  899. def _prune_heads(self, heads_to_prune):
  900. """
  901. Prunes heads of the model. heads_to_prune: dict of {layer_num: list of heads to prune in this layer} See base
  902. class PreTrainedModel
  903. """
  904. raise NotImplementedError(
  905. 'The prune function is not implemented in DeBERTa model.')
  906. def forward(
  907. self,
  908. input_ids: Optional[torch.Tensor] = None,
  909. attention_mask: Optional[torch.Tensor] = None,
  910. token_type_ids: Optional[torch.Tensor] = None,
  911. position_ids: Optional[torch.Tensor] = None,
  912. inputs_embeds: Optional[torch.Tensor] = None,
  913. output_attentions: Optional[bool] = None,
  914. output_hidden_states: Optional[bool] = None,
  915. return_dict: Optional[bool] = None,
  916. ) -> Union[Tuple, AttentionBackboneModelOutput]:
  917. r"""
  918. Args:
  919. input_ids (`torch.LongTensor` of shape `('batch_size, sequence_length')`):
  920. Indices of input sequence tokens in the vocabulary.
  921. attention_mask (`torch.FloatTensor` of shape `('batch_size, sequence_length')`, *optional*):
  922. Mask to avoid performing attention on padding token indices. Mask values selected in `[0, 1]`:
  923. - 1 for tokens that are **not masked**,
  924. - 0 for tokens that are **masked**.
  925. token_type_ids (`torch.LongTensor` of shape `('batch_size, sequence_length')`, *optional*):
  926. Segment token indices to indicate first and second portions of the inputs. Indices are selected in `[0,
  927. 1]`:
  928. - 0 corresponds to a *sentence A* token,
  929. - 1 corresponds to a *sentence B* token.
  930. position_ids (`torch.LongTensor` of shape `('batch_size, sequence_length')`, *optional*):
  931. Indices of positions of each input sequence tokens in the position embeddings. Selected in the range
  932. `[0,config.max_position_embeddings - 1]`.
  933. inputs_embeds (`torch.FloatTensor` of shape `('batch_size, sequence_length', hidden_size)`, *optional*):
  934. Optionally, instead of passing `input_ids` you can choose to directly pass an embedded representation.
  935. This is useful if you want more control over how to convert *input_ids* indices into associated
  936. vectors than the model's internal embedding lookup matrix.
  937. output_attentions (`bool`, *optional*):
  938. Whether or not to return the attentions tensors of all attention layers. See `attentions` under returned
  939. tensors for more detail.
  940. output_hidden_states (`bool`, *optional*):
  941. Whether or not to return the hidden states of all layers. See `hidden_states` under returned tensors for
  942. more detail.
  943. return_dict (`bool`, *optional*):
  944. Whether or not to return a dataclass instead of a plain tuple.
  945. Returns:
  946. Returns `modelscope.outputs.AttentionBackboneModelOutput`
  947. Examples:
  948. >>> from modelscope.models import Model
  949. >>> from modelscope.preprocessors import Preprocessor
  950. >>> model = Model.from_pretrained('damo/nlp_debertav2_fill-mask_chinese-lite', task='backbone')
  951. >>> preprocessor = Preprocessor.from_pretrained('damo/nlp_debertav2_fill-mask_chinese-lite')
  952. >>> print(model(**preprocessor('这是个测试')))
  953. """
  954. output_attentions = output_attentions if output_attentions is not None else self.config.output_attentions
  955. output_hidden_states = (
  956. output_hidden_states if output_hidden_states is not None else
  957. self.config.output_hidden_states)
  958. return_dict = return_dict if return_dict is not None else self.config.use_return_dict
  959. if input_ids is not None and inputs_embeds is not None:
  960. raise ValueError(
  961. 'You cannot specify both input_ids and inputs_embeds at the same time'
  962. )
  963. elif input_ids is not None:
  964. input_shape = input_ids.size()
  965. elif inputs_embeds is not None:
  966. input_shape = inputs_embeds.size()[:-1]
  967. else:
  968. raise ValueError(
  969. 'You have to specify either input_ids or inputs_embeds')
  970. device = input_ids.device if input_ids is not None else inputs_embeds.device
  971. if attention_mask is None:
  972. attention_mask = torch.ones(input_shape, device=device)
  973. if token_type_ids is None:
  974. token_type_ids = torch.zeros(
  975. input_shape, dtype=torch.long, device=device)
  976. embedding_output = self.embeddings(
  977. input_ids=input_ids,
  978. token_type_ids=token_type_ids,
  979. position_ids=position_ids,
  980. mask=attention_mask,
  981. inputs_embeds=inputs_embeds,
  982. )
  983. encoder_outputs = self.encoder(
  984. embedding_output,
  985. attention_mask,
  986. output_hidden_states=True,
  987. output_attentions=output_attentions,
  988. return_dict=return_dict,
  989. )
  990. encoded_layers = encoder_outputs[1]
  991. if self.z_steps > 1:
  992. hidden_states = encoded_layers[-2]
  993. layers = [self.encoder.layer[-1] for _ in range(self.z_steps)]
  994. query_states = encoded_layers[-1]
  995. rel_embeddings = self.encoder.get_rel_embedding()
  996. attention_mask = self.encoder.get_attention_mask(attention_mask)
  997. rel_pos = self.encoder.get_rel_pos(embedding_output)
  998. for layer in layers[1:]:
  999. query_states = layer(
  1000. hidden_states,
  1001. attention_mask,
  1002. output_attentions=False,
  1003. query_states=query_states,
  1004. relative_pos=rel_pos,
  1005. rel_embeddings=rel_embeddings,
  1006. )
  1007. encoded_layers.append(query_states)
  1008. sequence_output = encoded_layers[-1]
  1009. if not return_dict:
  1010. return (sequence_output, ) + encoder_outputs[
  1011. (1 if output_hidden_states else 2):]
  1012. return AttentionBackboneModelOutput(
  1013. last_hidden_state=sequence_output,
  1014. hidden_states=encoder_outputs.hidden_states
  1015. if output_hidden_states else None,
  1016. attentions=encoder_outputs.attentions,
  1017. )