Files

217 lines
11 KiB
C#
Raw Permalink Normal View History

/*
* Copyright (c) 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.
*/
namespace TencentCloud.Soe.V20180724
{
using Newtonsoft.Json;
using System.Threading.Tasks;
using TencentCloud.Common;
using TencentCloud.Common.Profile;
using TencentCloud.Soe.V20180724.Models;
public class SoeClient : AbstractClient{
private const string endpoint = "soe.tencentcloudapi.com";
private const string version = "2018-07-24";
/// <summary>
/// Client constructor.
/// </summary>
/// <param name="credential">Credentials.</param>
/// <param name="region">Region name, such as "ap-guangzhou".</param>
public SoeClient(Credential credential, string region)
: this(credential, region, new ClientProfile())
{
}
/// <summary>
/// Client Constructor.
/// </summary>
/// <param name="credential">Credentials.</param>
/// <param name="region">Region name, such as "ap-guangzhou".</param>
/// <param name="profile">Client profiles.</param>
public SoeClient(Credential credential, string region, ClientProfile profile)
: base(endpoint, version, credential, region, profile)
{
}
/// <summary>
/// 初始化发音评估过程,每一轮评估前进行调用。语音输入模式分为流式模式和非流式模式,流式模式支持数据分片传输,可以加快评估响应速度。评估模式分为词模式和句子模式,词模式会标注每个音节的详细信息;句子模式会有完整度和流利度的评估。
/// </summary>
/// <param name="req"><see cref="InitOralProcessRequest"/></param>
/// <returns><see cref="InitOralProcessResponse"/></returns>
public async Task<InitOralProcessResponse> InitOralProcess(InitOralProcessRequest req)
{
JsonResponseModel<InitOralProcessResponse> rsp = null;
try
{
var strResp = await this.InternalRequest(req, "InitOralProcess");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<InitOralProcessResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 初始化发音评估过程,每一轮评估前进行调用。语音输入模式分为流式模式和非流式模式,流式模式支持数据分片传输,可以加快评估响应速度。评估模式分为词模式和句子模式,词模式会标注每个音节的详细信息;句子模式会有完整度和流利度的评估。
/// </summary>
/// <param name="req"><see cref="InitOralProcessRequest"/></param>
/// <returns><see cref="InitOralProcessResponse"/></returns>
public InitOralProcessResponse InitOralProcessSync(InitOralProcessRequest req)
{
JsonResponseModel<InitOralProcessResponse> rsp = null;
try
{
var strResp = this.InternalRequestSync(req, "InitOralProcess");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<InitOralProcessResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 指定主题关键词词汇评估分析语音与关键词的切合程度可指定多个关键词支持中文英文同时评测。分片传输时尽量保证纯异步调用即不等待上一个分片的传输结果边录边传这样可以尽可能早的提供音频数据。音频源目前仅支持16k采样率16bit单声道编码方式如有不一致可能导致评估不准确或失败。
/// </summary>
/// <param name="req"><see cref="KeywordEvaluateRequest"/></param>
/// <returns><see cref="KeywordEvaluateResponse"/></returns>
public async Task<KeywordEvaluateResponse> KeywordEvaluate(KeywordEvaluateRequest req)
{
JsonResponseModel<KeywordEvaluateResponse> rsp = null;
try
{
var strResp = await this.InternalRequest(req, "KeywordEvaluate");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<KeywordEvaluateResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 指定主题关键词词汇评估分析语音与关键词的切合程度可指定多个关键词支持中文英文同时评测。分片传输时尽量保证纯异步调用即不等待上一个分片的传输结果边录边传这样可以尽可能早的提供音频数据。音频源目前仅支持16k采样率16bit单声道编码方式如有不一致可能导致评估不准确或失败。
/// </summary>
/// <param name="req"><see cref="KeywordEvaluateRequest"/></param>
/// <returns><see cref="KeywordEvaluateResponse"/></returns>
public KeywordEvaluateResponse KeywordEvaluateSync(KeywordEvaluateRequest req)
{
JsonResponseModel<KeywordEvaluateResponse> rsp = null;
try
{
var strResp = this.InternalRequestSync(req, "KeywordEvaluate");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<KeywordEvaluateResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 传输音频数据必须在完成发音评估初始化接口之后调用且SessonId要与初始化接口保持一致。分片传输时尽量保证SeqId顺序传输。音频源目前仅支持16k采样率16bit单声道编码方式如有不一致可能导致评估不准确或失败。
/// </summary>
/// <param name="req"><see cref="TransmitOralProcessRequest"/></param>
/// <returns><see cref="TransmitOralProcessResponse"/></returns>
public async Task<TransmitOralProcessResponse> TransmitOralProcess(TransmitOralProcessRequest req)
{
JsonResponseModel<TransmitOralProcessResponse> rsp = null;
try
{
var strResp = await this.InternalRequest(req, "TransmitOralProcess");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<TransmitOralProcessResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 传输音频数据必须在完成发音评估初始化接口之后调用且SessonId要与初始化接口保持一致。分片传输时尽量保证SeqId顺序传输。音频源目前仅支持16k采样率16bit单声道编码方式如有不一致可能导致评估不准确或失败。
/// </summary>
/// <param name="req"><see cref="TransmitOralProcessRequest"/></param>
/// <returns><see cref="TransmitOralProcessResponse"/></returns>
public TransmitOralProcessResponse TransmitOralProcessSync(TransmitOralProcessRequest req)
{
JsonResponseModel<TransmitOralProcessResponse> rsp = null;
try
{
var strResp = this.InternalRequestSync(req, "TransmitOralProcess");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<TransmitOralProcessResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 初始化并传输音频数据分片传输时尽量保证SeqId顺序传输。音频源目前仅支持16k采样率16bit单声道编码方式如有不一致可能导致评估不准确或失败。
/// </summary>
/// <param name="req"><see cref="TransmitOralProcessWithInitRequest"/></param>
/// <returns><see cref="TransmitOralProcessWithInitResponse"/></returns>
public async Task<TransmitOralProcessWithInitResponse> TransmitOralProcessWithInit(TransmitOralProcessWithInitRequest req)
{
JsonResponseModel<TransmitOralProcessWithInitResponse> rsp = null;
try
{
var strResp = await this.InternalRequest(req, "TransmitOralProcessWithInit");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<TransmitOralProcessWithInitResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 初始化并传输音频数据分片传输时尽量保证SeqId顺序传输。音频源目前仅支持16k采样率16bit单声道编码方式如有不一致可能导致评估不准确或失败。
/// </summary>
/// <param name="req"><see cref="TransmitOralProcessWithInitRequest"/></param>
/// <returns><see cref="TransmitOralProcessWithInitResponse"/></returns>
public TransmitOralProcessWithInitResponse TransmitOralProcessWithInitSync(TransmitOralProcessWithInitRequest req)
{
JsonResponseModel<TransmitOralProcessWithInitResponse> rsp = null;
try
{
var strResp = this.InternalRequestSync(req, "TransmitOralProcessWithInit");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<TransmitOralProcessWithInitResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
}
}