国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

從視頻到音頻:使用VIT進行音頻分類

人工智能 機器學(xué)習(xí)
就機器學(xué)習(xí)而言,音頻本身是一個有廣泛應(yīng)用的完整的領(lǐng)域,包括語音識別、音樂分類和聲音事件檢測等等。

就機器學(xué)習(xí)而言,音頻本身是一個有廣泛應(yīng)用的完整的領(lǐng)域,包括語音識別、音樂分類和聲音事件檢測等等。傳統(tǒng)上音頻分類一直使用譜圖分析和隱馬爾可夫模型等方法,這些方法已被證明是有效的,但也有其局限性。近期VIT已經(jīng)成為音頻任務(wù)的一個有前途的替代品,OpenAI的Whisper就是一個很好的例子。

在本文中,我們將利用ViT - Vision Transformer的是一個Pytorch實現(xiàn)在音頻分類數(shù)據(jù)集GTZAN數(shù)據(jù)集-音樂類型分類上訓(xùn)練它。

數(shù)據(jù)集介紹

GTZAN 數(shù)據(jù)集是在音樂流派識別 (MGR) 研究中最常用的公共數(shù)據(jù)集。 這些文件是在 2000-2001 年從各種來源收集的,包括個人 CD、收音機、麥克風(fēng)錄音,代表各種錄音條件下的聲音。

這個數(shù)據(jù)集由子文件夾組成,每個子文件夾是一種類型。

加載數(shù)據(jù)集

我們將加載每個.wav文件,并通過librosa庫生成相應(yīng)的Mel譜圖。

mel譜圖是聲音信號的頻譜內(nèi)容的一種可視化表示,它的垂直軸表示mel尺度上的頻率,水平軸表示時間。它是音頻信號處理中常用的一種表示形式,特別是在音樂信息檢索領(lǐng)域。

梅爾音階(Mel scale,英語:mel scale)是一個考慮到人類音高感知的音階。因為人類不會感知線性范圍的頻率,也就是說我們在檢測低頻差異方面要勝于高頻。 例如,我們可以輕松分辨出500 Hz和1000 Hz之間的差異,但是即使之間的距離相同,我們也很難分辨出10,000 Hz和10,500 Hz之間的差異。所以梅爾音階解決了這個問題,如果梅爾音階的差異相同,則意指人類感覺到的音高差異將相同。

def wav2melspec(fp):
y, sr = librosa.load(fp)
S = librosa.feature.melspectrogram(y=y, sr=sr, n_mels=128)
log_S = librosa.amplitude_to_db(S, ref=np.max)
img = librosa.display.specshow(log_S, sr=sr, x_axis='time', y_axis='mel')
# get current figure without white border
img = plt.gcf()
img.gca().xaxis.set_major_locator(plt.NullLocator())
img.gca().yaxis.set_major_locator(plt.NullLocator())
img.subplots_adjust(top = 1, bottom = 0, right = 1, left = 0,
hspace = 0, wspace = 0)
img.gca().xaxis.set_major_locator(plt.NullLocator())
img.gca().yaxis.set_major_locator(plt.NullLocator())
# to pil image
img.canvas.draw()
img = Image.frombytes('RGB', img.canvas.get_width_height(), img.canvas.tostring_rgb())
return img

上述函數(shù)將產(chǎn)生一個簡單的mel譜圖:

圖片

現(xiàn)在我們從文件夾中加載數(shù)據(jù)集,并對圖像應(yīng)用轉(zhuǎn)換。

class AudioDataset(Dataset):
def __init__(self, root, transform=None):
self.root = root
self.transform = transform
self.classes = sorted(os.listdir(root))
self.class_to_idx = {c: i for i, c in enumerate(self.classes)}
self.samples = []
for c in self.classes:
for fp in os.listdir(os.path.join(root, c)):
self.samples.append((os.path.join(root, c, fp), self.class_to_idx[c]))

def __len__(self):
return len(self.samples)

def __getitem__(self, idx):
fp, target = self.samples[idx]
img = Image.open(fp)
if self.transform:
img = self.transform(img)
return img, target

train_dataset = AudioDataset(root, transform=transforms.Compose([
transforms.Resize((480, 480)),
transforms.ToTensor(),
transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))
]))

ViT模型

我們將利用ViT來作為我們的模型:Vision Transformer在論文中首次介紹了一幅圖像等于16x16個單詞,并成功地展示了這種方式不依賴任何的cnn,直接應(yīng)用于圖像Patches序列的純Transformer可以很好地執(zhí)行圖像分類任務(wù)。

將圖像分割成Patches,并將這些Patches的線性嵌入序列作為Transformer的輸入。Patches的處理方式與NLP應(yīng)用程序中的標記(單詞)是相同的。

由于缺乏CNN固有的歸納偏差(如局部性),Transformer在訓(xùn)練數(shù)據(jù)量不足時不能很好地泛化。但是當(dāng)在大型數(shù)據(jù)集上訓(xùn)練時,它確實在多個圖像識別基準上達到或擊敗了最先進的水平。

實現(xiàn)的結(jié)構(gòu)如下所示:

class ViT(nn.Sequential):
def __init__(self,
in_channels: int = 3,
patch_size: int = 16,
emb_size: int = 768,
img_size: int = 356,
depth: int = 12,
n_classes: int = 1000,
**kwargs):
super().__init__(
PatchEmbedding(in_channels, patch_size, emb_size, img_size),
TransformerEncoder(depth, emb_size=emb_size, **kwargs),
ClassificationHead(emb_size, n_classes)

訓(xùn)練

訓(xùn)練循環(huán)也是傳統(tǒng)的訓(xùn)練過程:

vit = ViT(
n_classes = len(train_dataset.classes)
)

vit.to(device)

# train
train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)
optimizer = optim.Adam(vit.parameters(), lr=1e-3)
scheduler = ReduceLROnPlateau(optimizer, 'max', factor=0.3, patience=3, verbose=True)
criterion = nn.CrossEntropyLoss()
num_epochs = 30

for epoch in range(num_epochs):
print('Epoch {}/{}'.format(epoch, num_epochs - 1))
print('-' * 10)

vit.train()

running_loss = 0.0
running_corrects = 0

for inputs, labels in tqdm.tqdm(train_loader):
inputs = inputs.to(device)
labels = labels.to(device)

optimizer.zero_grad()

with torch.set_grad_enabled(True):
outputs = vit(inputs)
loss = criterion(outputs, labels)

_, preds = torch.max(outputs, 1)
loss.backward()
optimizer.step()

running_loss += loss.item() * inputs.size(0)
running_corrects += torch.sum(preds == labels.data)

epoch_loss = running_loss / len(train_dataset)
epoch_acc = running_corrects.double() / len(train_dataset)
scheduler.step(epoch_acc)

print('Loss: {:.4f} Acc: {:.4f}'.format(epoch_loss, epoch_acc))

總結(jié)

使用PyTorch從頭開始訓(xùn)練了這個Vision Transformer架構(gòu)的自定義實現(xiàn)。因為數(shù)據(jù)集非常小(每個類只有100個樣本),這影響了模型的性能,只獲得了0.71的準確率。

這只是一個簡單的演示,如果需要提高模型表現(xiàn),可以使用更大的數(shù)據(jù)集,或者稍微調(diào)整架構(gòu)的各種超參數(shù)!

這里使用的vit代碼來自:

https://medium.com/artificialis/vit-visiontransformer-a-pytorch-implementation-8d6a1033bdc5

責(zé)任編輯:華軒 來源: DeepHub IMBA
相關(guān)推薦

2021-03-19 17:59:30

深度學(xué)習(xí)音頻程序

2021-03-29 10:56:51

人工智能深度學(xué)習(xí)

2024-09-20 10:02:13

2022-08-12 08:38:52

FFmpegLinux命令

2024-11-21 16:06:02

2016-09-12 14:42:24

LinuxOctave音頻文件

2009-12-28 17:33:19

WPF視頻音頻

2016-10-31 19:41:50

LinuxOctave音頻文件

2020-05-15 08:06:37

JavaScriptobject URL對象

2011-06-13 16:22:49

Core AudioCocoa TouchiOS

2015-08-26 10:27:33

2013-05-03 13:59:18

視頻會議音頻音頻通話

2022-09-28 15:26:45

視覺任務(wù)

2015-10-28 13:29:21

音頻源碼audio

2021-09-07 15:25:51

鴻蒙HarmonyOS應(yīng)用

2022-07-08 08:00:00

流混合開發(fā)Web

2011-04-18 11:00:34

使用音頻BlackBerry

2023-11-21 21:39:38

單例模式音頻管理器

2011-08-02 16:58:15

iPhone AVAudioPla 音頻播放

2016-04-19 11:50:58

開源音頻視頻
點贊
收藏

51CTO技術(shù)棧公眾號

精品国产一区二区三区日日嗨| av在线播放不卡| 先锋影音国产精品| 东北少妇不带套对白| 中文在线不卡视频| 欧美日韩国产丝袜另类| 美洲天堂一区二卡三卡四卡视频| 精品三级在线观看视频| 色网在线观看| 在线观看黄网| 草草在线视频| 日韩欧美在线观看强乱免费| 久久亚洲综合网| 亚洲2020天天堂在线观看| 亚洲人吸女人奶水| 久久久影院免费| 日本精品在线播放| 性感美女一区二区在线观看| 欧美日韩免费做爰大片| 亚洲国产伊人| 国产最新视频在线| 日韩精品一区二区在线视频| 亚洲一品av免费观看| 91精品综合久久久久久| 依依成人精品视频| 日韩一区欧美一区| 国产精品免费丝袜| 国产精品国产三级国产三级人妇 | 国产精品黄网站| 成人毛片高清视频观看| 日本一区二区三区精品视频| 欧美精品与人动性物交免费看| 国产视频久久网| eeuss国产一区二区三区| 久久国产电影| av有声小说一区二区三区| 在线观看视频网站你懂得| 中文字幕99| 国产欧美日韩一区| 国产91精品久久久久| 色综合久久久888| 欧美不卡视频一区| 亚洲a一区二区| av一区二区不卡| 国产成人综合在线播放| 性欧美xxxx大乳国产app| 国际精品欧美精品| 成人午夜大片| 亚洲人体在线| 伊人久久高清| 欧美videos另类精品| 91在线中字| 26uuu亚洲电影在线观看| 91国内在线| 影音先锋在线视频| av文字幕在线观看| 久久精品视频免费看| 成人av黄色| wwwwxxxx在线观看| 亚洲天堂资源| 成人国产精品| 激情久久一区二区| 激情视频亚洲| 毛片一区二区三区| 99re66热这里只有精品3直播| av一区二区高清| 日韩精品2区| 欧美日韩国产高清电影| 日本一区二区在线看| 日韩免费在线| 欧美一级淫片| 欧美女激情福利| 97国产一区二区| 午夜精品123| 91在线码无精品| 亚洲欧美国产毛片在线| 中文精品99久久国产香蕉| 欧美极品在线视频| 日韩av免费在线播放| 精选一区二区三区四区五区| 亚洲www永久成人夜色| 国外成人在线播放| 国产精品视频1区| 91精品国自产在线观看| 亚洲午夜精品一区二区三区| a天堂中文在线官网| 污污片在线免费视频| 久久婷婷五月综合色丁香| 欧美va天堂| 美国十次了思思久久精品导航 | 中文字字幕在线中文乱码电影| 最近中文视频在线| 9色在线观看| 亚洲女色av| 国产乱人伦丫前精品视频| 影院欧美亚洲| 99久久精品国产麻豆演员表| 久久亚洲精品国产亚洲老地址| 不卡中文字幕av| 午夜精品一区二区三区四区| 青青草视频免费在线观看| 激情欧美一区二区三区黑长吊| 欧美淫片网站| 韩日精品视频一区| 日韩毛片在线免费观看| 欧美精品精品一区| 色综合老司机第九色激情| 国产主播在线一区| 免费拍拍拍网站| 污视频在线看网站| 亚洲性感美女99在线| 精品久久久国产| 亚洲精品视频中文字幕| 少妇高潮久久77777| 精品国产一区二区三区免费| 久久综合久久网| 亚洲乱码一区| 国产麻豆午夜三级精品| 91在线高清观看| 69堂国产成人免费视频| 国产精品色午夜在线观看| 天堂av在线资源| 国产69精品久久777的优势| 日韩高清不卡av| 国产伦精品免费视频| 97影院理论片在线播放| 国产亚洲女人久久久久毛片| 免费观看亚洲视频| 日韩 欧美一区二区三区| 国产丝袜高跟一区| 欧美激情亚洲天堂| 国产三级一区| 成人综合婷婷国产精品久久蜜臀| 亚洲毛茸茸少妇高潮呻吟| 午夜肉伦伦影院| 婷婷综合视频| 国产欧美一区二区精品性色超碰 | 欧美在线导航| 久久99精品国产麻豆不卡| 色婷婷综合五月| 92看片淫黄大片欧美看国产片| 国产激情二区| xxxx成人| 日本午夜一区二区| 色婷婷**av毛片一区| 国产特级嫩嫩嫩bbb| 日韩视频在线直播| 色噜噜狠狠色综合中国| 中文字幕网av| 日本中文字幕在线一区| 亚洲欧洲av色图| 亚洲国产高潮在线观看| 成人xxxxx色| 牛牛电影国产一区二区| 日韩和欧美一区二区三区| 疯狂做受xxxx欧美肥白少妇| 精品乱色一区二区中文字幕| 永久免费av片在线观看全网站| 日韩av网站在线观看| 天天综合色天天| 97色在线观看| 色婷婷av金发美女在线播放| 亚洲在线黄色| 国产在线播放91| av在线最新| 国产激情精品久久久第一区二区| 亚洲国产精品久久| 久久久天堂国产精品| 性高爱久久久久久久久| 激情六月婷婷久久| 国产精品中文久久久久久久| 高清电影一区| 国产精品久久久久影院色老大| 国产最新精品视频| 日本成人中文字幕在线| 日韩一区二区三区精品视频第3页| 国产日韩成人精品| 99精品在线直播| 日本在线成人| 日韩精品中文字幕在线不卡尤物| 日韩av电影中文字幕| av女同在线| 日韩高清一区二区| 欧美成人r级一区二区三区| 黄色污网站在线免费观看| 欧美国产一区二区在线观看| 国产精品乱码一区二区三区| 美女91在线| 人妖欧美一区二区| 中文字幕日韩欧美在线视频| 欧美日韩免费做爰大片| 国产亚洲综合在线| 日日橹狠狠爱欧美超碰| 红桃成人av在线播放| 亚洲女人天堂成人av在线| 国产成人精品一区二区三区在线 | 色哟哟入口国产精品| 男女小视频在线观看| 国产精品一区二区在线观看不卡 | 亚洲偷熟乱区亚洲香蕉av|