【百度AI语音合成】会员到访门店语音提醒
?
?
?每次會員到訪都需要。會員自主結賬或找導購才能被發現。或者需要一個人員站在門口,并且對會員都全部了解,才能對會員到訪進行更好服務的接待。
小帥為了免去這些操作呢。就想到了百度AI。語音合成。再結合第三方的人臉庫會員到訪推送。做了一個簡單的會員到訪語音提醒推送小工程。
下面我們就一起看一下整體流程吧~
實現步驟
?Step1:成為百度AI開放平臺的開發者
我們有賬號之后登錄,并且點擊此處(百度語音)創建一個應用,如下圖
然后就能看到創建完的應用和 APPID、API KEY 以及 Secret KEY了
?
Step2:準備數據
語音合成是將文本轉換為可以播放的音頻文件的服務,我們從大姚的訂單庫中找一段訂單信息的文本如下:
三分鐘前,由北京市順義區二經路與二緯路交匯處北側,北京首都國際機場T3航站樓 去往 東城區北三環東路36號喜來登大酒店(北京金隅店)
Step3: 編寫一個語音合成示例程序
有 第一步 的 API KEY 以及 Secret KEY,以及 第二步 的數據,我們就可以寫一個示例代碼調用百度AI開放平臺的文字識別能力
準備開發環境
小帥選擇用 Java來快速搭建一個原型,關于如何安裝Java。可以參考百度經驗哦~。百度AI有很完善的API文檔、和封裝調用更方便的工具包。接下來小帥就用Maven搭建工程環境
pom.xml配置如下:
<!-- https://mvnrepository.com/artifact/com.baidu.aip/java-sdk --> <dependency><groupId>com.baidu.aip</groupId><artifactId>java-sdk</artifactId><version>4.12.0</version> </dependency>編寫代碼
粘貼以下內容,不要忘記替換你的 APPID APIKEY 以及 SECRETKEY 和 圖片文件
運行main方法即可
import com.baidu.aip.speech.AipSpeech; import com.baidu.aip.speech.TtsResponse; import com.baidu.aip.util.Util; import org.json.JSONObject;import java.util.HashMap;public class Sample {//第一步創建應用獲取的三個值private static String APPID = "你的 App ID";private static String APIKEY = "你的 Api Key";private static String SECRETKEY = "你的 Secret Key";public static void main(String[] args) {// 初始化一個AipSpeech AipSpeech client = new AipSpeech(APPID,APIKEY,SECRETKEY);// 調用接口 第二步準備的圖片HashMap<String, Object> options = new HashMap<>();//合成的文本內容String text = "三分鐘前,由北京市順義區二經路與二緯路交匯處北側,北京首都國際機場T3航站樓 去往 東城區北三環東路36號喜來登大酒店(北京金隅店)";//發音人選擇/*** 度小宇=1,度小美=0,度逍遙=3,度丫丫=4* 度博文=106,度小童=110,度小萌=111,度米朵=103,度小嬌=5**/options.put("per","0");//語速,取值0-9,默認為5中語速options.put("spd", "3");TtsResponse res = client.synthesis(text , "zh", 1, options);byte[] data = res.getData();JSONObject res1 = res.getResult();if (data != null) {try {Util.writeBytesToFileSystem(data, "F:\\testaudio\\度小美Demooutput.mp3");} catch (IOException e) {e.printStackTrace();}}if (res1 != null) {System.out.println(res1.toString());}} }保存接口返回語音byte[] 轉存為MP3格式文件。這里說明一下默認返回就是MP3格式的數據哦。如果想要其他格式
//3為mp3格式(默認); //4為pcm-16k; //5為pcm-8k; //6為wav(內容同pcm-16k); //注意aue=4或者6是語音識別要求的格式,但是音頻內容不是語音識別要求的自然人發音,所以識別效果會受影響。options.put("aue","3");點擊訪問合成的示例MP3文件
?
語音合成 單例加載。10次測試耗時如下(單位:ms(毫秒))。第一次需要加載一次AUTH。耗時多了一些。后續基本都持平在710ms以內
發送請求到返回數據耗時:1493 發送請求到保存文件耗時:1495發送請求到返回數據耗時:611 發送請求到保存文件耗時:612發送請求到返回數據耗時:609 發送請求到保存文件耗時:610發送請求到返回數據耗時:473 發送請求到保存文件耗時:474發送請求到返回數據耗時:549 發送請求到保存文件耗時:550發送請求到返回數據耗時:673 發送請求到保存文件耗時:674發送請求到返回數據耗時:754 發送請求到保存文件耗時:755發送請求到返回數據耗時:676 發送請求到保存文件耗時:676發送請求到返回數據耗時:582 發送請求到保存文件耗時:582發送請求到返回數據耗時:662 發送請求到保存文件耗時:663發送請求到返回數據平均耗時:708.2ms 發送請求到保存文件平均耗時:709.1ms for (int i = 0; i < 10; i++) {// 調用接口String text = "三分鐘前,由北京市順義區二經路與二緯路交匯處北側,北京首都國際機場T3航站樓 去往 東城區北三環東路36號喜來登大酒店(北京金隅店)";HashMap<String, Object> options = new HashMap<String, Object>();options.put("per", "0");options.put("spd", "3");long startTime = System.currentTimeMillis();TtsResponse res = client.synthesis(text, "zh", 1, options);byte[] data = res.getData();if (data != null) {long endTime = System.currentTimeMillis();System.out.println("發送請求到返回數據耗時:"+(endTime - startTime));try {Util.writeBytesToFileSystem(data, "F:\\testaudio\\度小美Demooutput.mp3");long saveEndTime = System.currentTimeMillis();System.out.println("發送請求到保存文件耗時:"+(saveEndTime - startTime));} catch (IOException e) {e.printStackTrace();}}JSONObject res1 = res.getResult();if (res1 != null) {System.out.println(res1.toString());}System.out.println();} 帶寬聯通100M以上數據可以看出。平均耗時在0.7s上下。如果服務器配置賊6、帶寬也賊寬。應該耗時還會更低哦
接下來。咱們就拿語音合成的服務。來結合實際業務做一個小的功能哦~
會員到訪語音提醒搞起來
簡單看一下業務流程圖。主要看語音合成、語音提醒部分即可
人臉會員識別可以看百度AI的官方解決方案 https://ai.baidu.com/solution/faceidentify
本業務中人臉識別、攝像頭廠商暫時沒用百度AI。這一點我也很無奈。迫于公司要求呀。如果再來一次選擇。絕對強制提議選擇百度AI(怕太便宜而告終 你懂得)
接口調用封裝,并符合業務系統使用
簡單說明一下:
案例中Java后端部分整體使用SpringBoot框架 JDK1.8
1.會員人臉照片信息上傳這一步小帥設計的是定時任務去執行語音信息并進行合成操作。所以需要對Java的定時任務、任務調度有一定了解哦
2.定時任務就是對人臉會員信息讀取并進行會員到訪語音提示音頻文件合成
會員信息采集
會員到訪提示音發音類型默認 度米多。也可以根據會員不同給不同的發音類型哦~
基礎音庫 精品音庫?
- 會員提示音類型修改
下拉選擇精品音庫 或 基礎音庫 的具體類型即可
- 后端會員人臉信息處理
- 會員到訪定制提示音頻合成定時任務
- 添加一條定時任務
這里是5秒執行一次。其實可以根據自我需求來定義。定時任務形式也不是必須。
- 會員音頻提示文件生成
數字代表的是發音類型。每添加一個會員。則會生成所有發音類型的音頻文件哦。方便后續給每個到訪會員給定不同聲音的提醒
會員到訪APP推送
非百度AI人臉會員解決方案哦~ 不要問為什么不用百度AI的。上面已經給出說明了。
1.攝像頭抓怕推送到人臉庫系統
2.人臉庫系統對比并推送結果到內部業務系統
3.內部業務系統|人臉庫系統推送給APP(小帥使用前者)
下圖是一個gif。會演示app收到推送彈窗并播放語音提醒。
帶聲音訪問這里 https://mp.weixin.qq.com/s/qL57AxdS4r5zlDzM57z2CQ
總結
以上是生活随笔為你收集整理的【百度AI语音合成】会员到访门店语音提醒的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ANNOVAR gene-based a
- 下一篇: 干货 | MAC地址可能泄露设备信息?一