Hunting for Bugs in Source Code of Video and Computer Games

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

基本信息

  • 批准号:
    RGPIN-2014-04406
  • 负责人:
  • 金额:
    $ 2.33万
  • 依托单位:
  • 依托单位国家:
    加拿大
  • 项目类别:
    Discovery Grants Program - Individual
  • 财政年份:
    2018
  • 资助国家:
    加拿大
  • 起止时间:
    2018-01-01 至 2019-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
  • 财政年份:
    2017
  • 资助金额:
    $ 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
  • 财政年份:
    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
  • 财政年份:
    2017
  • 资助金额:
    $ 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
  • 财政年份:
    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 }}

知道了