Hunting for Bugs in Source Code of Video and Computer Games

寻找视频和电脑游戏源代码中的错误

基本信息

  • 批准号:
    RGPIN-2014-04406
  • 负责人:
  • 金额:
    $ 2.33万
  • 依托单位:
  • 依托单位国家:
    加拿大
  • 项目类别:
    Discovery Grants Program - Individual
  • 财政年份:
    2017
  • 资助国家:
    加拿大
  • 起止时间:
    2017-01-01 至 2018-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
  • 财政年份:
    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
  • 财政年份:
    2021
  • 资助金额:
    $ 2.33万
  • 项目类别:
    Discovery Grants Program - Individual
Generating and Checking Probabilistic Models
生成和检查概率模型
  • 批准号:
    RGPIN-2019-06372
  • 财政年份:
    2020
  • 资助金额:
    $ 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
  • 财政年份:
    2018
  • 资助金额:
    $ 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
  • 财政年份:
    2016
  • 资助金额:
    $ 2.33万
  • 项目类别:
    Discovery Grants Program - Individual

相似国自然基金

融合细粒度时空态势的农作物害虫子类别辨识及演化分析
  • 批准号:
    62006008
  • 批准年份:
    2020
  • 资助金额:
    24 万元
  • 项目类别:
    青年科学基金项目
疟原虫子孢子募集H因子抑制补体杀伤的成分鉴定及功能研究
  • 批准号:
    81802033
  • 批准年份:
    2018
  • 资助金额:
    21.0 万元
  • 项目类别:
    青年科学基金项目
遗传杂交分析疟原虫子孢子入侵唾液腺相关基因及其功能研究
  • 批准号:
    81601783
  • 批准年份:
    2016
  • 资助金额:
    17.0 万元
  • 项目类别:
    青年科学基金项目
基于代谢组学研究柔嫩艾美耳球虫子孢子能量代谢途径
  • 批准号:
    31302087
  • 批准年份:
    2013
  • 资助金额:
    23.0 万元
  • 项目类别:
    青年科学基金项目
柔嫩艾美耳球虫子孢子入侵关键结构 Moving Junction 的分子基础与功能研究
  • 批准号:
    31201699
  • 批准年份:
    2012
  • 资助金额:
    23.0 万元
  • 项目类别:
    青年科学基金项目

相似海外基金

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
  • 财政年份:
    2018
  • 资助金额:
    $ 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
  • 财政年份:
    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
{{ showInfoDetail.title }}

作者:{{ showInfoDetail.author }}

知道了