Add note on random selection of magnitude value

pull/33/head
Ross Wightman 5 years ago
parent b750b76f67
commit c06274e5a2

@ -251,18 +251,22 @@ class AutoAugmentOp:
self.level_fn = level_to_arg(hparams)[name] self.level_fn = level_to_arg(hparams)[name]
self.prob = prob self.prob = prob
self.magnitude = magnitude self.magnitude = magnitude
# If std deviation of magnitude is > 0, we introduce some randomness
# in the usually fixed policy and sample magnitude from normal dist
# with mean magnitude and std-dev of magnitude_std.
# NOTE This is being tested as it's not in paper or reference impl.
self.magnitude_std = 0.5 # FIXME add arg/hparam
self.kwargs = { self.kwargs = {
'fillcolor': hparams['img_mean'] if 'img_mean' in hparams else _FILL, 'fillcolor': hparams['img_mean'] if 'img_mean' in hparams else _FILL,
'resample': hparams['interpolation'] if 'interpolation' in hparams else _RANDOM_INTERPOLATION 'resample': hparams['interpolation'] if 'interpolation' in hparams else _RANDOM_INTERPOLATION
} }
self.rand_magnitude = True
def __call__(self, img): def __call__(self, img):
if self.prob < random.random(): if self.prob < random.random():
return img return img
magnitude = self.magnitude magnitude = self.magnitude
if self.rand_magnitude: if self.magnitude_std and self.magnitude_std > 0:
magnitude = random.normalvariate(magnitude, 0.5) magnitude = random.gauss(magnitude, self.magnitude_std)
magnitude = min(_MAX_LEVEL, max(0, magnitude)) magnitude = min(_MAX_LEVEL, max(0, magnitude))
level_args = self.level_fn(magnitude) level_args = self.level_fn(magnitude)
return self.aug_fn(img, *level_args, **self.kwargs) return self.aug_fn(img, *level_args, **self.kwargs)

Loading…
Cancel
Save