首页
pygame.sprite.sprite
pygame.sprite.sprite
时间: 2023-04-24 13:02:29
浏览: 294
Sprites.py
立即下载
Sprites.py
Pygame.sprite.Sprite 是 Pygame 库中用于管理游戏中精灵(Sprite)的类。它提供了许多便利的方法来管理精灵,如碰撞检测、绘制等。使用这个类可以轻松地创建和管理游戏中的精灵对象。
阅读全文
相关推荐
Pygame.docx
Pygame 是一个基于 Python 的游戏开发库,它简化了创建2D游戏的过程。要开始使用 Pygame,首先...在进一步学习中,还可以了解更多的 Pygame 特性,如精灵(Sprite)、碰撞检测和音乐播放等,以实现更复杂的游戏功能。
pygame安装.pdf
4. **动画模块**:创建动画,例如 pygame.sprite 模块可以帮助你创建动画精灵。 5. **碰撞检测模块**:提供矩形和圆形的碰撞检测,如 pygame.math.Vector2.distance_to() 和 pygame.Rect.colliderect()。 要...
pygame.sprite.sprite()
根据提供的引用内容,没有直接涉及到pygame.sprite.sprite()的介绍或演示。但是可以根据提供的引用内容介绍pygame.sprite模块的一些基本概念和用法。 pygame.sprite模块提供了一个用于处理精灵(sprite)的类和函数...
class Sprite(pygame.sprite.Sprite):
class Sprite(pygame.sprite.Sprite): def __init__(self): super().__init__() # 在这里添加你的代码,定义Sprite类的属性和方法 # ... # ... # ... def update(self): # 在这里添加你的代码,更新Sprite...
pygame.sprite.Sprite有什么用
pygame.sprite.Sprite 是 Pygame 中的一个基础类,用于创建游戏中的精灵对象。精灵是游戏中的可移动对象,可以是角色、敌人、子弹等。 使用 pygame.sprite.Sprite 类可以方便地管理精灵的属性和行为。它提供了一些...
pygame.sprite.Sprite.__init__(self)
在 Pygame 中,我们可以通过继承 pygame.sprite.Sprite 类来创建自己的精灵类,并使用 __init__() 函数来初始化精灵的属性、图像和位置等信息。 在这个初始化函数中,self 是当前对象的引用,它会被传递给 ...
pygame.sprite.Sprite.add() argument after * must be an iterable, not AlienInvasion
这个错误是因为在调用pygame.sprite.Sprite.add()方法时,传递给它的参数不是可迭代的对象。在这种情况下,它期望一个可迭代的对象,例如列表或元组,而不是一个单独的对象。 如果你想将一个单独的精灵添加到一个...
TypeError: pygame.sprite.Sprite.add() argument after * must be an iterable, not Settings
add() 方法需要接收一个或多个可迭代对象,例如一个 Sprite 对象或一个 Group 对象。你需要检查代码中调用 add() 方法的位置,并确保你传递给它的参数是一个可迭代的对象。 例如,如果你想将一个 sprite ...
TypeError: pygame.sprite.Sprite.add() argument after * must be an iterable, not AlienInvasion
这个错误通常是因为在调用pygame.sprite.Sprite.add()方法时,传递的参数不是可迭代的对象,而是一个AlienInvasion对象。解决这个问题的方法是将AlienInvasion对象放入一个可迭代的对象中,例如列表或元组。...
class gemSprite(pygame.sprite.Sprite): def __init__(self, img_path, size, position, downlen, **kwargs): pygame.sprite.Sprite.__init__(self) self.image = pygame.image.load(img_path) self.image = pygame.transform.smoothscale(self.image, size) self.rect = self.image.get_rect() self.rect.left, self.rect.top = position self.downlen = downlen self.target_x = position[0] self.target_y = position[1] + downlen self.type = img_path.split('/')[-1].split('.')[0] self.fixed = False self.speed_x = 10 self.speed_y = 10 self.direction = 'down'
在初始化方法中,gemSprite类接受一些参数,包括图片路径、大小、位置、下降距离等,然后通过调用pygame.sprite.Sprite的__init__方法,初始化了一个pygame.sprite.Sprite对象。之后,通过pygame.image.load加载图片...
class Bullet1(pygame.sprite.Sprite): def __init__(self, position): pygame.sprite.Sprite.__init__(self) self.shot_count = 0 self.max_shots = 3 # 在1秒内最多能发射3个子弹 self.shot_timer = pygame.time.get_ticks() self.image = pygame.image.load("素材/bullet_UK4.png").convert_alpha() self.rect = self.image.get_rect() self.rect.left, self.rect.top = position self.speed = 12 self.active = False self.mask = pygame.mask.from_surface(self.image) def move(self): current_time = pygame.time.get_ticks() if current_time - self.shot_timer > 1000: self.shot_timer = current_time self.shot_count = 0 if self.shot_count < self.max_shots: self.rect.right += self.speed if self.rect.left > 1023: self.active = False self.shot_count += 1 def reset(self, position): self.rect.left, self.rect.top = position self.active = True
这段代码是一个名为 Bullet1 的类,继承自 pygame.sprite.Sprite 类,用于创建子弹对象。它有以下属性: - shot_count:已经发射的子弹数量。 - max_shots:在一秒内最多能发射的子弹数量。 - shot_timer:用于控制...
class Tile(pygame.sprite.Sprite): def __init__(self,pos,groups,sprite_type,surface = pygame.Surface((TILESIZE,TILESIZE))): super().__init__(groups) self.sprite_type = sprite_type y_offset = HITBOX_OFFSET[sprite_type] self.image = surface if sprite_type == 'object': self.rect = self.image.get_rect(topleft = (pos[0],pos[1] - TILESIZE)) else: self.rect = self.image.get_rect(topleft = pos) self.hitbox = self.rect.inflate(0,y_offset)
这个类继承了 Pygame.sprite.Sprite 类,用于在游戏中显示图像。 在 __init__ 方法中,传入了 pos、groups、sprite_type 和 surface 四个参数。其中,pos 表示 Tile 对象在游戏中的位置;groups 表示 Tile 对象所属...
def __init__(self, position): pygame.sprite.Sprite.__init__(self) self.image = pygame.image.load("素材/bullet_UK4.png").convert_alpha() self.rect = self.image.get_rect() self.rect.left, self.rect.top = position self.speed = 12 self.active = False self.mask = pygame.mask.from_surface(self.image) def move(self): self.rect.right += self.speed if self.rect.left >1023: self.active = False def reset(self, position): self.rect.left, self.rect.top = position self.active = True
- image:子弹的图像,使用 pygame.image.load 加载。 - rect:子弹在屏幕上的矩形区域,使用 get_rect 方法获取。 - speed:子弹的速度。 - active:子弹是否还在屏幕上。 - mask:子弹的掩膜,...
import pygame import sys class Card(pygame.sprite.Sprite): def __init__(self, image1, image2, pos): super().__init__() self.image1 = image1 self.image2 = image2 self.image = self.image1 self.rect = self.image.get_rect() self.rect.center = pos self.is_flipped = False def flip(self): self.is_flipped = not self.is_flipped if self.is_flipped: self.image = self.image2 else: self.image = self.image1 def update(self): pass pygame.init() screen = pygame.display.set_mode((800, 600)) pygame.display.set_caption("Card Game") images = [] for i in range(1, 11): image1 = pygame.image.load(f"card{i}.png") image2 = pygame.image.load(f"card{i}_back.png") images.append((image1, image2)) cards = pygame.sprite.Group() for i in range(10): card = Card(images[i][0], images[i][1], ((i % 5) * 150 + 75, (i // 5) * 150 + 75)) cards.add(card) clock = pygame.time.Clock() while True: for event in pygame.event.get(): if event.type == pygame.QUIT: pygame.quit() sys.exit() elif event.type == pygame.MOUSEBUTTONDOWN: for card in cards: if card.rect.collidepoint(event.pos): card.flip() screen.fill((255, 255, 255)) cards.update() cards.draw(screen) pygame.display.update() clock.tick(60)
这是一个使用 Pygame 库制作的简单的翻牌游戏示例代码。程序首先导入 Pygame 和 sys 模块,然后定义了一个 Card 类,表示一张卡牌,其中包括两个图片和位置信息等属性。Card 类还定义了 flip() 方法用于翻牌,并在 ...
import pygame from pygame.mixer import music import random class Ball(pygame.sprite.Sprite): def __init__(self,image_file,location,speed): pygame.sprite.Sprite.__init__(self) self.image = pygame.image.load(image_file) self.rect = self.image.get_rect() self.rect.left,self.rect.top = location self.speed = speed def move(self): self.rect = self.rect.move(self.speed) if self.rect.left < 0 or self.rect.right > width: self.speed[0] = -self.speed[0] if self.rect.top < 0 and (self.rect.left < 240 or self.rect.right > 400) : self.speed[1] = -self.speed[1] pygame.init() pygame.mixer.init() # 初始化混音器 clock = pygame.time.Clock() pygame.key.set_repeat(500,50) size = width,height = 640,480 screen = pygame.display.set_mode(size) screen.fill([255,255,255]) ball = Ball("desk_ball.png",[320,240],[10,8]) def new_func(Ball): bat = Ball("bat.png",[320,460],[0,0]) return bat bat = new_func(Ball) goal = Ball("goal.png",[240,0],[0,0]) screen.blit(ball.image,ball.rect) pygame.display.set_caption('乒乓球小游戏') #游戏标题 pygame.display.update() score = 0 lives = 5#总共有5个球 music.load("bg.mp3") # 加载背景音乐 music.play(-1) # 循环播放背景音乐,直到程序退出 done = False running = True while running: for event in pygame.event.get(): if event.type == pygame.QUIT: running = False if event.type == pygame.MOUSEMOTION: bat.rect.centerx = event.pos[0] if event.type == pygame.KEYDOWN: if event.key == pygame.K_y and lives == 0: lives = 5 done = False elif event.key == pygame.K_n and lives == 0: running = False if not done: ball.move() if pygame.sprite.collide_rect(ball,bat): ball.speed[1] = -10 if pygame.sprite.collide_rect(ball,goal): score += 1 ball.speed[1] = 10 screen.blit(ball.image,ball.rect) screen.blit(bat.image,bat.rect) for num in range(lives-1): screen.blit(ball.image,[600-num*40,0]) if ball.rect.bottom > height: lives -= 1 ball.rect.left,ball.rect.top = 320,240 if lives == 0: done = True else: over_font = pygame.font.Font(None,50) over_surf = over_font.render("Game over",1,[255,0,0]) screen.blit(over_surf,[240,240]) yn_font = pygame.font.Font(None,40) yn_surf = yn_font.render("Y:continue N:quit",1,[255,0,0]) screen.blit(yn_surf,[210,280]) score_font = pygame.font.Font(None,40) score_surf = score_font.render("score:"+str(score),1,[255,0,0]) screen.blit(score_surf,[0,0]) screen.blit(goal.image,goal.rect) pygame.display.update() clock.tick(20) screen.fill([255,255,255]) pygame.quit()基于这些代码补充在游戏界面加一条分割线
pygame.sprite.Sprite.__init__(self) self.image = pygame.image.load(image_file) self.rect = self.image.get_rect() self.rect.left,self.rect.top = location self.speed = speed def move(self): self...
class HeroPlane(pygame.sprite.Sprite): def __init__(self,screen): pygame.sprite.Sprite.__init__(self) #初始化精灵类 self.image1 = pygame.image.load("D:/PYTHON/pointgame/hero1.jpg") self.rect = self.image1.get_rect() #获取图片大小 self.rect.topleft = [300,700] #获取飞机左上角坐标 self.speed = 10 # 飞机速度 self.screen = screen self.screen_rect = self.screen.get_rect() self.bullets = pygame.sprite.Group() #group方法 类似列表 def key_control(self): # 键盘输入 key_pressed = pygame.key.get_pressed() if key_pressed[K_w] or key_pressed[K_UP]: self.rect.top -= self.speed if key_pressed[K_s] or key_pressed[K_DOWN]: self.rect.bottom += self.speed if key_pressed[K_a] or key_pressed[K_LEFT]: self.rect.left -= self.speed if key_pressed[K_d] or key_pressed[K_RIGHT]: self.rect.right += self.speed if key_pressed[K_SPACE]: bullet = Bullet(self.screen,self.rect.left,self.rect.top) #飞机参数调用 self.bullets.add(bullet) #把子弹放入列表 if self.rect.left < 0:# 控制player不能离开屏幕 self.rect.left = 0 elif self.rect.right > self.screen.rect.right: self.rect.right = self.screen.rect.right 错误是 File "D:/PYTHON/pointgame/pointgame.py", line 124, in <module> main() File "D:/PYTHON/pointgame/pointgame.py", line 117, in main player.key_control() File "D:/PYTHON/pointgame/pointgame.py", line 33, in key_control elif self.rect.right > self.screen.rect.right: AttributeError: 'pygame.surface.Surface' object has no attribute 'rect'怎么修改
pygame.sprite.Sprite.__init__(self) #初始化精灵类 self.image1 = pygame.image.load("D:/PYTHON/pointgame/hero1.jpg") self.rect = self.image1.get_rect() #获取图片大小 self.rect.topleft = [300,700] #...
# 设置屏幕宽高 import random import sys import pygame from pygame import QUIT width = 800 height = 600 # 设置下落速度 speed = [15, 30] # 字母大小范围 size = [5, 30] # code长度范围 LEN = [1, 8] # 随机生成颜色 def randomColor(): return random.randint(0, 255), random.randint(0, 255), random.randint(0, 255) # 随机生成一个速度 def randomSpeed(): return random.randint(speed[0], speed[1]) # 随机生成一个长度 def randomSize(): return random.randint(size[0], size[1]) def randomLen(): return random.randint(LEN[0], LEN[1]) # 随机生成一个位置 def randomPos(): return random.randint(0, width), -20 # 随机生成一个字符串 def randomCode(): return random.choice('qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890') # 定义代码精灵类 class Code(pygame.sprite.Sprite): def __init__(self): pygame.sprite.Sprite.__init__(self) # 随机字体大小 self.font = pygame.font.Font('./font.ttf', randomSize()) # 随机速度 self.speed = randomSpeed() # 随机长度 self.code = self.getCode() # 创建位图image返回image值,随机颜色 self.image = self.font.render(self.code, True, randomCode()) self.image = self.transform.rotate(self.image, random.randint(87, 93)) self.rect = self.image.get_rect() self.rect.topleft = randomPos() def getCode(self): length = randomLen() code = '' for i in range(length): code += randomCode() return code def updateCode(self): self.rect = self.rect.move(0, self.speed) if self.rect.top > height: self.kill() pygame.init() # 成成主屏幕screen第一个参数是屏幕大小 screen = pygame.display.set_mode((width, height)) # 窗口命名 pygame.display.set_caption("哈哈哈") # 初始化一个clock对象 clock = pygame.time.Clock() codesGroup = pygame.sprite.Group() while True: clock.tick(24) for event in pygame.event.get(): if event.type == QUIT: pygame.quit() sys.exit(0) screen.fill((0, 0, 0)) codeobject = Code() codesGroup.add(codeobject) codesGroup.update() codesGroup.draw(screen) pygame.display.update()
3. 代码中定义了一个Code类来表示每个下落的字符代码,它继承自pygame.sprite.Sprite类。在类的初始化方法中,通过随机生成的参数来创建字体、速度、长度、颜色等,并使用render方法生成一个位图image作为字符代码的...
CPPC++_PCLPoint Cloud Library点云库学习记录.zip
CPPC++_PCLPoint Cloud Library点云库学习记录
基于Python的百度百科爬虫.zip
基于Python的百度百科爬虫
CSDN会员
开通CSDN年卡参与万元壕礼抽奖
海量
VIP免费资源
千本
正版电子书
商城
会员专享价
千门
课程&专栏
全年可省5,000元
立即开通
全年可省5,000元
立即开通
最新推荐
CPPC++_PCLPoint Cloud Library点云库学习记录.zip
CPPC++_PCLPoint Cloud Library点云库学习记录
基于Python的百度百科爬虫.zip
基于Python的百度百科爬虫
CPPC++_Qt 之 GUI 控件使用 网络 架构原理 运行机制理解DTK 重绘控件方式的框架解析IDE 技巧.zip
CPPC++_Qt 之 GUI 控件使用 网络 架构原理 运行机制理解DTK 重绘控件方式的框架解析IDE 技巧
10020.doc
10020
前端协作项目:发布猜图游戏功能与待修复事项
资源摘要信息:"People-peephole-frontend是一个面向前端开发者的仓库,包含了一个由Rails和IOS团队在2015年夏季亚特兰大Iron Yard协作完成的项目。该仓库中的项目是一个具有特定功能的应用,允许用户通过iPhone或Web应用发布图像,并通过多项选择的方式让用户猜测图像是什么。该项目提供了一个互动性的平台,使用户能够通过猜测来获取分数,正确答案将提供积分,并防止用户对同一帖子重复提交答案。 当前项目存在一些待修复的错误,主要包括: 1. 答案提交功能存在问题,所有答案提交操作均返回布尔值true,表明可能存在逻辑错误或前端与后端的数据交互问题。 2. 猜测功能无法正常工作,这可能涉及到游戏逻辑、数据处理或是用户界面的交互问题。 3. 需要添加计分板功能,以展示用户的得分情况,增强游戏的激励机制。 4. 删除帖子功能存在损坏,需要修复以保证应用的正常运行。 5. 项目的样式过时,需要更新以反映跨所有平台的流程,提高用户体验。 技术栈和依赖项方面,该项目需要Node.js环境和npm包管理器进行依赖安装,因为项目中使用了大量Node软件包。此外,Bower也是一个重要的依赖项,需要通过bower install命令安装。Font-Awesome和Materialize是该项目用到的前端资源,它们提供了图标和界面组件,增强了项目的视觉效果和用户交互体验。 由于本仓库的主要内容是前端项目,因此JavaScript知识在其中扮演着重要角色。开发者需要掌握JavaScript的基础知识,以及可能涉及到的任何相关库或框架,比如用于开发Web应用的AngularJS、React.js或Vue.js。同时,对于iOS开发,可能还会涉及到Swift或Objective-C等编程语言,以及相应的开发工具Xcode。对于Rails,开发者则需要熟悉Ruby编程语言以及Rails框架的相关知识。 开发流程中可能会使用的其他工具包括: - Git:用于版本控制和代码管理。 - HTML/CSS:用于构建网页结构和样式。 - Webpack或Gulp:用于项目构建和优化流程。 - Babel:用于JavaScript代码的兼容性处理。 - Linting工具:如ESLint,用于代码质量检查和维护代码风格一致性。 总结来看,People-peephole-frontend项目不仅涉及到了跨平台协作的经验分享,还提供了前端开发的学习和实践机会,尤其在交互设计、前端工程化、依赖管理及样式设计等方面。开发者可以通过参与该项目的修复和完善工作,提高自身技能并积累宝贵的项目经验。"
管理建模和仿真的文件
管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
【高斯信道信号编码优化】:4大方法优化Chirp信号编码过程
![高斯信道下的chirp信号解调](https://img-blog.csdnimg.cn/d37646d14e4e4b51b01e617b59167c74.png) # 1. 高斯信道与Chirp信号编码基础 ## 简介 在现代通信领域,信息的传递无处不在,而保障信息传递的清晰与高效是通信技术的核心挑战之一。高斯信道作为通信系统中最常见和基础的模型,为我们理解和优化信号传输提供了重要的理论支持。Chirp信号,以其独特的频谱扩展特性,在无线通信、雷达和声纳系统中发挥着越来越重要的作用。本章将介绍高斯信道的特性以及Chirp信号的基础知识,为读者搭建起后续章节深入探讨优化方法的理论基础。
对给定图,实现图的深度优先遍历和广度优先遍历。以邻接表或邻接矩阵为存储结构,实现连通无向图的深度优先和广度优先遍历。以用户指定的结点为起点,分别输出每种遍历下的结点访问序列,并调试算法。使用C语言
在C语言中,我们可以使用邻接表或邻接矩阵来存储图的数据结构。这里我将简单介绍如何实现深度优先搜索(DFS)和广度优先搜索(BFS): **使用邻接表实现:** ```c #include <stdio.h> #include <stdlib.h> typedef struct Node { int val; struct Node* next; } Node; // 创建邻接列表表示图 Node* createAdjacencyList(int numNodes) { // 初始化节点数组 Node** adjList = malloc(sizeof(No
Spring框架REST服务开发实践指南
资源摘要信息: "在本教程中,我们将详细介绍如何使用Spring框架来构建RESTful Web服务,提供对Java开发人员的基础知识和学习参考。" 一、Spring框架基础知识 Spring是一个开源的Java/Java EE全功能栈(full-stack)应用程序框架和 inversion of control(IoC)容器。它主要分为以下几个核心模块: - 核心容器:包括Core、Beans、Context和Expression Language模块。 - 数据访问/集成:涵盖JDBC、ORM、OXM、JMS和Transaction模块。 - Web模块:提供构建Web应用程序的Spring MVC框架。 - AOP和Aspects:提供面向切面编程的实现,允许定义方法拦截器和切点来清晰地分离功能。 - 消息:提供对消息传递的支持。 - 测试:支持使用JUnit或TestNG对Spring组件进行测试。 二、构建RESTful Web服务 RESTful Web服务是一种使用HTTP和REST原则来设计网络服务的方法。Spring通过Spring MVC模块提供对RESTful服务的构建支持。以下是一些关键知识点: - 控制器(Controller):处理用户请求并返回响应的组件。 - REST控制器:特殊的控制器,用于创建RESTful服务,可以返回多种格式的数据(如JSON、XML等)。 - 资源(Resource):代表网络中的数据对象,可以通过URI寻址。 - @RestController注解:一个方便的注解,结合@Controller注解使用,将类标记为控制器,并自动将返回的响应体绑定到HTTP响应体中。 - @RequestMapping注解:用于映射Web请求到特定处理器的方法。 - HTTP动词(GET、POST、PUT、DELETE等):在RESTful服务中用于执行CRUD(创建、读取、更新、删除)操作。 三、使用Spring构建REST服务 构建REST服务需要对Spring框架有深入的理解,以及熟悉MVC设计模式和HTTP协议。以下是一些关键步骤: 1. 创建Spring Boot项目:使用Spring Initializr或相关构建工具(如Maven或Gradle)初始化项目。 2. 配置Spring MVC:在Spring Boot应用中通常不需要手动配置,但可以进行自定义。 3. 创建实体类和资源控制器:实体类映射数据库中的数据,资源控制器处理与实体相关的请求。 4. 使用Spring Data JPA或MyBatis进行数据持久化:JPA是一个Java持久化API,而MyBatis是一个支持定制化SQL、存储过程以及高级映射的持久层框架。 5. 应用切面编程(AOP):使用@Aspect注解定义切面,通过切点表达式实现方法的拦截。 6. 异常处理:使用@ControllerAdvice注解创建全局异常处理器。 7. 单元测试和集成测试:使用Spring Test模块进行控制器的测试。 四、学习参考 - 国际奥委会:可能是错误的提及,对于本教程没有相关性。 - AOP:面向切面编程,是Spring的核心功能之一。 - MVC:模型-视图-控制器设计模式,是构建Web应用的常见架构。 - 道:在这里可能指学习之道,或者是学习Spring的原则和最佳实践。 - JDBC:Java数据库连接,是Java EE的一部分,用于在Java代码中连接和操作数据库。 - Hibernate:一个对象关系映射(ORM)框架,简化了数据库访问代码。 - MyBatis:一个半自动化的ORM框架,它提供了更细致的SQL操作方式。 五、结束语 以上内容为《learnSpring:学习春天》的核心知识点,涵盖了从Spring框架的基础知识、RESTful Web服务的构建、使用Spring开发REST服务的方法,以及与学习Spring相关的技术栈介绍。对于想要深入学习Java开发,特别是RESTful服务开发的开发者来说,这是一份非常宝贵的资源。
"互动学习:行动中的多样性与论文攻读经历"
多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依