python 希尔伯特变换_用CUDA实现Hilbert变换

为了对一维阵列进行希尔伯特变换,必须:FFT阵列

将数组的一半加倍,另一半归零

逆FFT结果

我用的是PyCuLib。到目前为止我的代码def htransforms(data):

N = data.shape[0]

transforms = nb.cuda.device_array_like(data) # Allocates memory on GPU with size/dimensions of signal

transforms.dtype = np.complex64 # Change GPU array type to complex for FFT

pyculib.fft.fft(signal.astype(np.complex64), transforms) # Do FFT on GPU

transforms[1:N/2] *= 2.0 # THIS STEP DOESN'T WORK

transforms[N/2 + 1: N] = 0+0j # NEITHER DOES THIS ONE

pyculib.fft.ifft_inplace(transforms) # Do IFFT on GPU: in place (same memory)

envelope_function = transforms.copy_to_host() # Copy results to host (computer) memory

return abs(envelope_function)

我有一种感觉,这可能与Numba的CUDA接口本身有关。。。它允许像这样修改数组(或数组切片)的单个元素吗?我假设可能,因为变量transforms是一个numba.cuda.cudadrv.devicearray.DeviceNDArray,所以我认为它可能有一些与numpy的ndarray相同的操作。在

简而言之,使用Numba的device_arrays,在切片上做一个简单的操作最简单的方法是什么?我得到的错误是unsupported operand type(s) for *=: 'DeviceNDArray' and 'float'

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值