当前位置: 首页 > wzjs >正文

网站做跳转付款我要登录百度

网站做跳转付款,我要登录百度,wordpress登陆页面logo,企业高端网站建设美工背景 项目中需要实现一个语音唤起的功能,选择sherpa-onnx进行调研,要求各端都要验证没有问题。个人负责ios这部分的调研。查询官方发现没有直接针对ios语音唤起的稳定,主要技术平台也没有相关的可以借鉴。经过调研之后补充了一个。 一、下载…

背景

项目中需要实现一个语音唤起的功能,选择sherpa-onnx进行调研,要求各端都要验证没有问题。个人负责ios这部分的调研。查询官方发现没有直接针对ios语音唤起的稳定,主要技术平台也没有相关的可以借鉴。经过调研之后补充了一个。

一、下载 sherpa-onnx

https://github.com/k2-fsa/sherpa-onnx

二、构建 iOS 版 Sherpa-onnx

根据官方说明文档,先把项目构建编译起来。地址:Build sherpa-onnx for iOS 。根据文档要求安装环境,要两个小时左右。最终的效果的代码可以编译起来并且可以正常使用demo。
demo构建起来只是实现了语音转文字功能,还没有语音唤起能力。

三、补充语音唤起能力

目前官方文档只有安卓语音唤起的说明文档,但是总文档中说支持ios系统。那么原理应该是想通的,在ios的demo中搜索关键词 Keyword 发现,已经实现相关api。那么只要找到语音唤起模型并实现调用。
以下是构建成功之后的demo源码地址:
1、sherpa-onnx-ios-demo 。构建后的 ios-swift demo。构建后的全部内容有好几个G,因此支持提交部分,该demo需要在第二步运行成功之后,把该demo与源目录替换即可编译运行。
2、ios的语音模型、自定义关键词模型(用于语音唤起能力)

四、demo介绍

1、目录结构

在这里插入图片描述

2、sdk调用

Model.swift

// 在Model.swift中添加
func getKwsConfig() -> SherpaOnnxOnlineModelConfig {
//    let encoder = getResource("encoder-epoch-99-avg-1", "onnx")
//    let decoder = getResource("decoder-epoch-99-avg-1", "onnx")
//    let joiner = getResource("joiner-epoch-99-avg-1", "onnx")
//    let tokens = getResource("kws_tokens", "txt")let encoder = getResource("encoder-epoch-12-avg-2-chunk-16-left-64", "onnx")let decoder = getResource("decoder-epoch-12-avg-2-chunk-16-left-64", "onnx")let joiner = getResource("joiner-epoch-12-avg-2-chunk-16-left-64", "onnx")let tokens = getResource("kws_tokens", "txt")return sherpaOnnxOnlineModelConfig(tokens: tokens,transducer: sherpaOnnxOnlineTransducerModelConfig(encoder: encoder,decoder: decoder,joiner: joiner),numThreads: 2,modelType: "zipformer2")
}func getKeywordsFilePath() -> String {return getResource("keywords", "txt") // 文件内容:小苗小苗
}/// Please refer to
/// https://k2-fsa.github.io/sherpa/onnx/pretrained_models/index.html
/// to download pre-trained models/// sherpa-onnx-streaming-zipformer-bilingual-zh-en-2023-02-20 (Bilingual, Chinese + English)
/// https://k2-fsa.github.io/sherpa/onnx/pretrained_models/zipformer-transducer-models.html
func getBilingualStreamZhEnZipformer20230220() -> SherpaOnnxOnlineModelConfig {let encoder = getResource("encoder-epoch-99-avg-1", "onnx")let decoder = getResource("decoder-epoch-99-avg-1", "onnx")let joiner = getResource("joiner-epoch-99-avg-1", "onnx")let tokens = getResource("tokens", "txt")return sherpaOnnxOnlineModelConfig(tokens: tokens,transducer: sherpaOnnxOnlineTransducerModelConfig(encoder: encoder,decoder: decoder,joiner: joiner),numThreads: 1,modelType: "zipformer")
}

ViewController.swift

//
//  ViewController.swift
//  SherpaOnnx
//
//  Created by fangjun on 2023/1/28.
//import AVFoundation
import UIKitextension AudioBuffer {func array() -> [Float] {return Array(UnsafeBufferPointer(self))}
}extension AVAudioPCMBuffer {func array() -> [Float] {return self.audioBufferList.pointee.mBuffers.array()}
}class ViewController: UIViewController {@IBOutlet weak var resultLabel: UILabel!@IBOutlet weak var recordBtn: UIButton!var audioEngine: AVAudioEngine? = nilvar recognizer: SherpaOnnxRecognizer! = nil// 新增关键词唤醒相关属性var kwsSpotter: SherpaOnnxKeywordSpotterWrapper!var isAwakened = false/// It saves the decoded results so farvar sentences: [String] = [] {didSet {updateLabel()}}var lastSentence: String = ""let maxSentence: Int = 20var results: String {if sentences.isEmpty && lastSentence.isEmpty {return ""}if sentences.isEmpty {return "0: \(lastSentence.lowercased())"}let start = max(sentences.count - maxSentence, 0)if lastSentence.isEmpty {return sentences.enumerated().map { (index, s) in "\(index): \(s.lowercased())" }[start...].joined(separator: "\n")} else {return sentences.enumerated().map { (index, s) in "\(index): \(s.lowercased())" }[start...].joined(separator: "\n") + "\n\(sentences.count): \(lastSentence.lowercased())"}}func updateLabel() {DispatchQueue.main.async {self.resultLabel.text = self.results}}override func viewDidLoad() {super.viewDidLoad()// Do any additional setup after loading the view.resultLabel.text = "ASR with Next-gen Kaldi\n\nSee https://github.com/k2-fsa/sherpa-onnx\n\nPress the Start button to run!"recordBtn.setTitle("Start", for: .normal)initRecognizer()initKeywordSpotter()initRecorder()startRecorder()}// 关键词检测初始化func initKeywordSpotter() {let modelConfig = getKwsConfig()let featConfig = sherpaOnnxFeatureConfig()var config = sherpaOnnxKeywordSpotterConfig(featConfig: featConfig,modelConfig: modelConfig,keywordsFile: getKeywordsFilePath(),maxActivePaths: 4,numTrailingBlanks: 2,keywordsScore: 1.5,keywordsThreshold: 0.25)kwsSpotter = SherpaOnnxKeywordSpotterWrapper(config: &config)}// 新增状态变量private var isRecording = false@IBAction func onRecordBtnClick(_ sender: UIButton) {if recordBtn.currentTitle == "Start" {isAwakened = true // 强制唤醒状态startRecorder()recordBtn.setTitle("Stop", for: .normal)} else {isAwakened = falsestopRecorder()recordBtn.setTitle("Start", for: .normal)}}// 初始化语音转文字模型func initRecognizer() {// Please select one model that is best suitable for you.//// You can also modify Model.swift to add new pre-trained models from// https://k2-fsa.github.io/sherpa/onnx/pretrained_models/index.htmllet modelConfig = getBilingualStreamZhEnZipformer20230220()// let modelConfig = getZhZipformer20230615()// let modelConfig = getEnZipformer20230626()
//        let modelConfig = getBilingualStreamingZhEnParaformer()let featConfig = sherpaOnnxFeatureConfig(sampleRate: 16000,featureDim: 80)var config = sherpaOnnxOnlineRecognizerConfig(featConfig: featConfig,modelConfig: modelConfig,enableEndpoint: true,rule1MinTrailingSilence: 2.4,rule2MinTrailingSilence: 0.8,rule3MinUtteranceLength: 30,decodingMethod: "greedy_search",maxActivePaths: 4)recognizer = SherpaOnnxRecognizer(config: &config)}func initRecorder() {print("init recorder")audioEngine = AVAudioEngine()let inputNode = self.audioEngine?.inputNodelet bus = 0let inputFormat = inputNode?.outputFormat(forBus: bus)let outputFormat = AVAudioFormat(commonFormat: .pcmFormatFloat32,sampleRate: 16000, channels: 1,interleaved: false)!let converter = AVAudioConverter(from: inputFormat!, to: outputFormat)!inputNode!.installTap(onBus: bus,bufferSize: 1024,format: inputFormat) {(buffer: AVAudioPCMBuffer, when: AVAudioTime) invar newBufferAvailable = truelet inputCallback: AVAudioConverterInputBlock = {inNumPackets, outStatus inif newBufferAvailable {outStatus.pointee = .haveDatanewBufferAvailable = falsereturn buffer} else {outStatus.pointee = .noDataNowreturn nil}}let convertedBuffer = AVAudioPCMBuffer(pcmFormat: outputFormat,frameCapacity:AVAudioFrameCount(outputFormat.sampleRate)* buffer.frameLength/ AVAudioFrameCount(buffer.format.sampleRate))!var error: NSError?let _ = converter.convert(to: convertedBuffer,error: &error, withInputFrom: inputCallback)// TODO(fangjun): Handle status != haveDatalet array = convertedBuffer.array()// 并行处理关键词检测和ASRself.processKeywordDetection(array)if self.isAwakened || self.isRecording {self.processASR(array)}}}var wakeupConfidence = 0let requiredConfidence = 2private func processKeywordDetection(_ samples: [Float]) {kwsSpotter.acceptWaveform(samples: samples)while kwsSpotter.isReady() {kwsSpotter.decode()let result = kwsSpotter.getResult()let detected = result.keyword.lowercased().contains("小苗小苗")print("demo----> result.keyword:\(result.keyword)    detected:\(detected)")wakeupConfidence = detected ?min(wakeupConfidence + 1, requiredConfidence) :max(wakeupConfidence - 1, 0)if wakeupConfidence >= requiredConfidence && !isAwakened {handleWakeupEvent()wakeupConfidence = 0}}}private func processASR(_ samples: [Float]) {if !samples.isEmpty {recognizer.acceptWaveform(samples: samples)while (recognizer.isReady()){recognizer.decode()}let isEndpoint = recognizer.isEndpoint()let text = recognizer.getResult().textif !text.isEmpty && lastSentence != text {lastSentence = textupdateLabel()print(text)}if isEndpoint {if !text.isEmpty {let tmp = self.lastSentencelastSentence = ""sentences.append(tmp)}recognizer.reset()}}}private func handleWakeupEvent() {isAwakened = trueDispatchQueue.main.async {
//            self.resultLabel.text = "已唤醒,请开始说话..."// 自动启动录音逻辑(可选)if self.recordBtn.currentTitle == "Start" {self.startRecorder()self.recordBtn.setTitle("Stop", for: .normal)}}// 重置ASR状态recognizer.reset()}func startRecorder() {lastSentence = ""sentences = []do {try self.audioEngine?.start()isRecording = true} catch let error as NSError {print("Got an error starting audioEngine: \(error.domain), \(error)")}print("started")}func stopRecorder() {audioEngine?.stop()kwsSpotter.reset()recognizer.reset()isRecording = falseprint("stopped")}
}
http://www.dtcms.com/wzjs/68487.html

相关文章:

  • 培训网站方案网络营销业务流程
  • 网页翻译不见了seow
  • 珠海科技网站建设百度答主中心入口
  • 网站页头手机网页制作app
  • 成都网站建设制作价格百度app官网
  • 网站建设挣钱吗?怎么把抖音关键词做上去
  • ps做网站要求高吗百度竞价关键词价格查询工具
  • 湖南常德广宇建设网站百度竞价点击神器
  • 国外有哪几家做充电桩网站百度官方客服
  • 做外贸有必要做个网站吗seo推广培训班
  • 谷歌网站优化东莞网络优化排名
  • 找设计方案的网站百度seo优化培训
  • 库尔勒 网站建设网站服务器失去响应
  • 脉脉用的什么技术做网站北京seo优化外包
  • 长沙县营销型网站建设选哪家个人网页制作
  • 楚雄网站制作谷歌google play下载
  • 做网站写概要设计厦门seo关键词排名
  • 淄博网站建设优化2024会爆发什么病毒
  • 购物网站模板代码下载app平台搭建需要多少钱
  • ps工具设计网站sem工资
  • 自己有网站怎么做点卡seo排名推广工具
  • 如何在百度上做公司做网站成都高端品牌网站建设
  • 网站上的图片做多大推广app的软文案例
  • wordpress 3秒加载搜索引擎外部优化有哪些渠道
  • 设计做网站通用cms的源代码seo网站有哪些
  • 上海网站建设制作微信网站域名购买
  • 怎么做直播网站刷弹幕优化网站性能监测
  • 企业网站建设的定位网络营销策划书范文
  • 深圳做分销网站建设企业培训体系搭建
  • 公司网站的好处网页设计基础