Bitwise operations including the return type and cast of numpy.random.choice

It is a Python3 series. So in the following, ʻint` is a multiple precision integer.

problem

We are introducing a bitboard to further promote the Reversi article I wrote earlier. Since 8x8 = 64 squares, it is expressed in 64 bits.

I wanted to randomly select one from the list of ʻint` and perform bit operation with the board, so I wrote the following code.

In [2]: array = [1, 2, 3]

In [3]: board = 0xfffffffffffffff

In [4]: np.random.choice(array) & board
Out[4]: 2

One is taken out from the list with numpy.random.choice and bit operation is performed. By the way, did you notice that the variable board uses only 15 fs, that is, the range that can be represented by 60 bits? Since the board is represented by up to 64 bits, try increasing f by one to make it 64 bits.

In [5]: array = [1, 2, 3]

In [6]: board = 0xffffffffffffffff

In [7]: np.random.choice(array) & board
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-7-cb36edc17d23> in <module>()
----> 1 np.random.choice(array) & board

TypeError: ufunc 'bitwise_and' not supported for the input types, and the inputs could not be safely coerced to any supported types according to the casting rule ''safe''

It seems that an error will occur if the number of bits of board is 64.

Cause

Let's take a look at the type of what appears in np.random.choice.

In [36]: type(np.random.choice(array))
Out[36]: numpy.int64

ʻArray is a list of ʻint, but it comes out as numpy.int64! It seems that numpy.int64 and 64-bit ʻint` cannot perform bit operations.

In [49]: np.int64(1) & board
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-49-3927f8b2d3d4> in <module>()
----> 1 np.int64(1) & board

TypeError: ufunc 'bitwise_and' not supported for the input types, and the inputs could not be safely coerced to any supported types according to the casting rule ''safe''

By the way, when I checked it, it seems that it is not possible to calculate ** by limiting it to 64-bit ʻint`. what is that.

In [24]: board = 0b111111111111111111111111111111111111111111111111111111111111111  # 63bit

In [25]: np.random.choice(array) & board
Out[25]: 1

In [26]: board = 0b1111111111111111111111111111111111111111111111111111111111111111  # 64bit

In [27]: np.random.choice(array) & board---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-27-cb36edc17d23> in <module>()
----> 1 np.random.choice(array) & board

TypeError: ufunc 'bitwise_and' not supported for the input types, and the inputs could not be safely coerced to any supported types according to the casting rule ''safe''

In [28]: board = 0b11111111111111111111111111111111111111111111111111111111111111111  # 65bit

In [29]: np.random.choice(array) & board
Out[29]: 3

Although casting is somehow written, the operation result of 63bit is numpy.int64 and the operation result of 65bit is ʻint`, so I don't know what to cast the boundary 64bit to. Is that so?

Workaround

Since numpy.int64 and 64-bit ʻint cannot be bitwise operated, it seems good to cast to numpy.uint64`.

In [55]: np.uint64(np.random.choice(array)) & board
Out[55]: 1

Maybe even negative numbers.

In [24]: np.uint64(-1)
Out[24]: 18446744073709551615

Considering the original board type, I would like to cast it to ʻint`, but I am not worried about the bit operation of negative numbers. I don't really understand this for multiple-precision integers.

Bonus postscript

In the first place, the return type of np.random.choice also changes depending on the contents.

In [13]: type(np.random.choice([1]))
Out[13]: numpy.int64

In [14]: type(np.random.choice([1<<63]))
Out[14]: numpy.uint64

In [15]: type(np.random.choice([1<<64]))
Out[15]: int

Too scary

Recommended Posts

Bitwise operations including the return type and cast of numpy.random.choice
Check the type and version of your Linux distribution
Netmiko automatically detects the type of network device and executes the command
The story of Python and the story of NaN
About the return value of pthread_mutex_init ()
About the return value of the histogram.
About the basic type of Go
This and that of the inclusion notation.
Review the concept and terminology of regression
[python] [meta] Is the type of python a type?
The story of trying deep3d and losing
[Python3] Understand the basics of file operations
I compared the moving average of IIR filter type with pandas and scipy