大模型学习笔记六:Semantic Kernel

news2024/11/22 9:31:49

文章目录

    • 一、Semantic Kernel介绍和发展
      • 1)SK 的语言开发进展
      • 2)SK的生态位
      • 3)SK基础架构
    • 二、环境搭建
      • 1)初始化
      • 2)Semantic Functions(不用编写代码,用配置实现回调函数)
      • 3)Native Functions(传统编程的回调函数)
      • 4)用 SKContext 实现多参数 Functions
      • 5)Plugins/Skills(plugin/skill 就是一组函数的集合。它可以包含两种函数:)
    • 三、函数的嵌套调用
      • 1)Semantic Function 嵌套调用(不用代码的函数)
      • 2)Native Function 嵌套调用(纯代码调用)
    • 四、Memory
      • 1)初始化 Embedding
      • 2)文本向量化
      • 3)向量搜索
      • 4)现在用函数嵌套做一个简单的 RAG
      • 5)连接其它 VectorDB
    • 五、Planner开发Agent
      • 1)什么是智能体(Agent)
      • 2)SK Python 提供了四种 Planner:
      • 3)用 Planner 实现一个能使用搜索和日历工具的 Agent
    • 六、VS Code 插件创建和调试Semantic Function
    • 七、Semantic Kernel 对新版 Assistants API 的支持计划

一、Semantic Kernel介绍和发展

  • 定义介绍
    1、Semantic Kernel 是微软研发的一个开源的,面向大模型的开发框架(SDK);
    2、它支持你用不同开发语言(C#/Python/Java)基于 OpenAI API/Azure OpenAI API/Huggingface 开发大模型应用;
    3、它封装了一系列开箱即用的工具,包括:提示词模板、链式调用、规划能力等。
  • SDK(补充说明)
    SDK:Software Development Kit,它是一组软件工具和资源的集合,旨在帮助开发者创建、测试、部署和维护应用程序或软件。

1)SK 的语言开发进展

1、C# 版最成熟,已开始 1.0.1:https://github.com/microsoft/semantic-kernel
2、Python 是 beta 版:https://github.com/microsoft/semantic-kernel
3、Java 版 alpha 阶段:https://github.com/microsoft/semantic-kernel/tree/experimental-java
4、TypeScript 版……,已经放弃了:https://github.com/microsoft/semantic-kernel/tree/experimental-typescript
文档写得特别好,但追不上代码更新速度:
5、更多讲解:https://learn.microsoft.com/en-us/semantic-kernel/overview/
6、更偏实操:https://github.com/microsoft/semantic-kernel/blob/main/python/notebooks/00-getting-started.ipynb
7、API Reference (目前只有C#): https://learn.microsoft.com/en-us/dotnet/api/microsoft.semantickernel?view=semantic-kernel-dotnet
8、更多生态:https://github.com/geffzhang/awesome-semantickernel
这里可以了解最新进展:https://learn.microsoft.com/en-us/semantic-kernel/get-started/supported-languages

2)SK的生态位

  • 补充
    微软将此技术栈命名为 Copilot Stack。
    在这里插入图片描述
  • 解释:
    1、Plugin extensibility: 插件扩展
    2、Copilots: AI 助手(副驾驶),例如 GitHub Copilot、Office 365 Copilot、Windows Copilot
    3、AI orchestration: AI 编排,SK 就在这里
    4、Foundation models: 基础大模型,例如 GPT-4
    5、AI infrastructure: AI 基础设施,例如 PyTorch、GPU

3)SK基础架构

在这里插入图片描述

  • 解释
    1、Models and Memory: 类比为大脑
    2、Connectors: 用来连接各种外部服务,类似驱动程序
    3、Plugins: 用来连接内部技能
    4、Triggers and actions: 外部系统的触发器和动作,类比为四肢
  • 说明
    1、Semantic Functions:通过 Prompt 实现的 LLM 能力
    2、Native Functions: 编程语言原生的函数功能
    3、在 SK 中,一组 Function 组成一个技能(Skill/Plugin)。要运行 Skill/Plugin,需要有一个配置和管理的单元,这个组织管理单元就是 Kernel。
    4、Kernel 负责管理底层接口与调用顺序,例如:OpenAI/Azure OpenAI 的授权信息、默认的 LLM 模型选择、对话上下文、技能参数的传递等等

二、环境搭建

  • 准备
    1、安装 Python 3.x:https://www.python.org/downloads/
    2、安装 SK 包:pip install semantic-kernel
    3、在项目目录创建 .env 文件,添加以下内容:
# .env
OPENAI_API_KEY=""
OPENAI_BASE_URL=""
AZURE_OPENAI_DEPLOYMENT_NAME=""
AZURE_OPENAI_ENDPOINT=""
AZURE_OPENAI_API_KEY=""
--OpenAI 和 Azure,配置好一个就行。

!pip install semantic-kernel==0.4.0.dev

1)初始化

  • 环境初始化
import semantic_kernel as sk
from semantic_kernel.connectors.ai.open_ai import OpenAIChatCompletion
import os

# 加载 .env 到环境变量
from dotenv import load_dotenv, find_dotenv
_ = load_dotenv(find_dotenv())

# 创建 semantic kernel
kernel = sk.Kernel()

# 配置 OpenAI 服务。OPENAI_BASE_URL 会被自动加载生效
api_key = os.getenv('OPENAI_API_KEY')
model = OpenAIChatCompletion(
    "gpt-3.5-turbo",
    api_key
)

# 把 LLM 服务加入 kernel
# 可以加多个。第一个加入的会被默认使用,非默认的要被指定使用
kernel.add_text_completion_service("my-demo", model)
  • 接口解释
划重点: 用我们熟悉的操作系统来类比,可以更好地理解 SK。
1、启动操作系统:kernel = sk.Kernel()
2、安装驱动程序:kernel.add_xxx_service()
3、安装应用程序:func = kernel.create_semantic_function()
4、运行应用程序:func()
  • 举例使用prompt说笑话(实验室版本)
# 定义 semantic function (实验室版本)
# 参数由{{ }}标识

tell_joke_about = kernel.create_semantic_function("给我讲个关于{{$input}}的笑话吧")

# 运行 function 看结果
result = await kernel.run_async(
        tell_joke_about,
        input_str="Hello world"
    )
print(result)
  • 举例使用prompt说笑话
import asyncio

async def run_function(*args):
    return await kernel.invoke(*args)

result = asyncio.run(
    run_function(tell_joke_about, input_str="Hello world")
)
  • 新版加载方式
    注意:新版的加载方式将发生变化,详见:https://github.com/microsoft/semantic-kernel/blob/main/python/notebooks/03-prompt-function-inline.ipynb

2)Semantic Functions(不用编写代码,用配置实现回调函数)

  • 介绍
    Semantic Functions 是纯用数据(Prompt + 配置文件)定义的,不需要编写任何代码。所以它与编程语言无关,可以被任何编程语言调用
  • 组成
1、skprompt.txt: 存放 prompt,可以包含参数,还可以调用其它函数
2、config.json: 存放配置,包括函数功能,参数的数据类型,以及调用大模型时的参数
  • 举例:
    根据用户的自然语言指示,生成 Linux 命令
  • skprompt.txt
已知数据库结构为:

CREATE TABLE Courses (
    id INT AUTO_INCREMENT PRIMARY KEY,
    course_date DATE NOT NULL,
    start_time TIME NOT NULL,
    end_time TIME NOT NULL,
    course_name VARCHAR(255) NOT NULL,
    instructor VARCHAR(255) NOT NULL
);
请将下述用户输入转为SQL表达式
用户输入:{{$input}}

直接输出SQL语句,不要评论,不要分析,不要Markdown标识!
  • config.json
{
    "schema": 1,
    "type": "completion",
    "description": "将用户的输入转换成 SQL 语句",   #功能描述
    "completion": { 
        "max_tokens": 256,
        "temperature": 0,
        "top_p": 0,
        "presence_penalty": 0,
        "frequency_penalty": 0
    },
    "input": {
        "parameters": [
            {
                "name": "input",
                "description": "用户的输入",
                "defaultValue": ""
            }
        ]
    }
}
  • 说明
    type 只有 “completion” 和 “embedding” 两种
  • 注意
    新版格式将发生变化,详见:https://github.com/microsoft/semantic-kernel/blob/main/python/notebooks/02-running-prompts-from-file.ipynb
  • 备注
    上面两个文件都在 demo/MyPlugins/Text2SQL/ 目录下。
    在这里插入图片描述
  • 附加(查询数据库)
from semantic_kernel.skill_definition import sk_function

class DBConnector:
    def __init__(self, db_cursor):
        self.db_cursor = db_cursor
        
    @sk_function(
        description="查询数据库", # function 描述
        name="query_database", # function 名字
    )
    def exec(self, sql_exp: str) -> str:
        self.db_cursor.execute(sql_exp)
        records = cursor.fetchall()
        return str(records)
  • 正式开始调用
# 加载 semantic function。注意目录结构
my_plugins = kernel.import_semantic_skill_from_directory(
    "./demo", "MyPlugins")

# 运行
result = await kernel.run_async(
    my_plugins["Text2SQL"],
    input_str="2024年4月有哪些课",
)
print(result)
  • 回复
SELECT * FROM Courses WHERE course_date BETWEEN '2024-04-01' AND '2024-04-30';
  • 若要维护多轮对话(加入历史)
    需求:例如我们要维护一个多轮对话,通过 request 和 history 两个变量分别存储 当前输入 和 对话历史
prompt = """对话历史如下:
{{$history}}
---
User: {{$request}}
Assistant:  """
  • 实际代码展示
history = []

while True:
    request = input("User > ").strip()
    if not request:
        break

    # 通过 ContextVariables 维护多个输入变量
    variables = sk.ContextVariables()
    variables["request"] = request
    variables["history"] = "\n".join(history)

    # 运行 prompt
    semantic_function = kernel.create_semantic_function(prompt)
    result = await kernel.run_async(
        semantic_function,
        input_vars=variables, # 注意这里从 input_str 改为 input_vars
    )

    # 将新的一轮添加到 history 中
    history.append("User: " + request)
    history.append("Assistant: " + result.result)

    print("Assistant > " + result.result)
  • 回复
User >  你好
Assistant > 你好,请问有什么可以帮助您的吗?
User >  我刚才问你什么
Assistant > 您刚才问我有什么可以帮助您的。您还有其他问题需要我回答吗?
User >  
  • 注意
    1、官方提供了一些 Semantic Functions 例子参考:https://github.com/microsoft/semantic-kernel/tree/main/samples/plugins
    2、注意:新版将引入一个 ChatHistory 类来管理对话上下文,详见:https://github.com/microsoft/semantic-kernel/blob/main/python/notebooks/04-kernel-arguments-chat.ipynb

3)Native Functions(传统编程的回调函数)

  • 需求
    用编程语言写的函数,如果用 SK 的 Native Function 方式定义,就能纳入到 SK 的编排体系,可以被 Planner、其它 plugin 调用。
  • 举例
    写一个查询数据库的函数。这个函数名是 query_database。输入为一个 SQL 表达式。它可以放到目录结构中,在 demo/MyPlugins/DBPlugin.py 里加入。
from semantic_kernel.skill_definition import sk_function

class DBConnector:
    def __init__(self, db_cursor):
        self.db_cursor = db_cursor
        
    @sk_function(
        description="查询数据库", # function 描述
        name="query_database", # function 名字
    )
    def exec(self, sql_exp: str) -> str:
        self.db_cursor.execute(sql_exp)
        records = cursor.fetchall()
        return str(records)


-------------------------------------
# 定义本地函数和数据库

import sqlite3

# 创建数据库连接
conn = sqlite3.connect(':memory:')
cursor = conn.cursor()

# 创建orders表
cursor.execute("""
CREATE TABLE Courses (
    id INT AUTO_INCREMENT PRIMARY KEY,
    course_date DATE NOT NULL,
    start_time TIME NOT NULL,
    end_time TIME NOT NULL,
    course_name VARCHAR(255) NOT NULL,
    instructor VARCHAR(255) NOT NULL
);
""")

# 插入5条明确的模拟记录
timetable = [
    ('2024-01-23', '20:00', '22:00', '大模型应用开发基础', '孙志岗'),
    ('2024-01-25', '20:00', '22:00', 'Prompt Engineering', '孙志岗'),
    ('2024-01-29', '20:00', '22:00', '赠课:软件开发基础概念与环境搭建', '西树'),
    ('2024-02-20', '20:00', '22:00', '从AI编程认知AI', '林晓鑫'),
    ('2024-02-22', '20:00', '22:00', 'Function Calling', '孙志岗'),
    ('2024-02-29', '20:00', '22:00', 'RAG和Embeddings', '王卓然'),
    ('2024-03-05', '20:00', '22:00', 'Assistants API', '王卓然'),
    ('2024-03-07', '20:00', '22:00', 'Semantic Kernel', '王卓然'),
    ('2024-03-14', '20:00', '22:00', 'LangChain', '王卓然'),
    ('2024-03-19', '20:00', '22:00', 'LLM应用开发工具链', '王卓然'),
    ('2024-03-21', '20:00', '22:00', '手撕 AutoGPT', '王卓然'),
    ('2024-03-26', '20:00', '22:00', '模型微调(上)', '王卓然'),
    ('2024-03-28', '20:00', '22:00', '模型微调(下)', '王卓然'),
    ('2024-04-09', '20:00', '22:00', '多模态大模型(上)', '多老师'),
    ('2024-04-11', '20:00', '22:00', '多模态大模型(中)', '多老师'),
    ('2024-04-16', '20:00', '22:00', '多模态大模型(下)', '多老师'),
    ('2024-04-18', '20:00', '22:00', 'AI产品部署和交付(上)', '王树冬'),
    ('2024-04-23', '20:00', '22:00', 'AI产品部署和交付(下)', '王树冬'),
    ('2024-04-25', '20:00', '22:00', '抓住大模型时代的创业机遇', '孙志岗'),
    ('2024-05-07', '20:00', '22:00', '产品运营和业务沟通', '孙志岗'),
    ('2024-05-09', '20:00', '22:00', '产品设计', '孙志岗'),
    ('2024-05-14', '20:00', '22:00', '项目方案分析与设计', '王卓然'),
]

for record in timetable:
    cursor.execute('''
    INSERT INTO Courses (course_date, start_time, end_time, course_name, instructor)
    VALUES (?, ?, ?, ?, ?)
    ''', record)

# 提交事务
conn.commit()
----------------------
#加载function
# 加载 native function
db_connector = kernel.import_skill(DBConnector(cursor), "DBConnector")

# 看结果
result = await kernel.run_async(
    db_connector["query_database"],
    input_str="SELECT COUNT(*) as count FROM Courses WHERE instructor = '王卓然'",
)

print(result)
  • 回复
[(9,)]

4)用 SKContext 实现多参数 Functions

  • 需求
    需要实现多参数(如果 Function 都只有一个参数,那么只要把参数定义为 {{KaTeX parse error: Expected 'EOF', got '}' at position 6: input}̲},就可以按前面的例子来使用,…input}}会默认被赋值。多参数时,就不能用默认机制了,需要定义 SKContext 类型的变量。)
  • 多参数的用法
from semantic_kernel.skill_definition import sk_function, sk_function_context_parameter
from semantic_kernel.orchestration.sk_context import SKContext

class NewDBConnector:
    def __init__(self, db_cursor):
        self.db_cursor = db_cursor
        
    @sk_function(
        description="查询数据库", # function 描述
        name="query_database", # function 名字
    )
    @sk_function_context_parameter(
        name="sql_exp",
        description="SQL表达式",
    )
    @sk_function_context_parameter(
        name="output_prefix",
        description="输出的文本前缀",
    )
    def exec(self, context: SKContext) -> str:
        self.db_cursor.execute(context['sql_exp'])
        records = cursor.fetchall()
        return f"{context['output_prefix']}: {str(records)}"
----------------
# 加载 native function
new_db_connector = kernel.import_skill(NewDBConnector(cursor), "NewDBConnector")


# 创建 SKContext
context = sk.ContextVariables()

# 变量赋值
context["sql_exp"] = "SELECT COUNT(*) as count FROM Courses WHERE instructor = '王卓然'"
context["output_prefix"] = "课节数"

# 看结果
result = await kernel.run_async(
    new_db_connector["query_database"],
    input_vars=context
)
print(result)
  • 回复
课节数: [(9,)]
  • 注意
    注意:多参数的 Native Function 的写法,在新版中会简化,详见:https://github.com/microsoft/semantic-kernel/blob/main/python/notebooks/08-native-function-inline.ipynb

5)Plugins/Skills(plugin/skill 就是一组函数的集合。它可以包含两种函数:)

  • 介绍
简单说,plugin/skill 就是一组函数的集合。它可以包含两种函数:
1、Semantic Functions - 语义函数,本质是 Prompt Engineering
2、Native Functions - 原生函数,类似 OpenAI 的 Function Calling

值得一提的是,SK 的 plugin 会和 ChatGPT、Bing、Microsoft 365 通用。「很快」你用 SK 写的 plugin 就可以在这些平台上无缝使用了。这些平台上的 plugin 也可以通过 SK 被你调用。
  • 补充
    Plugins 最初命名为 Skills,后来改为 Plugins。但是文档中还可能有「Skill」遗留。见到后,就知道两者是一回事就好
  • 配套内置的plugin
from semantic_kernel.core_plugins import <PluginName>
  • ConversationSummaryPlugin - 生成对话的摘要
  • HttpPlugin - 发出 HTTP 请求,支持 GET、POST、PUT 和 DELETE
  • MathPlugin - 加法和减法计算
  • TextMemoryPlugin - 保存文本到 memory 中,可以对其做向量检索
  • TextPlugin - 把文本全部转为大写或小写,去掉头尾的空格(trim)
  • TimePlugin - 获取当前时间及用多种格式获取时间参数
  • WaitPlugin - 等待指定的时间
  • WebSearchEnginePlugin - 在互联网上搜索给定的文本

三、函数的嵌套调用

1)Semantic Function 嵌套调用(不用代码的函数)

2)Native Function 嵌套调用(纯代码调用)

四、Memory

1)初始化 Embedding

2)文本向量化

3)向量搜索

4)现在用函数嵌套做一个简单的 RAG

5)连接其它 VectorDB

五、Planner开发Agent

1)什么是智能体(Agent)

2)SK Python 提供了四种 Planner:

3)用 Planner 实现一个能使用搜索和日历工具的 Agent

六、VS Code 插件创建和调试Semantic Function

七、Semantic Kernel 对新版 Assistants API 的支持计划

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1512912.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vb oe20.03 ssh nat

环境 virtual boxopeneuler 20.03 LTS网络设置 nat 主机端口可以自行设置&#xff0c;其余三项固定不变。然后即可通过ssh进行连接。

Dynamic Wallpaper v17.4 mac版 动态视频壁纸 兼容 M1/M2

Dynamic Wallpaper Engine 是一款适用于 Mac 电脑的视频动态壁纸&#xff0c; 告别单调的静态壁纸&#xff0c;拥抱活泼的动态壁纸。内置在线视频素材库&#xff0c;一键下载应用&#xff0c;也可导入本地视频&#xff0c;同时可以将视频设置为您的电脑屏保。 应用介绍 Dynam…

pycharm @NotNull parameter ‘module‘ of ...

下载了最新pycharm &#xff0c;无法启动运行 pycharm或者idea中Run/Debug Python项目报错 Argument for NotNull parameter ‘module‘ of … 解决方案 删除项目根目录的 idea 文件夹 随后重启&#xff0c;重新配置即可

探索Linux世界:基本指令(文件查看、时间相关、grep、打包压缩及相关知识)

今天继续介绍一些指令 文章目录 1.cat - 查看文件1.1输出重定向和追加重定向1.2指令echo 2.more 指令3.less - 逐页查看文本文件内容4.head- 显示文件开头部分内容5.tail - 显示文件末尾部分内容5.1输入重定向&#xff08;<&#xff09;5.2管道&#xff08;|&#xff09; 6.…

第2篇【Docker项目实战】使用Docker部署Raneto知识库平台(转载)

【Docker项目实战】使用Docker部署Raneto知识库平台 一、Raneto介绍 1.1 Raneto简介 Raneto是一个免费、开放、简单的 Markdown 支持的 Node.js 知识库。 1.2 知识库介绍 知识库 知识库是指存储和组织知识的系统或库&#xff0c;它包括了各种类型的信息和知识&#xff0c;如…

Nodejs 第五十一章(限流阀)

限流功能 目前我们学习了redis,lua,nodejs&#xff0c;于是可以结合起来做一个限流功能&#xff0c;好比一个抽奖功能&#xff0c;你点击次数过多&#xff0c;就会提示请稍后重试&#xff0c;进行限制&#xff0c;我们来实现一下该功能。 安装依赖 npm i ioredis express代码…

git提交代码描述时如何换行(更新时间24/3/12)

问题复现&#xff08;信心满满使用转义字符换行&#xff09; 解决方法&#xff1a; 写多个-m字符串的结构可以实现自动换行 注意空格 git commit -m"第一行描述" -m"第二行描述" 效果演示&#xff1a;&#xff08;强迫症福利&#xff09;

【20240309】WORD宏设置批量修改全部表格格式

WORD宏设置批量修改全部表格格式 引言1. 设置表格文字样式2. 设置表格边框样式3. 设置所有表格边框样式为075pt4. 删除行参考 引言 这两周已经彻底变为office工程师了&#xff0c;更准确一点应该是Word工程师&#xff0c;一篇文档动不动就成百上千页&#xff0c;表格图片也是上…

导入空管基础数据

1、首先将data.tar.gz解压到自定义目录中 注意&#xff1a;由于数据文件的压缩包比较大&#xff0c;解压过程可能会持续3~5分钟&#xff0c;请耐心等待。 [rootnode3 ~]# cd /opt/software/ [rootnode3 software]# tar -xzf data.tar.gz -C /opt/ 2、利用SQLyog或者其他数据库…

鸿蒙不再适合JS语言开发

ArkTS是鸿蒙生态的应用开发语言。它在保持TypeScript&#xff08;简称TS&#xff09;基本语法风格的基础上&#xff0c;对TS的动态类型特性施加更严格的约束&#xff0c;引入静态类型。同时&#xff0c;提供了声明式UI、状态管理等相应的能力&#xff0c;让开发者可以以更简洁、…

力扣爆刷第93天之hot100五连刷51-55

力扣爆刷第93天之hot100五连刷51-55 文章目录 力扣爆刷第93天之hot100五连刷51-55一、200. 岛屿数量二、994. 腐烂的橘子三、207. 课程表四、208. 实现 Trie (前缀树)五、46. 全排列 一、200. 岛屿数量 题目链接&#xff1a;https://leetcode.cn/problems/number-of-islands/d…

基于YOLOv5的手机顶盖焊缺陷检测系统

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文主要内容:详细介绍了工业手机顶盖焊缺陷测整个过程&#xff0c;从数据集到训练模型到结果可视化分析。 博主简介 AI小怪兽&#xff0c;YOLO骨灰级玩家&#xff0c;1&#xff09;YOLOv5、v7、v8优化创新&#xff0c;轻松涨点和模型…

Android 生成SO - 基础工程创建

最近需要给小伙伴扫盲一下如何使用Android Studio 生成一个SO文件&#xff0c;网上找了很多都没有合适的样例&#xff0c;那只能自己来写一个了。 原先生成SO是一个很麻烦的事情&#xff0c;现在Android Studio帮忙做了很多的事情&#xff0c;基本只要管好自己的C代码即可。 …

coreldraw是什么软件 矢量图设计软件推荐 CDR学习入门 CDR2024发布 cdr2024免费激活下载

CDR是一款平面设计软件&#xff0c;全称为CorelDRAW&#xff0c;是由Corel公司开发的矢量图形编辑工具套件。这款软件结合了矢量图形设计和页面布局的全功能&#xff0c;被广泛应用于商标设计、标志制作、模型绘制、插图描画、排版及分色输出等诸多领域。 2024年3月&#xff0…

STM32进阶笔记——FATFS文件系统(下)

本专栏争取每周三更新直到更新完成&#xff0c;期待大家的订阅关注&#xff0c;欢迎互相学习交流。 本文需要一些SD卡和内存管理等前置知识&#xff0c;后续文章会介绍&#xff0c;这里先介绍一下FATFS文件系统。关于FATFS的文章分为上下两篇&#xff0c;上篇主要介绍什么是FAT…

【C语言】tcp_transmit_skb

一、__tcp_transmit_skb讲解 这个函数 __tcp_transmit_skb() 是 Linux 内核中 TCP/IP 协议栈的一部分&#xff0c;负责处理传输控制协议&#xff08;TCP&#xff09;数据包的发送。具体来说&#xff0c;这个函数将 TCP 头部添加到一个没有任何头部信息的 socket buffer (sk_bu…

【大模型API调用初尝试二】星火认知大模型 百度千帆大模型

大模型API调用初尝试二 科大讯飞—星火认知大模型单论会话调用多轮会话调用 百度—千帆大模型获取access_token单轮会话多轮会话 科大讯飞—星火认知大模型 星火认知大模型是科大讯飞开发的&#xff0c;直接使用可以点击星火认知大模型&#xff0c;要调用API的话在讯飞开发平台…

python文本转语音的开源库介绍

本文介绍Python中用于文本转语音&#xff08;Text-to-Speech, TTS&#xff09;的三个开源库&#xff1a;pyttsx3、gtts和espeak。这些库可以在Windows平台上运行&#xff0c;并允许用户将文本转换为语音输出。 pyttsx3 pyttsx3是一个Python库&#xff0c;用于跨平台的文本到语音…

PLC远程故障诊断

随着工业自动化水平的不断提升&#xff0c;可编程逻辑控制器&#xff08;PLC&#xff09;在生产线控制、设备自动化等领域发挥着越来越重要的作用。然而&#xff0c;PLC在运行过程中难免会出现故障&#xff0c;影响生产线的稳定运行。因此&#xff0c;如何迅速、准确地诊断并解…

jenkins部署go应用 基于docker

丢弃旧的的构建 github 拉取代码 拉取代码排除指定配置文件 报错 环境变量失效 服务器版本为1.21.6 但是一直没有生效