# frozen_string_literal: true # Copyright (c) 2017-2018 THL A29 Limited, a Tencent company. All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. module TencentCloud module Asr module V20190614 # 音频流异步识别任务信息 class AsyncRecognitionTaskInfo < TencentCloud::Common::AbstractModel # @param TaskId: 任务ID # @type TaskId: Integer # @param Url: 音频流Url # @type Url: String attr_accessor :TaskId, :Url def initialize(taskid=nil, url=nil) @TaskId = taskid @Url = url end def deserialize(params) @TaskId = params['TaskId'] @Url = params['Url'] end end # 音频流异步识别任务列表 class AsyncRecognitionTasks < TencentCloud::Common::AbstractModel # @param Tasks: 任务列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Tasks: Array attr_accessor :Tasks def initialize(tasks=nil) @Tasks = tasks end def deserialize(params) unless params['Tasks'].nil? @Tasks = [] params['Tasks'].each do |i| asyncrecognitiontaskinfo_tmp = AsyncRecognitionTaskInfo.new asyncrecognitiontaskinfo_tmp.deserialize(i) @Tasks << asyncrecognitiontaskinfo_tmp end end end end # CloseAsyncRecognitionTask请求参数结构体 class CloseAsyncRecognitionTaskRequest < TencentCloud::Common::AbstractModel # @param TaskId: 语音流异步识别任务的唯一标识,在创建任务时会返回 # @type TaskId: Integer attr_accessor :TaskId def initialize(taskid=nil) @TaskId = taskid end def deserialize(params) @TaskId = params['TaskId'] end end # CloseAsyncRecognitionTask返回参数结构体 class CloseAsyncRecognitionTaskResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # CreateAsrVocab请求参数结构体 class CreateAsrVocabRequest < TencentCloud::Common::AbstractModel # @param Name: 热词表名称,长度在1-255之间 # @type Name: String # @param Description: 热词表描述,长度在0-1000之间 # @type Description: String # @param WordWeights: 词权重数组,包含全部的热词和对应的权重。每个热词的长度不大于10个汉字或30个英文字符,权重为[1,10]之间整数,数组长度不大于128 # @type WordWeights: Array # @param WordWeightStr: 词权重文件(纯文本文件)的二进制base64编码,以行分隔,每行的格式为word|weight,即以英文符号|为分割,左边为词,右边为权重,如:你好|5。 # 当用户传此参数(参数长度大于0),即以此参数解析词权重,WordWeights会被忽略 # @type WordWeightStr: String attr_accessor :Name, :Description, :WordWeights, :WordWeightStr def initialize(name=nil, description=nil, wordweights=nil, wordweightstr=nil) @Name = name @Description = description @WordWeights = wordweights @WordWeightStr = wordweightstr end def deserialize(params) @Name = params['Name'] @Description = params['Description'] unless params['WordWeights'].nil? @WordWeights = [] params['WordWeights'].each do |i| hotword_tmp = HotWord.new hotword_tmp.deserialize(i) @WordWeights << hotword_tmp end end @WordWeightStr = params['WordWeightStr'] end end # CreateAsrVocab返回参数结构体 class CreateAsrVocabResponse < TencentCloud::Common::AbstractModel # @param VocabId: 词表ID,可用于获取词表信息 # @type VocabId: String # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :VocabId, :RequestId def initialize(vocabid=nil, requestid=nil) @VocabId = vocabid @RequestId = requestid end def deserialize(params) @VocabId = params['VocabId'] @RequestId = params['RequestId'] end end # CreateAsyncRecognitionTask请求参数结构体 class CreateAsyncRecognitionTaskRequest < TencentCloud::Common::AbstractModel # @param EngineType: 引擎模型类型。 # • 16k_zh:中文普通话通用; # • 16k_en:英语; # • 16k_yue:粤语; # • 16k_id:印度尼西亚语; # • 16k_fil:菲律宾语; # • 16k_th:泰语; # • 16k_pt:葡萄牙语; # • 16k_tr:土耳其语; # • 16k_ar:阿拉伯语; # • 16k_es:西班牙语; # @type EngineType: String # @param Url: 语音流地址,支持rtmp、rtsp等流媒体协议,以及各类基于http协议的直播流(不支持hls, m3u8) # @type Url: String # @param CallbackUrl: 支持HTTP和HTTPS协议,用于接收识别结果,您需要自行搭建公网可调用的服务。回调格式&内容详见:[语音流异步识别回调说明](https://cloud.tencent.com/document/product/1093/52633) # @type CallbackUrl: String # @param SignToken: 用于生成回调通知中的签名 # @type SignToken: String # @param FilterDirty: 是否过滤脏词(目前支持中文普通话引擎)。0:不过滤脏词;1:过滤脏词;2:将脏词替换为 * 。默认值为 0 # @type FilterDirty: Integer # @param FilterModal: 是否过语气词(目前支持中文普通话引擎)。0:不过滤语气词;1:部分过滤;2:严格过滤 。默认值为 0 # @type FilterModal: Integer # @param FilterPunc: 是否过滤标点符号(目前支持中文普通话引擎)。 0:不过滤,1:过滤句末标点,2:过滤所有标点。默认为0 # @type FilterPunc: Integer # @param ConvertNumMode: 是否进行阿拉伯数字智能转换。0:不转换,直接输出中文数字,1:根据场景智能转换为阿拉伯数字。默认值为1 # @type ConvertNumMode: Integer # @param WordInfo: 是否显示词级别时间戳。0:不显示;1:显示,不包含标点时间戳,2:显示,包含标点时间戳。默认为0 # @type WordInfo: Integer # @param HotwordId: 热词id。用于调用对应的热词表,如果在调用语音识别服务时,不进行单独的热词id设置,自动生效默认热词;如果进行了单独的热词id设置,那么将生效单独设置的热词id。 # @type HotwordId: String # @param AudioData: 回调数据中,是否需要对应音频数据。 # @type AudioData: Boolean attr_accessor :EngineType, :Url, :CallbackUrl, :SignToken, :FilterDirty, :FilterModal, :FilterPunc, :ConvertNumMode, :WordInfo, :HotwordId, :AudioData def initialize(enginetype=nil, url=nil, callbackurl=nil, signtoken=nil, filterdirty=nil, filtermodal=nil, filterpunc=nil, convertnummode=nil, wordinfo=nil, hotwordid=nil, audiodata=nil) @EngineType = enginetype @Url = url @CallbackUrl = callbackurl @SignToken = signtoken @FilterDirty = filterdirty @FilterModal = filtermodal @FilterPunc = filterpunc @ConvertNumMode = convertnummode @WordInfo = wordinfo @HotwordId = hotwordid @AudioData = audiodata end def deserialize(params) @EngineType = params['EngineType'] @Url = params['Url'] @CallbackUrl = params['CallbackUrl'] @SignToken = params['SignToken'] @FilterDirty = params['FilterDirty'] @FilterModal = params['FilterModal'] @FilterPunc = params['FilterPunc'] @ConvertNumMode = params['ConvertNumMode'] @WordInfo = params['WordInfo'] @HotwordId = params['HotwordId'] @AudioData = params['AudioData'] end end # CreateAsyncRecognitionTask返回参数结构体 class CreateAsyncRecognitionTaskResponse < TencentCloud::Common::AbstractModel # @param Data: 请求返回结果,包含本次的任务ID(TaskId) # @type Data: :class:`Tencentcloud::Asr.v20190614.models.Task` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = Task.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # CreateCustomization请求参数结构体 class CreateCustomizationRequest < TencentCloud::Common::AbstractModel # @param ModelName: 自学习模型名称,需在1-20字符之间 # @type ModelName: String # @param TextUrl: 文本文件的下载地址,服务会从该地址下载文件,目前仅支持腾讯云cos # @type TextUrl: String # @param ModelType: 自学习模型类型,填写8k或者16k # @type ModelType: String # @param TagInfos: 标签信息 # @type TagInfos: Array attr_accessor :ModelName, :TextUrl, :ModelType, :TagInfos def initialize(modelname=nil, texturl=nil, modeltype=nil, taginfos=nil) @ModelName = modelname @TextUrl = texturl @ModelType = modeltype @TagInfos = taginfos end def deserialize(params) @ModelName = params['ModelName'] @TextUrl = params['TextUrl'] @ModelType = params['ModelType'] @TagInfos = params['TagInfos'] end end # CreateCustomization返回参数结构体 class CreateCustomizationResponse < TencentCloud::Common::AbstractModel # @param ModelId: 模型ID # @type ModelId: String # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :ModelId, :RequestId def initialize(modelid=nil, requestid=nil) @ModelId = modelid @RequestId = requestid end def deserialize(params) @ModelId = params['ModelId'] @RequestId = params['RequestId'] end end # CreateRecTask请求参数结构体 class CreateRecTaskRequest < TencentCloud::Common::AbstractModel # @param EngineModelType: 引擎模型类型。注意:非电话场景请务必使用16k的引擎。 # 电话场景: # • 8k_zh:中文电话通用; # • 8k_en:英文电话通用; # 非电话场景: # • 16k_zh:中文通用; # • 16k_zh-PY:中英粤; # • 16k_zh_medical:中文医疗; # • 16k_en:英语; # • 16k_yue:粤语; # • 16k_ja:日语; # • 16k_ko:韩语; # • 16k_vi:越南语; # • 16k_ms:马来语; # • 16k_id:印度尼西亚语; # • 16k_fil:菲律宾语; # • 16k_th:泰语; # • 16k_pt:葡萄牙语; # • 16k_tr:土耳其语; # • 16k_ar:阿拉伯语; # • 16k_es:西班牙语; # • 16k_zh_dialect:多方言,支持23种方言(上海话、四川话、武汉话、贵阳话、昆明话、西安话、郑州话、太原话、兰州话、银川话、西宁话、南京话、合肥话、南昌话、长沙话、苏州话、杭州话、济南话、天津话、石家庄话、黑龙江话、吉林话、辽宁话); # @type EngineModelType: String # @param ChannelNum: 识别声道数。1:单声道(非电话场景,直接选择单声道即可,忽略音频声道数);2:双声道(仅支持8k_zh电话场景,双声道应分别对应通话双方)。注意:双声道的电话音频已物理分离说话人,无需再开启说话人分离功能。 # @type ChannelNum: Integer # @param ResTextFormat: 识别结果返回形式。0: 识别结果文本(含分段时间戳); 1:词级别粒度的[详细识别结果](https://cloud.tencent.com/document/api/1093/37824#SentenceDetail)(不含标点,含语速值);2:词级别粒度的详细识别结果(包含标点、语速值);3: 标点符号分段,包含每段时间戳,特别适用于字幕场景(包含词级时间、标点、语速值)。4:【增值付费功能】对识别结果按照语义分段,并展示词级别粒度的详细识别结果,仅支持8k_zh、16k_zh引擎,需购买对应资源包使用(注意:如果账号后付费功能开启并使用此功能,将[自动计费](https://cloud.tencent.com/document/product/1093/35686)) # @type ResTextFormat: Integer # @param SourceType: 语音数据来源。0:语音 URL;1:语音数据(post body)。 # @type SourceType: Integer # @param SpeakerDiarization: 是否开启说话人分离,0:不开启,1:开启(仅支持8k_zh/16k_zh,ChannelNum=1时可用),默认值为 0。 # 注意:8k电话场景建议使用双声道来区分通话双方,设置ChannelNum=2即可,不用开启说话人分离,如果设置了ChannelNum=1,后台会先转码成单声道,说话人分离结果可能产生偏差。 # @type SpeakerDiarization: Integer # @param SpeakerNumber: 说话人分离人数(需配合开启说话人分离使用),取值范围:0-10,0代表自动分离(目前仅支持≤6个人),1-10代表指定说话人数分离。默认值为 0。 # 注:此功能结果仅供参考,请根据您的需要谨慎使用。 # @type SpeakerNumber: Integer # @param CallbackUrl: 回调 URL,用户自行搭建的用于接收识别结果的服务URL。如果用户使用轮询方式获取识别结果,则无需提交该参数。回调格式&内容详见:[录音识别回调说明](https://cloud.tencent.com/document/product/1093/52632) # @type CallbackUrl: String # @param Url: 语音的URL地址,需要公网环境浏览器可下载。当 SourceType 值为 0 时须填写该字段,为 1 时不需要填写。注意:请确保录音文件时长在5个小时之内,否则可能识别失败。请保证文件的下载速度,否则可能下载失败。 # @type Url: String # @param Data: 语音数据base64编码,当SourceType 值为1时必须填写,为0可不写。音频数据要小于5MB。 # @type Data: String # @param DataLen: 数据长度,非必填(此数据长度为数据未进行base64编码时的数据长度)。 # @type DataLen: Integer # @param ConvertNumMode: 是否进行阿拉伯数字智能转换(目前支持中文普通话引擎)。0:不转换,直接输出中文数字,1:根据场景智能转换为阿拉伯数字,3: 打开数学相关数字转换。默认值为 1。 # @type ConvertNumMode: Integer # @param FilterDirty: 是否过滤脏词(目前支持中文普通话引擎)。0:不过滤脏词;1:过滤脏词;2:将脏词替换为 * 。默认值为 0。 # @type FilterDirty: Integer # @param HotwordId: 热词表id。如不设置该参数,自动生效默认热词表;如设置了该参数,那么将生效对应的热词表。 # @type HotwordId: String # @param CustomizationId: 自学习模型 id。如设置了该参数,将生效对应的自学习模型。 # @type CustomizationId: String # @param Extra: 附加参数(该参数无意义,忽略即可) # @type Extra: String # @param FilterPunc: 是否过滤标点符号(目前支持中文普通话引擎)。 0:不过滤,1:过滤句末标点,2:过滤所有标点。默认值为 0。 # @type FilterPunc: Integer # @param FilterModal: 是否过滤语气词(目前支持中文普通话引擎)。0:不过滤语气词;1:部分过滤;2:严格过滤 。默认值为 0。 # @type FilterModal: Integer # @param EmotionalEnergy: 情绪能量值,取值为音量分贝值/10。取值范围:[1,10]。值越高情绪越强烈。0:不开启,1:开启 # @type EmotionalEnergy: Integer # @param ReinforceHotword: 热词增强功能。1:开启后(仅支持8k_zh,16k_zh),将开启同音替换功能,同音字、词在热词中配置。举例:热词配置“蜜制”并开启增强功能后,与“蜜制”同拼音(mizhi)的“秘制”的识别结果会被强制替换成“蜜制”。因此建议客户根据自己的实际情况开启该功能。 # @type ReinforceHotword: Integer # @param SentenceMaxLength: 单标点最多字数,取值范围:[6,40]。默认为0,不开启该功能。该参数可用于字幕生成场景,控制单行字幕最大字数(设置ResTextFormat为3,解析返回的ResultDetail列表,通过结构中FinalSentence获取单个标点断句结果)。 # @type SentenceMaxLength: Integer # @param EmotionRecognition: 情绪识别能力(目前支持16k_zh) 默认为0,不开启。 1:开启情绪识别但是不会在文本展示“情绪标签”, 2:开启情绪识别并且在文本展示“情绪标签”。(该功能需要设置ResTextFormat 大于0) # 注意:本功能为增值服务,购买对应套餐包后,将参数设置为1或2时方可按对应方式生效,并消耗套餐包对应资源。参数设置为0时无需购买套餐包,也不会消耗对应资源。 # @type EmotionRecognition: Integer attr_accessor :EngineModelType, :ChannelNum, :ResTextFormat, :SourceType, :SpeakerDiarization, :SpeakerNumber, :CallbackUrl, :Url, :Data, :DataLen, :ConvertNumMode, :FilterDirty, :HotwordId, :CustomizationId, :Extra, :FilterPunc, :FilterModal, :EmotionalEnergy, :ReinforceHotword, :SentenceMaxLength, :EmotionRecognition def initialize(enginemodeltype=nil, channelnum=nil, restextformat=nil, sourcetype=nil, speakerdiarization=nil, speakernumber=nil, callbackurl=nil, url=nil, data=nil, datalen=nil, convertnummode=nil, filterdirty=nil, hotwordid=nil, customizationid=nil, extra=nil, filterpunc=nil, filtermodal=nil, emotionalenergy=nil, reinforcehotword=nil, sentencemaxlength=nil, emotionrecognition=nil) @EngineModelType = enginemodeltype @ChannelNum = channelnum @ResTextFormat = restextformat @SourceType = sourcetype @SpeakerDiarization = speakerdiarization @SpeakerNumber = speakernumber @CallbackUrl = callbackurl @Url = url @Data = data @DataLen = datalen @ConvertNumMode = convertnummode @FilterDirty = filterdirty @HotwordId = hotwordid @CustomizationId = customizationid @Extra = extra @FilterPunc = filterpunc @FilterModal = filtermodal @EmotionalEnergy = emotionalenergy @ReinforceHotword = reinforcehotword @SentenceMaxLength = sentencemaxlength @EmotionRecognition = emotionrecognition end def deserialize(params) @EngineModelType = params['EngineModelType'] @ChannelNum = params['ChannelNum'] @ResTextFormat = params['ResTextFormat'] @SourceType = params['SourceType'] @SpeakerDiarization = params['SpeakerDiarization'] @SpeakerNumber = params['SpeakerNumber'] @CallbackUrl = params['CallbackUrl'] @Url = params['Url'] @Data = params['Data'] @DataLen = params['DataLen'] @ConvertNumMode = params['ConvertNumMode'] @FilterDirty = params['FilterDirty'] @HotwordId = params['HotwordId'] @CustomizationId = params['CustomizationId'] @Extra = params['Extra'] @FilterPunc = params['FilterPunc'] @FilterModal = params['FilterModal'] @EmotionalEnergy = params['EmotionalEnergy'] @ReinforceHotword = params['ReinforceHotword'] @SentenceMaxLength = params['SentenceMaxLength'] @EmotionRecognition = params['EmotionRecognition'] end end # CreateRecTask返回参数结构体 class CreateRecTaskResponse < TencentCloud::Common::AbstractModel # @param Data: 录音文件识别的请求返回结果,包含结果查询需要的TaskId # @type Data: :class:`Tencentcloud::Asr.v20190614.models.Task` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = Task.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # DeleteAsrVocab请求参数结构体 class DeleteAsrVocabRequest < TencentCloud::Common::AbstractModel # @param VocabId: 热词表Id # @type VocabId: String attr_accessor :VocabId def initialize(vocabid=nil) @VocabId = vocabid end def deserialize(params) @VocabId = params['VocabId'] end end # DeleteAsrVocab返回参数结构体 class DeleteAsrVocabResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # DeleteCustomization请求参数结构体 class DeleteCustomizationRequest < TencentCloud::Common::AbstractModel # @param ModelId: 要删除的模型ID # @type ModelId: String attr_accessor :ModelId def initialize(modelid=nil) @ModelId = modelid end def deserialize(params) @ModelId = params['ModelId'] end end # DeleteCustomization返回参数结构体 class DeleteCustomizationResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # DescribeAsyncRecognitionTasks请求参数结构体 class DescribeAsyncRecognitionTasksRequest < TencentCloud::Common::AbstractModel def initialize() end def deserialize(params) end end # DescribeAsyncRecognitionTasks返回参数结构体 class DescribeAsyncRecognitionTasksResponse < TencentCloud::Common::AbstractModel # @param Data: 任务列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.AsyncRecognitionTasks` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = AsyncRecognitionTasks.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # DescribeTaskStatus请求参数结构体 class DescribeTaskStatusRequest < TencentCloud::Common::AbstractModel # @param TaskId: 从CreateRecTask接口获取的TaskId,用于获取任务状态与结果。 # @type TaskId: Integer attr_accessor :TaskId def initialize(taskid=nil) @TaskId = taskid end def deserialize(params) @TaskId = params['TaskId'] end end # DescribeTaskStatus返回参数结构体 class DescribeTaskStatusResponse < TencentCloud::Common::AbstractModel # @param Data: 录音文件识别的请求返回结果。 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.TaskStatus` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = TaskStatus.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # DownloadAsrVocab请求参数结构体 class DownloadAsrVocabRequest < TencentCloud::Common::AbstractModel # @param VocabId: 词表ID。 # @type VocabId: String attr_accessor :VocabId def initialize(vocabid=nil) @VocabId = vocabid end def deserialize(params) @VocabId = params['VocabId'] end end # DownloadAsrVocab返回参数结构体 class DownloadAsrVocabResponse < TencentCloud::Common::AbstractModel # @param VocabId: 词表ID。 # @type VocabId: String # @param WordWeightStr: 词表权重文件形式的base64值。 # @type WordWeightStr: String # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :VocabId, :WordWeightStr, :RequestId def initialize(vocabid=nil, wordweightstr=nil, requestid=nil) @VocabId = vocabid @WordWeightStr = wordweightstr @RequestId = requestid end def deserialize(params) @VocabId = params['VocabId'] @WordWeightStr = params['WordWeightStr'] @RequestId = params['RequestId'] end end # DownloadCustomization请求参数结构体 class DownloadCustomizationRequest < TencentCloud::Common::AbstractModel # @param ModelId: 自学习模型ID # @type ModelId: String attr_accessor :ModelId def initialize(modelid=nil) @ModelId = modelid end def deserialize(params) @ModelId = params['ModelId'] end end # DownloadCustomization返回参数结构体 class DownloadCustomizationResponse < TencentCloud::Common::AbstractModel # @param DownloadUrl: 下载地址 # @type DownloadUrl: String # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :DownloadUrl, :RequestId def initialize(downloadurl=nil, requestid=nil) @DownloadUrl = downloadurl @RequestId = requestid end def deserialize(params) @DownloadUrl = params['DownloadUrl'] @RequestId = params['RequestId'] end end # GetAsrVocabList请求参数结构体 class GetAsrVocabListRequest < TencentCloud::Common::AbstractModel # @param TagInfos: 标签信息,格式为“$TagKey : $TagValue ”,中间分隔符为“空格”+“:”+“空格” # @type TagInfos: Array # @param Offset: 分页Offset # @type Offset: Integer # @param Limit: 分页Limit # @type Limit: Integer attr_accessor :TagInfos, :Offset, :Limit def initialize(taginfos=nil, offset=nil, limit=nil) @TagInfos = taginfos @Offset = offset @Limit = limit end def deserialize(params) @TagInfos = params['TagInfos'] @Offset = params['Offset'] @Limit = params['Limit'] end end # GetAsrVocabList返回参数结构体 class GetAsrVocabListResponse < TencentCloud::Common::AbstractModel # @param VocabList: 热词表列表 # @type VocabList: Array # @param TotalCount: 热词列表总数 # @type TotalCount: Integer # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :VocabList, :TotalCount, :RequestId def initialize(vocablist=nil, totalcount=nil, requestid=nil) @VocabList = vocablist @TotalCount = totalcount @RequestId = requestid end def deserialize(params) unless params['VocabList'].nil? @VocabList = [] params['VocabList'].each do |i| vocab_tmp = Vocab.new vocab_tmp.deserialize(i) @VocabList << vocab_tmp end end @TotalCount = params['TotalCount'] @RequestId = params['RequestId'] end end # GetAsrVocab请求参数结构体 class GetAsrVocabRequest < TencentCloud::Common::AbstractModel # @param VocabId: 热词表ID # @type VocabId: String attr_accessor :VocabId def initialize(vocabid=nil) @VocabId = vocabid end def deserialize(params) @VocabId = params['VocabId'] end end # GetAsrVocab返回参数结构体 class GetAsrVocabResponse < TencentCloud::Common::AbstractModel # @param Name: 热词表名称 # @type Name: String # @param Description: 热词表描述 # @type Description: String # @param VocabId: 热词表ID # @type VocabId: String # @param WordWeights: 词权重列表 # @type WordWeights: Array # @param CreateTime: 词表创建时间 # @type CreateTime: String # @param UpdateTime: 词表更新时间 # @type UpdateTime: String # @param State: 热词表状态,1为默认状态即在识别时默认加载该热词表进行识别,0为初始状态 # @type State: Integer # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Name, :Description, :VocabId, :WordWeights, :CreateTime, :UpdateTime, :State, :RequestId def initialize(name=nil, description=nil, vocabid=nil, wordweights=nil, createtime=nil, updatetime=nil, state=nil, requestid=nil) @Name = name @Description = description @VocabId = vocabid @WordWeights = wordweights @CreateTime = createtime @UpdateTime = updatetime @State = state @RequestId = requestid end def deserialize(params) @Name = params['Name'] @Description = params['Description'] @VocabId = params['VocabId'] unless params['WordWeights'].nil? @WordWeights = [] params['WordWeights'].each do |i| hotword_tmp = HotWord.new hotword_tmp.deserialize(i) @WordWeights << hotword_tmp end end @CreateTime = params['CreateTime'] @UpdateTime = params['UpdateTime'] @State = params['State'] @RequestId = params['RequestId'] end end # GetCustomizationList请求参数结构体 class GetCustomizationListRequest < TencentCloud::Common::AbstractModel # @param TagInfos: 标签信息,格式为“$TagKey : $TagValue ”,中间分隔符为“空格”+“:”+“空格” # @type TagInfos: Array # @param Limit: 分页大小,默认1000 # @type Limit: Integer # @param Offset: 分页offset,默认0 # @type Offset: Integer attr_accessor :TagInfos, :Limit, :Offset def initialize(taginfos=nil, limit=nil, offset=nil) @TagInfos = taginfos @Limit = limit @Offset = offset end def deserialize(params) @TagInfos = params['TagInfos'] @Limit = params['Limit'] @Offset = params['Offset'] end end # GetCustomizationList返回参数结构体 class GetCustomizationListResponse < TencentCloud::Common::AbstractModel # @param Data: 自学习模型数组 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Data: Array # @param TotalCount: 自学习模型总量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TotalCount: Integer # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :TotalCount, :RequestId def initialize(data=nil, totalcount=nil, requestid=nil) @Data = data @TotalCount = totalcount @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = [] params['Data'].each do |i| model_tmp = Model.new model_tmp.deserialize(i) @Data << model_tmp end end @TotalCount = params['TotalCount'] @RequestId = params['RequestId'] end end # GetModelInfo请求参数结构体 class GetModelInfoRequest < TencentCloud::Common::AbstractModel # @param ModelId: 模型id # @type ModelId: String attr_accessor :ModelId def initialize(modelid=nil) @ModelId = modelid end def deserialize(params) @ModelId = params['ModelId'] end end # GetModelInfo返回参数结构体 class GetModelInfoResponse < TencentCloud::Common::AbstractModel # @param Data: 模型信息 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.Model` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = Model.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # 热词的词和权重 class HotWord < TencentCloud::Common::AbstractModel # @param Word: 热词 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Word: String # @param Weight: 权重 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Weight: Integer attr_accessor :Word, :Weight def initialize(word=nil, weight=nil) @Word = word @Weight = weight end def deserialize(params) @Word = params['Word'] @Weight = params['Weight'] end end # 自学习模型信息 class Model < TencentCloud::Common::AbstractModel # @param ModelName: 模型名称 # @type ModelName: String # @param DictName: 模型文件名称 # @type DictName: String # @param ModelId: 模型Id # @type ModelId: String # @param ModelType: 模型类型,“8k”或者”16k“ # @type ModelType: String # @param ServiceType: 服务类型 # @type ServiceType: String # @param ModelState: 模型状态: # -2:模型训练失败; # -1:已下线; # 0:训练中; # 1:已上线; # 3:上线中; # 4:下线中; # @type ModelState: Integer # @param AtUpdated: 最后更新时间 # @type AtUpdated: String # @param TagInfos: 标签信息 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TagInfos: Array attr_accessor :ModelName, :DictName, :ModelId, :ModelType, :ServiceType, :ModelState, :AtUpdated, :TagInfos def initialize(modelname=nil, dictname=nil, modelid=nil, modeltype=nil, servicetype=nil, modelstate=nil, atupdated=nil, taginfos=nil) @ModelName = modelname @DictName = dictname @ModelId = modelid @ModelType = modeltype @ServiceType = servicetype @ModelState = modelstate @AtUpdated = atupdated @TagInfos = taginfos end def deserialize(params) @ModelName = params['ModelName'] @DictName = params['DictName'] @ModelId = params['ModelId'] @ModelType = params['ModelType'] @ServiceType = params['ServiceType'] @ModelState = params['ModelState'] @AtUpdated = params['AtUpdated'] @TagInfos = params['TagInfos'] end end # ModifyCustomization请求参数结构体 class ModifyCustomizationRequest < TencentCloud::Common::AbstractModel # @param ModelId: 要修改的模型ID # @type ModelId: String # @param ModelName: 要修改的模型名称,长度需在1-20个字符之间 # @type ModelName: String # @param ModelType: 要修改的模型类型,为8k或者16k # @type ModelType: String # @param TextUrl: 要修改的模型语料的下载地址,目前仅支持腾讯云cos # @type TextUrl: String attr_accessor :ModelId, :ModelName, :ModelType, :TextUrl def initialize(modelid=nil, modelname=nil, modeltype=nil, texturl=nil) @ModelId = modelid @ModelName = modelname @ModelType = modeltype @TextUrl = texturl end def deserialize(params) @ModelId = params['ModelId'] @ModelName = params['ModelName'] @ModelType = params['ModelType'] @TextUrl = params['TextUrl'] end end # ModifyCustomization返回参数结构体 class ModifyCustomizationResponse < TencentCloud::Common::AbstractModel # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :RequestId def initialize(requestid=nil) @RequestId = requestid end def deserialize(params) @RequestId = params['RequestId'] end end # ModifyCustomizationState请求参数结构体 class ModifyCustomizationStateRequest < TencentCloud::Common::AbstractModel # @param ModelId: 自学习模型ID # @type ModelId: String # @param ToState: 想要变换的模型状态,-1代表下线,1代表上线 # @type ToState: Integer attr_accessor :ModelId, :ToState def initialize(modelid=nil, tostate=nil) @ModelId = modelid @ToState = tostate end def deserialize(params) @ModelId = params['ModelId'] @ToState = params['ToState'] end end # ModifyCustomizationState返回参数结构体 class ModifyCustomizationStateResponse < TencentCloud::Common::AbstractModel # @param ModelId: 自学习模型ID # @type ModelId: String # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :ModelId, :RequestId def initialize(modelid=nil, requestid=nil) @ModelId = modelid @RequestId = requestid end def deserialize(params) @ModelId = params['ModelId'] @RequestId = params['RequestId'] end end # 单句的详细识别结果,包含单个词的时间偏移,一般用于生成字幕的场景。 class SentenceDetail < TencentCloud::Common::AbstractModel # @param FinalSentence: 单句最终识别结果 # 注意:此字段可能返回 null,表示取不到有效值。 # @type FinalSentence: String # @param SliceSentence: 单句中间识别结果,使用空格拆分为多个词 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SliceSentence: String # @param StartMs: 单句开始时间(毫秒) # 注意:此字段可能返回 null,表示取不到有效值。 # @type StartMs: Integer # @param EndMs: 单句结束时间(毫秒) # 注意:此字段可能返回 null,表示取不到有效值。 # @type EndMs: Integer # @param WordsNum: 单句中词个数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type WordsNum: Integer # @param Words: 单句中词详情 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Words: Array # @param SpeechSpeed: 单句语速,单位:字数/秒 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SpeechSpeed: Float # @param SpeakerId: 声道或说话人 Id(请求中如果设置了 speaker_diarization或者ChannelNum为双声道,可区分说话人或声道) # 注意:此字段可能返回 null,表示取不到有效值。 # @type SpeakerId: Integer # @param EmotionalEnergy: 情绪能量值,取值为音量分贝值/10。取值范围:[1,10]。值越高情绪越强烈。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type EmotionalEnergy: Float # @param SilenceTime: 本句与上一句之间的静音时长 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SilenceTime: Integer # @param EmotionType: 情绪类型(可能为空) # 注意:此字段可能返回 null,表示取不到有效值。 # @type EmotionType: Array attr_accessor :FinalSentence, :SliceSentence, :StartMs, :EndMs, :WordsNum, :Words, :SpeechSpeed, :SpeakerId, :EmotionalEnergy, :SilenceTime, :EmotionType def initialize(finalsentence=nil, slicesentence=nil, startms=nil, endms=nil, wordsnum=nil, words=nil, speechspeed=nil, speakerid=nil, emotionalenergy=nil, silencetime=nil, emotiontype=nil) @FinalSentence = finalsentence @SliceSentence = slicesentence @StartMs = startms @EndMs = endms @WordsNum = wordsnum @Words = words @SpeechSpeed = speechspeed @SpeakerId = speakerid @EmotionalEnergy = emotionalenergy @SilenceTime = silencetime @EmotionType = emotiontype end def deserialize(params) @FinalSentence = params['FinalSentence'] @SliceSentence = params['SliceSentence'] @StartMs = params['StartMs'] @EndMs = params['EndMs'] @WordsNum = params['WordsNum'] unless params['Words'].nil? @Words = [] params['Words'].each do |i| sentencewords_tmp = SentenceWords.new sentencewords_tmp.deserialize(i) @Words << sentencewords_tmp end end @SpeechSpeed = params['SpeechSpeed'] @SpeakerId = params['SpeakerId'] @EmotionalEnergy = params['EmotionalEnergy'] @SilenceTime = params['SilenceTime'] @EmotionType = params['EmotionType'] end end # SentenceRecognition请求参数结构体 class SentenceRecognitionRequest < TencentCloud::Common::AbstractModel # @param EngSerViceType: 引擎模型类型。 # 电话场景: # • 8k_zh:中文电话通用; # • 8k_en:英文电话通用; # 非电话场景: # • 16k_zh:中文通用; # • 16k_zh-PY:中英粤; # • 16k_zh_medical:中文医疗; # • 16k_en:英语; # • 16k_yue:粤语; # • 16k_ja:日语; # • 16k_ko:韩语; # • 16k_vi:越南语; # • 16k_ms:马来语; # • 16k_id:印度尼西亚语; # • 16k_fil:菲律宾语; # • 16k_th:泰语; # • 16k_pt:葡萄牙语; # • 16k_tr:土耳其语; # • 16k_ar:阿拉伯语; # • 16k_es:西班牙语; # • 16k_zh_dialect:多方言,支持23种方言(上海话、四川话、武汉话、贵阳话、昆明话、西安话、郑州话、太原话、兰州话、银川话、西宁话、南京话、合肥话、南昌话、长沙话、苏州话、杭州话、济南话、天津话、石家庄话、黑龙江话、吉林话、辽宁话); # @type EngSerViceType: String # @param SourceType: 语音数据来源。0:语音 URL;1:语音数据(post body)。 # @type SourceType: Integer # @param VoiceFormat: 识别音频的音频格式,支持wav、pcm、ogg-opus、speex、silk、mp3、m4a、aac、amr。 # @type VoiceFormat: String # @param ProjectId: 腾讯云项目 ID,废弃参数,填写0即可。 # @type ProjectId: Integer # @param SubServiceType: 子服务类型。2: 一句话识别。 # @type SubServiceType: Integer # @param Url: 语音的URL地址,需要公网环境浏览器可下载。当 SourceType 值为 0时须填写该字段,为 1 时不填。音频时长不能超过60s,音频文件大小不能超过3MB。 # @type Url: String # @param UsrAudioKey: 废弃参数,填写任意字符串即可。 # @type UsrAudioKey: String # @param Data: 语音数据,当SourceType 值为1(本地语音数据上传)时必须填写,当SourceType 值为0(语音 URL上传)可不写。要使用base64编码(采用python语言时注意读取文件应该为string而不是byte,以byte格式读取后要decode()。编码后的数据不可带有回车换行符)。音频时长不能超过60s,音频文件大小不能超过3MB(Base64后)。 # @type Data: String # @param DataLen: 数据长度,单位为字节。当 SourceType 值为1(本地语音数据上传)时必须填写,当 SourceType 值为0(语音 URL上传)可不写(此数据长度为数据未进行base64编码时的数据长度)。 # @type DataLen: Integer # @param WordInfo: 是否显示词级别时间戳。0:不显示;1:显示,不包含标点时间戳,2:显示,包含标点时间戳。默认值为 0。 # @type WordInfo: Integer # @param FilterDirty: 是否过滤脏词(目前支持中文普通话引擎)。0:不过滤脏词;1:过滤脏词;2:将脏词替换为 * 。默认值为 0。 # @type FilterDirty: Integer # @param FilterModal: 是否过语气词(目前支持中文普通话引擎)。0:不过滤语气词;1:部分过滤;2:严格过滤 。默认值为 0。 # @type FilterModal: Integer # @param FilterPunc: 是否过滤标点符号(目前支持中文普通话引擎)。 0:不过滤,1:过滤句末标点,2:过滤所有标点。默认值为 0。 # @type FilterPunc: Integer # @param ConvertNumMode: 是否进行阿拉伯数字智能转换。0:不转换,直接输出中文数字,1:根据场景智能转换为阿拉伯数字。默认值为1。 # @type ConvertNumMode: Integer # @param HotwordId: 热词id。用于调用对应的热词表,如果在调用语音识别服务时,不进行单独的热词id设置,自动生效默认热词;如果进行了单独的热词id设置,那么将生效单独设置的热词id。 # @type HotwordId: String # @param CustomizationId: 自学习模型 id。如设置了该参数,将生效对应的自学习模型。 # @type CustomizationId: String # @param ReinforceHotword: 热词增强功能。1:开启后(仅支持8k_zh,16k_zh),将开启同音替换功能,同音字、词在热词中配置。举例:热词配置“蜜制”并开启增强功能后,与“蜜制”同拼音(mizhi)的“秘制”的识别结果会被强制替换成“蜜制”。因此建议客户根据自己的实际情况开启该功能。 # @type ReinforceHotword: Integer # @param HotwordList: 临时热词表,该参数用于提升热词识别准确率。 # 单个热词规则:"热词|权重",不超过30个字符(最多10个汉字),权重1-10; # 临时热词表限制:多个热词用英文逗号分割,最多128个热词,参数示例:"腾讯云|10,语音识别|5,ASR|10"; # 参数 hotword_list 与 hotword_id 区别: # hotword_id:需要先在控制台或接口创建热词表,获得对应hotword_id传入参数来使用热词功能; # hotword_list:每次请求时直接传入临时热词表来使用热词功能,云端不保留临时热词表; # 注意:如果同时传入了 hotword_id 和 hotword_list,会优先使用 hotword_list。 # @type HotwordList: String # @param InputSampleRate: 支持pcm格式的8k音频在与引擎采样率不匹配的情况下升采样到16k后识别,能有效提升识别准确率。仅支持:8000。如:传入 8000 ,则pcm音频采样率为8k,当引擎选用16k_zh, 那么该8k采样率的pcm音频可以在16k_zh引擎下正常识别。 注:此参数仅适用于pcm格式音频,不传入值将维持默认状态,即默认调用的引擎采样率等于pcm音频采样率。 # @type InputSampleRate: Integer attr_accessor :EngSerViceType, :SourceType, :VoiceFormat, :ProjectId, :SubServiceType, :Url, :UsrAudioKey, :Data, :DataLen, :WordInfo, :FilterDirty, :FilterModal, :FilterPunc, :ConvertNumMode, :HotwordId, :CustomizationId, :ReinforceHotword, :HotwordList, :InputSampleRate extend Gem::Deprecate deprecate :ProjectId, :none, 2023, 8 deprecate :ProjectId=, :none, 2023, 8 deprecate :SubServiceType, :none, 2023, 8 deprecate :SubServiceType=, :none, 2023, 8 deprecate :UsrAudioKey, :none, 2023, 8 deprecate :UsrAudioKey=, :none, 2023, 8 def initialize(engservicetype=nil, sourcetype=nil, voiceformat=nil, projectid=nil, subservicetype=nil, url=nil, usraudiokey=nil, data=nil, datalen=nil, wordinfo=nil, filterdirty=nil, filtermodal=nil, filterpunc=nil, convertnummode=nil, hotwordid=nil, customizationid=nil, reinforcehotword=nil, hotwordlist=nil, inputsamplerate=nil) @EngSerViceType = engservicetype @SourceType = sourcetype @VoiceFormat = voiceformat @ProjectId = projectid @SubServiceType = subservicetype @Url = url @UsrAudioKey = usraudiokey @Data = data @DataLen = datalen @WordInfo = wordinfo @FilterDirty = filterdirty @FilterModal = filtermodal @FilterPunc = filterpunc @ConvertNumMode = convertnummode @HotwordId = hotwordid @CustomizationId = customizationid @ReinforceHotword = reinforcehotword @HotwordList = hotwordlist @InputSampleRate = inputsamplerate end def deserialize(params) @EngSerViceType = params['EngSerViceType'] @SourceType = params['SourceType'] @VoiceFormat = params['VoiceFormat'] @ProjectId = params['ProjectId'] @SubServiceType = params['SubServiceType'] @Url = params['Url'] @UsrAudioKey = params['UsrAudioKey'] @Data = params['Data'] @DataLen = params['DataLen'] @WordInfo = params['WordInfo'] @FilterDirty = params['FilterDirty'] @FilterModal = params['FilterModal'] @FilterPunc = params['FilterPunc'] @ConvertNumMode = params['ConvertNumMode'] @HotwordId = params['HotwordId'] @CustomizationId = params['CustomizationId'] @ReinforceHotword = params['ReinforceHotword'] @HotwordList = params['HotwordList'] @InputSampleRate = params['InputSampleRate'] end end # SentenceRecognition返回参数结构体 class SentenceRecognitionResponse < TencentCloud::Common::AbstractModel # @param Result: 识别结果。 # @type Result: String # @param AudioDuration: 请求的音频时长,单位为ms # @type AudioDuration: Integer # @param WordSize: 词时间戳列表的长度 # 注意:此字段可能返回 null,表示取不到有效值。 # @type WordSize: Integer # @param WordList: 词时间戳列表 # 注意:此字段可能返回 null,表示取不到有效值。 # @type WordList: Array # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Result, :AudioDuration, :WordSize, :WordList, :RequestId def initialize(result=nil, audioduration=nil, wordsize=nil, wordlist=nil, requestid=nil) @Result = result @AudioDuration = audioduration @WordSize = wordsize @WordList = wordlist @RequestId = requestid end def deserialize(params) @Result = params['Result'] @AudioDuration = params['AudioDuration'] @WordSize = params['WordSize'] unless params['WordList'].nil? @WordList = [] params['WordList'].each do |i| sentenceword_tmp = SentenceWord.new sentenceword_tmp.deserialize(i) @WordList << sentenceword_tmp end end @RequestId = params['RequestId'] end end # 一句话识别返回的词时间戳 class SentenceWord < TencentCloud::Common::AbstractModel # @param Word: 词结果 # @type Word: String # @param StartTime: 词在音频中的开始时间 # @type StartTime: Integer # @param EndTime: 词在音频中的结束时间 # @type EndTime: Integer attr_accessor :Word, :StartTime, :EndTime def initialize(word=nil, starttime=nil, endtime=nil) @Word = word @StartTime = starttime @EndTime = endtime end def deserialize(params) @Word = params['Word'] @StartTime = params['StartTime'] @EndTime = params['EndTime'] end end # 识别结果中词文本,以及对应时间偏移 class SentenceWords < TencentCloud::Common::AbstractModel # @param Word: 词文本 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Word: String # @param OffsetStartMs: 在句子中的开始时间偏移量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OffsetStartMs: Integer # @param OffsetEndMs: 在句子中的结束时间偏移量 # 注意:此字段可能返回 null,表示取不到有效值。 # @type OffsetEndMs: Integer attr_accessor :Word, :OffsetStartMs, :OffsetEndMs def initialize(word=nil, offsetstartms=nil, offsetendms=nil) @Word = word @OffsetStartMs = offsetstartms @OffsetEndMs = offsetendms end def deserialize(params) @Word = params['Word'] @OffsetStartMs = params['OffsetStartMs'] @OffsetEndMs = params['OffsetEndMs'] end end # SetVocabState请求参数结构体 class SetVocabStateRequest < TencentCloud::Common::AbstractModel # @param VocabId: 热词表ID。 # @type VocabId: String # @param State: 热词表状态,1:设为默认状态;0:设为非默认状态。 # @type State: Integer attr_accessor :VocabId, :State def initialize(vocabid=nil, state=nil) @VocabId = vocabid @State = state end def deserialize(params) @VocabId = params['VocabId'] @State = params['State'] end end # SetVocabState返回参数结构体 class SetVocabStateResponse < TencentCloud::Common::AbstractModel # @param VocabId: 热词表ID # @type VocabId: String # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :VocabId, :RequestId def initialize(vocabid=nil, requestid=nil) @VocabId = vocabid @RequestId = requestid end def deserialize(params) @VocabId = params['VocabId'] @RequestId = params['RequestId'] end end # 录音文件识别、实时语音异步识别请求的返回数据 class Task < TencentCloud::Common::AbstractModel # @param TaskId: 任务ID,可通过此ID在轮询接口获取识别状态与结果。注意:TaskId数据类型为uint64 # @type TaskId: Integer attr_accessor :TaskId def initialize(taskid=nil) @TaskId = taskid end def deserialize(params) @TaskId = params['TaskId'] end end # 获取录音识别结果的返回参数 class TaskStatus < TencentCloud::Common::AbstractModel # @param TaskId: 任务标识。注意:TaskId数据类型为uint64。 # @type TaskId: Integer # @param Status: 任务状态码,0:任务等待,1:任务执行中,2:任务成功,3:任务失败。 # @type Status: Integer # @param StatusStr: 任务状态,waiting:任务等待,doing:任务执行中,success:任务成功,failed:任务失败。 # @type StatusStr: String # @param Result: 识别结果。 # @type Result: String # @param ErrorMsg: 失败原因说明。 # @type ErrorMsg: String # @param ResultDetail: 识别结果详情,包含每个句子中的词时间偏移,一般用于生成字幕的场景。(录音识别请求中ResTextFormat=1时该字段不为空) # 注意:此字段可能返回 null,表示取不到有效值。 # @type ResultDetail: Array # @param AudioDuration: 音频时长(秒)。 # 注意:此字段可能返回 null,表示取不到有效值。 # @type AudioDuration: Float attr_accessor :TaskId, :Status, :StatusStr, :Result, :ErrorMsg, :ResultDetail, :AudioDuration def initialize(taskid=nil, status=nil, statusstr=nil, result=nil, errormsg=nil, resultdetail=nil, audioduration=nil) @TaskId = taskid @Status = status @StatusStr = statusstr @Result = result @ErrorMsg = errormsg @ResultDetail = resultdetail @AudioDuration = audioduration end def deserialize(params) @TaskId = params['TaskId'] @Status = params['Status'] @StatusStr = params['StatusStr'] @Result = params['Result'] @ErrorMsg = params['ErrorMsg'] unless params['ResultDetail'].nil? @ResultDetail = [] params['ResultDetail'].each do |i| sentencedetail_tmp = SentenceDetail.new sentencedetail_tmp.deserialize(i) @ResultDetail << sentencedetail_tmp end end @AudioDuration = params['AudioDuration'] end end # UpdateAsrVocab请求参数结构体 class UpdateAsrVocabRequest < TencentCloud::Common::AbstractModel # @param VocabId: 热词表ID # @type VocabId: String # @param Name: 热词表名称,长度在1-255之间 # @type Name: String # @param WordWeights: 词权重数组,包含全部的热词和对应的权重。每个热词的长度不大于10,权重为[1,10]之间整数,数组长度不大于128 # @type WordWeights: Array # @param WordWeightStr: 词权重文件(纯文本文件)的二进制base64编码,以行分隔,每行的格式为word|weight,即以英文符号|为分割,左边为词,右边为权重,如:你好|5。 # 当用户传此参数(参数长度大于0),即以此参数解析词权重,WordWeights会被忽略 # @type WordWeightStr: String # @param Description: 热词表描述,长度在0-1000之间 # @type Description: String attr_accessor :VocabId, :Name, :WordWeights, :WordWeightStr, :Description def initialize(vocabid=nil, name=nil, wordweights=nil, wordweightstr=nil, description=nil) @VocabId = vocabid @Name = name @WordWeights = wordweights @WordWeightStr = wordweightstr @Description = description end def deserialize(params) @VocabId = params['VocabId'] @Name = params['Name'] unless params['WordWeights'].nil? @WordWeights = [] params['WordWeights'].each do |i| hotword_tmp = HotWord.new hotword_tmp.deserialize(i) @WordWeights << hotword_tmp end end @WordWeightStr = params['WordWeightStr'] @Description = params['Description'] end end # UpdateAsrVocab返回参数结构体 class UpdateAsrVocabResponse < TencentCloud::Common::AbstractModel # @param VocabId: 热词表ID # @type VocabId: String # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :VocabId, :RequestId def initialize(vocabid=nil, requestid=nil) @VocabId = vocabid @RequestId = requestid end def deserialize(params) @VocabId = params['VocabId'] @RequestId = params['RequestId'] end end # 词表内容 class Vocab < TencentCloud::Common::AbstractModel # @param Name: 热词表名称 # @type Name: String # @param Description: 热词表描述 # @type Description: String # @param VocabId: 热词表ID # @type VocabId: String # @param WordWeights: 词权重列表 # @type WordWeights: Array # @param CreateTime: 词表创建时间 # @type CreateTime: String # @param UpdateTime: 词表更新时间 # @type UpdateTime: String # @param State: 热词表状态,1为默认状态即在识别时默认加载该热词表进行识别,0为初始状态 # @type State: Integer # @param TagInfos: 标签数组 # 注意:此字段可能返回 null,表示取不到有效值。 # @type TagInfos: Array attr_accessor :Name, :Description, :VocabId, :WordWeights, :CreateTime, :UpdateTime, :State, :TagInfos def initialize(name=nil, description=nil, vocabid=nil, wordweights=nil, createtime=nil, updatetime=nil, state=nil, taginfos=nil) @Name = name @Description = description @VocabId = vocabid @WordWeights = wordweights @CreateTime = createtime @UpdateTime = updatetime @State = state @TagInfos = taginfos end def deserialize(params) @Name = params['Name'] @Description = params['Description'] @VocabId = params['VocabId'] unless params['WordWeights'].nil? @WordWeights = [] params['WordWeights'].each do |i| hotword_tmp = HotWord.new hotword_tmp.deserialize(i) @WordWeights << hotword_tmp end end @CreateTime = params['CreateTime'] @UpdateTime = params['UpdateTime'] @State = params['State'] @TagInfos = params['TagInfos'] end end # 说话人基础数据,包括说话人id和说话人昵称 class VoicePrintBaseData < TencentCloud::Common::AbstractModel # @param VoicePrintId: 说话人id # 注意:此字段可能返回 null,表示取不到有效值。 # @type VoicePrintId: String # @param SpeakerNick: 说话人昵称 # 注意:此字段可能返回 null,表示取不到有效值。 # @type SpeakerNick: String attr_accessor :VoicePrintId, :SpeakerNick def initialize(voiceprintid=nil, speakernick=nil) @VoicePrintId = voiceprintid @SpeakerNick = speakernick end def deserialize(params) @VoicePrintId = params['VoicePrintId'] @SpeakerNick = params['SpeakerNick'] end end # 统计返回注册数量结构 class VoicePrintCountData < TencentCloud::Common::AbstractModel # @param Total: 总数 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Total: Integer attr_accessor :Total def initialize(total=nil) @Total = total end def deserialize(params) @Total = params['Total'] end end # VoicePrintCount请求参数结构体 class VoicePrintCountRequest < TencentCloud::Common::AbstractModel def initialize() end def deserialize(params) end end # VoicePrintCount返回参数结构体 class VoicePrintCountResponse < TencentCloud::Common::AbstractModel # @param Data: 统计数据 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.VoicePrintCountData` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = VoicePrintCountData.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # VoicePrintDelete请求参数结构体 class VoicePrintDeleteRequest < TencentCloud::Common::AbstractModel # @param VoicePrintId: 说话人id,说话人唯一标识 # @type VoicePrintId: String attr_accessor :VoicePrintId def initialize(voiceprintid=nil) @VoicePrintId = voiceprintid end def deserialize(params) @VoicePrintId = params['VoicePrintId'] end end # VoicePrintDelete返回参数结构体 class VoicePrintDeleteResponse < TencentCloud::Common::AbstractModel # @param Data: 说话人基本信息 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.VoicePrintBaseData` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = VoicePrintBaseData.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # VoicePrintEnroll请求参数结构体 class VoicePrintEnrollRequest < TencentCloud::Common::AbstractModel # @param VoiceFormat: 音频格式 0: pcm, 1: wav # @type VoiceFormat: Integer # @param SampleRate: 音频采样率,目前支持16000,单位:Hz,必填 # @type SampleRate: Integer # @param Data: 音频数据, base64 编码, 音频时长不能超过30s,数据大小不超过2M # @type Data: String # @param SpeakerNick: 说话人昵称 不超过32字节 # @type SpeakerNick: String attr_accessor :VoiceFormat, :SampleRate, :Data, :SpeakerNick def initialize(voiceformat=nil, samplerate=nil, data=nil, speakernick=nil) @VoiceFormat = voiceformat @SampleRate = samplerate @Data = data @SpeakerNick = speakernick end def deserialize(params) @VoiceFormat = params['VoiceFormat'] @SampleRate = params['SampleRate'] @Data = params['Data'] @SpeakerNick = params['SpeakerNick'] end end # VoicePrintEnroll返回参数结构体 class VoicePrintEnrollResponse < TencentCloud::Common::AbstractModel # @param Data: 说话人基本数据 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.VoicePrintBaseData` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = VoicePrintBaseData.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # VoicePrintUpdate请求参数结构体 class VoicePrintUpdateRequest < TencentCloud::Common::AbstractModel # @param VoiceFormat: 音频格式 0: pcm, 1: wav # @type VoiceFormat: Integer # @param SampleRate: 音频采样率 目前仅支持16000 单位Hz # @type SampleRate: Integer # @param VoicePrintId: 说话人id, 说话人唯一标识 # @type VoicePrintId: String # @param Data: 音频数据, base64 编码, 音频时长不能超过30s,数据大小不超过2M # @type Data: String # @param SpeakerNick: 说话人昵称 不超过32字节 # @type SpeakerNick: String attr_accessor :VoiceFormat, :SampleRate, :VoicePrintId, :Data, :SpeakerNick def initialize(voiceformat=nil, samplerate=nil, voiceprintid=nil, data=nil, speakernick=nil) @VoiceFormat = voiceformat @SampleRate = samplerate @VoicePrintId = voiceprintid @Data = data @SpeakerNick = speakernick end def deserialize(params) @VoiceFormat = params['VoiceFormat'] @SampleRate = params['SampleRate'] @VoicePrintId = params['VoicePrintId'] @Data = params['Data'] @SpeakerNick = params['SpeakerNick'] end end # VoicePrintUpdate返回参数结构体 class VoicePrintUpdateResponse < TencentCloud::Common::AbstractModel # @param Data: 说话人基础数据 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.VoicePrintBaseData` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = VoicePrintBaseData.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end # 说话人验证数据 class VoicePrintVerifyData < TencentCloud::Common::AbstractModel # @param VoicePrintId: 说话人id # 注意:此字段可能返回 null,表示取不到有效值。 # @type VoicePrintId: String # @param Score: 匹配度 取值范围(0.0 - 100.0) # 注意:此字段可能返回 null,表示取不到有效值。 # @type Score: String # @param Decision: 验证结果 0: 未通过 1: 通过 # 注意:此字段可能返回 null,表示取不到有效值。 # @type Decision: Integer attr_accessor :VoicePrintId, :Score, :Decision def initialize(voiceprintid=nil, score=nil, decision=nil) @VoicePrintId = voiceprintid @Score = score @Decision = decision end def deserialize(params) @VoicePrintId = params['VoicePrintId'] @Score = params['Score'] @Decision = params['Decision'] end end # VoicePrintVerify请求参数结构体 class VoicePrintVerifyRequest < TencentCloud::Common::AbstractModel # @param VoiceFormat: 音频格式 0: pcm, 1: wav # @type VoiceFormat: Integer # @param SampleRate: 音频采样率,目前支持16000,单位:Hz,必填 # @type SampleRate: Integer # @param VoicePrintId: 说话人id, 说话人唯一标识 # @type VoicePrintId: String # @param Data: 音频数据, base64 编码, 音频时长不能超过30s,数据大小不超过2M # @type Data: String attr_accessor :VoiceFormat, :SampleRate, :VoicePrintId, :Data def initialize(voiceformat=nil, samplerate=nil, voiceprintid=nil, data=nil) @VoiceFormat = voiceformat @SampleRate = samplerate @VoicePrintId = voiceprintid @Data = data end def deserialize(params) @VoiceFormat = params['VoiceFormat'] @SampleRate = params['SampleRate'] @VoicePrintId = params['VoicePrintId'] @Data = params['Data'] end end # VoicePrintVerify返回参数结构体 class VoicePrintVerifyResponse < TencentCloud::Common::AbstractModel # @param Data: 说话人验证数据 # @type Data: :class:`Tencentcloud::Asr.v20190614.models.VoicePrintVerifyData` # @param RequestId: 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :Data, :RequestId def initialize(data=nil, requestid=nil) @Data = data @RequestId = requestid end def deserialize(params) unless params['Data'].nil? @Data = VoicePrintVerifyData.new @Data.deserialize(params['Data']) end @RequestId = params['RequestId'] end end end end end