Generating and Checking Probabilistic Models
生成和检查概率模型
基本信息
- 批准号:RGPIN-2019-06372
- 负责人:
- 金额:$ 1.68万
- 依托单位:
- 依托单位国家:加拿大
- 项目类别:Discovery Grants Program - Individual
- 财政年份:2020
- 资助国家:加拿大
- 起止时间:2020-01-01 至 2021-12-31
- 项目状态:已结题
- 来源:
- 关键词:
项目摘要
Nowadays, many software systems rely on randomness. For example, it is well known that randomness provides computer games with the ability to surprise players, which is a key factor in their long-term appeal. Randomness is also prominent in machine learning, as exemplified by the use of randomized algorithms such as stochastic gradient descent. Randomness is also ubiquitous in cryptography. These are just three examples that show how pervasive randomness is in today's software.
As Dijkstra wrote half a century ago, “Program testing can be used to show the presence of bugs, but never to show their absence!” Testing is the most commonly used technique to detect bugs in software systems. Software with randomness usually gives rise to multiple, potentially different, executions. Hence, running a test on software with randomness multiple times does not provide any guarantee that different executions are checked. Furthermore, if a bug has been found, reproducing it is difficult. Therefore, in the presence of randomness, techniques complementary to testing are essential for detecting bugs.
Model checking, a technique introduced by Clarke, Emerson, and Sifakis, complements testing in the quest to find bugs. Roughly, this technique consists of three major steps. Firstly, the software system is modeled. The resulting model is usually a state machine, where each state is an abstraction of a snapshot of the system and transitions between states describe all possible ways the system can evolve. Secondly, the properties of interest of the software system are expressed as formulas of a logic. Thirdly, the model checker is run. A model checker is a tool that takes as input a model and a property and attempts to check whether the property is satisfied in the model. Generally, there are three outcomes. Either the model checker confirms that the property holds in the model, or it provides a counterexample demonstrating that the property does not hold (which may indicate a bug in the modeled software system), or it runs out of memory or time.
In this proposal, I focus on models of software systems with randomness, which are often called probabilistic models. Checking properties of such models is known as probabilistic model checking. To evaluate new techniques and tools for probabilistic model checking, researchers either have considered less than a handful of realistic probabilistic models or have used randomly generated probabilistic models. Both approaches have serious shortcomings. The former approach gives us little confidence in the results. The latter approach only gives us useful results if the generated models have the same characteristics as models encountered in practice.
The two goals of my research program are
- developing techniques and tools that support probabilistic model checking, and
- generating realistic instances of probabilistic models to evaluate those techniques and tools.
如今,许多软件系统依赖于随机性。例如,众所周知,随机性为计算机游戏提供了让玩家感到惊讶的能力,这是其长期吸引力的关键因素。随机性在机器学习中也很突出,例如使用随机梯度下降等随机算法。随机性在密码学中也是普遍存在的。这仅仅是三个例子,显示了随机性在当今软件中是多么普遍。
正如Dijkstra在半个世纪前所写的那样,“程序测试可以用来显示bug的存在,但永远不能显示它们的不存在!”测试是检测软件系统中错误的最常用技术。具有随机性的软件通常会产生多个可能不同的执行。因此,在软件上随机多次运行测试并不能保证检查到不同的执行。此外,如果发现了一个bug,复制它是困难的。因此,在存在随机性的情况下,与测试互补的技术对于检测bug是必不可少的。
模型检查是由Clarke、Emerson和Sifakis提出的一种技术,它补充了测试以寻找bug。粗略地说,这项技术包括三个主要步骤。首先,对软件系统进行建模。结果模型通常是一个状态机,其中每个状态都是系统快照的抽象,状态之间的转换描述了系统可以进化的所有可能方式。其次,软件系统的感兴趣的属性被表示为逻辑公式。第三,运行模型检查器。模型检查器是一种工具,它将模型和属性作为输入,并尝试检查模型中是否满足属性。一般来说,有三种结果。模型检查器要么确认属性在模型中成立,要么提供一个反例来证明属性不成立(这可能表明建模的软件系统中存在错误),或者它耗尽内存或时间。
在这个建议中,我专注于具有随机性的软件系统模型,这些模型通常被称为概率模型。检查这些模型的属性被称为概率模型检查。为了评估概率模型检查的新技术和工具,研究人员要么考虑了不到几个现实的概率模型,要么使用了随机生成的概率模型。这两种方法都有严重的缺点。前一种方法使我们对结果没有多少信心。后一种方法只有在生成的模型与实际中遇到的模型具有相同的特征时才能给我们有用的结果。
我的研究计划的两个目标是
- 开发支持概率模型检查的技术和工具,以及
- 生成概率模型的真实实例,以评估这些技术和工具。
项目成果
期刊论文数量(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
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Generating and Checking Probabilistic Models
生成和检查概率模型
- 批准号:
RGPIN-2019-06372 - 财政年份:2021
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:
RGPIN-2014-04406 - 财政年份:2018
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:
RGPIN-2014-04406 - 财政年份:2017
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:
RGPIN-2014-04406 - 财政年份:2016
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:
RGPIN-2014-04406 - 财政年份:2015
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Hunting for Bugs in Source Code of Video and Computer Games
寻找视频和电脑游戏源代码中的错误
- 批准号:
RGPIN-2014-04406 - 财政年份:2014
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
相似海外基金
Probabilistic Checking against Non-Signaling Strategies
针对非信号策略的概率检查
- 批准号:
RGPIN-2019-06236 - 财政年份:2022
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Generating and Checking Probabilistic Models
生成和检查概率模型
- 批准号:
RGPIN-2019-06372 - 财政年份:2022
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Probabilistic Checking against Non-Signaling Strategies
针对非信号策略的概率检查
- 批准号:
RGPIN-2019-06236 - 财政年份:2021
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Generating and Checking Probabilistic Models
生成和检查概率模型
- 批准号:
RGPIN-2019-06372 - 财政年份:2021
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Probabilistic Checking against Non-Signaling Strategies
针对非信号策略的概率检查
- 批准号:
RGPIN-2019-06236 - 财政年份:2020
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Benchmarks for Probabilistic Model Checking
概率模型检查的基准
- 批准号:
542243-2019 - 财政年份:2019
- 资助金额:
$ 1.68万 - 项目类别:
Alexander Graham Bell Canada Graduate Scholarships - Master's
Probabilistic Checking against Non-Signaling Strategies
针对非信号策略的概率检查
- 批准号:
RGPIN-2019-06236 - 财政年份:2019
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Generating and Checking Probabilistic Models
生成和检查概率模型
- 批准号:
RGPIN-2019-06372 - 财政年份:2019
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Grants Program - Individual
Benchmarks for Probabilistic Model Checking
概率模型检查的基准
- 批准号:
539700-2019 - 财政年份:2019
- 资助金额:
$ 1.68万 - 项目类别:
University Undergraduate Student Research Awards
Probabilistic Checking against Non-Signaling Strategies
针对非信号策略的概率检查
- 批准号:
DGECR-2019-00399 - 财政年份:2019
- 资助金额:
$ 1.68万 - 项目类别:
Discovery Launch Supplement