【正点原子i.MX93开发板试用连载体验】录音小程序采集语料
创始人
2025-01-10 22:35:42
0

 本文最早发表于电子发烧友论坛:【新提醒】【正点原子i.MX93开发板试用连载体验】基于深度学习的语音本地控制 - 正点原子学习小组 - 电子技术论坛 - 广受欢迎的专业电子论坛! (elecfans.com)

接下来就是要尝试训练中文提示词。首先要进行语料采集,这是一个比较耗费人力的事情,通常大公司会有有专人进行语料收集,我只好自己亲自做。这里参考了AliOS Things里面提供的一个录音工具,方便快速录音。对这个工具做了一点修改,原来的代码只能在Linux下运行,现在改成在Windows下也能运行。

import pyaudio import wave import random import time import os from IPython import display #from pydub import AudioSebment #from pydub.playback import play #from playsound import playsound CHUNK = 2 FORMAT = pyaudio.paInt16 CHANNELS = 1 RATE = 16000 SAMPLEWIDTH = 2 RECORD_SECONDS = 1 FILE_FORMAT = '.wav' RECODER_NAME = 'lk' #play stream def play_wav(name, pyaudio):     f = wave.open(name,"rb")       #open stream       play_stream = pyaudio.open(format = p.get_format_from_width(f.getsampwidth()),                       channels = f.getnchannels(),                       rate = f.getframerate(),                       output = True)       #read data       data = f.readframes(CHUNK)     while data:           play_stream.write(data)         data = f.readframes(CHUNK)     #stop stream     play_stream.stop_stream()       play_stream.close()       #close PyAudio   #    pyaudio.terminate()     f.close() def save_wav(name, frames):     wf = wave.open(name, 'wb')     wf.setnchannels(CHANNELS)     wf.setsampwidth(p.get_sample_size(FORMAT))     wf.setframerate(RATE)     wf.writeframes(b''.join(frames))     wf.close()   def record_wav(duration):     time.sleep(0.2) # 1sec, 0.1sec     print("开始录音,请说话......") #    count = 3 #    for i in range(3): #        time.sleep(0.2) # 1sec, 0.1sec #        count -= 1 #        print(count)     frames = []     stream = p.open(format=FORMAT,             channels=CHANNELS,             rate=RATE,             input=True,             frames_per_buffer=CHUNK)     for i in range(0, int(RATE * duration / SAMPLEWIDTH)):         data = stream.read(CHUNK, exception_on_overflow = False)         frames.append(data)     #count = 0     #while count < int(RECORD_SECONDS * RATE):     #    data = stream.read(CHUNK)     #    frames.append(data)     #     count += CHUNK     stream.stop_stream()     stream.close()     print("录音结束!")     return frames # main function if __name__ == '__main__':     p = pyaudio.PyAudio()     # input('请按回车键开始录制!\n')     # record files     count = 0     for i in range(250):         input('请按回车键开始录制!\n')         print("开始第%d录制!" % count)         hash_name = str(hex(abs(hash(RECODER_NAME + str(random.random()))) % 1000000000)).replace('0x','') \                     + '_nohash_' + str(count) + FILE_FORMAT         rframes = record_wav(1) # record 1 sec         save_wav(hash_name, rframes)         #time.sleep(0.5) # 1sec, 0.1sec         print("录音回放开始!\n")         play_wav(hash_name, p)         print("录音回放结束!\n")         value = input("按‘回车’保存,放弃本条请按‘其他’键并回车!\n")         if (value == ''):             count += 1             print("保存录音成功!")         else:             os.remove(hash_name)             print("已删除本条录音!")                  #display.display(display.Audio(hash_name, rate=16000))     #wav = AudioSegment.from_wav(hash_name)     #play(wav)     p.terminate() 

相关内容

热门资讯

第四分钟了解!广东雀神智能插件... 第四分钟了解!广东雀神智能插件安装软件(辅助)牌友开挂辅助app-果然真的是有安装在进入广东雀神智能...
第1分钟了解!炸金花辅助哪里有... 第1分钟了解!炸金花辅助哪里有卖(辅助)天涯麻将开挂辅助平台-果然存在有软件1、游戏颠覆性的策略玩法...
七分钟了解!牵手跑得辅助器下载... 七分钟了解!牵手跑得辅助器下载(辅助)闲逸游戏开挂辅助插件-原来是有平台1、上手简单,内置详细流程视...
第5分钟了解!丽水都来大菠萝脚... 第5分钟了解!丽水都来大菠萝脚本辅助(辅助)八闽十三张开挂辅助工具-都是真的是有下载1)丽水都来大菠...
第五分钟了解!竹间智能辅助助手... 第五分钟了解!竹间智能辅助助手(辅助)欢乐达人开挂辅助神器-竟然是有下载1、竹间智能辅助助手辅助器安...
6分钟了解!潮汕雀友百度贴吧辅... 6分钟了解!潮汕雀友百度贴吧辅助软件(辅助)芒杏儿小盒开挂辅助辅助器-竟然是真的平台1、完成潮汕雀友...
两分钟了解!闲来辅助神器免费版... 两分钟了解!闲来辅助神器免费版在哪下载(辅助)海宁拾贝开挂辅助app-好像是真的工具1、每一步都需要...
第6分钟了解!蛮王辅助器(辅助... 第6分钟了解!蛮王辅助器(辅助)云鹤九霄开挂辅助平台-总是有挂修改器1、完成蛮王辅助器辅助器v3.3...
第5分钟了解!夜猫十三道辅助器... 第5分钟了解!夜猫十三道辅助器(辅助)闲玩开挂辅助修改器-确实是真的安装1、夜猫十三道辅助器免费脚本...
第9分钟了解!微信小游戏破解版... 第9分钟了解!微信小游戏破解版(辅助)中至赣牌圈开挂辅助安装-原来真的是有修改器1、微信小游戏破解版...