Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Should I use np.absolute or np.abs?

Numpy provides both np.absolute and the alias np.abs defined via

from .numeric import absolute as abs

which seems to be in obvious violation of the zen of python:

There should be one-- and preferably only one --obvious way to do it.

So I'm guessing that there is a good reason for this.

I have personally been using np.abs in almost all of my code and looking at e.g. the number of search results for np.abs vs np.absolute on Stack Overflow it seems like an overwhelming majority does the same (2130 vs 244 hits).

Is there any reason i should preferentially use np.absolute over np.abs in my code, or should I simply go for the more "standard" np.abs?

like image 899
Jonas Adler Avatar asked Jul 31 '17 10:07

Jonas Adler


People also ask

What does NP abs do in Python?

Apply np. abs() on the array array_1D , it computes the absolute value of every value in the array. The output is a new array that contains those absolute values.

Is Python slow on abs?

It is not that the abs() function is slow; it is calling any function that is 'slow'. Looking up the global name is slower than looking up locals, and then you need to push the current frame on the stack, execute the function, then pop the frame from the stack again.

How do you take absolute value in Numpy?

Get absolute values from a NumPy array To get their absolute values, we call the numpy. abs() function and pass in that array as an argument. As a result NumPy returns a new array, with the absolute value of each number in the original array.

How do you take the absolute value of an array?

Y = abs( X ) returns the absolute value of each element in array X . If X is complex, abs(X) returns the complex magnitude.


2 Answers

It's likely because there a built-in functions with the same name, abs. The same is true for np.amax, np.amin and np.round_.

The aliases for the NumPy functions abs, min, max and round are only defined in the top-level package.

So np.abs and np.absolute are completely identical. It doesn't matter which one you use.

There are several advantages to the short names: They are shorter and they are known to Python programmers because the names are identical to the built-in Python functions. So end-users have it easier (less to type, less to remember).

But there are reasons to have different names too: NumPy (or more generally 3rd party packages) sometimes need the Python functions abs, min, etc. So inside the package they define functions with a different name so you can still access the Python functions - and just in the top-level of the package you expose the "shortcuts". Note: Different names are not the only available option in that case: One could work around that with the Python module builtins to access the built-in functions if one shadowed a built-in name.

It might also be the case (but that's pure speculation on my part) that they originally only included the long-named functions absolute (and so on) and only added the short aliases later. Being a large and well-used library the NumPy developers don't remove or deprecate stuff lightly. So they may just keep the long names around because it could break old code/scripts if they would remove them.

like image 73
MSeifert Avatar answered Oct 19 '22 04:10

MSeifert


There also is Python's built-in abs(), but really all those functions are doing the same thing. They're even exactly equally fast! (This is not the case for other functions, like max().)

enter image description here

Code to reproduce the plot:

import numpy as np
import perfplot


def np_absolute(x):
    return np.absolute(x)


def np_abs(x):
    return np.abs(x)


def builtin_abs(x):
    return abs(x)


b = perfplot.bench(
    setup=np.random.rand,
    kernels=[np_abs, np_absolute, builtin_abs],
    n_range=[2 ** k for k in range(25)],
    xlabel="len(data)",
)
b.save("out.png")
b.show()
like image 8
Nico Schlömer Avatar answered Oct 19 '22 04:10

Nico Schlömer