99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

手語翻譯系統(tǒng)系列之使用旭日X3派實時識別播報手語

地瓜機(jī)器人 ? 2022-12-20 09:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、準(zhǔn)備工作

硬件部分:旭日X3派,USB免驅(qū)攝像頭,電源適配器,燒錄Ubuntu系統(tǒng)的SD卡,USB揚(yáng)聲器,顯示屏(或者VNC/SSH遠(yuǎn)程連接)

軟件部分:Thonny IDE集成開發(fā)環(huán)境

1.jfif

首先,關(guān)于Ubuntu系統(tǒng)鏡像的燒錄官方有詳細(xì)的教程,這里不再贅述,我自己是選擇桌面Ubuntu 20.04,大家選擇最新的即可。如果是第一次進(jìn)入系統(tǒng),記得使用命令行更新一下軟件源等,使用快捷鍵ctrl+alt+T打開命令行,輸入以下命令:

# 更新軟件源 apt-get update # 更新升級所有軟件 apt-get upgrade

接下來就可以開始安裝Thonny IDE,作為一款輕量化的python集成開發(fā)環(huán)境,對新手十分友好,簡單易上手,后續(xù)安裝各種python依賴庫也相當(dāng)方便。安裝方式Thonny官方網(wǎng)址提供了三種Linux的命令行下載方式,大家可以根據(jù)自己的情況進(jìn)行選擇。

flatpak install org.thonny.Thonny //Flatpak sudo apt install thonny //Debian,Raspbian,Ubuntu,Mintand others sudo dnf install thonny //FedoraFedora

耐心等待程序安裝即可,如果中途出現(xiàn)異常大概率是網(wǎng)絡(luò)不穩(wěn)定導(dǎo)致,檢查網(wǎng)絡(luò)連接并再次運(yùn)行命令行即可。由于Ubuntu系統(tǒng)不會自動生成快捷方式,所以安裝成功后在命令行輸入Thonny即可啟動IDE。

重頭戲來了,安裝項目依賴庫。啟動Thonny IDE后,選擇左上方工具>>管理包,根據(jù)附件中提供的程序開始安裝python依賴庫。過程可能會比較漫長,這取決于當(dāng)前網(wǎng)絡(luò)情況,還有部分庫文件可能會出現(xiàn)下載失敗的情況,請耐心多嘗試幾次。

2.jfif

import os import threading import cv2 import mediapipe as mp import time import torch as t from model import HandModel from tools.landmark_handle import landmark_handle from tools.draw_landmarks import draw_landmarks from tools.draw_bounding_rect import draw_bounding_rect import numpy as np from tools.draw_rect_text import draw_rect_txt from PIL import Image, ImageFont, ImageDraw import pyttsx3 # 大家可以根據(jù)這個來添加項目依賴

(PS.cv2是opencv-python的縮寫,在import的時候采用這種縮寫,但添加庫的時候不能直接搜索cv2,而是要打全稱opencv-python。)

二、實現(xiàn)原理

智能手語識別系統(tǒng)共包括語音播報模塊,模型訓(xùn)練模塊,手勢識別模塊,文字轉(zhuǎn)寫模塊,一共可識別播報“也”、“吸引”、“美麗的”、 “相信”、“的”、“懷疑”、“夢想”、“表達(dá)”、“眼睛”、 “給”、“很難”、“有”、“許多”、“我”、“方法”、“不”, “只有”、“超過”、“請”、“放”、“說”、“微笑”、“星星”、“十分”、“看”、“你”等27個國家通用手語。

model_path = 'checkpoints/model_test1.pth' label = ["也", "吸引", "美麗的", "相信", "的", "懷疑", "夢想", "表達(dá)", "眼睛", "給", "很難","有","許多","我", "方法", "不", "只有", "結(jié)束", "請", "放", "說", "微信", "星星", "十分","看","你"]

語音播報模塊采用pyttsx3第三方庫,它是一個用于文字轉(zhuǎn)語音的第三方python庫,還可實現(xiàn)對音量,聲源,語速的調(diào)整,可脫機(jī)工作,兼容python2和python3

def run(): str_show = this_label star_date = open("2.txt", "w", encoding="utf-8") star_date.write(str_show) star_date.close() star_data = open("2.txt", "r", encoding="utf-8") star_read = star_data.readlines() star_data.close() file = "2.txt" res = open(file, encoding="utf-8").read() engine = pyttsx3.init() content = res engine.say(content) engine.runAndWait() time.sleep(1)

模型訓(xùn)練模塊采用torch第三方庫,torch廣泛運(yùn)用深度學(xué)習(xí)。它能夠幫助我們構(gòu)建深度學(xué)習(xí)項目,強(qiáng)調(diào)靈活性,而且允許使用我們習(xí)慣的python表示方法來表達(dá)深度學(xué)習(xí)模型。算力高,易學(xué)習(xí),比較容易入門。

# 模型保存地址 targetX = [0 for xx in range(label_num)] target = [] for xx in range(label_num): target_this = copy.deepcopy(targetX) target_this[xx] = 1 target.append(target_this) # 獨熱碼 lr = 1e-3 # learning rate model_saved = 'checkpoints/model' # 模型定義 model = HandModel() optimizer = t.optim.Adam(model.parameters(), lr=lr) criterion = nn.CrossEntropyLoss() loss_meter = meter.AverageValueMeter() epochs = 40 for epoch in range(epochs): print("epoch:" + str(epoch)) loss_meter.reset() count = 0 allnum = 1 for i in range(len(label)): data = np.load('./npz_files/' + label[i] + ".npz", allow_pickle=True) data = data['data'] for j in range(len(data)): xdata = t.tensor(data[j]) optimizer.zero_grad() this_target = t.tensor(target[i]).float() input_, this_target = Variable(xdata), Variable(this_target) output = model(input_) outLabel = label[output.tolist().index(max(output))] targetIndex = target[i].index(1) targetLabel = label[targetIndex] if targetLabel == outLabel: count += 1 allnum += 1 output = t.unsqueeze(output, 0) this_target = t.unsqueeze(this_target, 0) loss = criterion(output, this_target) loss.backward() optimizer.step() loss_meter.add(loss.data) print("correct_rate:", str(count / allnum)) t.save(model.state_dict(), '%s_%s.pth' % (model_saved, epoch))

準(zhǔn)備好數(shù)據(jù)集就可以開始進(jìn)行模型訓(xùn)練,模型推薦在電腦上進(jìn)行訓(xùn)練,我自己的電腦是win10的系統(tǒng),用的pycharm IDE的集成開發(fā)環(huán)境,如果只是想體驗一下的話也可以直接使用附件里訓(xùn)練好的模型。

3.png

手勢識別模塊采用Mediapipe和OpenCV庫對人手進(jìn)行特征提取與骨骼綁定,旭日X3派根據(jù)攝像頭捕捉的關(guān)鍵幀的進(jìn)行特征提取,基于PyTorch模型進(jìn)行推理,并將推理翻譯結(jié)果顯示到屏幕上,同時將翻譯結(jié)果以txt文件形式進(jìn)行保存和API接入后上傳到百度語音開發(fā)平臺,由平臺進(jìn)行人聲的合成,然后將生成的mp3文件下載到旭日X3派終端用揚(yáng)聲器進(jìn)行播放,實現(xiàn)了為語言障礙人士發(fā)聲,為“礙”發(fā)聲。

# 百度大腦AI開放平臺API接入實現(xiàn)語音合成的示例 def fetch_token(): print("fetch token begin") params = {'grant_type': 'client_credentials', 'client_id': API_KEY, 'client_secret': SECRET_KEY} post_data = urlencode(params) if (IS_PY3): post_data = post_data.encode('utf-8') req = Request(TOKEN_URL, post_data) try: f = urlopen(req, timeout=5) result_str = f.read() except URLError as err: print('token http response http code : ' + str(err.code)) result_str = err.read() if (IS_PY3): result_str = result_str.decode() print(result_str) result = json.loads(result_str) print(result) if ('access_token' in result.keys() and 'scope' in result.keys()): if not SCOPE in result['scope'].split(' '): raise DemoError('scope is not correct') print('SUCCESS WITH TOKEN: %s ; EXPIRES IN SECONDS: %s' % (result['access_token'], result['expires_in'])) return result['access_token'] else: raise DemoError('MAYBE API_KEY or SECRET_KEY not correct: access_token or scope not found in token response') """ TOKEN end """ if __name__ == '__main__': token = fetch_token() tex = quote_plus(TEXT) # 此處TEXT需要兩次urlencode print(tex) params = {'tok': token, 'tex': tex, 'per': PER, 'spd': SPD, 'pit': PIT, 'vol': VOL, 'aue': AUE, 'cuid': CUID, 'lan': 'zh', 'ctp': 1} # lan ctp 固定參數(shù) data = urlencode(params) print('test on Web Browser' + TTS_URL + '?' + data) req = Request(TTS_URL, data.encode('utf-8')) has_error = False try: f = urlopen(req) result_str = f.read() headers = dict((name.lower(), value) for name, value in f.headers.items()) has_error = ('content-type' not in headers.keys() or headers['content-type'].find('audio/') < 0) except URLError as err: print('asr http response http code : ' + str(err.code)) result_str = err.read() has_error = True save_file = "error.txt" if has_error else 'result.' + FORMAT with open(save_file, 'wb') as of: of.write(result_str) if has_error: if (IS_PY3): result_str = str(result_str, 'utf-8') print("tts api error:" + result_str) print("result saved as :" + save_file) # 骨架綁定的可視化 draw_landmarks(frame, hand_local) brect = draw_bounding_rect(frame, hand_local)

4.png

文字轉(zhuǎn)寫模塊通過旭日X3派外接麥克風(fēng)進(jìn)行收音,API接入后將錄制的mp3文件上傳,通過云端語音平臺實時轉(zhuǎn)寫為文字后顯示到旭日X3派終端的屏幕上。最后利用python的多線程將手勢識別,語音播報,文字轉(zhuǎn)寫同時運(yùn)行,至此,實現(xiàn)了聾啞人士與普通人的雙向無障礙溝通交流。

三、效果展示

得益于旭日X3派的強(qiáng)大算力,系統(tǒng)對手勢的識別展示并播報十分靈敏,畫面流程度也得到保障(溫馨提示:長時間運(yùn)行請準(zhǔn)備小風(fēng)扇給開發(fā)板降溫哦)。

5.jfif


6.jfif

四、性能測試

系統(tǒng)測試方案:將訓(xùn)練好模型導(dǎo)入旭日X3派中,接入電源后等待初始化完成,由小組成員們隨機(jī)在鏡頭前做出27個國家通用手語,將翻譯終端識別播報的準(zhǔn)確率記錄,同時將識別的總時長記錄收集。

測試數(shù)據(jù)如下:

7.jfif


8.jfif

結(jié)果分析:實驗數(shù)據(jù)表明,27個國家通用手語隨機(jī)檢驗的識別準(zhǔn)確率均在90%以上,單次執(zhí)行時間也均在1秒之內(nèi)。

結(jié)論:手語翻譯終端有很高的實時性,充分保障聾啞殘障人士的無障礙溝通交流。

本文轉(zhuǎn)自地平線開發(fā)者社區(qū)
原作者:鑫辰大海王

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5150

    文章

    19665

    瀏覽量

    317459
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4827

    瀏覽量

    86716
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    樹莓分類器:用樹莓識別不同型號的樹莓

    在本教程系列的第一部分中,您將學(xué)習(xí)如何使用樹莓AI攝像頭來檢測不同的樹莓型號。本系列由DavidPlowman創(chuàng)建,他是樹莓工程師,專
    的頭像 發(fā)表于 06-13 16:39 ?408次閱讀
    樹莓<b class='flag-5'>派</b>分類器:用樹莓<b class='flag-5'>派</b><b class='flag-5'>識別</b>不同型號的樹莓<b class='flag-5'>派</b>!

    樹莓項目實戰(zhàn):車牌識別系統(tǒng)開發(fā)全記錄!

    介紹本項目的目標(biāo)是設(shè)計一個基于樹莓微電腦的自動車牌識別系統(tǒng),用于控制停車場的道閘。為什么?我有一臺閑置的樹莓,沒有參與任何項目,還有一臺攝像頭,以及一個潛在的問題點——辦公室停車場沒有自動化的道
    的頭像 發(fā)表于 06-11 17:22 ?286次閱讀
    樹莓<b class='flag-5'>派</b>項目實戰(zhàn):車牌<b class='flag-5'>識別系統(tǒng)</b>開發(fā)全記錄!

    韻樂Vinal X3/X5卡拉OK音頻處理器調(diào)音軟件簡介

    韻樂Vinal X3/X5卡拉OK音頻處理器調(diào)音軟件軟件簡介韻樂Vinal X3/X5調(diào)音軟件具有音箱處理器功能的卡拉ok效果器每個功能部分都獨立可調(diào)且有相應(yīng)的PC界面可直觀調(diào)節(jié)易于操
    發(fā)表于 05-16 15:33 ?1次下載

    搭建樹莓網(wǎng)絡(luò)監(jiān)控系統(tǒng):頂級工具與技術(shù)終極指南!

    樹莓網(wǎng)絡(luò)監(jiān)控系統(tǒng)是一種經(jīng)濟(jì)高效且功能多樣的解決方案,可用于監(jiān)控網(wǎng)絡(luò)性能、流量及整體運(yùn)行狀況。借助樹莓,我們可以搭建一個網(wǎng)絡(luò)監(jiān)控系統(tǒng)實時
    的頭像 發(fā)表于 05-14 15:32 ?692次閱讀
    搭建樹莓<b class='flag-5'>派</b>網(wǎng)絡(luò)監(jiān)控<b class='flag-5'>系統(tǒng)</b>:頂級工具與技術(shù)終極指南!

    RDK X3 帶飛的智能護(hù)理系統(tǒng):讓機(jī)器人秒變貼心小棉襖

    濟(jì)往開來團(tuán)隊帶著超燃黑科技來了!基于 RDK X3 開發(fā)的老年智能監(jiān)控系統(tǒng),跌倒秒報警、手勢一鍵呼叫、還能陪嘮嗑!最絕的是 開源代碼直接甩鏈接 ,技術(shù)黨狂喜!
    的頭像 發(fā)表于 05-09 21:53 ?259次閱讀
    RDK <b class='flag-5'>X3</b> 帶飛的智能護(hù)理<b class='flag-5'>系統(tǒng)</b>:讓機(jī)器人秒變貼心小棉襖

    車牌識別新花樣:樹莓打造智能車牌監(jiān)控系統(tǒng)

    樹莓是創(chuàng)客們打造家庭安防系統(tǒng)的熱門選,這得益于其具備運(yùn)用人工智能(AI)的能力。AI系統(tǒng)識別潛在威脅,在此情境下,還能
    的頭像 發(fā)表于 04-26 09:03 ?253次閱讀
    車牌<b class='flag-5'>識別</b>新花樣:樹莓<b class='flag-5'>派</b>打造智能車牌監(jiān)控<b class='flag-5'>系統(tǒng)</b>!

    HMC-XTB110 無源x3倍頻器,24-30GHz輸入技術(shù)手冊

    HMC-XTB110是一款單芯片x3無源倍頻器,采用GaAs肖特基二極管技術(shù),具有低轉(zhuǎn)換損耗和高度Fo隔離。 這款寬帶x3倍頻器無需直流電源,適用于低頻率的3倍頻率比直接生成高頻率更加經(jīng)濟(jì)的大規(guī)模
    的頭像 發(fā)表于 04-16 16:15 ?326次閱讀
    HMC-XTB110 無源<b class='flag-5'>x3</b>倍頻器,24-30GHz輸入技術(shù)手冊

    百度AI手語數(shù)字人助力聽障人士“聽見”聲音

    近幾年,百度先后與天津理工大學(xué)、鯨言科技合作,共同研發(fā)出百度智能云曦靈AI手語平臺與雙向手語翻譯機(jī),讓手語的“聲音”,被更多人聽見。
    的頭像 發(fā)表于 02-21 11:29 ?842次閱讀

    “你的錢來了”:財神1號,RDK X3驅(qū)動,自動撿錢不手軟!

    采用 RDK X3 打造無情的撿錢機(jī)器,每天8億紙幣掉在路面上,財神1號幫你撿個夠!
    的頭像 發(fā)表于 02-18 11:15 ?592次閱讀
    “你的錢來了”:財神1號,RDK <b class='flag-5'>X3</b>驅(qū)動,自動撿錢不手軟!

    全平臺搭載旭日5!科沃斯GOAT智能割草機(jī)器人全新系列正式開售

    科沃斯GOAT全新系列產(chǎn)品全平臺搭載地瓜機(jī)器人全新推出的旭日5智能計算芯片
    的頭像 發(fā)表于 02-18 11:03 ?795次閱讀
    全平臺搭載<b class='flag-5'>旭日</b>5!科沃斯GOAT智能割草機(jī)器人全新<b class='flag-5'>系列</b>正式開售

    AI助力實時翻譯耳機(jī)

    是一種能夠實時將一種語言翻譯成另一種語言的耳機(jī)設(shè)備。它通常由一個耳機(jī)和一個配套的應(yīng)用程序組成,用戶可以通過應(yīng)用程序選擇需要翻譯的語言,并通過耳機(jī)聽到翻譯結(jié)果。 2
    的頭像 發(fā)表于 01-24 11:14 ?1661次閱讀
    AI助力<b class='flag-5'>實時</b><b class='flag-5'>翻譯</b>耳機(jī)

    Cadence推出Palladium Z3與Protium X3系統(tǒng)

    楷登電子(Cadence)公司近日宣布,正式推出新一代Cadence? Palladium? Z3 Emulation和Protium? X3 FPGA原型驗證系統(tǒng)。這一組合標(biāo)志著數(shù)字孿生
    的頭像 發(fā)表于 01-07 13:48 ?1054次閱讀

    HarmonyOS NEXT 應(yīng)用開發(fā)練習(xí):AI智能語音播報

    (Text-To-Speech,文本轉(zhuǎn)語音)技術(shù)將文本轉(zhuǎn)換為語音進(jìn)行播報。 當(dāng)然除了基本的文本輸入和播報功能外,我們還增加了語音識別的功能,允許用戶通過語音輸入要播報的文本。 還優(yōu)化了
    發(fā)表于 01-06 15:33

    英飛凌AURIX? TC3x MCU系列新增FreeRTOS支持

    全球功率系統(tǒng)和物聯(lián)網(wǎng)領(lǐng)域的半導(dǎo)體領(lǐng)軍企業(yè)英飛凌科技股份公司,近日宣布其AURIX? TC3x微控制器(MCU)系列新增了對FreeRTOS的支持。這一舉措標(biāo)志著AURIX? TC3x
    的頭像 發(fā)表于 12-11 14:06 ?816次閱讀

    中山大學(xué):基于定制裂紋設(shè)計的超靈敏透氣水凝膠纖維應(yīng)變傳感器及無線手語識別應(yīng)用

    和地域多樣性可能會給不懂手語的人造成交流障礙。目前,各種識別人類手勢的技術(shù),包括視覺圖像處理、肌電圖和可穿戴應(yīng)變傳感器,在改善聾啞人群體的溝通方面發(fā)揮了重要作用。特別地,視覺圖像處理在手語識別
    的頭像 發(fā)表于 12-02 17:29 ?906次閱讀
    中山大學(xué):基于定制裂紋設(shè)計的超靈敏透氣水凝膠纖維應(yīng)變傳感器及無線<b class='flag-5'>手語</b><b class='flag-5'>識別</b>應(yīng)用