I dislike this API. What's the point of calling clamp(x)? clamp(b, a) is min(a, b) and clamp(a, max_val=b) is just max(a, b). My point is that all parameters must be mandatory.
bottom, top = None, None# ... some code that might derive values for bottom and/or topx = clamp(x, bottom, top)
y = clamp(y, max_val=100)
Le 31 juil. 2016 6:41 AM, "David Mertz" <mertz@gnosis.cx> a écrit :Is there some special subtlety or edge case where a hand rolled function will go wrong? I like the SO version spelled like this (a little fleshed out):
def clamp(val, min_val=None, max_val=None):
min_val = val if min_val is None else min_val
max_val = val if max_val is None else max_val
assert min_val <= max_val
return max(min(val , max_val), min_val)On Sat, Jul 30, 2016 at 2:57 PM, Neil Girdhar <mistersheik@gmail.com> wrote:Am I right that there is no *obvious* way to do this? If so, I suggest adding math.clip (or math.clamp) to the standard library that has the meaning: