[CLIP] fix logit_scale init (#13436)

* fix logit_scale init

* add logit_scale_init_value as config param
This commit is contained in:
Suraj Patil
2021-09-08 14:21:13 +05:30
committed by GitHub
parent f667d5b260
commit c164c651dc
4 changed files with 42 additions and 3 deletions

View File

@@ -20,6 +20,8 @@ import os
import tempfile
import unittest
import numpy as np
import requests
from transformers import CLIPConfig, CLIPTextConfig, CLIPVisionConfig
from transformers.file_utils import is_torch_available, is_vision_available
@@ -478,6 +480,30 @@ class CLIPModelTest(ModelTesterMixin, unittest.TestCase):
def test_model_common_attributes(self):
pass
# override as the `logit_scale` parameter initilization is different for CLIP
def test_initialization(self):
config, inputs_dict = self.model_tester.prepare_config_and_inputs_for_common()
configs_no_init = _config_zero_init(config)
for model_class in self.all_model_classes:
model = model_class(config=configs_no_init)
for name, param in model.named_parameters():
if param.requires_grad:
# check if `logit_scale` is initilized as per the original implementation
if name == "logit_scale":
self.assertAlmostEqual(
param.data.item(),
np.log(1 / 0.07),
delta=1e-3,
msg=f"Parameter {name} of model {model_class} seems not properly initialized",
)
else:
self.assertIn(
((param.data.mean() * 1e9).round() / 1e9).item(),
[0.0, 1.0],
msg=f"Parameter {name} of model {model_class} seems not properly initialized",
)
def _create_and_check_torchscript(self, config, inputs_dict):
if not self.test_torchscript:
return