【发布时间】:2015-11-02 06:33:44
【问题描述】:
我想将一个日期时间数组传递给一个 Numba 函数(它不能被矢量化,否则会很慢)。我了解 Numba 支持 numpy.datetime64。但是,它似乎支持 datetime64[D](天精度)但不支持 datetime64[ns](毫秒精度)(我很难学到这一点:它记录了吗?)。
我尝试将 datetime64[ns] 转换为 datetime64[D],但似乎找不到方法!有什么想法吗?
我用下面的最少代码总结了我的问题。如果你运行testdf(mydates),也就是 datetime64[D],它可以正常工作。如果您运行 testdf(dates_input),即 datetime64[ns],则不会。请注意,此示例只是将日期传递给 Numba 函数,该函数(尚未)对它们做任何事情。我尝试将 dates_input 转换为 datetime64[D],但转换不起作用。在我的原始代码中,我从 SQL 表中读取到 pandas 数据帧,并且需要一列将每个日期的日期更改为 15 日。
import numba
import numpy as np
import pandas as pd
import datetime
mydates =np.array(['2010-01-01','2011-01-02']).astype('datetime64[D]')
df=pd.DataFrame()
df["rawdate"]=mydates
df["month_15"] = df["rawdate"].apply(lambda r: datetime.date( r.year, r.month,15 ) )
dates_input = df["month_15"].astype('datetime64[D]')
print dates_input.dtype # Why datetime64[ns] and not datetime64[D] ??
@numba.jit(nopython=True)
def testf(dates):
return 1
print testf(mydates)
如果我运行testdf(dates_input),我得到的错误是:
numba.typeinfer.TypingError: Failed at nopython (nopython frontend)
Var 'dates' unified to object: dates := {pyobject}
【问题讨论】:
-
这是一个非常有用的问题,但由于某种原因很难通过搜索找到。我在尝试对 pandas 数据使用
np.busday_count时收到了类似的错误,内容为:TypeError: Iterator operand 0 dtype could not be cast from dtype('<M8[ns]') to dtype('<M8[D]') according to the rule 'safe'