torch中傅里叶变换函数定义和用法的新旧版对比是怎样
Admin 2022-11-03 群英技术资讯 1217 次浏览
本篇内容介绍了“torch中傅里叶变换函数定义和用法的新旧版对比是怎样”的有关知识,在实际项目的操作过程或是学习过程中,不少人都会遇到这样的问题,接下来就让小编带大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!fft = torch.rfft(input, 2, normalized=True, onesided=False) # input 为输入的图片或者向量,dtype=torch.float32,size比如为[1,3,64,64] # signal_ndim(int):The number of dimensions in each signal,can only be 1、2、3 # normalized(bool,optional):controls wheather to return normallized results. Default:False # onesided(bool,optional):controls whether to return half of results to avoid redundancy.Default:True
上面例子中图像中 singal_ndim = 2 ,是因为输入图像是2维的。
1.7之后的版本中,如果要用 oneside output,则改用torch.fft.rfft();如果要用two-side output,则改用torch.fft.fft()
input= torch.arange(4) fft = torch.rfft(input, 2, normalized=True, onesided=False)
一维离散傅里叶变换
torch.fft.rfft(input,n=None,dim=-1,norm=None) --> Tensor
# input:Tensor
# n(int,optional):Output signal length. This determines the length of the
output signal.
# dim(int, optional): The dimension along which to take the one dimensional real IFFT.
# norm (str, optional): Normalization mode.
二维离散傅里叶变换
torch.fft.rfft2(input, s=None, dim=(-2, -1), norm=None, *, out=None) -> Tensor input (Tensor): the input tensor s (Tuple[int], optional): Signal size in the transformed dimensions. dim (Tuple[int], optional): Dimensions to be transformed. norm (str, optional): Normalization mode.
高维离散傅里叶变换
rfftn(input, s=None, dim=None, norm=None, *, out=None) -> Tensor input (Tensor): the input tensor s (Tuple[int], optional): Signal size in the transformed dimensions. dim (Tuple[int], optional): Dimensions to be transformed. norm (str, optional): Normalization mode. For the forward transform
import torch input = torch.rand(1,3,32,32) # 旧版pytorch.rfft()函数 fft = torch.rfft(input, 2, normalized=True, onesided=False) # 新版 pytorch.fft.rfft2()函数 output = torch.fft.fft2(input, dim=(-2, -1)) output = torch.stack((output.real, output_new.imag), -1)
ffted = torch.rfft(input, 1, onesided=False) to ffted = torch.view_as_real(torch.fft.fft(input, dim=1)) and iffted = torch.irfft(time_step_as_inner, 1, onesided=False) to iffted = torch.fft.irfft(torch.view_as_complex(time_step_as_inner), n=time_step_as_inner.shape[1], dim=1)
import numpy as np
import torch
import paddle
def paddle_fft(x,dim=-1):
if dim==-1:
return paddle.to_tensor(np.fft.fft(x.numpy()))
else:
shape= [i for i in range(len(x.shape))]
shape[dim],shape[-1]=shape[-1],shape[dim]
x=np.transpose(np.fft.fft(np.transpose(x.numpy(), shape)),shape)
return paddle.to_tensor(x)
if __name__ == '__main__':
data=paddle.to_tensor(np.array([[[1, 4, 3], [1, 2, 3]], [[1, 2, 3], [1, 2, 3]]]))
paddle_f_d=paddle_fft(paddle_fft(data,-1),-2)
torch_f_d =paddle_fft(torch.fft.fft(torch.Tensor(data.numpy()),dim=-1),-2)
print(paddle_f_d.numpy())
print(torch_f_d.numpy())
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文实例为大家分享了Python实现双人五子棋对局的具体代码,供大家参考,具体内容如下效果:自己需要两个棋子:服务器玩家全部代码:# 案列使用TCP连接# 这是服务器端import socketim
这篇文章主要介绍了python 实现列表的切片操作允许索引超出范围,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
大家都知道concat()函数可以沿着一条轴将多个对象进行堆叠,其使用方式类似数据库中的数据表合并,在使用merge()函数进行合并时,默认会使用重叠的列索引做为合并键,即取行索引重叠的部分,本文给大家介绍python 数据合并concat函数与merge函数,感兴趣的朋友一起看看吧
这篇文章主要介绍了Python数据读写之Python读写CSV文件,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下
大家好,本篇文章主要讲的是Python实现多任务进程示例,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008