Python实例题:人机对战初体验Python基于Pygame实现四子棋游戏
目录
Python实例题
题目
代码实现
实现原理
游戏逻辑:
AI 算法:
界面渲染:
关键代码解析
游戏棋盘渲染
AI 决策算法
胜利条件检查
使用说明
安装依赖:
运行游戏:
游戏操作:
扩展建议
增强 AI:
界面改进:
功能扩展:
性能优化:
Python实例题
题目
人机对战初体验Python基于Pygame实现四子棋游戏
代码实现
import pygame
import sys
import numpy as np
import randomclass ConnectFour:def __init__(self):# 游戏常量self.ROWS = 6self.COLUMNS = 7self.SQUARE_SIZE = 100self.WIDTH = self.COLUMNS * self.SQUARE_SIZEself.HEIGHT = (self.ROWS + 1) * self.SQUARE_SIZEself.SCREEN_SIZE = (self.WIDTH, self.HEIGHT)self.RADIUS = int(self.SQUARE_SIZE / 2 - 5)# 颜色定义self.BLUE = (0, 0, 255)self.BLACK = (0, 0, 0)self.RED = (255, 0, 0)self.YELLOW = (255, 255, 0)self.WHITE = (255, 255, 255)# 初始化游戏pygame.init()self.screen = pygame.display.set_mode(self.SCREEN_SIZE)pygame.display.set_caption("四子棋")self.font = pygame.font.SysFont("SimHei", 40)self.small_font = pygame.font.SysFont("SimHei", 24)# 游戏变量self.board = np.zeros((self.ROWS, self.COLUMNS))self.game_over = Falseself.turn = 1 # 1: 玩家1/人类, 2: 玩家2/AIself.player_mode = 1 # 1: 人机对战, 2: 双人对战self.winner = 0# 绘制初始界面self.draw_board()pygame.display.update()def draw_board(self):"""绘制游戏棋盘"""# 绘制背景self.screen.fill(self.BLUE)# 绘制标题区域title_rect = pygame.Rect(0, 0, self.WIDTH, self.SQUARE_SIZE)pygame.draw.rect(self.screen, self.BLACK, title_rect)# 显示标题和模式title_text = self.font.render("四子棋", True, self.WHITE)self.screen.blit(title_text, (self.WIDTH // 2 - title_text.get_width() // 2, 30))mode_text = self.small_font.render("模式: 人机对战" if self.player_mode == 1 else "模式: 双人对战", True, self.WHITE)self.screen.blit(mode_text, (20, 35))# 绘制切换模式按钮button_rect = pygame.Rect(self.WIDTH - 150, 25, 120, 50)pygame.draw.rect(self.screen, self.RED if self.player_mode == 1 else self.YELLOW, button_rect)button_text = self.small_font.render("切换双人" if self.player_mode == 1 else "切换人机", True, self.WHITE)self.screen.blit(button_text, (button_rect.centerx - button_text.get_width() // 2, button_rect.centery - button_text.get_height() // 2))# 绘制棋盘格子for c in range(self.COLUMNS):for r in range(self.ROWS):pygame.draw.rect(self.screen, self.BLACK, (c * self.SQUARE_SIZE, (r + 1) * self.SQUARE_SIZE, self.SQUARE_SIZE, self.SQUARE_SIZE))pygame.draw.circle(self.screen, self.WHITE, (int(c * self.SQUARE_SIZE + self.SQUARE_SIZE / 2), int((r + 1) * self.SQUARE_SIZE + self.SQUARE_SIZE / 2)), self.RADIUS)# 绘制当前棋子for c in range(self.COLUMNS):for r in range(self.ROWS):if self.board[r][c] == 1:pygame.draw.circle(self.screen, self.RED, (int(c * self.SQUARE_SIZE + self.SQUARE_SIZE / 2), self.HEIGHT - int(r * self.SQUARE_SIZE + self.SQUARE_SIZE / 2)), self.RADIUS)elif self.board[r][c] == 2:pygame.draw.circle(self.screen, self.YELLOW, (int(c * self.SQUARE_SIZE + self.SQUARE_SIZE / 2), self.HEIGHT - int(r * self.SQUARE_SIZE + self.SQUARE_SIZE / 2)), self.RADIUS)# 如果游戏结束,显示获胜信息if self.game_over:overlay = pygame.Surface(self.SCREEN_SIZE, pygame.SRCALPHA)overlay.fill((0, 0, 0, 180))self.screen.blit(overlay, (0, 0))winner_text = self.font.render(f"玩家 {'红方' if self.winner == 1 else '黄方'} 获胜!" if self.winner != 0 else "平局!", True, self.WHITE)self.screen.blit(winner_text, (self.WIDTH // 2 - winner_text.get_width() // 2, self.HEIGHT // 2 - 30))restart_text = self.font.render("按R键重新开始", True, self.WHITE)self.screen.blit(restart_text, (self.WIDTH // 2 - restart_text.get_width() // 2, self.HEIGHT // 2 + 30))def is_valid_location(self, col):"""检查指定列是否可以放置棋子"""return self.board[0][col] == 0def get_next_open_row(self, col):"""获取指定列中下一个可用的行"""for r in range(self.ROWS - 1, -1, -1):if self.board[r][col] == 0:return rdef drop_piece(self, row, col, player):"""在指定位置放置棋子"""self.board[row][col] = playerdef check_winning_move(self, player):"""检查玩家是否获胜"""# 检查水平方向for c in range(self.COLUMNS - 3):for r in range(self.ROWS):if (self.board[r][c] == player and self.board[r][c + 1] == player and self.board[r][c + 2] == player and self.board[r][c + 3] == player):return True# 检查垂直方向for c in range(self.COLUMNS):for r in range(self.ROWS - 3):if (self.board[r][c] == player and self.board[r + 1][c] == player and self.board[r + 2][c] == player and self.board[r + 3][c] == player):return True# 检查正对角线for c in range(self.COLUMNS - 3):for r in range(self.ROWS - 3):if (self.board[r][c] == player and self.board[r + 1][c + 1] == player and self.board[r + 2][c + 2] == player and self.board[r + 3][c + 3] == player):return True# 检查反对角线for c in range(self.COLUMNS - 3):for r in range(3, self.ROWS):if (self.board[r][c] == player and self.board[r - 1][c + 1] == player and self.board[r - 2][c + 2] == player and self.board[r - 3][c + 3] == player):return Truereturn Falsedef is_board_full(self):"""检查棋盘是否已满"""for c in range(self.COLUMNS):if self.is_valid_location(c):return Falsereturn Truedef evaluate_window(self, window, player):"""评估一个窗口(四个位置)的得分"""score = 0opponent = 1 if player == 2 else 2if window.count(player) == 4:score += 100elif window.count(player) == 3 and window.count(0) == 1:score += 10elif window.count(player) == 2 and window.count(0) == 2:score += 5if window.count(opponent) == 3 and window.count(0) == 1:score -= 80 # 阻止对手三连return scoredef score_position(self, player):"""评估整个棋盘的得分"""score = 0# 评估中心列center_array = [int(i) for i in list(self.board[:, self.COLUMNS // 2])]center_count = center_array.count(player)score += center_count * 3# 评估水平方向for r in range(self.ROWS):row_array = [int(i) for i in list(self.board[r, :])]for c in range(self.COLUMNS - 3):window = row_array[c:c + 4]score += self.evaluate_window(window, player)# 评估垂直方向for c in range(self.COLUMNS):col_array = [int(i) for i in list(self.board[:, c])]for r in range(self.ROWS - 3):window = col_array[r:r + 4]score += self.evaluate_window(window, player)# 评估正对角线for r in range(self.ROWS - 3):for c in range(self.COLUMNS - 3):window = [self.board[r + i][c + i] for i in range(4)]score += self.evaluate_window(window, player)# 评估反对角线for r in range(self.ROWS - 3):for c in range(self.COLUMNS - 3):window = [self.board[r + 3 - i][c + i] for i in range(4)]score += self.evaluate_window(window, player)return scoredef get_valid_locations(self):"""获取所有可用的列"""valid_locations = []for col in range(self.COLUMNS):if self.is_valid_location(col):valid_locations.append(col)return valid_locationsdef minimax(self, depth, maximizingPlayer, alpha, beta):"""使用Minimax算法和Alpha-Beta剪枝选择最佳移动"""valid_locations = self.get_valid_locations()is_terminal = self.is_board_full() or self.check_winning_move(1) or self.check_winning_move(2)if depth == 0 or is_terminal:if is_terminal:if self.check_winning_move(2):return (None, 10000000)elif self.check_winning_move(1):return (None, -10000000)else: # 平局return (None, 0)else: # 深度为0return (None, self.score_position(2))if maximizingPlayer:value = -float('inf')column = random.choice(valid_locations)for col in valid_locations:row = self.get_next_open_row(col)temp_board = self.board.copy()self.drop_piece(row, col, 2)new_score = self.minimax(depth - 1, False, alpha, beta)[1]self.board = temp_boardif new_score > value:value = new_scorecolumn = colalpha = max(alpha, value)if alpha >= beta:breakreturn column, valueelse: # 最小化玩家value = float('inf')column = random.choice(valid_locations)for col in valid_locations:row = self.get_next_open_row(col)temp_board = self.board.copy()self.drop_piece(row, col, 1)new_score = self.minimax(depth - 1, True, alpha, beta)[1]self.board = temp_boardif new_score < value:value = new_scorecolumn = colbeta = min(beta, value)if alpha >= beta:breakreturn column, valuedef ai_move(self):"""AI移动逻辑"""if not self.game_over:# 使用minimax算法选择最佳列,深度为4col, _ = self.minimax(4, True, -float('inf'), float('inf'))if self.is_valid_location(col):pygame.time.wait(500) # 让AI思考看起来更自然row = self.get_next_open_row(col)self.drop_piece(row, col, 2)if self.check_winning_move(2):self.game_over = Trueself.winner = 2elif self.is_board_full():self.game_over = Trueself.winner = 0self.turn = 1 # 回到玩家1self.draw_board()pygame.display.update()def restart_game(self):"""重新开始游戏"""self.board = np.zeros((self.ROWS, self.COLUMNS))self.game_over = Falseself.turn = 1self.winner = 0self.draw_board()pygame.display.update()def run(self):"""运行游戏主循环"""clock = pygame.time.Clock()while True:clock.tick(60)for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit()if event.type == pygame.KEYDOWN:if event.key == pygame.K_r and self.game_over:self.restart_game()if event.type == pygame.MOUSEBUTTONDOWN:# 检查是否点击了模式切换按钮button_rect = pygame.Rect(self.WIDTH - 150, 25, 120, 50)if button_rect.collidepoint(event.pos):self.player_mode = 2 if self.player_mode == 1 else 1self.restart_game()continue# 游戏未结束且轮到人类玩家if not self.game_over and (self.turn == 1 or self.player_mode == 2):# 获取鼠标位置pos_x = event.pos[0]col = int(pos_x // self.SQUARE_SIZE)# 检查列是否有效if self.is_valid_location(col):# 获取下一个可用行row = self.get_next_open_row(col)# 放置棋子player = self.turnself.drop_piece(row, col, player)# 检查是否获胜if self.check_winning_move(player):self.game_over = Trueself.winner = player# 检查是否平局elif self.is_board_full():self.game_over = Trueself.winner = 0# 切换玩家self.turn = 2 if self.turn == 1 else 1# 绘制棋盘self.draw_board()pygame.display.update()# AI移动(人机对战且轮到AI)if not self.game_over and self.turn == 2 and self.player_mode == 1:self.ai_move()if __name__ == "__main__":game = ConnectFour()game.run()
实现原理
这个四子棋游戏基于以下核心技术实现:
-
游戏逻辑:
- 使用 numpy 数组表示游戏棋盘
- 实现棋子放置、胜利条件检查和棋盘状态评估
- 支持人机对战和双人对战模式
-
AI 算法:
- 使用 Minimax 算法进行决策
- 实现 Alpha-Beta 剪枝优化搜索效率
- 设计评分函数评估棋盘状态
-
界面渲染:
- 使用 Pygame 创建图形界面
- 实现棋盘、棋子和交互元素的绘制
- 添加游戏状态提示和模式切换功能
关键代码解析
游戏棋盘渲染
def draw_board(self):# 绘制背景和标题self.screen.fill(self.BLUE)title_rect = pygame.Rect(0, 0, self.WIDTH, self.SQUARE_SIZE)pygame.draw.rect(self.screen, self.BLACK, title_rect)# 绘制棋盘格子和棋子for c in range(self.COLUMNS):for r in range(self.ROWS):pygame.draw.rect(self.screen, self.BLACK, (c * self.SQUARE_SIZE, (r + 1) * self.SQUARE_SIZE, self.SQUARE_SIZE, self.SQUARE_SIZE))pygame.draw.circle(self.screen, self.WHITE, (int(c * self.SQUARE_SIZE + self.SQUARE_SIZE / 2), int((r + 1) * self.SQUARE_SIZE + self.SQUARE_SIZE / 2)), self.RADIUS)# 绘制当前棋子状态for c in range(self.COLUMNS):for r in range(self.ROWS):if self.board[r][c] == 1:pygame.draw.circle(self.screen, self.RED, (int(c * self.SQUARE_SIZE + self.SQUARE_SIZE / 2), self.HEIGHT - int(r * self.SQUARE_SIZE + self.SQUARE_SIZE / 2)), self.RADIUS)elif self.board[r][c] == 2:pygame.draw.circle(self.screen, self.YELLOW, (int(c * self.SQUARE_SIZE + self.SQUARE_SIZE / 2), self.HEIGHT - int(r * self.SQUARE_SIZE + self.SQUARE_SIZE / 2)), self.RADIUS)
AI 决策算法
def minimax(self, depth, maximizingPlayer, alpha, beta):valid_locations = self.get_valid_locations()is_terminal = self.is_board_full() or self.check_winning_move(1) or self.check_winning_move(2)if depth == 0 or is_terminal:if is_terminal:if self.check_winning_move(2):return (None, 10000000)elif self.check_winning_move(1):return (None, -10000000)else:return (None, 0)else:return (None, self.score_position(2))if maximizingPlayer:value = -float('inf')column = random.choice(valid_locations)for col in valid_locations:row = self.get_next_open_row(col)temp_board = self.board.copy()self.drop_piece(row, col, 2)new_score = self.minimax(depth - 1, False, alpha, beta)[1]self.board = temp_boardif new_score > value:value = new_scorecolumn = colalpha = max(alpha, value)if alpha >= beta:breakreturn column, valueelse:value = float('inf')column = random.choice(valid_locations)for col in valid_locations:row = self.get_next_open_row(col)temp_board = self.board.copy()self.drop_piece(row, col, 1)new_score = self.minimax(depth - 1, True, alpha, beta)[1]self.board = temp_boardif new_score < value:value = new_scorecolumn = colbeta = min(beta, value)if alpha >= beta:breakreturn column, value
胜利条件检查
def check_winning_move(self, player):# 检查水平方向for c in range(self.COLUMNS - 3):for r in range(self.ROWS):if (self.board[r][c] == player and self.board[r][c + 1] == player and self.board[r][c + 2] == player and self.board[r][c + 3] == player):return True# 检查垂直方向for c in range(self.COLUMNS):for r in range(self.ROWS - 3):if (self.board[r][c] == player and self.board[r + 1][c] == player and self.board[r + 2][c] == player and self.board[r + 3][c] == player):return True# 检查正对角线for c in range(self.COLUMNS - 3):for r in range(self.ROWS - 3):if (self.board[r][c] == player and self.board[r + 1][c + 1] == player and self.board[r + 2][c + 2] == player and self.board[r + 3][c + 3] == player):return True# 检查反对角线for c in range(self.COLUMNS - 3):for r in range(3, self.ROWS):if (self.board[r][c] == player and self.board[r - 1][c + 1] == player and self.board[r - 2][c + 2] == player and self.board[r - 3][c + 3] == player):return Truereturn False
使用说明
-
安装依赖:
pip install pygame numpy
-
运行游戏:
python connect_four.py
-
游戏操作:
- 人机对战:红方 (玩家) vs 黄方 (AI)
- 双人对战:红方 (玩家 1) vs 黄方 (玩家 2)
- 点击顶部按钮切换游戏模式
- 点击列顶部放置棋子
- 游戏结束后按 R 键重新开始
扩展建议
-
增强 AI:
- 优化评分函数,考虑更多策略因素
- 增加难度级别选择
- 实现蒙特卡洛树搜索算法
-
界面改进:
- 添加动画效果(棋子下落、胜利高亮)
- 设计更精美的 UI 元素
- 支持全屏模式和窗口调整
-
功能扩展:
- 实现游戏存档和回放功能
- 添加音效和背景音乐
- 支持局域网多人对战
-
性能优化:
- 使用位运算优化棋盘表示
- 实现多线程计算 AI 决策
- 添加游戏状态缓存机制
相关文章:
Python实例题:人机对战初体验Python基于Pygame实现四子棋游戏
目录 Python实例题 题目 代码实现 实现原理 游戏逻辑: AI 算法: 界面渲染: 关键代码解析 游戏棋盘渲染 AI 决策算法 胜利条件检查 使用说明 安装依赖: 运行游戏: 游戏操作: 扩展建议 增强…...

Vue3性能优化: 大规模列表渲染解决方案
# Vue3性能优化: 大规模列表渲染解决方案 一、背景与挑战 背景 在大规模应用中,Vue3的列表渲染性能一直是开发者关注的焦点。大规模列表渲染往往会导致卡顿、内存占用过高等问题,影响用户体验和系统整体性能。 挑战 渲染大规模列表时,DOM操作…...
笔记:将一个文件服务器上的文件(一个返回文件数据的url)作为另一个http接口的请求参数
笔记:将一个文件服务器上的文件(一个返回文件数据的url)作为另一个http接口的请求参数 最近有这么个需求,需要往某一个业务的外部接口上传文件信息,但是现在没有现成的文件,只在数据库存了对应的url&#…...

【RocketMQ 生产者和消费者】- 生产者启动源码 - MQClientInstance 定时任务(4)
文章目录 1. 前言2. startScheduledTask 启动定时任务2.1 fetchNameServerAddr 拉取名称服务地址2.2 updateTopicRouteInfoFromNameServer 更新 topic 路由信息2.2.1 topic 路由信息2.2.2 updateTopicRouteInfoFromNameServer 获取 topic2.2.3 updateTopicRouteInfoFromNameSer…...

超全GPT-4o 风格提示词案例,持续更新中,附使用方式
本文汇集了各类4o风格提示词的精选案例,从基础指令到复杂任务,从创意写作到专业领域,为您提供全方位的参考和灵感。我们将持续更新这份案例集,确保您始终能够获取最新、最有效的提示词技巧。 让我们一起探索如何通过精心设计的提…...

Android 自定义SnackBar和下滑取消
如何自定义SnackBar 首先我们得了解SnackBar的布局: 之前我看有一些方案是获取内部的contentLayout,然后做一些处理。但是现在已经行不通了: RestrictTo(LIBRARY_GROUP) public static final class SnackbarLayout extends BaseTransientB…...

Netty学习专栏(三):Netty重要组件详解(Future、ByteBuf、Bootstrap)
文章目录 前言一、Future & Promise:异步编程的救星1.1 传统NIO的问题1.2 Netty的解决方案1.3 代码示例:链式异步操作 二、ByteBuf:重新定义数据缓冲区2.1 传统NIO ByteBuffer的缺陷2.2 Netty ByteBuf的解决方案2.3 代码示例:…...

详解 C# 中基于发布-订阅模式的 Messenger 消息传递机制:Messenger.Default.Send/Register
🧑 博主简介:CSDN博客专家、CSDN平台优质创作者,高级开发工程师,数学专业,10年以上C/C, C#, Java等多种编程语言开发经验,拥有高级工程师证书;擅长C/C、C#等开发语言,熟悉Java常用开…...

多场景游戏AI新突破!Divide-Fuse-Conquer如何激发大模型“顿悟时刻“?
多场景游戏AI新突破!Divide-Fuse-Conquer如何激发大模型"顿悟时刻"? 大语言模型在强化学习中偶现的"顿悟时刻"引人关注,但多场景游戏中训练不稳定、泛化能力差等问题亟待解决。Divide-Fuse-Conquer方法,通过…...

Java 函数式接口(Functional Interface)
一、理论说明 1. 函数式接口的定义 Java 函数式接口是一种特殊的接口,它只包含一个抽象方法(Single Abstract Method, SAM),但可以包含多个默认方法或静态方法。函数式接口是 Java 8 引入 Lambda 表达式的基础,通过函…...

分布式锁总结
文章目录 分布式锁什么是分布式锁?分布式锁的实现方式基于数据库(mysql)实现基于缓存(redis)多实例并发访问问题演示项目代码(使用redis)配置nginx.confjmeter压测复现问题并发是1,即不产生并发问题并发30测试,产生并发问题(虽然单实例是synchronized&am…...

使用MybatisPlus实现sql日志打印优化
背景: 在排查无忧行后台服务日志时,一个请求可能会包含多个执行的sql,经常会遇到SQL语句与对应参数不连续显示,或者参数较多需要逐个匹配的情况。这种情况下,如果需要还原完整SQL语句就会比较耗时。因此,我…...
springboot中redis的事务的研究
redis的事务类似于队列操作,执行过程分为三步: 开启事务入队操作执行事务 使用到的几个命令如下: 命令说明multi开启一个事务exec事务提交discard事务回滚watch监听key(s):当监听一个key(s)时,如果在本次事务提交之…...
为什么我输入对了密码,还是不能用 su 切换到 root?
“为什么我输入对了密码,还是不能用 su 切换到 root?” 其实这背后可能不是“密码错了”,而是系统不允许你用 su 切 root,即使密码对了。 👇 以下是最常见的几个真正原因: ❌ 1. Root 用户没有设置密码&…...

client.chat.completions.create方法参数详解
response client.chat.completions.create(model"gpt-3.5-turbo", # 必需参数messages[], # 必需参数temperature1.0, # 可选参数max_tokensNone, # 可选参数top_p1.0, # 可选参数frequency_penalty0.0, # 可选参数presenc…...
量子计算与云计算的融合:技术前沿与应用前景
目录 引言 量子计算基础 量子计算的基本原理 量子计算的优势与挑战 量子计算的发展阶段 云计算基础 云计算的基本概念 云计算的应用领域 云计算面临的挑战 量子计算与云计算的结合 量子云计算的概念与架构 量子云计算的服务模式 量子云计算的优势 量子云计算的发展…...
《企业级日志该怎么打?Java日志规范、分层设计与埋点实践》
大家好呀!👋 今天我们要聊一个Java开发中超级重要但又经常被忽视的话题——日志系统!📝 不管你是刚入门的小白,还是工作多年的老司机,日志都是我们每天都要打交道的"好朋友"。那么,如…...
python模块管理环境变量
概要 在 Python 应用中,为了将配置信息与代码分离、增强安全性并支持多环境(开发、测试、生产)运行,使用专门的模块来管理环境变量是最佳实践。常见工具包括: 标准库 os.environ:直接读取操作系统环境变量…...
【泛微系统】后端开发Action常用方法
后端开发Action常用方法 代码实例经验分享:代码实例 经验分享: 本文分享了后端开发中处理工作流Action的常用方法,主要包含以下内容:1) 获取工作流基础信息,如流程ID、节点ID、表单ID等;2) 操作请求信息,包括请求紧急程度、操作类型、用户信息等;3) 表单数据处理,展示…...
【算法】力扣体系分类
第一章 算法基础题型 1.1 排序算法题 1.1.1 冒泡排序相关题 冒泡排序是一种简单的排序算法,它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,…...
sql:如何查询一个数据表字段:Scrp 数据不为空?
在SQL中,要查询一个数据表中的字段 Scrp 不为空的记录,可以使用 IS NOT NULL 条件。以下是一个基本的SQL查询示例: SELECT * FROM your_table_name WHERE Scrp IS NOT NULL;在这个查询中,your_table_name 应该替换为你的实际数据…...

深入浅出人工智能:机器学习、深度学习、强化学习原理详解与对比!
各位朋友,大家好!今天咱们聊聊人工智能领域里最火的“三剑客”:机器学习 (Machine Learning)、深度学习 (Deep Learning) 和 强化学习 (Reinforcement Learning)。 听起来是不是有点高大上? 别怕,我保证把它们讲得明明…...
索引下探(Index Condition Pushdown,简称ICP)
索引下探(Index Condition Pushdown,简称ICP)是一种数据库查询优化技术,常见于MySQL等关系型数据库中。 1. 核心概念 作用:将原本在服务器层执行的WHERE条件判断尽可能下推到存储引擎层执行。减少回表查询次数支持部…...

基于 ColBERT 框架的后交互 (late interaction) 模型速递:Reason-ModernColBERT
一、Reason-ModernColBERT 模型概述 Reason-ModernColBERT 是一种基于 ColBERT 框架的后交互 (late interaction) 模型,专为信息检索任务中的推理密集型场景设计。该模型在 reasonir-hq 数据集上进行训练,于 BRIGHT 基准测试中取得了极具竞争力的性能表…...

vector中reserve导致的析构函数问题
接上一节vector实现,解决杨辉三角问题时,我在最后调试的时候,发现return vv时,调用析构函数,到第四步时才析构含有14641的vector。我设置了一个全局变量i来记录。 初始为35: 当为39时,也就是第…...

微软开源多智能体自定义自动化工作流系统:构建企业级AI驱动的智能引擎
微软近期推出了一款开源解决方案加速器——Multi-Agent Custom Automation Engine Solution Accelerator,这是一个基于AI多智能体协作的自动化工作流系统。该系统通过指挥多个智能体(Agent)协同完成复杂任务,显著提升企业在数据处理、业务流程管理等场景中的效率与准确性。…...
关于vector、queue、list哪边是front、哪边是back,增加、删除元素操作
容器的 front、back 及操作方向 1.1vector(动态数组) 结构:连续内存块,支持快速随机访问。 操作方向: front:第一个元素(索引 0)。 back:最后一个元素(索引…...
KubeVela入门到精通-K8S多集群交付
目录 1、介绍 2、部署 3、部署UI界面 4、御载 5、Velaux概念 6、OAM应用模型介绍 7、应用部署计划 8、系统架构 9、基础环境配置 9.1 创建项目 9.2 创建集群 9.3 创建交付目标 9.4 创建环境 9.5、创建服务测试 9.6、服务操作 10、插件、项目、权限管理 10.1 插…...
RocketMq的消息类型及代码案例
RocketMQ 提供了多种消息类型,以满足不同业务场景对 顺序性、事务性、时效性 的要求。其核心设计思想是通过解耦 “消息传递模式” 与 “业务逻辑”,实现高性能、高可靠的分布式通信。 一、主要类型包括 普通消息(基础类型)顺序…...
Eigen 直线拟合/曲线拟合/圆拟合/椭圆拟合
一、直线拟合 使用Eigen库进行直线拟合是数据分析和科学计算中的常见任务,主要通过最小二乘法实现。以下是关键实现方法和示例: 核心原理最小二乘法通过最小化点到直线距离的平方和来求解最优直线参数间接平差法是最小二乘法的具体实现形式,适用于直线拟合场景通过构建误差…...