深入解析Semantic Kernel:构建智能应用的核心框架
2025-06-19 18:50:55作者:翟江哲Frasier
什么是Semantic Kernel?
Semantic Kernel(SK)是微软推出的一个开源SDK,它作为应用程序代码与大型语言模型(LLM)之间的中间件,帮助开发者轻松地将AI能力集成到应用中。SK的核心价值在于它能够:
- 桥接AI与代码:让AI能够理解和调用现有的代码功能
- 模块化设计:通过插件(Skills)系统实现功能的灵活扩展
- 企业级支持:内置安全、可观测性和合规性功能
- 多模态支持:兼容多种AI服务和模式
- 快速开发:简化提示编排、函数调用和内存管理等复杂任务
Semantic Kernel的核心组件
1. Kernel(内核)
Kernel是SK架构的核心,负责协调所有操作。它主要功能包括:
- 管理AI服务配置
- 维护插件(技能)系统
- 协调函数调用
- 维护上下文状态(内存)
from semantic_kernel.kernel import Kernel
kernel = Kernel()
2. AI服务连接
SK支持连接多种AI模型服务:
- 聊天模型(如Azure OpenAI GPT-4)
- 嵌入模型(用于文本向量化)
- 其他模态(如图像、语音等)
配置示例:
from semantic_kernel.connectors.ai.open_ai import AzureChatCompletion
# 从.env文件自动加载配置
chat_completion = AzureChatCompletion()
kernel.add_service(chat_completion)
函数与插件系统
1. 函数类型
SK支持两种函数类型:
-
语义函数:基于提示词和LLM
prompt_template = "{{$input}}\n\nTL;DR in one sentence:" summarize_fn = kernel.add_function( prompt=prompt_template, function_name="tldr", plugin_name="Summarizer" ) -
原生函数:基于代码实现
from semantic_kernel.functions import kernel_function class MathPlugin: @kernel_function def add(self, a: int, b: int) -> int: return a + b
2. 插件(Skills)
插件是相关功能的集合,可以:
- 通过类定义
- 从文件加载
- 基于OpenAPI规范创建
kernel.add_plugin(plugin=MathPlugin(), plugin_name="Math")
实战示例:智能家居控制
让我们通过一个智能家居灯光控制的例子,展示SK的自动函数调用能力:
class LightsPlugin:
def __init__(self, lights):
self.lights = lights
@kernel_function
async def get_lights(self) -> List[LightModel]:
return self.lights
@kernel_function
async def change_state(self, id: int, new_state: LightModel):
for light in self.lights:
if light["id"] == id:
light.update(new_state)
return light
return None
# 使用示例
lights = [{"id": 1, "name": "Table Lamp", "is_on": False}]
plugin = LightsPlugin(lights=lights)
kernel.add_plugin(plugin=plugin, plugin_name="Lights")
# AI自动调用函数
history.add_user_message("Please turn on the lamp")
result = await chat_completion.get_chat_message_content(
chat_history=history,
settings=execution_settings,
kernel=kernel
)
练习:创建天气插件
任务要求
创建一个WeatherPlugin类,包含以下功能:
get_current_weather(location):获取当前位置天气get_forecast(location, days):获取多日天气预报get_weather_alert(location):获取天气警报
参考实现
from typing import Annotated, List, Dict
from semantic_kernel.functions import kernel_function
import random
class WeatherPlugin:
def __init__(self):
self.conditions = ["晴", "多云", "雨", "雪", "大风", "雾", "雷暴"]
self.alerts = ["无", "暴雨警告", "大风警告", "高温预警"]
@kernel_function
async def get_current_weather(self, location: str) -> Dict:
return {
"location": location,
"temperature": random.randint(-10, 35),
"condition": random.choice(self.conditions)
}
@kernel_function
async def get_forecast(self, location: str, days: int) -> List[Dict]:
return [{
"date": f"Day {i+1}",
"temperature": random.randint(-10, 35),
"condition": random.choice(self.conditions)
} for i in range(days)]
@kernel_function
async def get_weather_alert(self, location: str) -> Dict:
return {
"location": location,
"alert": random.choice(self.alerts)
}
总结
Semantic Kernel为AI应用开发提供了强大的基础设施:
- 简化集成:轻松连接AI模型与现有代码
- 模块化架构:通过插件系统实现功能扩展
- 自动编排:智能管理多步骤函数调用
- 企业级支持:内置安全与监控功能
通过本文的讲解和示例,您应该已经掌握了SK的核心概念和基本使用方法。接下来可以尝试构建更复杂的AI应用,如智能客服、数据分析助手等。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0248- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
HivisionIDPhotos⚡️HivisionIDPhotos: a lightweight and efficient AI ID photos tools. 一个轻量级的AI证件照制作算法。Python05
项目优选
收起
deepin linux kernel
C
27
13
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
641
4.19 K
Ascend Extension for PyTorch
Python
478
579
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
934
841
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
386
272
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.52 K
866
暂无简介
Dart
885
211
仓颉编程语言运行时与标准库。
Cangjie
161
922
昇腾LLM分布式训练框架
Python
139
163
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21