ReactAgent:基于GPT-4的React组件智能生成器实战解析

news2026/4/30 1:07:36
1. 项目概述一个能“听懂”需求的React组件生成器如果你和我一样是个常年和React、TypeScript打交道的开发者那你肯定经历过这样的场景产品经理或者设计师拿着一个用户故事User Story过来描述了一个功能比如“需要一个能让用户上传头像并预览的卡片组件”。你听完后脑子里开始构思组件结构、状态管理、UI库选型然后打开编辑器开始敲代码。这个过程少则半小时多则半天。现在想象一下如果有一个“助手”能直接“听懂”这段用自然语言描述的需求然后自动为你生成一个结构清晰、样式现代、甚至可以直接运行的React组件代码。这听起来像是科幻但ReactAgent这个开源项目正在把这个想法变成现实。它本质上是一个基于GPT-4的自主智能体Autonomous LLM Agent专门用于将用户故事User Story转化为可用的React组件代码。我花了几天时间深入研究了它的源码和运行机制发现它不仅仅是一个简单的“代码生成器”而是一个融合了现代前端工程实践、原子设计思想以及大语言模型LLM提示工程的实验性项目。它生成的代码基于React、TypeScript、Tailwind CSS并且深度集成了像Radix UI、Shadcn/ui这样优秀的“无头UI”Headless UI库这意味着生成的组件不仅功能完整而且在样式和可访问性上也有不错的起点。这个项目非常适合那些希望快速构建原型、探索AI辅助编程可能性或者想学习如何将LLM与具体开发工作流结合的前端开发者。当然它目前定位是“实验性”的生成的代码并非开箱即用的生产级代码但它为我们清晰地展示了一条路径如何让AI理解业务需求并输出结构化的、符合工程规范的代码资产。接下来我将带你从零开始拆解它的设计思路、实操部署、核心工作流并分享我在使用过程中踩过的坑和总结的经验。2. 核心架构与设计思想拆解要理解ReactAgent不能只把它看作一个调用OpenAI API的黑盒。它的价值在于其精心设计的架构和背后遵循的工程原则。这套架构确保了生成的代码不是杂乱无章的“一次性脚本”而是能够融入现有项目、具备一定可维护性的组件。2.1 基于原子设计原则的组件生成策略ReactAgent的核心设计理念之一是原子设计。如果你不熟悉这个概念可以把它理解为一种构建UI的“乐高”方法论从最小的、不可再分的原子如按钮、输入框开始组合成分子如搜索框输入框按钮再形成有机体如导航栏最终组装成模板和页面。ReactAgent在生成组件时会尝试遵循这一原则。它不会为每一个用户故事都从头生成所有HTML标签和样式而是优先尝试利用项目中已有的、符合原子设计规范的“基础组件库”。项目默认集成了Shadcn/ui和Radix UI这两者都是典型的“Headless UI”库。什么是Headless UI简单来说它只提供组件的完整交互逻辑、状态管理和可访问性ARIA属性但不提供任何具体的样式CSS。样式完全由开发者通过Tailwind CSS等工具来自定义。这种“关注点分离”的设计使得ReactAgent生成的组件在逻辑上是健壮的同时在视觉上又具备极高的可定制性。这比生成一堆带着固定、难以修改的“内联样式”或特定框架样式的代码要实用得多。在ReactAgent的配置中你可以通过环境变量指定你的UI_COMPONENTS_DIR基础UI组件目录和DEMO_COMPONENTS_DIR组件演示目录。当Agent处理用户故事时它会先“扫描”这些目录理解现有组件的“能力”和“接口”然后在生成新组件时尽可能地复用和组合这些现有组件。这模拟了一个资深开发者接到需求时的思考过程先看看组件库里有什么能用的再考虑需要新建什么。2.2 双阶段生成工作流从“理解”到“实现”ReactAgent的工作流被清晰地分成了两个主要阶段这在其源码的generateComponents.ts文件中可以清楚地看到。这种分阶段的设计既是为了提高生成质量也为了方便开发者介入和调试。第一阶段需求分析与结构化User Story - JSON Skeleton这是最关键的一步也是LLM能力体现最明显的地方。Agent会接收一个用Markdown编写的、详细的用户故事文件例如user-story.md。然后它调用GPT-4通过精心设计的提示词Prompt让模型完成以下任务理解核心需求提取用户故事中的角色、目标、验收标准。分解UI结构将需求转化为一个分层的、描述性的JSON结构。这个JSON不是代码而是对页面或组件结构的抽象描述例如{ “type”: “Page”, “children”: [{ “type”: “Card”, “props”: { “title”: “用户资料” }, “children”: […] }] }。映射现有组件在JSON结构中为每个部分标注可能对应的、项目中已有的基础组件例如一个文件上传区域可能映射到Shadcn/ui的Input type“file” /和一个自定义的PreviewArea /。这个阶段生成的JSON文件是一个“设计稿”与“代码”之间的中间产物。它的质量直接决定了最终代码的准确性。项目文档也坦率地指出了这里的局限性GPT-4的解读可能不完美可能需要人工检查和修正这个JSON文件。第二阶段代码生成与组合JSON Skeleton - React/TSX Code拿到结构化的JSON后Agent进入第二阶段。它再次调用GPT-4或根据配置进行多次调用但这次的任务更具体组件实现根据JSON描述和映射关系为每个需要新建的部分生成具体的React函数组件代码使用TypeScript定义Props接口。样式集成使用Tailwind CSS类名编写样式遵循项目的设计规范。逻辑注入为组件添加基本的状态useState、效果useEffect和事件处理程序。例如为上传组件生成文件状态和onChange处理函数。组合导出将生成的子组件组合成最终的父组件并在指定的LOCAL_COMPONENTS_DIR目录中生成对应的.tsx文件和index.ts导出文件。整个流程就像一个自动化的“翻译官”和“组装工”把人类语言的需求先翻译成机器可理解的结构化蓝图再根据蓝图和现有的“零件库”基础组件组装出可运行的React代码。2.3 技术栈选型的深层考量为什么是React TypeScript Tailwind CSS Radix/Shadcn/ui这个技术栈的选择并非偶然它背后有很强的实用性考量React TypeScript这是当前企业级前端开发的事实标准。生成TypeScript代码能提供更好的类型安全性和开发体验也便于后续的人工维护和迭代。Tailwind CSS它的实用性优先Utility-First理念非常适合AI生成。模型不需要去“发明”或“描述”复杂的CSS规则只需要组合现成的、语义化的工具类如flex,p-4,rounded-lg就能构建出美观的UI。这大大降低了生成的难度和不可预测性。Radix UI Shadcn/ui如前所述Headless UI库提供了高质量的、可访问的组件逻辑“基座”。AI只需要在这些基座上添加Tailwind样式就能快速生成既专业又可定制的组件避免了从零开始编写复杂的交互逻辑如下拉菜单、模态框的状态管理。这个技术栈组合为AI代码生成划定了一个“高质量、高可控性”的输出范围是项目能够产出可用结果的重要基础。3. 从零开始的完整部署与实操指南理论讲得再多不如亲手跑一遍。下面是我根据官方文档和实际踩坑经验整理的详细部署步骤。请确保你的系统已安装Node.js建议18.x或20.x LTS版本和Yarn包管理器。3.1 环境准备与项目初始化首先我们需要获取项目代码并安装依赖。# 1. 克隆仓库到本地 git clone gitgithub.com:eylonmiz/react-agent.git # 如果SSH配置有问题也可以使用HTTPS方式 # git clone https://github.com/eylonmiz/react-agent.git # 2. 进入项目目录 cd react-agent # 3. 安装项目依赖 # 项目使用Yarn Workspaces管理前后端依赖根目录运行一次即可 yarn install这个过程可能会花费几分钟时间因为它会同时安装前端frontend/main和后端backend/main所需的全部依赖包。3.2 关键配置OpenAI API密钥ReactAgent的核心动力是GPT-4因此你必须拥有一个OpenAI的API账户并且账户需要有GPT-4的API访问权限。请注意GPT-3.5-turbo不被支持因为它在复杂代码生成和上下文理解上的能力不足以完成本项目的任务。访问 OpenAI平台 登录后创建一个新的API密钥。在项目根目录下找到backend/main文件夹这里有一个.env.example文件。复制它并重命名为.env。cd backend/main cp .env.example .env用文本编辑器打开新创建的.env文件找到OPENAI_SECRET_KEY这一行将你的API密钥填入引号内。OPENAI_SECRET_KEYsk-your-actual-api-key-here重要安全提示永远不要将包含真实API密钥的.env文件提交到Git仓库.env文件已被包含在项目的.gitignore中但请务必再次确认。3.3 首次运行与示例验证配置完成后我们可以启动服务看看项目自带的示例是如何工作的。# 确保在项目根目录react-agent/下执行 # 1. 启动后端服务组件生成引擎 # 这个命令会启动一个Node.js进程监听文件变化或执行生成脚本 yarn backend:dev # 2. 打开一个新的终端窗口同样在项目根目录下启动前端开发服务器 yarn frontend:dev前端服务启动后通常会告诉你应用运行在http://localhost:3000端口可能不同请以终端输出为准。用浏览器打开这个地址。此时你看到的可能是一个空白页面或者基础框架。这是因为前端应用需要指向你“生成”的组件。项目提供了一个示例组件路径。你需要打开文件frontend/main/src/GenReactApp.tsx。在这个文件中你会找到类似以下的导入和渲染代码// 示例导入生成的组件 import GeneratedComponent from ‘./react-agent/example-component/index’; function GenReactApp() { return ( div className“p-8” h1生成的组件演示/h1 {/* 在这里渲染你的生成组件 */} GeneratedComponent / /div ); }默认情况下它可能引用了一个示例路径。yarn backend:dev命令在首次运行时可能会根据项目内置的示例用户故事生成一些组件代码。你可以检查frontend/main/src/react-agent/目录下是否有新生成的文件夹和文件。如果目录是空的别担心我们下一步就来学习如何生成自己的第一个组件。4. 核心工作流实战生成你的第一个组件现在让我们来真正驱动ReactAgent为你描述的一个功能生成组件代码。整个过程就像是在给一位资深开发者布置任务。4.1 编写一份合格的用户故事User Story生成质量的好坏一半取决于你的“需求文档”——也就是user-story.md。一份模糊的指令只会得到模糊的代码。你需要尽可能详细、结构化地描述。创建组件目录在frontend/main/src/react-agent/目录下这是默认的LOCAL_COMPONENTS_DIR为你想要的功能创建一个新文件夹例如user-profile-card。mkdir -p frontend/main/src/react-agent/user-profile-card cd frontend/main/src/react-agent/user-profile-card编写用户故事在该文件夹内创建一个user-story.md文件并用编辑器打开。下面是一个详细的示例# 用户资料卡片组件 **角色**登录用户 **目标**在一个卡片中查看和编辑自己的基本资料信息 **场景**用户进入“我的账户”页面页面中央展示一个资料卡片。 ## 功能需求 1. **头像区域** - 显示用户当前头像圆形。 - 头像上方有一个悬浮的“更换”图标按钮点击后可以触发文件选择器上传新头像。 - 支持上传JPG/PNG格式图片大小不超过2MB。 - 上传后卡片内应实时预览新头像。 2. **基本信息区域** - 显示用户昵称大号字体加粗。 - 显示用户邮箱地址较小字体灰色。 - 昵称旁边有一个“编辑”图标按钮点击后昵称变为可编辑的输入框并出现“保存”和“取消”按钮。 3. **操作区域** - 卡片底部有一个水平排列的操作栏。 - 包含两个按钮“保存资料”主按钮蓝色和“重置修改”次要按钮灰色边框。 - 只有当头像或昵称被修改后“保存资料”按钮才变为可点击状态。 ## UI/UX 要求 - 整体采用白色卡片设计有轻微的阴影和圆角。 - 内部布局头像在左信息在右操作栏在下。 - 使用项目现有的设计系统Shadcn/ui中的组件如Button Card Avatar Input。 - 状态变化需要有视觉反馈如按钮禁用态、加载态。 ## 验收标准 - [ ] 用户可以上传并预览新头像。 - [ ] 用户可以点击编辑并成功修改昵称。 - [ ] 未修改时“保存资料”按钮为禁用状态。 - [ ] 点击“重置修改”可以撤销所有未保存的更改。写得越像产品需求文档GPT-4理解得就越到位。注意我们明确提到了要使用现有的Shadcn/ui组件这能引导Agent去复用代码库中的优质组件。4.2 配置并启动组件生成有了用户故事接下来需要告诉ReactAgent去处理它。修改生成配置打开后端的主要生成脚本文件backend/main/react-agent/generateComponents.ts。找到类似CONTAINER_PATH的配置项可能在文件顶部或作为函数参数。将其值修改为你刚刚创建的文件夹名称。// 在 generateComponents.ts 中 const CONTAINER_PATH ‘user-profile-card’; // 修改为你的文件夹名这个配置告诉Agent去哪里寻找user-story.md文件以及将生成的代码输出到何处。运行生成脚本确保你的yarn backend:dev进程正在运行。这个进程通常配置为监听文件变化或可以通过特定命令触发。根据项目设置你可能需要直接运行一个生成命令或者在修改generateComponents.ts后保存dev服务会自动触发。 查看backend/package.json中的脚本通常会有如yarn generate这样的命令。你可以尝试运行# 在 backend/main 目录下 yarn generate或者如果backend:dev是热重载模式它可能已经在监听了。观察运行backend:dev的终端窗口你会看到一系列日志输出显示Agent正在读取故事、调用OpenAI API、生成JSON骨架、最后编写组件文件。4.3 审查与集成生成的代码生成过程结束后回到你的组件目录frontend/main/src/react-agent/user-profile-card。你应该会看到类似如下的文件结构user-profile-card/ ├── user-story.md ├── skeleton.json # 第一阶段生成的需求结构文件 ├── index.ts # 导出文件 └── UserProfileCard.tsx # 第二阶段生成的主组件文件 └── (可能还有子组件如 AvatarUploader.tsx, EditableName.tsx)现在进行至关重要的一步代码审查。检查skeleton.json打开这个文件看GPT-4是否准确理解了你的需求结构。组件层级划分是否合理有没有遗漏关键元素如果发现明显偏差你可以手动修改这个JSON文件然后重新运行生成过程有时只运行第二阶段即可。审查.tsx文件打开生成的主组件文件。检查以下方面类型安全Props接口定义是否完整逻辑正确性状态useState和事件处理程序onClick, onChange是否合理例如文件上传的handleFileChange函数是否正确使用了FileReader组件引用它是否正确导入了/components/ui/button等Shadcn/ui组件路径可能需要根据你的项目别名配置进行调整。样式Tailwind CSS类名是否基本符合预期布局是否正常集成到前端应用参照GenReactApp.tsx中的示例导入你新生成的组件并渲染它。// 在 GenReactApp.tsx 中 import UserProfileCard from ‘./react-agent/user-profile-card’; // ... 在渲染函数中使用 UserProfileCard /启动前端并测试确保yarn frontend:dev正在运行刷新浏览器页面。你的组件应该已经显示出来了。尝试与它交互点击编辑按钮、上传图片等。观察功能是否按预期工作控制台是否有错误。5. 高级定制与项目配置详解当你熟悉基础流程后可以通过修改项目配置来让ReactAgent更贴合你的实际项目。5.1 自定义目录结构ReactAgent的核心行为由环境变量控制。让我们仔细看看backend/main/.env.example文件# 你的基础UI组件库位置例如Shadcn/ui组件 UI_COMPONENTS_DIRfrontend/main/src/components/ui # 你的组件演示/示例文件位置 DEMO_COMPONENTS_DIRfrontend/main/src/components/demo # 生成的组件存放位置 LOCAL_COMPONENTS_DIRfrontend/main/src/react-agent # OpenAI配置 OPENAI_SECRET_KEYyour_key_here OPENAI_MODELgpt-4-turbo-preview # 或 gpt-4UI_COMPONENTS_DIR这是Agent的“零件库”。它会读取这个目录下的所有组件学习它们的Props接口和用途。如果你有自己的组件库或者想引入其他第三方库如Mantine、Ant Design可以将它们安装并链接到这个目录或直接修改此路径指向你的组件源。Agent在生成代码时会尝试从这里导入。DEMO_COMPONENTS_DIR这里存放的演示代码可以帮助Agent更好地理解这些组件在上下文中是如何被使用的。提供丰富的Demo能提升生成代码的准确性。LOCAL_COMPONENTS_DIR所有由ReactAgent生成的组件都会放在这个目录下便于集中管理。你可以根据喜好修改它。修改这些路径后需要重启yarn backend:dev服务使配置生效。5.2 控制生成流程与步骤generateComponents.ts文件是生成过程的总控制器。你可以在这里定制工作流分步执行默认可能是全流程运行。你可以修改代码将其拆分为独立的函数例如generateSkeleton(),generateComponentsFromSkeleton()然后分别调用。这对于调试和人工干预中间结果非常有用。官方也建议“分步运行并审查”尤其是在生成复杂组件时。调整提示词虽然核心提示词可能被封装在更深层的模块中但你可以搜索systemPrompt、userPrompt等关键词。修改这些提示词可以影响GPT-4的“思考方式”。例如你可以强化“优先使用Headless UI组件”、“遵循特定的TypeScript命名规范”等要求。注意修改提示词是一项高级操作需要对GPT-4的提示工程有一定了解。模型参数你可以在调用OpenAI API的地方调整参数如temperature创造性值越低越确定、max_tokens生成的最大长度。降低temperature例如设为0.2可以使生成的代码更稳定、更少“天马行空”。5.3 集成到现有项目你并不一定要在ReactAgent的示例项目里使用它。你可以将其“后端”即backend/main下的生成逻辑作为一个独立的服务或脚本集成到你自己的大型React项目中。复制核心逻辑将backend/main/react-agent这个目录下的核心代码生成器、工具函数复制到你项目的某个工具目录下。调整路径配置修改环境变量和文件路径使其指向你实际项目的components/ui和src目录。建立触发机制可以创建一个简单的CLI命令或一个VS Code任务来运行这个生成脚本。这样你就能在任意React项目中通过编写用户故事来快速生成组件原型了。6. 常见问题、故障排查与经验心得在实际使用中你几乎一定会遇到各种问题。下面是我总结的一些典型情况及其解决方法。6.1 生成结果不理想或出现错误这是最常见的问题原因和解决方案多种多样问题现象可能原因排查与解决步骤生成的组件无法导入/编译1. 导入路径错误。2. 依赖的UI组件未安装。3. TypeScript类型错误。1. 检查生成文件中的import语句确保路径相对于你的项目根目录或配置的别名如/是正确的。2. 确认UI_COMPONENTS_DIR指向的组件库如Shadcn/ui已正确安装。运行yarn add radix-ui/react-avatar radix-ui/react-dialog等命令安装缺失的Radix原始包。3. 查看终端或IDE中的TypeScript错误提示通常是Props类型不匹配。可能需要手动调整生成的接口定义。组件布局/样式混乱1. Tailwind类名组合不当。2. 缺少必要的容器或布局组件。1. 直接修改生成组件中的className。AI对布局的理解有时会出错手动调整flex、grid、padding、margin等工具类是常态。2. 检查是否漏掉了Card、div className“container”等容器。可以在用户故事中更明确地指定布局结构。交互逻辑缺失或错误1. 用户故事描述不够精确。2. GPT-4未能理解复杂状态关系。1.这是根本原因。回头优化你的user-story.md用更清晰、分步骤的语言描述交互。例如明确写出“点击编辑按钮后昵称文本变为一个输入框同时编辑按钮变为保存和取消按钮”。2. 手动补全状态逻辑。生成代码是一个起点复杂的状态管理如Formik、React Hook Form集成或API调用通常需要开发者自己实现。调用OpenAI API失败1. API密钥错误或未设置。2. 账户余额不足或未开通GPT-4权限。3. 网络问题。1. 确认.env文件中的OPENAI_SECRET_KEY正确无误且没有多余空格。2. 登录OpenAI平台检查API使用情况和权限。务必注意GPT-4 API调用费用较高请设置使用限额。3. 查看backend:dev终端的错误日志如果是网络超时可以尝试重试或调整API的超时设置。6.2 成本控制与性能优化使用GPT-4生成代码是需要成本的。每个用户故事可能会消耗数千甚至上万个tokens取决于故事的复杂度和生成的代码量。设置预算和监控强烈建议在OpenAI平台上设置每月使用额度Usage Limits。你可以在“Billing” - “Usage limits”中设置硬性上限防止意外产生高额费用。优化用户故事冗长、模糊的故事会导致GPT-4生成更长的思考过程和代码增加token消耗。在保证清晰的前提下尽量精简描述。利用缓存ReactAgent项目本身可能没有内置缓存。你可以考虑自行实现一个简单的缓存层对相同的用户故事MD5哈希值缓存其skeleton.json或最终代码避免重复调用API。对于团队使用这能显著降低成本。分步生成与人工审核不要指望一键生成完美页面。采用“生成-审查-修改-再生成”的迭代循环。先生成一个简单的骨架审核并手动修正skeleton.json然后再生成完整代码。这样比一次性生成一个充满错误的大文件再修改效率更高成本也更低。6.3 我的实操心得与局限性认知经过一段时间的试用我对ReactAgent的定位和能力边界有了更清晰的认识它是一个强大的“高级原型草图工具”不要期望它直接输出生产代码。它的最大价值在于能在几分钟内将一个想法转化为一个可运行、可交互的视觉原型。这在进行早期UI验证、向非技术人员演示想法时效率提升是巨大的。严重依赖“高质量输入”Garbage in, garbage out垃圾进垃圾出的原则在这里完全适用。你花费在雕琢user-story.md上的时间会直接体现在生成代码的质量上。学会用结构化、无歧义的语言与AI协作是一项新技能。需要前端知识进行“精加工”生成的代码需要一名有经验的React开发者进行审查、调试和优化。你需要处理类型错误、调整样式细节、完善边界情况如加载状态、错误处理、集成真实的数据流和API。AI完成了80%的“体力活”但剩下的20%的“精细活”和“设计决策”仍然需要人来完成。对现有项目有侵入性它生成的代码风格、目录结构、依赖引用需要与你现有项目匹配。直接集成可能需要进行一些适配工作。更适合在绿色项目或独立模块中使用。未来可期但现在仍是辅助角色ReactAgent展示了AI辅助开发的巨大潜力。随着模型能力的进化如GPT-4o、Claude 3和工具链的成熟它的准确性和实用性会越来越高。但目前它是我工具箱里一个非常酷的、用于快速脑暴和原型设计的“副驾驶”而非替代我的“自动驾驶”。最后再次提醒务必关注OpenAI API的使用成本从小任务开始尝试逐步熟悉它的工作模式。这个项目是一个迷人的实验它让我们得以一窥未来人机协同编程的样貌。

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…