小白学Pytorch系列--Torch API (8)
创始人
2025-05-30 13:26:28
0

小白学Pytorch系列–Torch API (9)

Spectral Ops

stft

短时傅立叶变换 (STFT)。
STFT就是以滑动窗口的形式,在不同窗口内部做FFT。
得到结果为spectrum,横坐标时间,纵坐标频率,数值大小表示能量深度。


hop_length: 帧移(160)
winlength: 窗口长度(如果小于n_fft,那么按中间对称进行相乘,e.g. fft:[1,2,3,4], win:[1,1],input:[1,2,3,4]*[0,1,1,0])
center: False(直接做fft,droplast) 如果是True:按照对称性补对称的数,

x = torch.Tensor([[1,6,8,5,7,9,11]])
print(x.shape, x)y = torch.stft(x,n_fft=4,hop_length=2,win_length=4,window=torch.Tensor([1,1,0,0]),center=True)
print(y, y.shape)
import torch
from torch.autograd import Variable
from torch.nn.functional import conv1d
import matplotlib.pyplot as plt
from scipy.signal.windows import hann
import numpy as npstride = 512y = np.sin(2*np.pi*50*np.linspace(0,10,2048))+np.sin(2*np.pi*20*np.linspace(0,10,2048)) + np.random.normal(scale=1,size=2048)def create_filters(d,k,low=50,high=6000):x = np.arange(0, d, 1)wsin = np.empty((k,1,d), dtype=np.float32)wcos = np.empty((k,1,d), dtype=np.float32)start_freq = lowend_freq = high# num_cycles = start_freq*d/44000.# scaling_ind = np.log(end_freq/start_freq)/kwindow_mask = hann(2048, sym=False) # same as 0.5-0.5*np.cos(2*np.pi*x/(k))for ind in range(k):wsin[ind,0,:] = window_mask*np.sin(2*np.pi*ind/k*x)wcos[ind,0,:] = window_mask*np.cos(2*np.pi*ind/k*x)return wsin,wcoswsin, wcos = create_filters(2048,2048)wsin_var = Variable(torch.from_numpy(wsin), requires_grad=False)
wcos_var = Variable(torch.from_numpy(wcos),requires_grad=False)network_input = torch.from_numpy(y).float()
network_input = network_input.reshape(1,-1)zx = np.sqrt(conv1d(network_input[:,None,:], wsin_var, stride=stride).pow(2)+conv1d(network_input[:,None,:], wcos_var, stride=stride).pow(2))
pytorch_Xs = zx.cpu().numpy()
plt.plot(pytorch_Xs[0,:1025,0])

istft

短时间傅里叶逆变换。这应该是stft()的逆函数。

bartlett_window

Bartlett窗口功能。

blackman_window

blackman窗口功能。

hamming_window

Hamming窗口功能

hann_window

Hann窗口功能

kaiser_window

使用窗口长度window_length和形状参数beta计算Kaiser窗口。

相关内容

热门资讯

安卓系统包的预装软件,体验升级 你有没有发现,每次拿到新手机,打开安卓系统,总有一堆软件在那里等着你?这些软件就像小跟班一样,不管你...
安卓系统平板和win系统哪个好 你有没有想过,当你手捧一款平板,准备畅游知识的海洋时,是选择安卓系统还是Windows系统呢?这就像...
安卓系统如何下载立借,安卓系统... 你有没有想过,有时候资金周转不过来,急需一笔小钱?别急,今天就来教你怎么用安卓系统下载立借,轻松解决...
光遇ios系统如何加安卓系统,... 你有没有想过,你的光遇账号在iOS系统上玩得风生水起,但突然有一天,你想要在安卓系统上体验一番呢?别...
凤凰系统就是安卓吗,揭开其与安... 你有没有听说过凤凰系统?是不是觉得它和安卓有点像,但又不太一样?今天,我就来给你好好捋一捋,让你对凤...
电视系统安卓和云os,技术革新... 亲爱的读者们,你是否曾想过,家里的电视系统竟然也能如此智能?今天,就让我带你一起探索一下电视系统中的...
安卓系统基带工作原理,工作原理... 你有没有想过,你的安卓手机里那个默默无闻的基带,是怎么帮你打通世界的呢?它就像手机里的隐形英雄,每天...
锤子os安卓系统官网,创新与个... 你有没有听说过锤子OS安卓系统呢?这款系统可是近年来在手机圈里掀起了一股小热潮哦!今天,就让我带你一...
安卓值得玩的系统,盘点那些值得... 你知道吗?在手机世界里,安卓系统就像是个万能的魔法师,总能变出各种让人眼前一亮的玩法。今天,就让我带...
安卓系统如何app升级系统软件 你有没有发现,你的安卓手机最近是不是有点儿“慢吞吞”的?别急,这可能是你的手机在默默告诉你,是时候给...
电视盒子安卓系统设置,畅享智能... 亲爱的电视盒子用户们,你是否在享受高清影视的同时,也对安卓系统的设置感到一丝困惑呢?别担心,今天我就...
苹果13系统没有安卓好 你有没有发现,最近身边的朋友都在讨论苹果13的系统,说它没有安卓系统那么好。这可真是让人好奇,为什么...
vivo是安卓系统还是鸿蒙系统 你有没有想过,手机里的操作系统就像是我们的大脑,指挥着整个设备的运转呢?今天,咱们就来聊聊这个话题,...
王者安卓换苹果系统数据,数据迁... 你有没有想过,从王者安卓换到苹果系统,那数据迁移的过程,简直就像是一场穿越时空的冒险呢?想象你的英雄...
oppo安卓系统如何升级系统空... 亲爱的OPPO手机用户们,你是不是也遇到了这样的烦恼:想要升级安卓系统,却发现系统空间不足?别急,今...
安卓系统进不去无命令,安卓系统... 手机屏幕上突然黑屏了,安卓系统怎么就进不去了呢?别急,别慌,今天就来给你详细解析一下这个问题,让你轻...
适合安卓系统k歌软件,打造个人... 你有没有想过,在手机上也能尽情地唱出你的心声呢?现在,就让我带你走进一个神奇的世界,那就是适合安卓系...
安卓系统怎么充电的视频 手机电量告急,又到了充电的时刻啦!你是不是也和我一样,对安卓系统的充电方式充满了好奇?今天,就让我带...
ios系统与安卓系统的内存对比... 你有没有发现,手机里的世界越来越精彩了?各种应用层出不穷,游戏、社交、办公,样样都离不开手机。而支撑...
安卓7.1系统打开usb方法,... 你有没有想过,有时候你的安卓手机就像一个神秘的宝盒,里面藏着许多你意想不到的小秘密?今天,我就要给你...