Python实例题:人机对战初体验Python基于Pygame实现四子棋游戏

news2025/5/26 1:27:21

目录

Python实例题

题目

代码实现

实现原理

游戏逻辑:

AI 算法:

界面渲染:

关键代码解析

游戏棋盘渲染

AI 决策算法

胜利条件检查

使用说明

安装依赖:

运行游戏:

游戏操作:

扩展建议

增强 AI:

界面改进:

功能扩展:

性能优化:

Python实例题

题目

人机对战初体验Python基于Pygame实现四子棋游戏

代码实现

import pygame
import sys
import numpy as np
import random

class ConnectFour:
    def __init__(self):
        # 游戏常量
        self.ROWS = 6
        self.COLUMNS = 7
        self.SQUARE_SIZE = 100
        self.WIDTH = self.COLUMNS * self.SQUARE_SIZE
        self.HEIGHT = (self.ROWS + 1) * self.SQUARE_SIZE
        self.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 = False
        self.turn = 1  # 1: 玩家1/人类, 2: 玩家2/AI
        self.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] == 0
    
    def get_next_open_row(self, col):
        """获取指定列中下一个可用的行"""
        for r in range(self.ROWS - 1, -1, -1):
            if self.board[r][col] == 0:
                return r
    
    def drop_piece(self, row, col, player):
        """在指定位置放置棋子"""
        self.board[row][col] = player
    
    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 True
        
        return False
    
    def is_board_full(self):
        """检查棋盘是否已满"""
        for c in range(self.COLUMNS):
            if self.is_valid_location(c):
                return False
        return True
    
    def evaluate_window(self, window, player):
        """评估一个窗口(四个位置)的得分"""
        score = 0
        opponent = 1 if player == 2 else 2
        
        if window.count(player) == 4:
            score += 100
        elif window.count(player) == 3 and window.count(0) == 1:
            score += 10
        elif window.count(player) == 2 and window.count(0) == 2:
            score += 5
        
        if window.count(opponent) == 3 and window.count(0) == 1:
            score -= 80  # 阻止对手三连
        
        return score
    
    def 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 score
    
    def get_valid_locations(self):
        """获取所有可用的列"""
        valid_locations = []
        for col in range(self.COLUMNS):
            if self.is_valid_location(col):
                valid_locations.append(col)
        return valid_locations
    
    def 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:  # 深度为0
                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_board
                if new_score > value:
                    value = new_score
                    column = col
                alpha = max(alpha, value)
                if alpha >= beta:
                    break
            return column, value
        else:  # 最小化玩家
            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_board
                if new_score < value:
                    value = new_score
                    column = col
                beta = min(beta, value)
                if alpha >= beta:
                    break
            return column, value
    
    def ai_move(self):
        """AI移动逻辑"""
        if not self.game_over:
            # 使用minimax算法选择最佳列,深度为4
            col, _ = 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 = True
                    self.winner = 2
                elif self.is_board_full():
                    self.game_over = True
                    self.winner = 0
                
                self.turn = 1  # 回到玩家1
                self.draw_board()
                pygame.display.update()
    
    def restart_game(self):
        """重新开始游戏"""
        self.board = np.zeros((self.ROWS, self.COLUMNS))
        self.game_over = False
        self.turn = 1
        self.winner = 0
        self.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 1
                        self.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.turn
                            self.drop_piece(row, col, player)
                            
                            # 检查是否获胜
                            if self.check_winning_move(player):
                                self.game_over = True
                                self.winner = player
                            
                            # 检查是否平局
                            elif self.is_board_full():
                                self.game_over = True
                                self.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_board
            if new_score > value:
                value = new_score
                column = col
            alpha = max(alpha, value)
            if alpha >= beta:
                break
        return column, value
    else:
        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_board
            if new_score < value:
                value = new_score
                column = col
            beta = min(beta, value)
            if alpha >= beta:
                break
        return 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 True
    
    return False

使用说明

  • 安装依赖

pip install pygame numpy
  • 运行游戏

python connect_four.py
  • 游戏操作

    • 人机对战:红方 (玩家) vs 黄方 (AI)
    • 双人对战:红方 (玩家 1) vs 黄方 (玩家 2)
    • 点击顶部按钮切换游戏模式
    • 点击列顶部放置棋子
    • 游戏结束后按 R 键重新开始

扩展建议

  • 增强 AI

    • 优化评分函数,考虑更多策略因素
    • 增加难度级别选择
    • 实现蒙特卡洛树搜索算法
  • 界面改进

    • 添加动画效果(棋子下落、胜利高亮)
    • 设计更精美的 UI 元素
    • 支持全屏模式和窗口调整
  • 功能扩展

    • 实现游戏存档和回放功能
    • 添加音效和背景音乐
    • 支持局域网多人对战
  • 性能优化

    • 使用位运算优化棋盘表示
    • 实现多线程计算 AI 决策
    • 添加游戏状态缓存机制

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

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

相关文章

Vue3性能优化: 大规模列表渲染解决方案

# Vue3性能优化: 大规模列表渲染解决方案 一、背景与挑战 背景 在大规模应用中&#xff0c;Vue3的列表渲染性能一直是开发者关注的焦点。大规模列表渲染往往会导致卡顿、内存占用过高等问题&#xff0c;影响用户体验和系统整体性能。 挑战 渲染大规模列表时&#xff0c;DOM操作…

【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风格提示词的精选案例&#xff0c;从基础指令到复杂任务&#xff0c;从创意写作到专业领域&#xff0c;为您提供全方位的参考和灵感。我们将持续更新这份案例集&#xff0c;确保您始终能够获取最新、最有效的提示词技巧。 让我们一起探索如何通过精心设计的提…

Android 自定义SnackBar和下滑取消

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

Netty学习专栏(三):Netty重要组件详解(Future、ByteBuf、Bootstrap)

文章目录 前言一、Future & Promise&#xff1a;异步编程的救星1.1 传统NIO的问题1.2 Netty的解决方案1.3 代码示例&#xff1a;链式异步操作 二、ByteBuf&#xff1a;重新定义数据缓冲区2.1 传统NIO ByteBuffer的缺陷2.2 Netty ByteBuf的解决方案2.3 代码示例&#xff1a;…

详解 C# 中基于发布-订阅模式的 Messenger 消息传递机制:Messenger.Default.Send/Register

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家、CSDN平台优质创作者&#xff0c;高级开发工程师&#xff0c;数学专业&#xff0c;10年以上C/C, C#, Java等多种编程语言开发经验&#xff0c;拥有高级工程师证书&#xff1b;擅长C/C、C#等开发语言&#xff0c;熟悉Java常用开…

多场景游戏AI新突破!Divide-Fuse-Conquer如何激发大模型“顿悟时刻“?

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

Java 函数式接口(Functional Interface)

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

分布式锁总结

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

使用MybatisPlus实现sql日志打印优化

背景&#xff1a; 在排查无忧行后台服务日志时&#xff0c;一个请求可能会包含多个执行的sql&#xff0c;经常会遇到SQL语句与对应参数不连续显示&#xff0c;或者参数较多需要逐个匹配的情况。这种情况下&#xff0c;如果需要还原完整SQL语句就会比较耗时。因此&#xff0c;我…

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…

深入浅出人工智能:机器学习、深度学习、强化学习原理详解与对比!

各位朋友&#xff0c;大家好&#xff01;今天咱们聊聊人工智能领域里最火的“三剑客”&#xff1a;机器学习 (Machine Learning)、深度学习 (Deep Learning) 和 强化学习 (Reinforcement Learning)。 听起来是不是有点高大上&#xff1f; 别怕&#xff0c;我保证把它们讲得明明…

基于 ColBERT 框架的后交互 (late interaction) 模型速递:Reason-ModernColBERT

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

vector中reserve导致的析构函数问题

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

微软开源多智能体自定义自动化工作流系统:构建企业级AI驱动的智能引擎

微软近期推出了一款开源解决方案加速器——Multi-Agent Custom Automation Engine Solution Accelerator,这是一个基于AI多智能体协作的自动化工作流系统。该系统通过指挥多个智能体(Agent)协同完成复杂任务,显著提升企业在数据处理、业务流程管理等场景中的效率与准确性。…

安卓无障碍脚本开发全教程

文章目录 第一部分&#xff1a;无障碍服务基础1.1 无障碍服务概述核心功能&#xff1a; 1.2 基本原理与架构1.3 开发环境配置所需工具&#xff1a;关键依赖&#xff1a; 第二部分&#xff1a;创建基础无障碍服务2.1 服务声明配置2.2 服务配置文件关键属性说明&#xff1a; 2.3 …

SOC-ESP32S3部分:10-GPIO中断按键中断实现

飞书文档https://x509p6c8to.feishu.cn/wiki/W4Wlw45P2izk5PkfXEaceMAunKg 学习了GPIO输入和输出功能后&#xff0c;参考示例工程&#xff0c;我们再来看看GPIO中断&#xff0c;IO中断的配置分为三步 配置中断触发类型安装中断服务注册中断回调函数 ESP32-S3的所有通用GPIO…

战略-2.1 -战略分析(PEST/五力模型/成功关键因素)

战略分析路径&#xff0c;先宏观&#xff08;PEST&#xff09;、再产业&#xff08;产品生命周期、五力模型、成功关键因素&#xff09;、再竞争对手分析、最后企业内部分析。 本文介绍&#xff1a;PEST、产品生命周期、五力模型、成功关键因素、产业内的战略群组 一、宏观环境…

python第三方库安装错位

问题所在 今天在安装我的django库时&#xff0c;我的库安装到了python3.13版本。我本意是想安装到python3.11版本的。我的pycharm右下角也设置了python3.11 但是太可恶了&#xff0c;我在pycharm的项目终端执行安装命令的时候还是给我安装到了python3.13的位置。 解决方法 我…

如何把vue项目部署在nginx上

1&#xff1a;在vscode中把vue项目打包会出现dist文件夹 按照图示内容即可把vue项目部署在nginx上