AI辅助编程里的 Atom Group 的概念和使用

2024-09-08 11:52

本文主要是介绍AI辅助编程里的 Atom Group 的概念和使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

在我们实际的开发当中,一个需求往往会涉及到多个文件修改,而需求也往往有相似性。

举个例子,我经常需要在 auto-coder中需要添加命令行参数,通常是这样的:

/coding 添加一个新的命令行参数 --chat_model 默认值为空

实际上这个需求涉及到以下文件列表:

  • /Users/allwefantasy/projects/auto-coder/src/autocoder/auto_coder.py

  • /Users/allwefantasy/projects/auto-coder/src/autocoder/command_args.py

  • /Users/allwefantasy/projects/auto-coder/src/autocoder/lang.py

  • /Users/allwefantasy/projects/auto-coder/src/autocoder/common/__init__.py

每个文件都需要修改,大概修改流程是:

  1. 修改command_args.py 添加,更新,删除命令行参数。

  2. common/__init__.py 中的AutoCoderArgs 有对应的字段,也需要修改

  3. lang.py 中则对参数有相应的描述说明

  4. 如果是添加了类似 <xxxx>_model 的参数,那么需要在 auto_coder.py 中 用setup_sub_client 添加到主llm 中.

如果让auto-coder.chat 自己根据需求寻找文件,有可能会找不全,导致修改不完整,所以一般还是需要手动使用

/add_files xxxx

来进行上下文的添加。这样就比较繁琐了。此外,就算文件添加全了,大模型也不会一定每次都能改全,而用户倾向于这样写:

/coding 添加一个新的命令行参数 --chat_model 默认值为空

而不是:

/coding 添加一个新的命令行参数 --chat_model 默认值为空。具体修改逻辑为:
1.修改command_args.py 添加,更新,删除命令行参数。
common/__init__.py 中的AutoCoderArgs 有对应的字段,也需要修改
lang.py 中则对参数有相应的描述说明
如果是添加了类似 <xxxx>_model 的参数,那么需要在 auto_coder.py中 用setup_sub_client 添加到主llm 中.

实际上,在一个已经成熟的项目里,我们往往都是在做加法,或者一些有固定套路的`修改`。每个加法或者修改,都会作用在相对来说一组固定的文件。

这是一个极为有用的特性。

Atom Group

Atom Group 相当于帮助用户把一组文件以及对应的一组需求创建一个任务,用户提供这组文件以及为了满足这一组需求需要的任务拆解。

以前面为例子,你手动添加完文件后,可以这么做:

/add_files /group /add params

这样我们添加了一个 Atom Task,叫  params. 然后我们把修改逻辑也加到这个组里去:

/add_files /group /set params

6142a0d44c5b52afd4b222ac6144588c.png

在最后一行通过输入 /eof 结束内容编辑。

你可以通过 /add_files /group 查看所有已有 Atom Group:

df955fbb4909e0de31db9fdfe3b695ff.png

通过  /add_files /group params 进行激活:

0dc01526baf1f30e5287f06e0baca15c.png

现在,你就可以简单的这么说:

/coding 添加一个新的命令行参数 --ask_model 默认值为空

这个时候auto-coder.chat 就可以精准并且稳定性很高的实现对需求的修改。

下面是执行后的结果:系统会告诉你这次修改了几个文件,每个文件的diff 视角,当然实际上有个缩进问题,从diff 里还是很容易看出来的,可以手动修改下。

adbaf15587a5cd1a7880015f76fcbdc5.png

1f0b51cf316f4de37c187706ea5acc69.png

模型一次修改了四个文件的四块代码,完成“添加参数的需求”。你观察到了 缩进的问题,以及没有发现同步修改中文说明,你可以通过完善前面的 Atom Group 说明来完成。

总结

把对项目的常见更改 映射成 Atom Group, 从而帮助模型可以高效而稳定的实现新增需求,这样才能更加容易实现自动化,减少人工干预。

甚至对于比较稳定的这种 Atom Group,我们可以开放给产品经理,让产品经理也可以在可控的范围内使用指定的 Atom Group 完成一些自助项目修改或者迭代。

更多介绍,点击阅读原文。

额外注意点和小功能

实际上我们使用的Atom Group 永远都是一个 当前 组。当我们做 Atom Group 切换,本质上是清空当前组

Active 文件,然后拷贝对应组的文件进来。

比如执行:

/add_files /group params

然后接着你添加新的文件,只会影响 当前组 而不会影响 param 组。如果你希望影响,可以先:

/add_files /group /drop params
/add_files /group /add params

上面的语句表示 删除 params 组,然后新建一个组,然后将 当前组 拷贝到 params 组。

你也可以将多个组的文件同时加到当前组里,注意,加入之前会先清空再拷贝:

/add_files /group <group-1>,</group-2>

如果不想 Atom Group 影响编程行为,可以这样做:

/add_files /group /reset

会清理掉

这篇关于AI辅助编程里的 Atom Group 的概念和使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1148036

相关文章

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加