Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
基本信息
- 批准号:RGPIN-2014-04406
- 负责人:
- 金额:$ 2.33万
- 依托单位:
- 依托单位国家:加拿大
- 项目类别:Discovery Grants Program - Individual
- 财政年份:2014
- 资助国家:加拿大
- 起止时间:2014-01-01 至 2015-12-31
- 项目状态:已结题
- 来源:
- 关键词:
项目摘要
The aim of our research is to develop tools to detect bugs in video and computer games. Rather than applying well-known techniques to games, we focus on fundamental problems that are encountered when hunting for bugs in games. Our anticipated solutions will not only impact the game industry but also other application areas and academia. Testing is the most commonly used method to detect bugs. It is particularly effective for deterministic code, i.e., code that for a fixed input gives rise to a single execution. However, in the presence of nondeterminism, i.e., when there are different potential executions, testing is less effective. Running a test multiple times provides no guarantee that different executions have been checked. Also, if a bug has been found, it may be difficult to reproduce. Therefore, to detect bugs in nondeterministic code, methods that complement testing are needed. Model checking is an alternative to testing. Rather than checking a single execution, as is done in testing, model checking attempts to systematically check all potential executions. However, the number of potential executions can be exponential in the number of nondeterministic choices in the code. The fundamental problem of dealing with such a huge number of executions is known as the state space explosion problem. Randomization and concurrency, which are key ingredients of today’s games, both give rise to nondeterminism. Therefore, model checking seems a viable alternative to testing for finding bugs in games. Although numerous model checkers have been developed, we are not aware of any that can verify properties of the source code of games. Our overall aim is to develop the first such model checker. Our main objective is to combat the notorious state space explosion caused by a combination of randomization and concurrency. We focus on model checkers that work directly with the source code. We initially restrict our attention to Java, currently the most popular programming language. Although C++ is most widely used for games, many, in particular online games, are written in Java. For example, according to Guinness World Records, RuneScape, implemented in Java, is the world's most popular free massively multiplayer online role-playing game with more than 200 million registered accounts. The Java code of games contains native calls, i.e., calls which invoke code that is written in a language different from Java. For example, calls related to graphics, networking and sound are usually native. Model checking Java code with native calls usually involves modelling the native code in Java, which is time consuming and error-prone. To make our tools of use to game developers, native calls should be handled automatically. This is our second major objective. Players interact with a game by means of the video game controller, the mouse, the keyboard, etc. In order to model check a game, we need to incorporate a model of the players. Ideally, the models should be built automatically from the source code of the game, so that our tools are easy to use by game developers. Our third objective is to automate the generation of models of the players as much as possible. The Canadian video and computer game industry is among the largest in the world. It contributes almost two billion dollars per year to the Canadian economy. Since our tools will allow game developers to find bugs automatically, they will improve the quality of the games and increase the productivity of game developers. We expect our results to also impact other application areas and academia. For example, tools to find bugs in communication protocols implemented in Java toolkits, which contain numerous native calls, should benefit from our techniques to handle native calls.
我们研究的目的是开发工具来检测视频和电脑游戏中的错误。我们不是将众所周知的技术应用于游戏,而是专注于寻找游戏中的错误时遇到的基本问题。我们预期的解决方案不仅会影响游戏行业,还会影响其他应用领域和学术界。测试是检测错误最常用的方法。它对于确定性代码特别有效,即对于固定输入产生单次执行的代码。然而,在存在不确定性的情况下,即当存在不同的潜在执行时,测试的效率较低。多次运行测试并不能保证已检查不同的执行。此外,如果发现错误,则可能很难重现。因此,为了检测非确定性代码中的错误,需要补充测试的方法。模型检查是测试的替代方法。模型检查不是像测试中那样检查单个执行,而是尝试系统地检查所有潜在的执行。然而,潜在执行的数量可能会随着代码中不确定性选择的数量呈指数级增长。处理如此大量的执行的基本问题被称为状态空间爆炸问题。随机化和并发性是当今游戏的关键要素,两者都会产生不确定性。因此,模型检查似乎是寻找游戏错误的测试的可行替代方案。尽管已经开发了许多模型检查器,但我们还不知道有任何可以验证游戏源代码属性的模型。我们的总体目标是开发第一个此类模型检查器。我们的主要目标是对抗由随机化和并发性组合引起的臭名昭著的状态空间爆炸。我们专注于直接使用源代码的模型检查器。我们最初将注意力集中在当前最流行的编程语言 Java 上。尽管 C++ 最广泛用于游戏,但许多游戏(尤其是在线游戏)是用 Java 编写的。例如,根据吉尼斯世界纪录,用 Java 实现的 RuneScape 是世界上最受欢迎的免费大型多人在线角色扮演游戏,拥有超过 2 亿注册帐户。游戏的 Java 代码包含本机调用,即调用以不同于 Java 的语言编写的代码的调用。例如,与图形、网络和声音相关的调用通常是本机的。使用本机调用对 Java 代码进行模型检查通常涉及对 Java 中的本机代码进行建模,这既耗时又容易出错。为了使我们的工具可供游戏开发人员使用,本机调用应该自动处理。这是我们的第二个主要目标。玩家通过视频游戏控制器、鼠标、键盘等与游戏进行交互。为了对游戏进行模型检查,我们需要合并玩家的模型。理想情况下,模型应该从游戏的源代码自动构建,以便游戏开发者可以轻松使用我们的工具。我们的第三个目标是尽可能自动化地生成玩家模型。加拿大的视频和电脑游戏产业是世界上最大的产业之一。它每年为加拿大经济贡献近20亿美元。由于我们的工具将允许游戏开发者自动发现错误,因此他们将提高游戏的质量并提高游戏开发者的生产力。我们预计我们的结果也会影响其他应用领域和学术界。例如,用于查找 Java 工具包中实现的通信协议中的错误的工具(其中包含大量本机调用)应该受益于我们处理本机调用的技术。
项目成果
期刊论文数量(0)
专著数量(0)
科研奖励数量(0)
会议论文数量(0)
专利数量(0)
数据更新时间:{{ journalArticles.updateTime }}
{{
                item.title }}
{{ item.translation_title }}
- DOI:{{ item.doi }} 
- 发表时间:{{ item.publish_year }} 
- 期刊:
- 影响因子:{{ item.factor }}
- 作者:{{ item.authors }} 
- 通讯作者:{{ item.author }} 
数据更新时间:{{ journalArticles.updateTime }}
{{ item.title }}
- 作者:{{ item.author }} 
数据更新时间:{{ monograph.updateTime }}
{{ item.title }}
- 作者:{{ item.author }} 
数据更新时间:{{ sciAawards.updateTime }}
{{ item.title }}
- 作者:{{ item.author }} 
数据更新时间:{{ conferencePapers.updateTime }}
{{ item.title }}
- 作者:{{ item.author }} 
数据更新时间:{{ patent.updateTime }}
vanBreugel, Franck其他文献
vanBreugel, Franck的其他文献
{{
              item.title }}
{{ item.translation_title }}
- DOI:{{ item.doi }} 
- 发表时间:{{ item.publish_year }} 
- 期刊:
- 影响因子:{{ item.factor }}
- 作者:{{ item.authors }} 
- 通讯作者:{{ item.author }} 
{{ truncateString('vanBreugel, Franck', 18)}}的其他基金
Generating and Checking Probabilistic Models
生成和检查概率模型
- 批准号:RGPIN-2019-06372 
- 财政年份:2022
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
Generating and Checking Probabilistic Models
生成和检查概率模型
- 批准号:RGPIN-2019-06372 
- 财政年份:2021
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
Generating and Checking Probabilistic Models
生成和检查概率模型
- 批准号:RGPIN-2019-06372 
- 财政年份:2020
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:RGPIN-2014-04406 
- 财政年份:2018
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:RGPIN-2014-04406 
- 财政年份:2017
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:RGPIN-2014-04406 
- 财政年份:2016
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:RGPIN-2014-04406 
- 财政年份:2015
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
相似海外基金
CRII: SHF: An Automated and User-centered Framework for Reproducing System-level Concurrency Bugs by Analyzing Bug Reports
CRII:SHF:通过分析错误报告来重现系统级并发错误的自动化且以用户为中心的框架
- 批准号:2348277 
- 财政年份:2024
- 资助金额:$ 2.33万 
- 项目类别:Standard Grant 
CNS Core: Small: Intelligent Fault Injection to Expose and Reproduce Production-Grade Bugs in Cloud Systems
CNS 核心:小型:智能故障注入以暴露和重现云系统中的生产级错误
- 批准号:2317698 
- 财政年份:2023
- 资助金额:$ 2.33万 
- 项目类别:Standard Grant 
CAREER: Leveraging Everyday Usage of Programs to Eliminate Bugs
职业:利用程序的日常使用来消除错误
- 批准号:2333885 
- 财政年份:2023
- 资助金额:$ 2.33万 
- 项目类别:Continuing Grant 
Collaborative Research: Spatial phylogenomics and diet evolution of the megadiverse plant bugs (Hemiptera: Miridae)
合作研究:巨型植物昆虫(半翅目:蝽科)的空间系统发育和饮食进化
- 批准号:2317209 
- 财政年份:2023
- 资助金额:$ 2.33万 
- 项目类别:Standard Grant 
Collaborative Research: Spatial phylogenomics and diet evolution of the megadiverse plant bugs (Hemiptera: Miridae)
合作研究:巨型植物昆虫(半翅目:蝽科)的空间系统发育和饮食进化
- 批准号:2317210 
- 财政年份:2023
- 资助金额:$ 2.33万 
- 项目类别:Standard Grant 
Mining, Intelligence and Automation in Tackling Machine-Learning Bugs
挖掘、智能和自动化解决机器学习缺陷
- 批准号:RGPIN-2021-03236 
- 财政年份:2022
- 资助金额:$ 2.33万 
- 项目类别:Discovery Grants Program - Individual 
Kids, bugs and drugs: Human-microbial relations in everyday family life
孩子、虫子和药物:日常家庭生活中的人类与微生物的关系
- 批准号:DE220101498 
- 财政年份:2022
- 资助金额:$ 2.33万 
- 项目类别:Discovery Early Career Researcher Award 
New Drugs for CF Bugs: testing anti-virulence therapies against Pseudomonas aeruginosa in Cystic Fibrosis
治疗囊性纤维化病菌的新药:测试针对囊性纤维化的铜绿假单胞菌的抗毒力疗法
- 批准号:2749994 
- 财政年份:2022
- 资助金额:$ 2.33万 
- 项目类别:Studentship 
Joint research between Japan and South Korea to explore the essence of the unique   reproductive ecology of giant water bugs
日韩联合研究探索巨型水蝽独特生殖生态本质
- 批准号:22KK0103 
- 财政年份:2022
- 资助金额:$ 2.33万 
- 项目类别:Fund for the Promotion of Joint International Research (Fostering Joint International Research (B)) 
CNS Core: Small: Intelligent Fault Injection to Expose and Reproduce Production-Grade Bugs in Cloud Systems
CNS 核心:小型:智能故障注入以暴露和重现云系统中的生产级错误
- 批准号:2149664 
- 财政年份:2021
- 资助金额:$ 2.33万 
- 项目类别:Standard Grant 

 刷新
              刷新
            
















 {{item.name}}会员
              {{item.name}}会员
            



