将 math.ceil 应用于 python 中的数组

Applying math.ceil to an array in python

将 math.ceil 应用于整个数组的正确方法是什么?请参阅以下 Python 代码:

    index = np.zeros(len(any_array))
    index2 = [random.random() for x in xrange(len(any_array))
    ##indexfinal=math.ceil(index2)  <-?

我想 return 数组中每个元素的上限值。文档指出 math.ceil return 是任何输入 x 的上限,但是将此上限函数应用于数组中包含的每个元素的最佳方法是什么?

您可以在 python 中使用 map() 函数,它将一个方法作为第一个参数,一个可迭代对象作为第二个参数,returns 一个可迭代对象,在每个元素上应用给定的方法。

import math

arr = [1.2, 5.6, 8.0, 9.4, 48.6, 5.3]

arr_ceil = map(math.ceil, arr)

print arr_ceil

>>> [2.0, 6.0, 8.0, 10.0, 49.0, 6.0]

请改用 numpy.ceil() 函数。 Numpy 包提供了大多数标准数学函数的矢量化版本。

In [29]: import numpy as np
In [30]: a = np.arange(2, 3, 0.1)
In [31]: a
Out[31]: array([ 2. ,  2.1,  2.2,  2.3,  2.4,  2.5,  2.6,  2.7,  2.8,  2.9])

In [32]: np.ceil(a)
Out[32]: array([ 2.,  3.,  3.,  3.,  3.,  3.,  3.,  3.,  3.,  3.])

此技术适用于任意 ndarray 个对象:

In [53]: a2 = np.indices((3,3)) * 0.9

In [54]: a2
Out[54]:
array([[[ 0. ,  0. ,  0. ],
        [ 0.9,  0.9,  0.9],
        [ 1.8,  1.8,  1.8]],

       [[ 0. ,  0.9,  1.8],
        [ 0. ,  0.9,  1.8],
        [ 0. ,  0.9,  1.8]]])

In [55]: np.ceil(a2)
Out[55]:
array([[[ 0.,  0.,  0.],
        [ 1.,  1.,  1.],
        [ 2.,  2.,  2.]],

       [[ 0.,  1.,  2.],
        [ 0.,  1.,  2.],
        [ 0.,  1.,  2.]]])