发布时间:2026/6/15 22:50:03
冷扑大师AI如何用CFR算法在不完全信息博弈中战胜人类
1. 项目概述当AI坐上牌桌几年前当DeepMind的AlphaGo在围棋棋盘上击败李世石时很多人认为这已经是人工智能在博弈领域的巅峰。毕竟围棋的复杂度和信息完备性让AI的计算优势得以淋漓尽致地发挥。但德州扑克尤其是无限注德州扑克完全是另一回事。它不是一个信息透明的棋盘游戏而是一个充满了隐藏信息、欺诈和心理博弈的战场。在这里你不仅要计算概率更要读懂对手甚至要主动“说谎”——也就是我们常说的“诈唬”。所以当卡内基梅隆大学的研究团队宣布他们的AI“冷扑大师”Libratus要在宾夕法尼亚州匹兹堡的Rivers赌场与四位顶尖职业牌手进行为期20天、共计12万手的“人机扑克大战”时整个扑克界和AI界都屏住了呼吸。这不仅仅是技术的较量更是对“智能”本质的一次拷问一台没有情感、不会紧张的机器能否掌握人类最古老的欺骗艺术最终Libratus以压倒性的优势获胜累计赢得了超过170万美元的筹码虚拟货币。这背后远非简单的“算力碾压”而是一套精妙绝伦的算法哲学和工程实践。这篇文章我将从一个技术实践者和扑克爱好者的双重角度为你深度拆解Libratus是如何“学会”诈唬并最终在信息不完全的博弈中战胜人类的。我们会深入到它的核心算法、训练策略以及那些让职业牌手都感到“毛骨悚然”的战术细节。无论你是对AI技术感兴趣还是想提升自己的扑克策略相信都能从中获得启发。2. 核心挑战不完全信息博弈的“圣杯”在深入Libratus的细节之前我们必须理解它要解决的根本问题是什么。无限注德州扑克被公认为“不完全信息博弈”的典型代表其难度远超象棋、围棋等完全信息游戏。2.1 信息不对称扑克的核心魅力与难点在一局德州扑克中每个玩家只能看到自己的两张底牌公共牌是逐步发出的。这意味着在任何一个决策点你对于对手可能持有的牌型即游戏状态只有部分信息。这种信息不对称带来了几个核心挑战状态空间巨大且不可遍历由于隐藏信息的存在游戏的实际状态即所有玩家底牌的组合是天文数字。即使使用最强大的超级计算机也无法像国际象棋那样穷举所有可能的走法。需要推理与反推理你不仅要根据自己手中的牌和公共牌计算胜率更要推测对手可能持有什么牌范围同时还要考虑对手对你持牌范围的推测。这是一个多层嵌套的推理循环。策略必须混合且不可预测在完全信息游戏中存在一个理论上的“最优解”如象棋的某个残局走法。但在扑克中如果你的策略是固定的、可预测的对手很快就能找到漏洞并剥削你。因此最优策略必须是“混合策略”——即以一定的随机概率在不同的行动如加注、跟注、弃牌之间选择让对手无法猜透。2.2 纳什均衡在不完全信息中的“不输”策略Libratus的目标不是找到“必胜法”这在扑克中不存在而是逼近这个游戏的“纳什均衡”。在博弈论中纳什均衡指的是这样一种策略组合当所有参与者都采用这个策略时没有人可以通过单方面改变自己的策略而获得更多收益。在两人零和博弈如单挑德州扑克中达到纳什均衡的策略被称为“游戏理论最优”策略。这意味着无论对手如何调整你都能保证不输或至少不输超过某个极小的理论值。Libratus的核心就是通过算法来近似计算这个庞大游戏的纳什均衡策略。注意GTOGame Theory Optimal策略在扑克社区被广泛讨论但它不是“赢最多”的策略而是“不被剥削”的策略。在面对非最优的对手时偏离GTO进行针对性剥削Exploitative Play往往能赢更多。但Libratus首先追求的是GTO的稳健性。3. 算法核心蒙特卡洛反事实遗憾最小化Libratus的“大脑”基于一个名为反事实遗憾最小化的算法框架并结合了蒙特卡洛方法进行大规模采样。这套组合拳是它能处理如此庞大状态空间的关键。3.1 CFR从“后悔”中学习反事实遗憾最小化是一种迭代算法其核心思想非常直观让AI在自我对弈中通过计算“反事实遗憾值”来评估每个决策的好坏并逐步调整策略以减少“遗憾”。我们来打个比方假设在某个特定局面下你有三个选择加注、跟注、弃牌。CFR算法会让AI作为一个虚拟玩家尝试所有这些选择。模拟对局AI会进行大量虚拟手牌的对局在每一个决策点它根据当前策略一个概率分布随机选择一个行动。计算反事实值一手牌结束后算法会进行“反事实思考”“如果我在那个关键决策点固定选择行动A比如加注而其他所有决策都按实际策略进行这手牌的最终收益会是多少”这个收益就是选择A的“反事实值”。计算遗憾值将选择A的反事实值与所有可能行动的平均反事实值进行比较。如果A的反事实值高于平均值说明当初没有更多选择A是一种“遗憾”如果低于平均值则选择A本身带来了“遗憾”。这个差值就是“即时遗憾值”。更新策略算法会累积所有迭代中的遗憾值。在下一轮迭代中选择某个行动的概率会与其正遗憾值如果是负数则视为0成正比。也就是说那些被证明能带来更好结果的行动在未来被选中的概率会越来越高。经过数十亿次的迭代策略会收敛到一个接近纳什均衡的点此时对于任何一个决策点任何一个行动的“累积遗憾值”都趋近于零——这意味着你已经没有更好的单方面改进了。3.2 蒙特卡洛采样应对天文数字的状态纯CFR需要遍历游戏树这在德州扑克中是不可能的。Libratus引入了蒙特卡洛CFR。它不再尝试分析每一个可能的后续状态而是在每个决策点只随机采样少量甚至一个可能的后续发展路径进行深入计算。这就像天气预报。要精确计算地球上每一点未来的状态是不可能的但我们可以运行多个基于当前数据的随机模拟蒙特卡洛模拟然后统计这些模拟结果比如有70%的模拟显示会下雨从而得到一个概率性的预测。MCCFR同理它通过海量的随机采样来近似完整的游戏树分析极大地降低了计算量。实操心得MCCFR的成功极度依赖于采样策略的质量。均匀随机采样效率很低。Libratus团队采用了外部采样等方式优先采样那些更可能发生的、或对策略影响更大的分支这好比是天气预报中对台风路径的模拟次数远多于对微风区域的模拟用有限的算力抓住了主要矛盾。4. 工程架构分层抽象与实时计算仅有先进的算法还不够如何将其工程化应用到每一手具体的牌局中是另一个巨大挑战。Libratus的架构体现了精妙的“分而治之”思想。4.1 博弈树抽象将无限变为有限德州扑克的下注额是连续的无限注这意味着理论上你有无数种加注数额的选择。Libratus通过“抽象化”来解决这个问题。行动抽象它将连续的下注空间离散化为几个关键的行动选择。例如在翻牌前可能抽象为弃牌、跟注、加注到2倍底池、加注到全下等几个选项。这大大减少了决策分支。牌面抽象它还将可能的底牌和公共牌进行“聚类”。例如一手“A♥K♥”和一手“A♦K♦”在大多数情况下战略价值是相似的可以被归为同一类“同花AK”。通过将1326种底牌组合聚类成几百个“牌组”又将海量的公共牌面聚类成 manageable 的组别状态空间被进一步压缩。关键细节抽象是一把双刃剑。抽象得太粗糙策略会不精确抽象得太精细计算量又无法承受。Libratus的创新在于使用了非对称抽象。它在计算自己的策略时使用相对精细的抽象而在为对手建模时使用更粗糙的抽象。因为精确预测对手的每一个细节既不可能也无必要只需把握其大致策略倾向即可。4.2 三阶段策略系统Libratus的策略生成并非一蹴而就而是分为三个层次离线和在线相结合阶段名称计算时机作用类比第一阶段蓝图策略赛前离线计算生成整个游戏的“粗粒度”GTO策略基础。它基于高度抽象的游戏树运行MCCFR数十亿次迭代耗时数月。军事战略地图标明了主要地形和进攻方向。第二阶段残局求解牌局进行中实时计算当牌局进行到河牌圈最后一轮公共牌或全下等关键节点时Libratus会暂停思考调用更强大的服务器基于当前精确的底池和筹码量重新求解一个精细得多的子游戏。战役打响后针对当前战场的精确战术推演。第三阶段自我改进每日赛后离线计算每天比赛结束后Libratus会分析当天对手的实际行动找出自己蓝图策略中与对手行为偏差最大的局面在夜间专门为这些局面进行加强训练。根据敌人今天的战术连夜调整明天的作战计划。这个三阶段系统是Libratus获胜的核心工程秘诀。蓝图策略提供了全局视角和速度残局求解保证了关键时刻的精确性而自我改进则让它具备了针对特定对手的进化能力。职业牌手Jason Les赛后感叹“它每天都在变强。我们找到的漏洞第二天就消失了。”5. 诈唬的艺术AI如何“学会”欺骗这是最令人着迷的部分。一个没有情绪、不懂“心理”的AI是如何实施诈唬的其本质是数学上的必然。5.1 诈唬的本质平衡你的范围在GTO理论中诈唬不是随机的欺骗而是为了达到“范围平衡”的必要手段。所谓范围就是你在某个特定局面下可能持有的所有牌型的集合。价值下注你用强牌如顺子、同花下注是为了从对手更弱的牌那里赢得筹码。诈唬下注你用弱牌下注是为了迫使对手放弃那些虽然比你强但并非坚不可摧的牌如中等对子。GTO策略要求你在某一个下注尺度上价值下注的牌和诈唬下注的牌必须保持一个合理的比例。这个比例由底池赔率和下注尺度决定。例如如果你下注半个底池那么你的下注范围里大约应该有2/3的价值牌和1/3的诈唬牌。这样对手无论用跟注还是加注来应对都无法占便宜。Libratus通过CFR算法自然地在它的策略中形成了这种平衡。在它“眼中”一手完全没希望的垃圾牌在某个特定公共牌面和行动历史下被赋予一定的“诈唬频率”这不是因为它想骗人而是因为数学计算表明加入这手牌作为诈唬能使整个策略更接近纳什均衡从而无法被对手剥削。5.2 AI诈唬的“非人类”特征职业牌手在与Libratus对战后总结了其诈唬的一些令人不适的特点绝对随机无法读取人类的诈唬总有蛛丝马迹——时间拖延、下注尺度微小变化、之前的行动模式等。Libratus的诈唬是严格按概率执行的。当它决定用某手牌在某个点有10%的诈唬频率时这就像抛一枚不均匀的硬币正面10%反面90%结果完全随机没有任何“马脚”。尺度多变难以捉摸人类诈唬通常会选择一个“看起来像价值下注”的尺度。Libratus则不然它会使用从最小到全下之间各种尺度的下注来诈唬。这种极端的多变性让对手根本无法通过下注量来反向推断牌力。“无利可图”的诈唬人类诈唬通常选择那些有少许“赢率提升”的牌比如听牌即使被跟注也有机会反超。Libratus的CFR算法有时会赋予一些毫无胜算的纯垃圾牌以极低的诈唬频率。从单一手牌看这毫无意义但从整个策略范围平衡来看这是必要的。这让人类对手感到尤其困惑和沮丧。一个经典案例在一次对局中公共牌是K♠7♥2♦3♣8♠牌面非常干燥几乎没有顺子或同花可能。Libratus在河牌圈用一手像2♥3♥这样的绝对垃圾牌只能组成最小的对子进行了超池下注下注量大于底池。从人类视角看这完全疯狂。但AI的“思考”是在我的整个策略中在这个局面下我需要用我范围里最弱的一部分牌去执行诈唬以平衡我用顶对、两对等强牌所做的同样尺度的价值下注。而这手2♥3♥正好落在了那个“最弱诈唬牌”的区间里。6. 实战影响与职业牌手的困境面对这样一个对手四位世界顶级的职业牌手包括两位世界扑克系列赛金手链得主感到了前所未有的压力。6.1 人类策略的失效职业牌手的核心技能之一是“阅读”对手建立对手模型并针对其弱点进行剥削。然而面对Libratus这套方法论几乎失效模型无法建立Libratus的策略在宏观上是近乎完美的GTO在微观上又通过残局求解和自我改进不断修补漏洞。它的行动没有固定的模式人类无法总结出类似“他总是在转牌圈用听牌半诈唬”这样的规律。剥削无从下手要剥削一个对手你需要发现他策略中的“不平衡”之处。例如如果他诈唬太少你就应该更多地弃牌如果他价值下注太少你就应该更多地跟注。但Libratus的策略在各个层面都高度平衡人类牌手找不到一个稳定、可持续的剥削点。任何试图剥削的调整很快就会被Libratus在后续牌局中反制。心理战失效人类牌手之间会利用表情、动作、对话施加压力。但对AI这一切都是徒劳。它不会因为被加注而紧张也不会因为赢了一个大池而得意。情绪波动是人类游戏的组成部分但对AI而言这只是一个不存在的维度。6.2 对人类扑克理论的冲击Libratus的胜利不仅仅是技术的胜利也对扑克理论产生了深远影响证明了GTO的可逼近性它向扑克界证明即使在无限注德州扑克这样复杂的游戏中通过强大的算法和算力是可以非常接近那个理论上的“完美策略”的。凸显了剥削策略的局限性它表明一个足够接近GTO的策略在面对顶级人类专家时依然具有强大的抵抗力。这促使职业牌手更加重视自身策略的平衡性而不仅仅是寻找对手的漏洞。推动了“求解器”的普及赛后基于类似CFR算法的商业扑克求解器如PioSolver, GTO开始流行。现代职业牌手大量使用这些工具来研究游戏树优化自己的策略将扑克训练从“经验主义”推向“数据驱动”的新阶段。7. 超越扑克不完全信息博弈的通用框架Libratus的意义远不止于扑克。它为解决更广泛的不完全信息博弈问题提供了一个强大的框架。7.1 金融交易与谈判金融市场充满了不完全信息你不知道其他交易员的真实头寸和意图商业谈判中双方都在隐藏自己的底牌和底线。MCCFR和实时策略求解的框架可以用于构建更复杂的交易策略模型或自动化谈判代理在动态、充满欺骗的环境中寻找稳健策略。7.2 网络安全与军事策略网络攻防、电子对抗都是典型的不完全信息博弈。攻击方要隐藏自己的真实目标和手段防御方要判断威胁的真假和来源。类似Libratus的算法可以帮助设计更智能、更自适应、更难被预测的防御或探测策略。7.3 产品定价与市场竞争在市场竞争中公司对于竞争对手的成本、产能和战略规划信息是不完全的。定价决策可以建模为一个博弈过程。AI可以帮助模拟多种竞争场景找到即使在最坏情况下也能保证一定利润的“稳健”定价策略这与扑克中追求GTO的思路异曲同工。核心启示Libratus的成功告诉我们在面对复杂、不确定、对手可能欺骗的环境时追求一个“不被剥削”的稳健基础策略往往比追求高风险高回报的投机策略更具长期价值。这不仅是扑克哲学也是许多现实世界决策的智慧。8. 复现与学习的可行路径虽然我们无法完全复现一个需要超级计算资源运行数月的Libratus但理解其原理并应用于小规模问题或自身学习是完全可行的。8.1 对于开发者/研究者从简化游戏开始不要一开始就挑战德州扑克。可以从“石头剪刀布”、“ Kuhn Poker”一种极简的三人扑克或“Leduc Hold‘em”简化版德州扑克开始实现CFR算法。这些游戏状态空间小可以在个人电脑上快速验证算法。理解CFR核心代码CFR算法的核心迭代更新部分代码量并不大。关键是要理解“反事实值”的计算和策略的更新公式。网上有大量关于Kuhn Poker的CFR实现教程这是最好的起点。引入抽象和蒙特卡洛在简化游戏上跑通后可以尝试为Leduc Hold‘em设计简单的牌面抽象如只区分高牌、对子、同花并实现蒙特卡洛采样体验如何通过近似来应对增长的状态空间。使用现有库有像OpenSpielGoogle DeepMind这样的开源博弈框架里面集成了多种博弈环境和算法包括CFR可以用来进行更高级的实验。8.2 对于扑克爱好者/学习者拥抱求解器思维即使不使用软件也要学习GTO的基本概念如范围、平衡、频率、底池赔率等。这能让你从“猜对手有什么牌”的层面提升到“分析双方策略互动”的层面。分析自己的范围在复盘手牌时不要只盯着结果和对手的底牌。问自己在这个位置、这个行动线上我的范围是什么我的这个下注是代表价值多还是诈唬多平衡吗关注频率而非绝对不要总想“我这手牌该不该诈唬”而是想“在我范围里最弱的20%牌中我应该选择哪一部分来进行诈唬”。从单一手牌思维转向范围频率思维是迈向现代扑克理论的关键一步。利用免费/廉价资源许多扑克培训网站和社区都有基于GTO的讨论。YouTube上也有大量用求解器分析经典牌局的视频。通过观看这些分析你可以直观地感受平衡策略在具体牌局中是如何体现的。Libratus的故事是一个算法、算力与人类智慧在复杂博弈中碰撞的经典案例。它剥开了扑克中心理战的神秘外衣揭示了其底层坚实的数学与逻辑内核。对于AI领域它证明了在不完全信息这一更普世的环境下机器智能所能达到的新高度对于扑克玩家它带来了一场彻底的理论革命。最终它留给我们的启示是在充满不确定性和对抗的世界里构建一个坚实、平衡、难以被击垮的底层系统或许是应对复杂性的最有效方式。而这无论是对于打牌还是对于应对人生和事业中的各种挑战都不失为一种深刻的智慧。

相关新闻

别再只用WinForm了!手把手教你用WPF的MVVM模式重构数据大屏UI
2026/6/10 10:43:38

别再只用WinForm了!手把手教你用WPF的MVVM模式重构数据大屏UI

WPF数据大屏重构实战:用MVVM模式打造高维护性监控平台如果你正在维护一个界面逻辑混杂的WPF监控大屏项目,每次修改功能都像在拆解一团乱麻,那么是时候考虑架构升级了。本文将带你用MVVM设计模式重构传统数据大屏,解决三个核心痛点…

阅读更多
1Panel应用商店空白的终极修复:手动添加第三方仓库并解决脚本执行玄学问题
2026/6/11 8:52:16

1Panel应用商店空白的终极修复:手动添加第三方仓库并解决脚本执行玄学问题

1Panel应用商店空白的终极修复:手动添加第三方仓库并解决脚本执行玄学问题 最近在技术社区中,不少用户反馈1Panel面板的应用商店出现空白现象,这给日常运维工作带来了不小的困扰。本文将深入探讨这一问题的根源,并提供一套完整的解…

阅读更多
CUDA并行编程入门实战:用“像素级”思维手写卷积层,理解Block和Thread的分配
2026/6/15 12:06:25

CUDA并行编程入门实战:用“像素级”思维手写卷积层,理解Block和Thread的分配

CUDA并行编程入门实战:用“像素级”思维手写卷积层,理解Block和Thread的分配 当一张28x28的图片遇上5x5的卷积核,传统CPU需要串行计算576次乘加操作,而CUDA可以瞬间启动576个线程并行完成——这就是GPU并行计算的魅力。本文将带您…

阅读更多
从一次LabelImg闪退报错,聊聊Python GUI开发中那些‘坑爹’的数据类型转换
2026/6/15 21:57:58

从一次LabelImg闪退报错,聊聊Python GUI开发中那些‘坑爹’的数据类型转换

从LabelImg闪崩溃看Python GUI开发中的类型陷阱:防御性编程实战指南当你在LabelImg中精心标注到第87张图片时,程序突然闪退并抛出TypeError: argument 1 has unexpected type float——这个看似简单的类型错误背后,隐藏着Python GUI开发中一系…

阅读更多
GTA5线上小助手:一站式游戏增强工具完整指南
2026/6/15 21:57:58

GTA5线上小助手:一站式游戏增强工具完整指南

GTA5线上小助手:一站式游戏增强工具完整指南 【免费下载链接】GTA5OnlineTools GTA5线上小助手 项目地址: https://gitcode.com/gh_mirrors/gt/GTA5OnlineTools 你是否厌倦了在洛圣都的街头重复枯燥的刷钱任务?是否渴望拥有更多游戏自由却不知从何…

阅读更多
LLM 推理性能调优:从显存瓶颈到吞吐优化,大模型服务的工程化加速
2026/6/15 21:57:58

LLM 推理性能调优:从显存瓶颈到吞吐优化,大模型服务的工程化加速

LLM 推理性能调优:从显存瓶颈到吞吐优化,大模型服务的工程化加速 一、LLM 推理的性能瓶颈:显存墙与计算墙的双重制约 大模型推理的性能受两个物理约束制约。显存墙:模型权重必须加载到 GPU 显存中才能推理,7B 模型需要…

阅读更多
Redis 缓存一致性方案:从缓存穿透到数据同步,分布式系统的缓存治理
2026/6/15 21:57:58

Redis 缓存一致性方案:从缓存穿透到数据同步,分布式系统的缓存治理

Redis 缓存一致性方案:从缓存穿透到数据同步,分布式系统的缓存治理一、缓存一致性的本质矛盾:性能与一致性的不可能三角 Redis 缓存的核心价值是提升读取性能,但引入缓存后,数据存储在两个位置:数据库和 Re…

阅读更多
PXS20微控制器ADC中断机制详解:从架构到实战配置
2026/6/15 21:57:58

PXS20微控制器ADC中断机制详解:从架构到实战配置

1. 项目概述与核心价值在嵌入式开发,尤其是汽车电子和工业控制领域,模数转换器(ADC)扮演着连接物理世界与数字系统的桥梁角色。我们常常需要实时监控电池电压、采集温度传感器数据或检测电机电流,这些场景对数据的及时…

阅读更多
ZC706P+ADRV9009连接RADIOVERSE踩坑实录:从SD卡镜像制作到软件联调的全流程避坑指南
2026/6/15 20:57:58

ZC706P+ADRV9009连接RADIOVERSE踩坑实录:从SD卡镜像制作到软件联调的全流程避坑指南

ZC706PADRV9009连接RADIOVERSE实战避坑指南:从镜像制作到系统联调的深度解析当硬件工程师第一次将ZC706P开发板与ADRV9009射频收发器组合使用时,往往会遇到一系列令人困惑的技术障碍。本文将以实战视角,剖析从SD卡镜像制作到软件联调全流程中…

阅读更多
别再只用BERT了!用Transformers库的AutoModel,5分钟搞定文本相似度计算(附代码对比)
2026/6/14 0:57:30

别再只用BERT了!用Transformers库的AutoModel,5分钟搞定文本相似度计算(附代码对比)

超越BERT:用Transformers库高效实现文本相似度计算的三种实战方案在自然语言处理领域,文本相似度计算是信息检索、问答系统和推荐系统等应用的核心技术。传统方法如TF-IDF或Word2Vec已逐渐被基于Transformer的预训练模型所取代。Hugging Face的Transform…

阅读更多
Prompt Engineering:重构人机协作的工程化方法论
2026/6/14 0:57:30

Prompt Engineering:重构人机协作的工程化方法论

1. 项目概述:这不是“写提示词”,而是重构人机协作的底层逻辑“Prompt Engineering”这个词,这两年被讲得太多,也太轻飘。很多人把它理解成“给AI发指令的技巧”,甚至简化为“多加几个形容词”“换种说法再试一次”。我…

阅读更多
Anthropic提示层归零:模型即协议的工程实践
2026/6/14 0:57:30

Anthropic提示层归零:模型即协议的工程实践

1. 项目概述:这不是一次普通更新,而是一次架构级“蒸发”“Anthropic Just Shipped the Layer That’s Already Going to Zero”——这个标题一出来,我正在调试一个Claude调用链的终端前停了三秒。不是因为震惊,而是因为熟悉&…

阅读更多
TEKLauncher:终极ARK模组管理与性能优化解决方案
2026/6/15 0:57:55

TEKLauncher:终极ARK模组管理与性能优化解决方案

TEKLauncher:终极ARK模组管理与性能优化解决方案 【免费下载链接】TEKLauncher Launcher for ARK: Survival Evolved 项目地址: https://gitcode.com/gh_mirrors/te/TEKLauncher 你是否为ARK: Survival Evolved复杂的模组管理和服务器连接问题而烦恼&#xf…

阅读更多
如何3分钟免费解锁Cursor Pro:终极AI编程助手破解方案
2026/6/15 0:57:55

如何3分钟免费解锁Cursor Pro:终极AI编程助手破解方案

如何3分钟免费解锁Cursor Pro:终极AI编程助手破解方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your tri…

阅读更多
21.2 mcp-server-chart 图表化作用
2026/6/15 0:57:55

21.2 mcp-server-chart 图表化作用

如何检查 langchain_mcp_adapters 版本和 antv/mcp-server-chart 安装 1. 检查 langchain_mcp_adapters 版本 在终端(确保已激活虚拟环境)中运行: pip show langchain_mcp_adapters输出示例: Name: langchain-mcp-adapters Ve…

阅读更多
GIT修改用户名
2026/6/14 11:53:59

GIT修改用户名

在GIT中修改用户名可按以下步骤操作: 查看当前git的用户名,使用命令git config --list或git config user.name。修改git用户名,使用命令git config --global user.name "xxx(新的用户名)",将其中…

阅读更多
Win11Debloat:让你的Windows系统重获新生的终极优化工具
2026/6/15 2:21:34

Win11Debloat:让你的Windows系统重获新生的终极优化工具

Win11Debloat:让你的Windows系统重获新生的终极优化工具 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter and …

阅读更多
技术深度解析:m4s-converter实现原理与B站缓存视频转换最佳实践
2026/6/15 21:13:35

技术深度解析:m4s-converter实现原理与B站缓存视频转换最佳实践

技术深度解析:m4s-converter实现原理与B站缓存视频转换最佳实践 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter m4s-converter是一个…

阅读更多