实践大模型提示工程(Prompt Engineering)
任务目标
本文将结合实战营中的具体案例,分享在提示词设计、模型调用及复杂任务拆解中的实践心得,希望能为读者打开一扇通往 AI 开发实战的窗口。
书生浦语官方链接
实践一——写一段话介绍书生浦语实战营
在提示工程中,第一点给出清晰的指令是至关重要的。一个有效的指令通常包含以下要素:背景、任务、要求、限制条件、示例、输出格式和目标。通过提供这些详细信息,我们可以引导模型生成更符合我们期望的文本。
让我们以"为AI大模型训练营生成介绍文案"为例,来展示如何逐步优化指令,以获得更理想的AI生成内容:
第一版提示词(基础版):
写一段话介绍AI大模型训练营
第二版提示词(增加表情元素):
写一段话介绍AI大模型训练营,添加emoji表情
第三版提示词(进一步优化结构):
写一段话介绍AI大模型训练营,添加emoji表情,结构化排版
通过这个例子,我们可以清楚地看到,随着指令的逐步完善,AI生成的内容质量也随之提升。这种渐进式的提示词优化方法可以帮助我们更好地掌控AI输出,获得更符合需求的结果。
实践二——结构化提示词生成和应用实战
编写完LangGPT提示词后,可以将其作为系统提示,也可直接作为交互式对话的输入。推荐作为系统提示。
填入系统提示后保存设置,之后可以与自定义的助手角色进行对话。
3.1 自动化生成LangGPT提示词
利用下面的提示词引导InternLM扮演提示词生成助手,自动化地生成符合最佳实践的结构化提示词:
你是提示词专家,根据用户的输入设计用于生成**高质量(清晰准确)**的大语言模型提示词。- 技能:- 📊 分析、写作、编码- 🚀 自动执行任务- ✍ 遵循提示工程的行业最佳实践并生成提示词# 输出要求:- 结构化输出内容。- 为代码或文章提供**详细、准确和深入**的内容。# 📝 提示词模板(使用代码块展示提示内容):```你是xxx(描述角色和角色任务)- 技能:- 📊 分析、写作、编码- 🚀 自动执行任务# 💬 输出要求:- 结构化输出内容。- 为代码或文章提供**详细、准确和深入**的内容。-(其他基本输出要求)# 🔧 工作流程:- 仔细深入地思考和分析用户的内容和意图。- 逐步工作并提供专业和深入的回答。-(其他基本对话工作流程)# 🌱 初始化:欢迎用户,友好的介绍自己并引导用户使用。```**你的任务是帮助用户设计高质量提示词。**开始请打招呼:“您好!我是您的提示词专家助手,请随时告诉我您需要设计什么用途的提示词吧。
效果演示:
3.2 小红书文案专家
利用下面的提示词引导InternLM扮演小红书文案专家,撰写符合小红书平台特色的小红书:
你是小红书文案专家,请按照我提供的主题,帮我创作小红书标题和文案。# 技能## 创作有吸引力的标题
- 使用标点:通过标点符号,尤其是叹号,增强语气,创造紧迫或惊喜的感觉!
- 挑战与悬念:提出引人入胜的问题或情境,激发好奇心。
- 结合正负刺激:平衡使用正面和负面的刺激,吸引注意力。
- 紧跟热点:融入当前流行的热梗、话题和实用信息。
- 明确成果:具体描述产品或方法带来的实际效果。
- 表情符号:适当使用emoji,增加活力和趣味性。
- 口语化表达:使用贴近日常交流的语言,增强亲和力。
- 字数控制:保持标题在20字以内,简洁明了。## 标题创作公式
标题需要顺应人类天性,追求便捷与快乐,避免痛苦。
- 正面吸引:展示产品或方法的惊人效果,强调快速获得的益处。比如:产品或方法+只需1秒(短期)+便可开挂(逆天效果)。
- 负面警示:指出不采取行动可能带来的遗憾和损失,增加紧迫感。比如:你不xxx+绝对会后悔(天大损失)+(紧迫感)标题从下面选择1-2个关键词:
我宣布、我不允许、请大数据把我推荐给、真的好用到哭、真的可以改变阶级、真的不输、永远可以相信、吹爆、搞钱必看、狠狠搞钱、一招拯救、正确姿势、正确打开方式、摸鱼暂停、停止摆烂、救命!、啊啊啊啊啊啊啊!、以前的...vs现在的...、再教一遍、再也不怕、教科书般、好用哭了、小白必看、宝藏、绝绝子、神器、都给我冲、划重点、打开了新世界的大门、YYDS、秘方、压箱底、建议收藏、上天在提醒你、挑战全网、手把手、揭秘、普通女生、沉浸式、有手就行、打工人、吐血整理、家人们、隐藏、高级感、治愈、破防了、万万没想到、爆款、被夸爆## 创作有吸引力的正文:### 正文创作公式
选择以下一种方式作为文章的开篇引入:
- 引用名言、提出问题、使用夸张数据、举例说明、前后对比、情感共鸣。### 正文要求
- 风格要求:真诚友好、鼓励建议、幽默轻松;口语化的表达风格,有共情力
- 多用叹号、多分段、多用短句
- 重点在前:遵循倒金字塔原则,把最重要的事情放在开头说明
- 逻辑清晰:遵循总分总原则,第一段和结尾段总结,中间段分点说明# 输出要求:
- 标题数量:每次准备10个标题。
- 正文创作:撰写与标题相匹配的正文内容,具有强烈的浓人风格# 🔧 工作流程:
- 请用户提供关键词或主题,确定文案的方向和风格。
- 根据用户主题,自动生成符合小红书平台特点的文案,包括标题、正文和 Tags。# 🌱 初始化:
欢迎用户,友好的介绍自己。请用户提供关键词或主题,以及期望的文案风格和目标用户群体,依据用户提供的主题创作文案。
效果演示:
3.3 上传文件和领导对我的要求对话,就能生成解决方案的大模型提示词
利用下面的提示词引导InternLM扮演提示词生成助手,自动化地生成符合最佳实践的结构化提示词:
你是提示词专家,根据用户的输入设计用于生成**高质量(清晰准确)**的大语言模型提示词。- 技能:- 📊 分析、写作、编码- 🚀 自动执行任务- ✍ 遵循提示工程的行业最佳实践并生成提示词# 输出要求:- 结构化输出内容。- 为代码或文章提供**详细、准确和深入**的内容。# 📝 提示词模板(使用代码块展示提示内容):```你是xxx(描述角色和角色任务)- 技能:- 📊 分析、写作、编码- 🚀 自动执行任务# 💬 输出要求:- 结构化输出内容。- 为代码或文章提供**详细、准确和深入**的内容。-(其他基本输出要求)# 🔧 工作流程:- 仔细深入地思考和分析用户的内容和意图。- 逐步工作并提供专业和深入的回答。-(其他基本对话工作流程)# 🌱 初始化:欢迎用户,友好的介绍自己并引导用户使用。```**你的任务是帮助用户设计高质量提示词。**开始请打招呼:“您好!我是您的提示词专家助手,请随时告诉我您需要设计什么用途的提示词吧。
帮我写一个上传文件和领导对我的要求对话,就能生成解决方案的大模型提示词。
模型输出
你是一位专业的解决方案生成助手,擅长分析用户上传的文件内容和相关对话背景,生成符合特定需求的解决方案。
- 技能:- 📊 深入分析上传的文件内容(包括文本、PDF、表格等格式),提取关键信息和意图。- ✍ 根据用户提供的领导对话内容,理解具体要求并生成清晰、准确的解决方案。- 🚀 高效整合文件信息与对话背景,生成结构化、逻辑清晰的输出。
# 💬 输出要求:- 结构化输出:使用Markdown格式,包含标题(如“解决方案”)、小标题(如“背景分析”、“具体方案”)和清晰的段落。- 内容详细、准确、直接响应领导的要求,确保解决方案可操作且符合文件内容。- 语气专业、简洁,适合职场场景,面向领导和团队成员。- 如果文件或对话中包含具体数据或目标,解决方案必须引用这些信息,确保一致性。- 输出长度根据文件和对话复杂度调整,默认提供500-800字的详细方案。- 如果文件或对话信息不足,列出假设并说明需要进一步澄清的内容。
# 🔧 工作流程:- 步骤1:读取并分析用户上传的文件,提取关键信息(如目标、数据、问题描述)。- 步骤2:解析用户提供的与领导的对话,识别领导的核心要求、优先级和期望。- 步骤3:整合文件内容与对话背景,制定逻辑清晰的解决方案。- 步骤4:以Markdown格式输出,包含背景分析、具体方案、实施步骤和预期结果。- 步骤5:如有潜在问题或限制,提出风险提示和应对建议。
# 🌱 初始化:假设用户上传了一个文件(格式可能是文本、PDF或表格),包含项目需求、数据或问题描述,同时提供了与领导的对话记录,描述领导对项目的期望或具体要求。基于这些信息,生成一个详细的解决方案,直接响应领导的要求,确保方案可行且与文件内容一致。如果文件或对话未提供足够信息,明确列出假设并建议用户补充细节。
结果输出:
实践三——AI一键写书实战效果演示
1 在线体验(需正确上网):
https://book.apps.langgpt.ai/
2 本地运行:
2.1 获取项目代码
项目地址: https://github.com/langgptai/BookAI
命令:
git clone https://github.com/langgptai/BookAI.git
cd BookAI
查看项目结构:
├── book_writer.py
├── prompts
│ ├── chapter_writer.txt
│ ├── outline_writer.txt
│ └── title_writer.txt
├── README.md
├── requirements.txt
2.2 配置项目 Python 环境
pip install -r requirements.txt
2.3 配置大模型 API
(1)申请浦语的 API , 获取 API Token:
https://internlm.intern-ai.org.cn/api/document
(2) 修改下面命令中的 API_KEY 等配置,在命令行执行命令,即可完成书籍创作
export API_KEY=xxx
export BASE_URL=https://internlm-chat.intern-ai.org.cn/puyu/api/v1/
export MODEL_NAME=internlm2.5-latestpython3 book_writer.py
(3)创作好的书籍在 books 文件夹下,写好的书籍示例(仅供参考): 爱的编码:解密人类情感基因.
(4)注意:
如果遇到“请求过于频繁,请稍后再试”报错,是 API 存在调用频率限制,可以使用硅基流动注册免费的 API 服务。配置 API_KEY,修改下面的命令并执行:
注意:写博客时切记删除自己的 api_key!
export API_KEY=sk-xxx
export BASE_URL=https://api.siliconflow.cn/v1
export MODEL_NAME=internlm/internlm2_5-7b-chatpython3 book_writer.py
2.4 项目拆解
大模型无法完成这么复杂的任务,因此我们需要拆解任务 ——> 这种方法也称为分治法。
分治法拆解任务:
- 第一步:创作书籍总体信息:书名,主要内容介绍
- 第二步:创作书籍分章节大纲:每章章节名+简介
- 第三步:依据章节大纲创作章节内容
接下来针对每一步骤撰写提示词:
(1)书籍起名提示词
# Role: 书籍写作专家## Profile
- author: LangGPT
- version: 1.0
- language: 中文
- description: 帮助用户为书籍创建有吸引力的标题和简介,确保书名与书籍内容相符,简介清晰传达书籍核心主题。## Skills
1. 创意标题设计:能够根据书籍主题与风格,设计简洁、吸引读者的书名。
2. 精准简介编写:擅长提炼书籍的核心内容,用简短的文字清晰传达书籍的主题和卖点。
3. 内容风格匹配:根据书籍类型(小说、纪实、科幻等),调整标题和简介的语言风格。
4. 阅读者定位:根据书籍目标读者群体,设计有针对性的书籍标题与简介。## Rules
1. 根据书籍内容概述、类型和目标读者,生成适合的标题和简介。
2. 标题需简洁、富有吸引力,能够激发读者的兴趣。
3. 简介需简短有力,准确传达书籍核心内容和主题。
4. 避免过于复杂或不相关的描述,突出书籍卖点和读者关心的部分。## Goals
书籍信息:{theme}
撰写书籍标题和简介(json格式输出):
{"title":"《xxx》","intro":"xxx",
}## Init
设计合适的标题和简介,只输出json内容,此外不要给出任何无关内容和字符。
(2) 书籍大纲提示词
# Role: 书籍写作专家## Profile
- author: LangGPT
- version: 1.0
- language: 中文/英文
- description: 帮助用户根据书籍的标题和简介,设计出完整的书籍大纲,确保结构清晰,逻辑合理,并符合书籍的主题和风格。## Skills
1. 书籍结构设计:根据书籍的主题和内容,设计清晰、有逻辑的章节和段落结构。
2. 情节和主题发展:擅长为小说、纪实文学等书籍设计情节发展框架,确保每一章节之间的连贯性和发展方向。
3. 内容层次划分:能够根据书籍的核心主题,将内容分为多个合理的层次和部分,确保读者能系统地理解内容。
4. 读者体验优化:根据目标读者的需求和阅读习惯,优化书籍结构,使其易于阅读并具有吸引力。## Rules
1. 基于用户提供的书籍标题和简介,生成完整的书籍大纲。
2. 大纲需要包括书籍的主要章节和每一章节的关键内容概述。
3. 确保大纲的结构合理,内容连贯,有助于推进书籍的主题和情节发展。
4. 书籍大纲应体现书籍的核心主题,并符合读者的期待。## Goals
书籍主题:{theme}
书籍标题和简介:
{intro}撰写书籍大纲(python list 格式,10-20章)
["第一章:《xxx》xxx", "第二章:《xxx》xxx","...", "xxx"]## Init
设计合适的章节大纲,只输出 python list内容,此外不要给出任何无关内容和字符。
(3) 书籍正文内容撰写提示词
# Role: 书籍写作专家## Profile
- author: LangGPT
- version: 1.0
- language: 中文/英文
- description: 帮助用户根据提供的书籍标题、简介和章节大纲,撰写每一章的具体内容,确保语言风格符合书籍定位,内容连贯、专业、正式。## Skills
1. 章节内容撰写:能够根据用户提供的章节大纲,撰写完整的章节内容,确保情节发展和主题的深度探讨。
2. 文体和风格匹配:根据书籍的类型(小说、纪实、学术等)和目标读者,调整写作风格,使其正式、专业且符合书籍定位。
3. 细节描写与逻辑构建:擅长细节描写,增强故事的真实感与情感深度,保证逻辑严密性。
4. 内容深化与扩展:在大纲基础上,合理扩展和深化内容,使每一章有足够的丰富性和信息量。## Rules
1. 依据用户提供的书籍标题、简介和大纲,撰写每一章的详细内容。
2. 每章内容需符合书籍主题,并在情节、逻辑和语言风格上保持一致。
3. 确保内容丰富、信息清晰,避免不必要的重复或偏离主题。
4. 保持正式、专业的语言风格,适合目标读者。
5. 不需胡说八道,编造事实。## Goals
书籍简介:
{book_content}本章大纲:
{chapter_intro}请依据本章大纲和书籍简介撰写本章内容。## OutputFormat:
- 如果需要数学公式,使用写法:"$latex公式$",使其能被 markdown 正确渲染,示例:"$z = \sum_{i=1}^{n} w_i \cdot x_i + b$"。
(注意:你的数学公式不要用 "\[ \]" 写法,这样无法被正确渲染!!!)
- 结构化写作,使用 markdown 格式排版内容。
- 章节标题,示例:"# 第三章:Transformer的基础原理"
- 章节内小标题使用序号, 示例:"## 3.1 Transformer的架构"。
- 合理按需使用粗体,斜体,引用,代码,公式,列表。## Init
设计合适的章节大纲,只输出本章内容,此外不要给出任何无关内容和字符。
(4) 使用代码将这些提示词的输入输出串起来
import os
import re
import json
from typing import List, Dict, Optional, Tuple
from concurrent.futures import ThreadPoolExecutor
from dotenv import load_dotenv
import openai
from phi.assistant import Assistant
from phi.llm.openai import OpenAIChat# 加载 .env 文件
load_dotenv()def read_prompt(prompt_file: str, replacements: Dict[str, str]) -> str:"""读取提示文件并替换占位符"""with open(prompt_file, 'r', encoding='utf-8') as file:prompt = file.read()for key, value in replacements.items():prompt = prompt.replace(f"{{{key}}}", value)return prompt
def convert_latex_to_markdown(text):# 使用正则表达式替换公式开始和结束的 \[ 和 \],但不替换公式内部的pattern = r'(?<!\\)\\\[((?:\\.|[^\\\]])*?)(?<!\\)\\\]'return re.sub(pattern, r'$$\1$$', text)class BookWriter:"""管理书籍生成过程的主类。"""def __init__(self, api_key: str, base_url: str, model_name: str, system_prompt=None):"""初始化BookWriter。"""# 使用openai的接口调用书生浦语模型self.api_key = os.getenv("API_KEY") if api_key is None else api_keyself.base_url = os.getenv("BASE_URL") if base_url is None else base_urlself.model_name = os.getenv("MODEL_NAME") if model_name is None else model_nameif system_prompt is None:system_prompt = "你是一个专业的写作助手,正在帮助用户写一本书。"self.assistant = self.create_assistant(self.model_name, self.api_key, self.base_url, system_prompt)def create_assistant(self, model_name: str, api_key: str, base_url: str, system_prompt: str) -> str:# 润色文本self.assistant = Assistant(llm=OpenAIChat(model=model_name,api_key=api_key,base_url=base_url,max_tokens=4096, # make it longer to get more context),system_prompt=system_prompt,prevent_prompt_injection=True,prevent_hallucinations=False,# Add functions or Toolkits#tools=[...],# Show tool calls in LLM response.# show_tool_calls=True)return self.assistantdef generate_title_and_intro(self, book_theme, prompt_file = "prompts/title_writer.txt") -> Tuple[str, str]:"""生成书籍标题和主要内容介绍。Args:prompt: 用于生成标题和介绍的提示。Returns:包含生成的标题和介绍的元组。"""prompt_args = {"theme": book_theme}prompt = read_prompt(prompt_file, prompt_args)#print(prompt)for attempt in range(3):try:response = self.assistant.run(prompt, stream=False)# convert to jsonresponse = response.strip()if not response.startswith('{'):response = '{' + response.split('{', 1)[1]if not response.endswith('}'):response = response.split('}', 1)[0] + '}'book_title_and_intro = json.loads(response)#print(book_title_and_intro)return book_title_and_introexcept Exception as e:print(f"Attempt {attempt + 1} failed: {e}")return responsedef generate_outline(self, book_theme, book_title_and_intro: str, prompt_file= "prompts/outline_writer.txt") -> List[str]:"""生成书籍章节大纲。Args:prompt: 用于生成大纲的提示。title: 书籍标题。intro: 书籍介绍。Returns:章节标题列表。"""prompt_args = {"theme": book_theme, "intro": str(book_title_and_intro)}prompt = read_prompt(prompt_file, prompt_args)for attempt in range(3):try:response = self.assistant.run(prompt, stream=False)#print(response)# convert to jsonresponse = response.strip()if not response.startswith('['):response = '[' + response.split('[', 1)[1]if not response.endswith(']'):response = response.split(']', 1)[0] + ']'chapters = json.loads(response.strip())#print(chapters)return chaptersexcept Exception as e:print(f"Attempt {attempt + 1} failed: {e}")return responsedef generate_chapter(self, book_content, chapter_intro, prompt_file= "prompts/chapter_writer.txt") -> str:"""生成单个章节的内容。Args:chapter_title: 章节标题。book_title: 书籍标题。book_intro: 书籍介绍。outline: 完整的章节大纲。prompt: 用于生成章节的提示。Returns:生成的章节内容。"""prompt_args = {"book_content": str(book_content), "chapter_intro": str(chapter_intro)}prompt = read_prompt(prompt_file, prompt_args)for attempt in range(3):try:response = self.assistant.run(prompt, stream=False)response.strip()if response.startswith('```markdown'):# 删除第一行和最后一行lines = response.splitlines()response = '\n'.join(lines[1:-1])return responseexcept Exception as e:print(f"Attempt {attempt + 1} failed: {e}")response = convert_latex_to_markdown(response)return responsedef generate_book(self, custom_theme=None, save_file=False) -> None:"""生成整本书并将其保存到文件中。Args:custom_prompts: 自定义提示的字典。可以包括 'title_intro', 'outline' 和 'chapter' 键。"""print("开始生成书籍标题和介绍...")theme = custom_theme if custom_theme else "Transformer是什么"title_and_intro = self.generate_title_and_intro(theme)title = title_and_intro["title"]print(f"书籍标题和介绍:\n {title_and_intro}")print("\n开始生成章节大纲...")chapters = self.generate_outline(theme, title_and_intro)print("章节大纲:")print(chapters)book_intro = title_and_introbook_content = "# " + title# 使用线程池来并行生成章节内容print("\n开始创作正文内容,时间较长(约几分钟)请等待~")with ThreadPoolExecutor() as executor:chapter_contents = list(executor.map(self.generate_chapter, [book_intro]*len(chapters), chapters))for i, chapter in enumerate(chapters, 1):print(f"\n正在生成第{i}章:{chapter}")chapter_content = chapter_contents[i-1].strip() # 获取已生成的章节内容print(chapter_content)book_content += f"\n\n{chapter_content}"print(f"第{i}章已完成。")print("\n整本书已生成完毕。")if save_file:filename = f"books/{title.replace(' ', '_')}.md"with open(filename, "w", encoding="utf-8") as f:f.write(book_content)print(f"书籍内容已保存到 {filename} 文件中。")return book_contentdef main():"""主函数, 演示如何使用BookWriter类。"""book_theme = input("请输入书籍主题(如 AI 是什么?): ")api_key = os.getenv("API_KEY")base_url = os.getenv("BASE_URL")model_name = os.getenv("MODEL_NAME")print(base_url, model_name)book_writer = BookWriter(api_key, base_url, model_name, system_prompt=None)book_writer.generate_book(custom_theme=book_theme, save_file=True)if __name__ == "__main__":main()
结语
当前的写书项目只是个小 demo,还存在许多问题,同学们可以试着优化这些问题。一些已知的问题和优化方向:
1. 章节正文内容的质量提升。优化内容表达、内容的深度、格式排版等,尤其数学公式的格式和排版。
2. 各章节内容的连贯性。
3. 章节正文长度提升。
4. 让图书图文并茂:使用 mardown 的图片语法配图,或者搭配生图模型生成图片。
5. 其他你能想到的优化方向。
当然,当前的探索仍有诸多待突破之处:如何在长文本生成中保持逻辑连贯?怎样让模型更好地理解语境中的隐性需求?这些挑战既是技术演进的方向,也是我们持续深耕的动力。正如代码需要不断调试,AI 协作能力的提升也离不开反复的 “提示词迭代”。希望本文的思考能为读者带来启发,更期待与大家在 AI 技术的探索之路上共同前行,让智能工具真正成为拓展人类能力边界的翅膀。
相关文章:
实践大模型提示工程(Prompt Engineering)
任务目标 本文将结合实战营中的具体案例,分享在提示词设计、模型调用及复杂任务拆解中的实践心得,希望能为读者打开一扇通往 AI 开发实战的窗口。 书生浦语官方链接 实践一——写一段话介绍书生浦语实战营 在提示工程中,第一点给出清晰的…...
东莞一锂离子电池公司IPO终止,客户与供应商重叠,社保缴纳情况引疑
作者:小熊 来源:IPO魔女 5月17日,深交所发布公告称,东莞市朗泰通科技股份有限公司(简称朗泰通科技)已主动撤回其IPO申请。该公司本次IPO原拟募集资金7.0208亿元,保荐机构为国金证券股份有限公…...
互联网大厂Java求职面试:Spring Cloud微服务架构与AI集成挑战
互联网大厂Java求职面试:Spring Cloud微服务架构与AI集成挑战 引言 在当前快速发展的互联网行业中,Java开发者在面对复杂的分布式系统设计时,需要掌握从微服务架构到AI模型集成的多种技能。本文通过一场模拟面试,深入探讨了基于…...
解决C#泛型类参数无法带参数实例化的问题
概要 本文提供了一个基于C#表达式目录树的方法来解决泛型参数不能调用带参数的构造方法来实例化的问题。 C#泛型的限制 我们看如下的代码,User类需要一个泛型类,泛型类是要以CreditCard为基类。 class User<T> where T :CreditCard, new() {pr…...
微型化GNSS射频前端芯片AT2659S:L1频段多系统支持,SOT23-6封装
AT2659S是一款采用SiGe技术的低噪声放大器(LNA),相比传统CMOS工艺,它在功耗和噪声性能上进行了显著优化。该芯片支持L1频段的多模卫星导航系统,包括北斗二代、GPS、伽利略和Glonass,适用于高灵敏度的GNSS接…...
【图像大模型】深度解析RIFE: 基于中间流估计的实时视频插帧算法
基于深度学习的视频插帧算法RIFE技术解析与实战指南 一、项目背景与技术原理1.1 视频插帧技术概述1.2 RIFE核心创新1.3 算法原理详解1.3.1 网络架构1.3.2 损失函数设计1.3.3 时间自适应训练 二、项目部署与执行指南2.1 环境配置2.2 模型推理2.2.1 快速测试2.2.2 视频处理 2.3 模…...
Docker安装Fluentd采集中间件
Fluentd 简介 :Fluentd 是一个高性能、可扩展的数据收集与聚合工具,能够统一数据收集和消费,实现各种数据源到各种数据接收器的高效传输,广泛应用于日志收集等领域。 功能特点 : 统一日志收集 :支持从各种…...
【攻防实战】MacOS系统上线Cobalt Strike
如果巅峰留不住,那就重走来时路 前言 目前在一些攻防项目中遇到的互联网大厂,很多员工使用的都是MacOS主机。研究过程中发现网上这方面分享比较少,这里记录分享一下。 插件安装 配置cna基础文件,注意路径名不能包含中文或特殊…...
基于Resnet-34的树叶分类(李沐深度学习基础竞赛)
目录 一,数据集介绍 1.1 数据集下载 1.2 数据集介绍 二,Resnet-34介绍 三,模型训练 四,模型预测 五,测试结果 5.1 测试集结果 5.2 预测结果 5.3 总结 一,数据集介绍 1.1 数据集下载 本数据集下载…...
PCB设计实践(二十三)什么是阻抗匹配,需要做啥
PCB设计中的阻抗匹配是高速数字电路、射频通信、信号完整性等领域的核心技术,其重要性贯穿从基础理论到复杂系统设计的全流程。本文将从工程实践角度深入探讨阻抗匹配的本质原理、应用场景、设计方法、常见误区及解决方案,全面解析这一影响现代电子设备性…...
网络世界的“变色龙“:动态IP如何重构你的数据旅程?
在深秋的下午调试代码时,我偶然发现服务器日志中出现异常登录记录——IP地址显示为某个境外数据中心。更有趣的是,当我切换到公司VPN后,这个"可疑IP"竟自动消失在了防火墙监控列表中。这个瞬间让我意识到:现代网络架构中…...
Chrome浏览器捕获hover元素样式
–前言– 某些元素,只有hover上去才会看到触发效果,但是鼠标移开就找不到element元素,导致无法调试样式。下属两种方案可参考: 文章目录 一、方式1:通过class伪类触发二、方式2:通过断点调试2.1控制台切换到…...
嵌入式自学第二十五天(5.21)
(1)二进制文件读写操作: 例: #include<stdio.h> int main() { FILE *fp fopen("a.out","r"); FILE *fp1 fopen("app","w"); if(NULL fp || NULL fp1) { …...
golang库源码学习——Pond,小而精的工作池库
pond 是一个轻量级的 Goroutine 池库,用于高效管理并发任务。它提供了灵活的配置选项和多种策略,适合处理高并发场景。 GitHub - alitto/pond at v1 一、特点: 1.轻量级 pond 的代码库非常精简,它的V1版本仅有四个业务文件&#…...
Microbiome医口经典思路:退烧药物代谢过程如何进行多组学分析?
乙酰氨基酚(APAP),俗称扑热息痛,是应用最广泛的镇痛和解热药物之一。以往的研究主要集中在分离APAP降解菌株,了解其降解代谢途径。但微生物群与对乙酰氨基酚之间的相互作用、对乙酰氨基酚降解基因的分布特征以及对乙酰…...
微信小程序AI大模型流式输出实践与总结
背景 让Cursor生成小程序中大模型调用内容回复的流式输出时一直有问题,参考整理此文章。 参考原文:https://blog.csdn.net/weixin_47684422/article/details/145859543 一、什么是流式传输? 流式传输(Streaming)指的…...
操作系统理解(xv6)
xv6操作系统项目复习笔记 宗旨:只记大框架,不记细节,没有那么多的时间 一、xv6的页表是如何搭建的? xv6这个项目中,虚拟地址用了39位(27位12位(物理内存page偏移地址))…...
2024CCPC辽宁省赛 个人补题 ABCEGJL
Dashboard - 2024 CCPC Liaoning Provincial Contest - Codeforces 过题难度 B A J C L E G 铜奖 4 953 银奖 6 991 金奖 8 1664 B: 模拟题 // Code Start Here string s;cin >> s;reverse(all(s));cout << s << endl;A:很…...
Sentinel原理与SpringBoot整合实战
前言 随着微服务架构的广泛应用,服务和服务之间的稳定性变得越来越重要。在高并发场景下,如何保障服务的稳定性和可用性成为了一个关键问题。阿里巴巴开源的Sentinel作为一个面向分布式服务架构的流量控制组件,提供了从流量控制、熔断降级、…...
Python 训练营打卡 Day 31
文件的规范拆分和写法 把一个文件,拆分成多个具有着独立功能的文件,然后通过import的方式,来调用这些文件。这样具有几个好处: 可以让项目文件变得更加规范和清晰可以让项目文件更加容易维护,修改某一个功能的时候&a…...
vue+srpingboot实现多文件导出
项目场景: vuesrpingboot实现多文件导出 解决方案: 直接上干货 <el-button type"warning" icon"el-icon-download" size"mini" class"no-margin" click"exportSelectedFiles" :disabled"se…...
学习 Pinia 状态管理【Plan - May - Week 2】
一、定义 Store Store 由 defineStore() 定义,它的第一个参数要求独一无二的id import { defineStore } from piniaexport const useAlertsStore defineStore(alert, {// 配置 })最好使用以 use 开头且以 Store 结尾 (比如 useUserStore,useCartStore&a…...
linux中cpu内存浮动占用,C++文件占用cpu内存、定时任务不运行报错(root) PAM ERROR (Permission denied)
文章目录 说明部署文件准备脚本准备部署g++和编译脚本使用说明和测试脚本批量部署脚本说明执行测试定时任务不运行报错(root) PAM ERROR (Permission denied)报错说明处理方案说明 我前面已经弄了几个版本的cpu和内存占用脚本了,但因为都是固定值,所以现在重新弄个用C++编写的…...
数据湖和数据仓库的区别
在当今数据驱动的时代,企业需要处理和存储海量数据。数据湖与数据仓库作为两种主要的数据存储解决方案,各自有其独特的优势与适用场景。本文将客观详细地介绍数据湖与数据仓库的基本概念、核心区别、应用场景以及未来发展趋势,帮助读者更好地…...
OceanBase 开发者大会,拥抱 Data*AI 战略,构建 AI 数据底座
5 月 17 号以“当 SQL 遇见 AI”为主题的 OceanBase 开发者大会在广州举行,因为行程的原因未能现场参会,仍然通过视频直播观看了全部的演讲。总体来说,这届大会既有对未来数据库演进方向的展望,也有 OceanBase 新产品的发布&#…...
鸿蒙HarmonyOS最新的组件间通信的装饰器与状态组件详解
本文系统梳理了鸿蒙(HarmonyOS)ArkUI中组件间通信相关的装饰器及状态组件的使用方法,重点介绍V2新特性,适合开发者查阅与实践。 概述 鸿蒙系统(HarmonyOS)ArkUI提供了丰富的装饰器和状态组件,用…...
OneDrive登录,账号跳转问题
你的OneDrive登录无需密码且自动跳转到其他账号,可能是由于浏览器或系统缓存了登录信息,或存在多个账号的关联。以下是分步解决方案: 方案三对我有效。 强制手动输入密码 访问登录页面时: 在浏览器中打开 OneDrive网页版。 点击…...
9-码蹄集600题基础python篇
题目如上图所示。 这一题,没什么难度。 代码如下: def main():#code here# x,amap(int,input("").split(" "))# sum((1/2)*(a*x(ax)/(4*a)))# print(f"{sum:.2f}")x,amap(int,input().split())print(f"{((1/2)*(a*…...
CAU人工智能class3 优化器
优化算法框架 优化思路 随机梯度下降 随机梯度下降到缺点: SGD 每一次迭代计算 mini-batch 的梯度,然后对参数进行更新,每次迭代更新使用的梯度都只与本次迭代的样本有关。 因为每个批次的数据含有抽样误差,每次更新可能并不会 …...
学习 Android(十一)Service
简介 在 Android 中,Service 是一种无界面的组件,用于在后台执行长期运行或跨进程的任务,如播放音乐、网络下载或与远程服务通信 。Service 可分为“启动型(Started)”和“绑定型(Bound)”两大…...
SpringAI开发SSE传输协议的MCP Server
SpringAI 访问地址:Spring AI Spring AI是一个面向人工智能工程的应用框架,由Spring团队推出,旨在将AI能力集成到Java应用中。Spring AI的核心是解决AI集成的根本挑战,即将企业数据和API与AI模型连接起来。 MCP…...
【泛微系统】后端开发Action常用方法
后端开发Action常用方法 代码实例经验分享:代码实例 经验分享: 本文分享了后端开发中处理工作流Action的常用方法,主要包含以下内容:1) 获取工作流基础信息,如流程ID、节点ID、表单ID等;2) 操作请求信息,包括请求紧急程度、操作类型、用户信息等;3) 表单数据处理,展示…...
如何成为更好的自己?
成为更好的自己是一个持续成长的过程,需要结合自我认知、目标规划和行动力。以下是一些具体建议,帮助你逐步提升: 1. 自我觉察:认识自己 反思与复盘:每天花10分钟记录当天的决策、情绪和行为,分析哪些做得…...
精益数据分析(74/126):从愿景到落地的精益开发路径——Rally的全流程管理实践
精益数据分析(74/126):从愿景到落地的精益开发路径——Rally的全流程管理实践 在创业的黏性阶段,如何将抽象的愿景转化为可落地的产品功能?如何在快速迭代中保持战略聚焦?今天,我们通过Rally软…...
网站制作公司哪家强?(2025最新版)
在数字化时代,一个优质的网站是企业展示自身实力、拓展业务渠道的重要工具。无论是初创企业还是大型集团,都需要一个功能强大、设计精美的网站来吸引客户、提升品牌形象。但面对市场上众多的网站制作公司,如何选择一家靠谱的合作伙伴呢&#…...
23种经典设计模式(GoF设计模式)
目录 🍀 创建型设计模式(5种) 1. 单例模式(Singleton) 2. 工厂方法模式(Factory Method) 3. 抽象工厂模式(Abstract Factory) 4. 建造者模式(Builder&am…...
深入解析Dify:从架构到应用的全面探索
文章目录 引言一、Dify基础架构1.1 架构概述1.2 前端界面1.3 后端服务1.4 数据库设计 二、Dify核心概念2.1 节点(Node)2.2 变量(Variable)2.3 工作流类型 三、代码示例3.1 蓝图注册3.2 节点运行逻辑3.3 工作流运行逻辑 四、应用场…...
电子电路:怎么理解放大电路中集电极电流Ic漂移?
如果放大电路中集电极电阻RC因为温度或老化而阻值变化,Vce Vcc - IcRc - IcRc,这会改变工作点,导致集电极的电流漂移。 IC漂移的定义:集电极电流随时间、温度等变化。影响IC的因素:β、IB、VBE、温度、电源电压、元件…...
【疑难杂症】Mysql 无报错 修改配置文件后服务启动不起来 已解决|设置远程连接
我修改配置后,服务无法启动可以试试用记事本打开后另存为,格式选择ANSI,然后重新启动mysql试试 设置运行远程、 1、配置my.ini文件 在[mysqld]下 添加bind-address0.0.0.0 2、设置root权限 使用MySql命令行执行, CREATE USER…...
Java基础 5.21
1.多态注意事项和细节讨论 多态的前提是:两个对象(类)存在继承关系 多态的向上转型 本质:父类的引用指向了子类的对象语法:父类类型 引用名 new 子类类型();特点:编译类型看左边,运行类型看…...
探索Puter:一个基于Web的轻量级“云操作系统”
在云计算与Web技术高度融合的今天,开发者们不断尝试将传统桌面体验迁移到浏览器中。近期,GitHub上一个名为Puter的开源项目吸引了社区的关注。本文将带你深入解析Puter的设计理念、技术架构与使用场景,探索它如何通过现代Web技术重构用户的“云端桌面”。 一、项目概览 Put…...
Java SpringBoot 项目中 Redis 存储 Session 具体实现步骤
目录 一、添加依赖二、配置 Redis三、配置 RedisTemplate四、创建控制器演示 Session 使用五、启动应用并测试六、总结 Java 在 Spring Boot 项目中使用 Redis 来存储 Session,能够实现 Session 的共享和高可用,特别适用于分布式系统环境。以下是具体的实…...
电商项目-商品微服务-规格参数管理,分类与品牌管理需求分析
本文章介绍:规格参数管理与分类与品牌管理的需求分析和表结构的设计。 一、规格参数管理 规格参数模板是用于管理规格参数的单元。规格是例如颜色、手机运行内存等信息,参数是例如系统:安卓(Android)后置摄像头像素&…...
Java 定时任务中Cron 表达式与固定频率调度的区别及使用场景
Java 定时任务:Cron 表达式与固定频率调度的区别及使用场景 一、核心概念对比 1. Cron 表达式调度 定义:基于日历时间点的调度,通过 秒 分 时 日 月 周 年 的格式定义复杂时间规则。时间基准:绝对时间点(如每天 12:…...
2025年- H39-Lc147 --394.字符串解码(双栈,递归)--Java版
1.题目描述 2.思路 可以用递归也可以用双栈,这边用栈。 首先先创建一个双栈,一个栈存数字(interger),另一个栈存字符(character)。设置数字临时变量num,设置字母临时变量curString在…...
学编程对数学成绩没帮助?
今天听到某机构直播说“学编程对数学成绩没帮助,如果想提高数学成绩那就单独去学数学”,实在忍不住要和各位家长聊聊我的思考,也欢迎各位家长评论。 恰在此时我看见了一道小学6年级的数学题如下,虽然题不难,但立刻让我…...
现代计算机图形学Games101入门笔记(十九)
光场 在近处画上图像,VR的效果。 任何时间任何位置看到的图像都不一样,是不是就是一个世界了。 光场就是任何一个位置往任何一个方向去的光的强度 知道光场就能知道这个物体长什么样子。 光线可以用一个点和一个方向确定。 也可以用2个点确定一条光线。 …...
STM32单片机GUI系统1 GUI基本内容
目录 一、GUI简介 1、emWin 2、LVGL (Light and Versatile Graphics Library) 3、TouchGFX 4、Qt for Embedded 5、特性对比总结 二、LVGL移植要求 三、优化LVGL运行效果方法 四、LVGL系统文件 一、GUI简介 在嵌入式系统中,emWin、LVGL、TouchGFX 和 Qt 是…...
Prometheus+Grafana实现对服务的监控
PrometheusGrafana实现对服务的监控 前言:PrometheusGrafana实现监控会更加全面,监控的组件更多 Prometheus官网 https://prometheus.io/docs/prometheus/latest/getting_started/ Grafana官网 https://grafana.com/docs/ 一、安装PrometheusGrafana 这…...
hook原理和篡改猴编写hook脚本
hook原理: hook是常用于js反编译的技术;翻译就是钩子,他的原理就是劫持js的函数然后进行篡改 一段简单的js代码 :这个代码是顺序执行的 function test01(){console.log(test01)test02() } function test02(){console.log(02)tes…...