首页 > 其他分享 >Code Review、InLineChat、RAG能力全部独家提供,这波上新CodeGeeX平替Github Copilot稳了!

Code Review、InLineChat、RAG能力全部独家提供,这波上新CodeGeeX平替Github Copilot稳了!

时间:2024-01-18 12:12:04浏览次数:31  
标签:RAG 插件 Code CodeGeeX 代码 智能 问答 模型

智谱 AI 2024年度的技术开放日上,CodeGeeX重磅发布第三代模型。针对CodeGeeX插件产品的系列新功能,也同时上线发布,提供给用户免费使用。

file

一、第三代模型性能全面提升

CodeGeeX第三代模型正式发布,基础能力全面提升。
file

针对Python、Java、JavaScript、C++、Golang五种主流编程语言,代码生成准确率提升200%。
file

二、自定义系统指令

CodeGeeX 3代模型中,用户可以根据不同开发场景和习惯,自定义系统指令。这种方式在不用模型微调的情况下,代码注释匹配度提升20%、代码修复准确率提升20%、单元测试通过率提升40%,使同一模型在不同使用场景下的泛化能力大幅提升。
file

三、RAG检索增强

CodeGeeX 3代模型引入RAG算法,构建流行公有仓库和私有仓库的代码向量数据库,缓解代码生成模型幻觉性问题。包括:避免生成错误的私有函数调用、让模型拥有最新的代码仓库知识、对私有代码仓库建立知识库等。
file

基于CodeGeeX第三代模型能力的全面提升,插件产品推出多项全新功能。
file

一、新模型加持的代码补全和智能问答

在VSCode的CodeGeeX插件中,打开设置项,可以针对代码补全的模型,选择Pro版或Lite版的模型。Lite版的响应速度更快,Pro版则在代码补全的准确性上,有大幅提升。
file

智能问答的提问框中,也可以选择使用Pro版或者Lite版的模型。智能问答中的Pro版模型,支持16K的上下文。如果需要对较长的代码文件进行问答或者修复bug,则可以选择Pro版模型。如果对话的轮次非常多,也可以选择支持更长上下文的Pro版模型。
file

不同需求选择不同模型,智能问答的效果更符合预期。

二、开源代码库智能问答

针对开源代码仓库的智能问答,使用了 RAG 检索增强生成的技术。对新增的代码仓库,私有的代码仓库,以及原代码仓库的新增项,不用通过模型微调,通过RAG被检索到,并在生成中进行增强,大幅减轻生成内容的幻觉性。
file

利用@repo 的代码仓库智能问答,针对代码片段的生成也更准确,因为模型针对代码仓库进行检索,增强了生成能力。同时也会根据返回的代码索引,找到代码出处进行验证,实现更精准的代码生成。
file

如果用户在使用插件的过程中,发现某一个希望使用的代码库未被收录,则可以在插件中直接“点击提交”。
file

三、交互式编程 InLine Chat

InLine Chat是一种通过在代码中嵌入对话,与智能编程助手CodeGeeX进行交互的方式,你可以使用“ Command + I(mac)”或者“ Ctrl+Alt+I(Windows)”的快捷键触发InLine Chat功能。例如,在代码上下文中提出问题,根据你的描述生成代码,或者直接为代码添加注释等,各种你希望和智能编程助手交流的内容,并获得助手的回应。
file

这样使用后:
file

这使得在编写代码时能够获取实时的建议、解释或代码片段。通过上下文相关的交互,更好地提高编程效率和准确性。目前这个功能需要VSCode版本为1.73v以上,才可以正常使用。

四、代码审查 Code Review

代码审查Code Review功能,可以帮助用户自动检测潜在的代码问题、风格是否统一、以及潜在的代码性能问题等,减轻人工代码审查的负担。

在使用Code Review功能时,用户可以从源代码文件中,选择任意被修改的文件,然后使用CodeGeeX的代码变更审查,可以直观看出代码修改的部分。也可以看到智能编程助手给代码的优化建议。
file

file

file

五、预测推荐候选问题

在智能问答Ask CodeGeeX中,当用户提出一个问题获得回复后,会继续生成接下来的候选问题。这些推荐给用户的候选问题,是和用户提出的问题相关性很强或者更进一步的问题预测。
file

通过大模型预测用户接下来的候选问题,不仅能够提高内容生成的质量,还可以帮助用户用更准确的提出问题。CodeGeeX新一代模型及多项全新功能同时上新,希望能够为所有开发者提供更强大,更智能的编程体验。

以上所有最新功能已经在VSCode上CodeGeeX插件最新的v2.3.1版本中发布,JetBrains IDEs全家桶的全新版本插件即将发布,敬请期待!

本文由博客一文多发平台 OpenWrite 发布!

标签:RAG,插件,Code,CodeGeeX,代码,智能,问答,模型
From: https://www.cnblogs.com/chattech/p/17972237

相关文章

  • uni.setStorageSync在登录页面设置缓存,第一次进入首页在onload里面获取不到缓存数据的
    在onLoad里面获取不到缓存:onLoad(option){consttoken=uni.getStorageSync('token');if(!token){uni.showToast({title:"请先登录",icon:"error",......
  • 智能开发助手——华为云CodeArts Snap,揭开智能研发新篇章
    AIGC浪潮席卷全球,大模型技术应用到软件开发领域,正在颠覆传统的软件工程。华为云CodeArtsSnap是一款基于大模型技术打造的智能开发助手,旨在提高开发人员的生产力和代码质量,为开发者带来全新的编程方式和体验。▶华为云智能开发助手CodeArtsSnap,源于华为自身的研发实践华为拥有千亿......
  • 记录 | vscode json美化插件JSON Tools
    安装插件JSONTools原来的json的样子:JSONTools美化/格式化快捷键Ctrl+Alt+M(windows)/Command+Option+M(Mac),然后效果如下:......
  • 记录 | conda报错:conda json.decoder.JSONDecodeError: Expecting value: line 1 colu
    condacreate的时候报错:condajson.decoder.JSONDecodeError:Expectingvalue:line1column1(char0)解决办法:condaclean-i......
  • CodeForces 986F Oppa Funcan Style Remastered
    洛谷传送门CF传送门有意思的。对\(k\)分解质因数,题目实际上是想让我们解一个\(\sum\limits_{i=1}^ma_ix_i=n\)的方程。考虑\(m=1\)特判,\(m=2\)exgcd。\(m=3\)时发现\(\min\limits_{i=1}^ma_i\lek^{\frac{1}{3}}\le10^5\),所以可以跑同余最短路。......
  • AtCoder ABC 270 复盘
    A1-2-4TestACCodeBHammerACCodeCSimplepathACCodeDStones完全背包的应用。ACCodeEAppleBasketsonCircle有一点数学,又有一点贪心,还有二分。首先将每个篮子取走\(\min_{1\leqi\leqn}(A_i)\)个苹果,然后再不断扫描数组,按照题意取走苹果。ACCode......
  • 国产最强的 AI 代码生成插件:CodeGeeX
    国产最强的AI代码生成插件:CodeGeeX学习改变命运,技术铸就辉煌。大家好,我是銘,AI已经火了一年多了,国内很多公司也都开始开发了很多AI工具。今天我们就来聊一聊国产的AI代码生成工具CodeGeex。官方介绍首先,我们来看一下官方对它的介绍CodeGeeX是一款基于大模型的智......
  • CodeForces 814E An unavoidable detour for home
    洛谷传送门CF传送门考虑给图分层,一层的点一一对应上一层的一些点。设\(f_{i,j}\)为考虑了前\(i\)个点,最后一层有\(j\)个点,除了最后一层点的其他点度数限制已经满足的方案数。转移系数是\(g_{i,j,k}\)表示这一层有\(i\)个点,上一层有\(j\)个\(2\)度点,\(k\)个......
  • AtCoder ABC 267 复盘
    ASaturdayACCodeBSplit?ACCodeCIndex×A(Continuousver.)本题可以采用类似滑动窗口的做法,使得时间复杂度降至\(O(n+m)\)。ACCodeDIndex×A(NotContinuousver.)本题是典型的01背包问题,只需要对值进行相应的修改即可。ACCodeEErasingVertices2本题......
  • AtCoder Beginner Contest 336
    题目链接:AtCoderBeginnerContest336A-LongLoong题意:输出Long,其中'o'的数量等于n解题思路:签到(其实没看清楚题目wa了一发)查看代码voidsolve(){ intn; cin>>n; cout<<'L'; while(n--)cout<<'o'; cout<<"ng";}......