/* * 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.Nlp.V20190408 { using Newtonsoft.Json; using System.Threading.Tasks; using TencentCloud.Common; using TencentCloud.Common.Profile; using TencentCloud.Nlp.V20190408.Models; public class NlpClient : AbstractClient{ private const string endpoint = "nlp.tencentcloudapi.com"; private const string version = "2019-04-08"; /// /// Client constructor. /// /// Credentials. /// Region name, such as "ap-guangzhou". public NlpClient(Credential credential, string region) : this(credential, region, new ClientProfile()) { } /// /// Client Constructor. /// /// Credentials. /// Region name, such as "ap-guangzhou". /// Client profiles. public NlpClient(Credential credential, string region, ClientProfile profile) : base(endpoint, version, credential, region, profile) { } /// /// 利用人工智能算法,自动抽取文本中的关键信息并生成指定长度的文本摘要。可用于新闻标题生成、科技文献摘要生成和商品评论摘要等。 /// /// /// public async Task AutoSummarization(AutoSummarizationRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "AutoSummarization"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 利用人工智能算法,自动抽取文本中的关键信息并生成指定长度的文本摘要。可用于新闻标题生成、科技文献摘要生成和商品评论摘要等。 /// /// /// public AutoSummarizationResponse AutoSummarizationSync(AutoSummarizationRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "AutoSummarization"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 闲聊服务基于腾讯领先的NLP引擎能力、数据运算能力和千亿级互联网语料数据的支持,同时集成了广泛的知识问答能力,可实现上百种自定义属性配置,以及儿童语言风格及说话方式,从而让聊天变得更睿智、简单和有趣。 /// /// /// /// public async Task ChatBot(ChatBotRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "ChatBot"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 闲聊服务基于腾讯领先的NLP引擎能力、数据运算能力和千亿级互联网语料数据的支持,同时集成了广泛的知识问答能力,可实现上百种自定义属性配置,以及儿童语言风格及说话方式,从而让聊天变得更睿智、简单和有趣。 /// /// /// /// public ChatBotResponse ChatBotSync(ChatBotRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "ChatBot"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 句法依存分析接口能够分析出句子中词与词之间的相互依存关系,并揭示其句法结构,包括主谓关系、动宾关系、核心关系等等,可用于提取句子主干、提取句子核心词等,在机器翻译、自动问答、知识抽取等领域都有很好的应用。 /// /// /// public async Task DependencyParsing(DependencyParsingRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "DependencyParsing"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 句法依存分析接口能够分析出句子中词与词之间的相互依存关系,并揭示其句法结构,包括主谓关系、动宾关系、核心关系等等,可用于提取句子主干、提取句子核心词等,在机器翻译、自动问答、知识抽取等领域都有很好的应用。 /// /// /// public DependencyParsingResponse DependencyParsingSync(DependencyParsingRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "DependencyParsing"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 输入实体名称,返回实体相关的信息如实体别名、实体英文名、实体详细信息、相关实体等。 /// /// /// public async Task DescribeEntity(DescribeEntityRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "DescribeEntity"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 输入实体名称,返回实体相关的信息如实体别名、实体英文名、实体详细信息、相关实体等。 /// /// /// public DescribeEntityResponse DescribeEntitySync(DescribeEntityRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "DescribeEntity"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 输入两个实体,返回两个实体间的关系,例如马化腾与腾讯公司不仅是相关实体,二者还存在隶属关系(马化腾属于腾讯公司)。 /// /// /// public async Task DescribeRelation(DescribeRelationRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "DescribeRelation"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 输入两个实体,返回两个实体间的关系,例如马化腾与腾讯公司不仅是相关实体,二者还存在隶属关系(马化腾属于腾讯公司)。 /// /// /// public DescribeRelationResponse DescribeRelationSync(DescribeRelationRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "DescribeRelation"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 三元组查询,主要分为两类,SP查询和PO查询。SP查询表示已知主语和谓语查询宾语,PO查询表示已知宾语和谓语查询主语。每一个SP或PO查询都是一个可独立执行的查询,TQL支持SP查询的嵌套查询,即主语可以是一个嵌套的子查询。其他复杂的三元组查询方法,请参考官网API文档示例。 /// /// /// public async Task DescribeTriple(DescribeTripleRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "DescribeTriple"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 三元组查询,主要分为两类,SP查询和PO查询。SP查询表示已知主语和谓语查询宾语,PO查询表示已知宾语和谓语查询主语。每一个SP或PO查询都是一个可独立执行的查询,TQL支持SP查询的嵌套查询,即主语可以是一个嵌套的子查询。其他复杂的三元组查询方法,请参考官网API文档示例。 /// /// /// public DescribeTripleResponse DescribeTripleSync(DescribeTripleRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "DescribeTriple"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 基于关键词提取平台,通过对文本内容进行深度分析,提取出文本内容中的关键信息,为用户实现诸如新闻内容关键词自动提取、评论关键词提取等提供基础服务。 /// /// /// public async Task KeywordsExtraction(KeywordsExtractionRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "KeywordsExtraction"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 基于关键词提取平台,通过对文本内容进行深度分析,提取出文本内容中的关键信息,为用户实现诸如新闻内容关键词自动提取、评论关键词提取等提供基础服务。 /// /// /// public KeywordsExtractionResponse KeywordsExtractionSync(KeywordsExtractionRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "KeywordsExtraction"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 词法分析接口提供以下三个功能: /// /// 1、智能分词:将连续的自然语言文本,切分成具有语义合理性和完整性的词汇序列; /// /// 2、词性标注:为每一个词附上对应的词性,例如名词、代词、形容词、动词等; /// /// 3、命名实体识别:快速识别文本中的实体,例如人名、地名、机构名等。 /// /// 所有的功能均基于千亿级大规模互联网语料进行持续迭代更新,以保证效果不断提升,用户无需担心新词发现、歧义消除、调用性能等问题。目前词法分析已经在泛互联网、金融、政务等不同垂直领域提供业务支持,并取得良好的效果。 /// /// /// public async Task LexicalAnalysis(LexicalAnalysisRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "LexicalAnalysis"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 词法分析接口提供以下三个功能: /// /// 1、智能分词:将连续的自然语言文本,切分成具有语义合理性和完整性的词汇序列; /// /// 2、词性标注:为每一个词附上对应的词性,例如名词、代词、形容词、动词等; /// /// 3、命名实体识别:快速识别文本中的实体,例如人名、地名、机构名等。 /// /// 所有的功能均基于千亿级大规模互联网语料进行持续迭代更新,以保证效果不断提升,用户无需担心新词发现、歧义消除、调用性能等问题。目前词法分析已经在泛互联网、金融、政务等不同垂直领域提供业务支持,并取得良好的效果。 /// /// /// public LexicalAnalysisResponse LexicalAnalysisSync(LexicalAnalysisRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "LexicalAnalysis"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 句向量接口能够将输入的句子映射成一个固定维度的向量,用来表示这个句子的语义特征,可用于文本聚类、文本相似度、文本分类等任务,能够显著提高它们的效果。 /// /// 该句向量服务由腾讯知文自然语言处理团队联合腾讯AI Lab共同打造,基于千亿级大规模互联网语料并采用AI Lab自研的DSG算法训练而成,在腾讯内部诸多业务的NLP任务上实测效果显著。 /// /// /// public async Task SentenceEmbedding(SentenceEmbeddingRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "SentenceEmbedding"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 句向量接口能够将输入的句子映射成一个固定维度的向量,用来表示这个句子的语义特征,可用于文本聚类、文本相似度、文本分类等任务,能够显著提高它们的效果。 /// /// 该句向量服务由腾讯知文自然语言处理团队联合腾讯AI Lab共同打造,基于千亿级大规模互联网语料并采用AI Lab自研的DSG算法训练而成,在腾讯内部诸多业务的NLP任务上实测效果显著。 /// /// /// public SentenceEmbeddingResponse SentenceEmbeddingSync(SentenceEmbeddingRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "SentenceEmbedding"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 文本相似度接口能够基于深度学习技术来计算两个输入文本的相似度,相似度数值越大的两个文本在语义上越相似。目前仅支持短文本的相似度计算,长文本的相似度计算也即将推出。 /// /// 鉴于文本相似度是一个应用非常广泛的功能,腾讯知文自然语言处理团队在深度神经网络模型的基础上,专门针对文本相似任务进行了优化,并持续迭代更新。基于文本相似度,可以轻松实现诸如文本去重、相似推荐等功能。 /// /// /// public async Task SentenceSimilarity(SentenceSimilarityRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "SentenceSimilarity"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 文本相似度接口能够基于深度学习技术来计算两个输入文本的相似度,相似度数值越大的两个文本在语义上越相似。目前仅支持短文本的相似度计算,长文本的相似度计算也即将推出。 /// /// 鉴于文本相似度是一个应用非常广泛的功能,腾讯知文自然语言处理团队在深度神经网络模型的基础上,专门针对文本相似任务进行了优化,并持续迭代更新。基于文本相似度,可以轻松实现诸如文本去重、相似推荐等功能。 /// /// /// public SentenceSimilarityResponse SentenceSimilaritySync(SentenceSimilarityRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "SentenceSimilarity"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 情感分析接口能够对带有情感色彩的主观性文本进行分析、处理、归纳和推理,识别出用户的情感倾向,是积极还是消极,并且提供各自概率。 /// /// 该功能基于基于千亿级大规模互联网语料和LSTM、BERT等深度神经网络模型进行训练,并持续迭代更新,以保证效果不断提升。 /// /// /// public async Task SentimentAnalysis(SentimentAnalysisRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "SentimentAnalysis"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 情感分析接口能够对带有情感色彩的主观性文本进行分析、处理、归纳和推理,识别出用户的情感倾向,是积极还是消极,并且提供各自概率。 /// /// 该功能基于基于千亿级大规模互联网语料和LSTM、BERT等深度神经网络模型进行训练,并持续迭代更新,以保证效果不断提升。 /// /// /// public SentimentAnalysisResponse SentimentAnalysisSync(SentimentAnalysisRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "SentimentAnalysis"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 相似词接口能够基于同义词库及词向量技术,检索出与输入词语在语义上最相似的若干个词语,可广泛用于检索系统、问答系统、文档归档等场景。 /// /// /// public async Task SimilarWords(SimilarWordsRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "SimilarWords"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 相似词接口能够基于同义词库及词向量技术,检索出与输入词语在语义上最相似的若干个词语,可广泛用于检索系统、问答系统、文档归档等场景。 /// /// /// public SimilarWordsResponse SimilarWordsSync(SimilarWordsRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "SimilarWords"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 文本分类接口能够对用户输入的文本进行自动分类,将其映射到具体的类目上,用户只需要提供待分类的文本,而无需关注具体实现。 /// /// 该功能基于基于千亿级大规模互联网语料和LSTM、BERT等深度神经网络模型进行训练,并持续迭代更新,以保证效果不断提升。 /// /// 目前已提供: /// /// - 通用领域分类体系,包括15个分类类目,分别是汽车、科技、健康、体育、旅行、教育、职业、文化、军事、房产、娱乐、女性、奥运、财经以及其他,适用于通用的场景。 /// /// - 新闻领域分类体系,包括37个一级分类类目,285个二级分类(详细请见 [类目体系映射表](https://cloud.tencent.com/document/product/271/36459)),已应用于腾讯新闻的文章分类。 /// /// 更多垂直领域的分类体系即将推出,敬请期待。 /// /// /// public async Task TextClassification(TextClassificationRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "TextClassification"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 文本分类接口能够对用户输入的文本进行自动分类,将其映射到具体的类目上,用户只需要提供待分类的文本,而无需关注具体实现。 /// /// 该功能基于基于千亿级大规模互联网语料和LSTM、BERT等深度神经网络模型进行训练,并持续迭代更新,以保证效果不断提升。 /// /// 目前已提供: /// /// - 通用领域分类体系,包括15个分类类目,分别是汽车、科技、健康、体育、旅行、教育、职业、文化、军事、房产、娱乐、女性、奥运、财经以及其他,适用于通用的场景。 /// /// - 新闻领域分类体系,包括37个一级分类类目,285个二级分类(详细请见 [类目体系映射表](https://cloud.tencent.com/document/product/271/36459)),已应用于腾讯新闻的文章分类。 /// /// 更多垂直领域的分类体系即将推出,敬请期待。 /// /// /// public TextClassificationResponse TextClassificationSync(TextClassificationRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "TextClassification"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 提供对中文文本的自动纠错功能,能够识别输入文本中的错误片段,定位错误并给出正确的文本结果;支持长度不超过2000字的长文本纠错。 /// /// 此功能是基于千亿级大规模互联网语料和LSTM、BERT等深度神经网络模型进行训练,并持续迭代更新,以保证效果不断提升,是搜索引擎、语音识别、内容审核等功能更好运行的基础之一。 /// /// /// public async Task TextCorrection(TextCorrectionRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "TextCorrection"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 提供对中文文本的自动纠错功能,能够识别输入文本中的错误片段,定位错误并给出正确的文本结果;支持长度不超过2000字的长文本纠错。 /// /// 此功能是基于千亿级大规模互联网语料和LSTM、BERT等深度神经网络模型进行训练,并持续迭代更新,以保证效果不断提升,是搜索引擎、语音识别、内容审核等功能更好运行的基础之一。 /// /// /// public TextCorrectionResponse TextCorrectionSync(TextCorrectionRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "TextCorrection"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 词向量接口能够将输入的词语映射成一个固定维度的词向量,用来表示这个词语的语义特征。词向量是很多自然语言处理技术的基础,能够显著提高它们的效果。 /// /// 该词向量服务由腾讯知文自然语言处理团队联合腾讯AI Lab共同打造。使用的词向量基于千亿级大规模互联网语料并采用AI Lab自研的DSG算法训练而成,开源的词向量包含800多万中文词汇,在覆盖率、新鲜度及准确性等三方面性能突出。 /// /// 腾讯AI Lab词向量相关资料: /// /// https://ai.tencent.com/ailab/zh/news/detial?id=22 /// /// https://ai.tencent.com/ailab/nlp/embedding.html /// /// /// public async Task WordEmbedding(WordEmbeddingRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "WordEmbedding"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 词向量接口能够将输入的词语映射成一个固定维度的词向量,用来表示这个词语的语义特征。词向量是很多自然语言处理技术的基础,能够显著提高它们的效果。 /// /// 该词向量服务由腾讯知文自然语言处理团队联合腾讯AI Lab共同打造。使用的词向量基于千亿级大规模互联网语料并采用AI Lab自研的DSG算法训练而成,开源的词向量包含800多万中文词汇,在覆盖率、新鲜度及准确性等三方面性能突出。 /// /// 腾讯AI Lab词向量相关资料: /// /// https://ai.tencent.com/ailab/zh/news/detial?id=22 /// /// https://ai.tencent.com/ailab/nlp/embedding.html /// /// /// public WordEmbeddingResponse WordEmbeddingSync(WordEmbeddingRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "WordEmbedding"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 词相似度接口能够基于词向量技术来计算两个输入词语的余弦相似度,相似度数值越大的两个词语在语义上越相似。 /// /// /// public async Task WordSimilarity(WordSimilarityRequest req) { JsonResponseModel rsp = null; try { var strResp = await this.InternalRequest(req, "WordSimilarity"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } /// /// 词相似度接口能够基于词向量技术来计算两个输入词语的余弦相似度,相似度数值越大的两个词语在语义上越相似。 /// /// /// public WordSimilarityResponse WordSimilaritySync(WordSimilarityRequest req) { JsonResponseModel rsp = null; try { var strResp = this.InternalRequestSync(req, "WordSimilarity"); rsp = JsonConvert.DeserializeObject>(strResp); } catch (JsonSerializationException e) { throw new TencentCloudSDKException(e.Message); } return rsp.Response; } } }