如何拿到接口返回的消耗token
SemanticKernel
以下引用自官方案例
- Text模型
- 使用Kernel
FunctionResult functionResult = await kernel.InvokePromptAsync(promptTestDataGeneration);
CompletionsUsage? usage = FunctionResult.Metadata?["Usage"] as CompletionsUsage;
//回答消耗的Token
Console.WriteLine(usage.CompletionTokens);
//提示词消耗的Token
Console.WriteLine(usage.PromptTokens);
//一共消耗的Token
Console.WriteLine(usage.TotalTokens);
```
- 直接使用AzureOpenAIChatCompletionService
var service = new AzureOpenAIChatCompletionService("deployment", "https://endpoint", "api-key", "model-id", this._httpClient);
var result = await service.GetChatMessageContentsAsync([], settings, kernel);
var usage = result[0].Metadata?["Usage"] as CompletionsUsage;
//回答消耗的Token
Console.WriteLine(usage.CompletionTokens);
//提示词消耗的Token
Console.WriteLine(usage.PromptTokens);
//一共消耗的Token
Console.WriteLine(usage.TotalTokens);
```
- 使用Kernel
- 暂不支持Embedding模型
客制方法
- 当前SK仅支持OpenAI和AzureOpenAI的模型调用,如何需要其他模型供应商目前有两种办法解决
- 使用OneAPI做一个中转成AzureOpenAI然后使用上述SK的方法使用。
- 自定义方法发送请求,使用AddKeyedSingleton注入。
定义IAzureTextEmbeddingCompletionService接口,引用ITextEmbeddingGenerationService
public interface IAzureTextEmbeddingCompletionService : ITextEmbeddingGenerationService
{
Task<(List<float>, TextEmbeddingUsage)> GenerateEmbeddingsByUsageAsync(IList<string> data, Kernel kernel = null, CancellationToken cancellationToken = default);
}
定义AzureTextEmbeddingCompletionService实现IAzureTextEmbeddingCompletionService接口
public class AzureTextEmbeddingCompletionService : IAzureTextEmbeddingCompletionService
{
private readonly SemanticAzureOpenAIConfig config;
private readonly Dictionary<string, object?> _attributes = new();
private readonly ModelClient client;
public IReadOnlyDictionary<string, object> Attributes => _attributes; public AzureTextEmbeddingCompletionService(ModelOptions options)
{
config = new SemanticAzureOpenAIConfig()
{
ApiKey = options.ApiKey,
Endpoint = options.Endpoint,
DeploymentName = "text-embedding-ada-002",
ApiVersion = options.ModelVersion
};
client = new(config.ApiKey, ModelType.AzureOpenAI, config.Endpoint);
} public async Task<IList<ReadOnlyMemory<float>>> GenerateEmbeddingsAsync(IList<string> data, Kernel kernel = null, CancellationToken cancellationToken = default)
{
var result = await client.AzureOpenAI.GenerateEmbeddingsAsync(config.DeploymentName, data.First());
var list = result.Data[0].Embedding.ToList();
IList<ReadOnlyMemory<float>> readOnlyMemoryList = list.Select(f => new ReadOnlyMemory<float>(new[] { f })).ToList();
return readOnlyMemoryList;
} public async Task<(List<float>, TextEmbeddingUsage)> GenerateEmbeddingsByUsageAsync(IList<string> data, Kernel kernel = null, CancellationToken cancellationToken = default)
{
var result = await client.AzureOpenAI.GenerateEmbeddingsAsync(config.DeploymentName, data.First());
var list = result.Data[0].Embedding.ToList();
IList<ReadOnlyMemory<float>> readOnlyMemoryList = list.Select(f => new ReadOnlyMemory<float>(new[] { f })).ToList();
return (list, result.Usage);
}
}
//定义入参类
public class ModelOptions
{
public string AppId { get; set; } public string ApiKey { get; set; } public string ApiSecret { get; set; }
public string Endpoint { get; set; }
public string DeploymentName { get; set; }
public ChatHistory ChatHistory { get; set; } = new ChatHistory(); public string ModelVersion { get; set; }
}
ModelClient的实现参考对话模型的对接方式实现,原理是一致的这里不详述。(.Net接入AzureOpenAI、OpenAI、通义千问、智谱AI、讯飞星火、文心一言大语言模型。 | FaceMan)
创建Kernel实例,注入IAzureTextEmbeddingCompletionService服务
var builder = Kernel.CreateBuilder();
var options = new ModelOptions()
{
Endpoint = "YourEndpoint",
ApiKey = "YourApiKey",
DeploymentName = "YourDeploymentName",,
ChatHistory = "YourChatHistory",//Embedding可不填
};
builder.Services.AddKeyedSingleton<IAzureTextEmbeddingCompletionService>("AzureOpenAIEmbedding", new AzureTextEmbeddingCompletionService(options));
获取Embedding服务,获取Token
var service = _kernel.GetRequiredService<IAzureTextEmbeddingCompletionService>();
var res = await service.GenerateEmbeddingsByUsageAsync
(new List<string> { partitionContent }, cancellationToken: cancellationToken)
.ConfigureAwait(false);
// item1 向量,item2消耗的token
float[] result = res.Item1.ToArray<float>();
totalToken += res.Item2.TotalTokens;
Embedding embedding = new Embedding(result);
如何拿到接口返回的消耗token的更多相关文章
- httprunner学习3-extract提取token值参数关联(上个接口返回的token,传给下个接口请求参数)
前言 如何将上个接口的返回token,传给下个接口当做请求参数?这是最常见的一个问题了. 解决这个问题其实很简单,我们只需取出token值,设置为一个中间变量a,下个接口传这个变量a就可以了.那么接下 ...
- Postman----登录接口返回的reponse中token值传递给其他接口的一个简单接口测试示例
注: 在进行接口测试时,我们都需要使用登录,并且其他的接口都要在登录后进行,那么必不可少的会使用到将登录接口的reponse返回结果中的某些参数值需要进行返回,并传递给其他接口,这样才可以进行登录后的 ...
- C#进阶系列——WebApi 接口返回值不困惑:返回值类型详解
前言:已经有一个月没写点什么了,感觉心里空落落的.今天再来篇干货,想要学习Webapi的园友们速速动起来,跟着博主一起来学习吧.之前分享过一篇 C#进阶系列——WebApi接口传参不再困惑:传参详解 ...
- WebApi 接口返回值类型详解 ( 转 )
使用过Webapi的园友应该都知道,Webapi的接口返回值主要有四种类型 void无返回值 IHttpActionResult HttpResponseMessage 自定义类型 此篇就围绕这四块分 ...
- WebApi接口返回值不困惑:返回值类型详解
前言:已经有一个月没写点什么了,感觉心里空落落的.今天再来篇干货,想要学习Webapi的园友们速速动起来,跟着博主一起来学习吧.作为程序猿,我们都知道参数和返回值是编程领域不可分割的两大块,此前分享了 ...
- WebApi 接口返回值不困惑:返回值类型详解。IHttpActionResult、void、HttpResponseMessage、自定义类型
首先声明,我还没有这么强大的功底,只是感觉博主写的很好,就做了一个复制,请别因为这个鄙视我,博主网址:http://www.cnblogs.com/landeanfen/p/5501487.html ...
- (转)C# WebApi 接口返回值不困惑:返回值类型详解
原文地址:http://www.cnblogs.com/landeanfen/p/5501487.html 正文 前言:已经有一个月没写点什么了,感觉心里空落落的.今天再来篇干货,想要学习Webapi ...
- [转]C#进阶系列——WebApi 接口返回值不困惑:返回值类型详解
本文转自:http://www.cnblogs.com/landeanfen/p/5501487.html 阅读目录 一.void无返回值 二.IHttpActionResult 1.Json(T c ...
- C#进阶系列——WebApi接口返回值类型详解
阅读目录 一.void无返回值 二.IHttpActionResult 1.Json(T content) 2.Ok(). Ok(T content) 3.NotFound() 4.其他 5.自定义I ...
- WebService如何封装XML请求 以及解析接口返回的XML
原 WebService如何封装XML请求 以及解析接口返回的XML 置顶 2019年08月16日 15:00:47 童子泛舟 阅读数 28 标签: XML解析WebService第三方API 更多 ...
随机推荐
- 【.Net Core】.Net Core 源码分析与深入理解 - 入口 Program.cs (一)
研究原因:学习 .Net Core 两年有余,实际项目也使用了一年半,自己的技术已经到了瓶颈,需要有一个突破,我觉得首先研究架构师的设计思想,其次分析一下.Net Core的源码,这将会是一个很好的学 ...
- error LNK2019: unresolved external symbol _CrtDbgReport referenced in function xxxx
现象 在用C++调试dll动态库的时候汇报上述错误,我用VS2015编译的DEBUG版本动态库,实际在VS2019中调试 解决方法 在工程属性中做出如下选择,代码生成->多线程调试DLL ,出现 ...
- 【Azure 应用服务】更新镜像后并重启应用服务,部署日志始终没有出现加载新镜像成功的日志
问题描述 在App Service中部署镜像文件,发现镜像一直没有部署,重启App Service服务也无效果. DockerFile如下: FROM crunchgeek/php-fpm:7.0 # ...
- MAUI调用.so库
必要条件: (一)安装JDK (二)安装NDK (三)安装Android Studio(其实可以不用装也行) 使用Android Studio构件.so包 构件.so包 1. 使用Android st ...
- [笔记]git pull vs git pull --rebase
git pull vs git pull -rebase 背景 最近在实际开发过程,之前一直使用git pull 去更新该分支的代码,之前认为一旦pull 操作产生新的节点是对合并操作的一个记录,但是 ...
- 3DES算法的起源与演进:保障信息安全的重要里程碑
一.3DES算法的起源与演进 3DES算法是DES算法的增强版,由IBM公司在上世纪90年代初提出.DES算法的密钥长度只有56位,随着计算机计算能力的提升,其安全性逐渐受到威胁.为了增强数据的安全性 ...
- linux脚本免密的方法/不用输入密码
第一种方法:使用管道(上一个命令的 stdout 接到下一个命令的 stdin):在脚本首行添加 #!/bin/bashecho password | sudo -S apt-get update 第 ...
- Linux 服务器Python后台运行服务(ssh断开不退出)
壹: 最近用python搭建一个物联网数据存储的微服务,部署到ubuntu上去,所以,python后台运行是一个必不可少的环节. 贰: 这个只需要是一个命令即可: 命令1(记录所有日志): nohup ...
- C语言中的强制转换
许久没有遇到的问题 C语言真是博大精深,越使用它,就越发感觉到它的威力和恐怖,最近在做算法的时候,遇到了一个强转的错误,把人折腾的够受,这次要好好梳理一下了,希望下次不能再犯此类的问题. 强制转换 ...
- display标签简介
下面是网友总结的display标签的优缺点: 1. 分页 如果想对代码分页,只需在display:table标签中添加一项pagesize="每页显示行数" 2. 对列排序 dis ...