我在一些python项目中使用numba(numba-0.20.0-n)。某个例行程序的编译失败
python: APFloat.cpp:273:
void interpretDecimal(
llvm::StringRef::iterator, llvm::StringRef::iterator, decimalInfo*):
Zusicherung »(*p == 'e' || *p == 'E') && "Invalid character in significand"«
nicht erfüllt.
Abgebrochen (Speicherabzug geschrieben)
对不起德语输出,但如果我将系统语言(Ubuntu 14.04 64bit)设置为英语
export LC_ALL=C
错误消失了。我怀疑十进制表示会导致一些奇怪的行为,因为在德国逗号“,”而不是点“。”用于分隔数字。当然,在我的代码中我只使用点作为分隔符,我认为所有编程语言都是如此。有什么想法吗?
修改 也许实际的代码可以帮助你们。请注意,只有在系统语言为德语(或至少不是英语)时才会出现错误:
from numba import jit
import numpy as np
@jit( nopython = True )
def numba_shift(array, shift):
'''
if shift > 0 -> left shift
if shift < 0 -> right shift
'''
if shift > 0:
for k in xrange(array.shape[0]):
#~ print k + shift, array.shape[0]
if k + shift >= array.shape[0] or k + shift < 0:
array[k] = 0
else:
array[k] = array[k+shift]
else:
for k in range(array.shape[0]-1,-1,-1):
#~ print k + shift, array.shape[0]
if k + shift >= array.shape[0] or k + shift < 0:
array[k] = 0
else:
array[k] = array[k+shift]
return array
@jit(nopython = True )
def numba_shift_image(image, shift, rows, cols ):
for row in xrange(rows):
shift = (row - rows / 2) * shift
new_row = np.zeros(cols)
for k in xrange(cols):
new_row[k] = image[row, k]
new_row = numba_shift(new_row, shift)
for k in xrange(cols):
image[row, k] = new_row[k]
return image
a = np.random.random((100,100))
b = numba_shift_image(a, 2, 100, 100)
答案 0 :(得分:0)
在anaconda上次更新以下软件包之后,这个错误似乎已得到解决:
llvmlite:0.6.0-py27_0 - &gt; 0.7.0-py27_3
numba:0.20.0-np19py27_0 - &gt; 0.21.0-np19py27_0