Issue 36788: Add clamp() function to builtins (original) (raw)
It would be nice to have a clamp() builtin in addition to min() and max() so one can type e.g. "clamp(value, 2, 5)" instead of having to type "min(max(value, 5), 2)".
I doubt this is important enough to go into builtins, the only practical use-case I know of for this function is with numbers, so this could go in the math module.
But putting that aside, there are some other problems:
it isn't clear that clamp() is meaningful for anything that could possibly need a key function;
the behaviour you have for iterable arguments is inconsistent with the existing behaviour of min(max(x, a), b):
min(max('a string', 'd'), 'm') => returns 'd' not ['d', 'd', 'm', 'm', 'm', 'i', 'm', 'g']
- your iterable behaviour is easily done with a comprehension and doesn't need to be supported by the function itself
[clamp(x, a, b) for x in values]
what do you intend clamp() to do with NAN arguments?
for numbers, it is sometimes useful to do one-sided clamping, e.g. clamp(x, -1, ∞).
You should read over this thread here:
https://mail.python.org/pipermail/python-ideas/2016-July/041262.html
Maybe port this discussion over python-ideas and after the resolution open it again?
Sounds good to me. Adding a new builtin function is a big deal that would likely need a PEP. I'm not keen on adding something like this to the math module, either, when it's so simple to construct from max and min.
Closing as rejected here; it can be re-opened if there's a strong consensus for adding it on the ideas list.