Collaborative Research: Expeditions in Computing: The Science of Deep Specification
合作研究:计算探索:深度规范的科学
基本信息
- 批准号:1521539
- 负责人:
- 金额:$ 335.18万
- 依托单位:
- 依托单位国家:美国
- 项目类别:Continuing Grant
- 财政年份:2015
- 资助国家:美国
- 起止时间:2015-12-15 至 2022-11-30
- 项目状态:已结题
- 来源:
- 关键词:
项目摘要
In our interconnected world, software bugs and security vulnerabilities pose enormous costs and risks. The Deep Specification ("DeepSpec", deepspec.org) project addresses this problem by showing how to build software that does what it is supposed to do, no less and (just as important) no more: No unintended backdoors that allow hackers in, no bugs that crash your app, your computer, or your car. "What the software is supposed to do" is called its specification. The DeepSpec project will develop new science, technology, and tools--for specifying what programs should do, for building programs that conform to those specifications, and for verifying that programs do behave exactly as intended. The key enabling technology for this effort is modern interactive proof assistants, which support rigorous mathematical proofs about complex software artifacts. Project activities will focus on core software-systems infrastructure such as operating systems, programming-language compilers, and computer chips, with applications such as elections and voting systems, cars, and smartphones.Better-specified and better-behaved software will benefit us all. Many high-profile security breaches and low-profile intrusions use software bugs as their entry points. Building on decades of previous work, DeepSpec will advance methods for specifying and verifying software so they can be used by the software industry. The project will include workshops and summer schools to bring in industrial collaborators for technology transfer. But the broader use of specifications in engineering also requires software engineers trained in specification and verification--so DeepSpec has a major component in education: the development of introductory and intermediate curriculum in how to think logically about specifications, how to use specifications in building systems-software components, or how to connect to such components. The education component includes textbook and on-line course material to be developed at Princeton, Penn, MIT, and Yale, and to be available for use by students and instructors worldwide. There will also be a summer school to train the teachers who can bring this science to colleges nationwide.Abstraction and modularity underlie all successful hardware and software systems: We build complex artifacts by decomposing them into parts that can be understood separately. Modular decomposition depends crucially on the artful choice of interfaces between pieces. As these interfaces become more expressive, we think of them as specifications of components or layers. Rich specifications based on formal logic are little used in industry today, but a practical platform for working with them will significantly reduce the costs of system implementation and evolution by identifying vulnerabilities, helping programmers understand the behavior of new components, facilitating rigorous change-impact analysis, and supporting maintainable machine-checked verifications that components are correct and fit together correctly. This Expedition focuses on a particularly rich class of specifications, "deep specifications." These impose strong functional correctness requirements on individual components such that they connect together with rigorous composition theorems. The Expedition's goal is to focus the efforts of the programming languages and formal methods communities on developing and using deep specifications in the large. Working in a formal proof management system, the project will concentrate particularly on connecting infrastructure components together at specification interfaces: compilers, operating systems, program analysis tools, and processor architectures.
在我们这个相互关联的世界中,软件漏洞和安全漏洞带来了巨大的成本和风险。 Deep Specification(“DeepSpec”,deepspec.org)项目通过展示如何构建软件来解决这个问题,这些软件做了它应该做的事情,没有更少,也没有更多:没有让黑客进入的意外后门,没有崩溃你的应用程序,你的计算机或你的汽车的错误。 “软件应该做什么”被称为它的规范。 DeepSpec项目将开发新的科学、技术和工具--用于指定程序应该做什么,用于构建符合这些规范的程序,以及用于验证程序是否完全按照预期运行。 这项工作的关键技术是现代交互式证明助手,它支持对复杂软件工件的严格数学证明。 项目活动将集中于核心软件系统基础设施,如操作系统、编程语言编译器和计算机芯片,以及选举和投票系统、汽车和智能手机等应用。 许多高调的安全漏洞和低调的入侵都使用软件漏洞作为切入点。 在之前数十年工作的基础上,DeepSpec将改进指定和验证软件的方法,以便软件行业可以使用它们。 该项目将包括讲习班和暑期学校,以吸引工业合作者进行技术转让。 但是,在工程中更广泛地使用规范也需要在规范和验证方面受过培训的软件工程师-因此DeepSpec在教育方面有一个重要组成部分:开发入门和中级课程,如何逻辑地思考规范,如何在构建系统软件组件时使用规范,或者如何连接到这些组件。 教育部分包括教科书和在线课程材料,将在普林斯顿大学,宾夕法尼亚大学,麻省理工学院和耶鲁大学开发,并提供给世界各地的学生和教师使用。 此外,还将举办暑期学校,培训能够将这门科学带到全国大学的教师。抽象和模块化是所有成功的硬件和软件系统的基础:我们通过将复杂的工件分解为可以单独理解的部分来构建它们。模块化分解关键取决于巧妙地选择部件之间的接口。当这些接口变得更有表现力时,我们将它们视为组件或层的规范。基于形式逻辑的丰富规范在当今的工业中很少使用,但一个实用的平台将通过识别漏洞,帮助程序员理解新组件的行为,促进严格的更改影响分析,并支持维护机器检查验证组件是否正确并正确地配合在一起,从而显着降低系统实现和发展的成本。 本远征集中在一个特别丰富的规格,“深规格。“这些对各个组件施加了强大的功能正确性要求,使它们与严格的组合定理连接在一起。Expedition的目标是将编程语言和形式方法社区的努力集中在开发和使用大规模的深度规范上。 在正式的证明管理系统中工作,该项目将特别关注在规范接口处将基础设施组件连接在一起:编译器,操作系统,程序分析工具和处理器架构。
项目成果
期刊论文数量(10)
专著数量(0)
科研奖励数量(0)
会议论文数量(0)
专利数量(0)
A role for dependent types in Haskell
Haskell 中依赖类型的角色
- DOI:10.1145/3341705
- 发表时间:2019
- 期刊:
- 影响因子:0
- 作者:Weirich, Stephanie;Choudhury, Pritam;Voizard, Antoine;Eisenberg, Richard A.
- 通讯作者:Eisenberg, Richard A.
Type variables in patterns
在模式中键入变量
- DOI:10.1145/3242744.3242753
- 发表时间:2018
- 期刊:
- 影响因子:0
- 作者:Eisenberg, Richard A.;Breitner, Joachim;Peyton Jones, Simon
- 通讯作者:Peyton Jones, Simon
Model-based testing of networked applications
基于模型的网络应用程序测试
- DOI:10.1145/3460319.3464798
- 发表时间:2021
- 期刊:
- 影响因子:0
- 作者:Li, Yishuai;Pierce, Benjamin C;Zdancewic, Steve
- 通讯作者:Zdancewic, Steve
Total Haskell is reasonable Coq
- DOI:10.1145/3167092
- 发表时间:2017-11
- 期刊:
- 影响因子:0
- 作者:Antal Spector-Zabusky;Joachim Breitner;C. Rizkallah;Stephanie Weirich
- 通讯作者:Antal Spector-Zabusky;Joachim Breitner;C. Rizkallah;Stephanie Weirich
A graded dependent type system with a usage-aware semantics
具有使用感知语义的分级依赖类型系统
- DOI:10.1145/3410265
- 发表时间:2021
- 期刊:
- 影响因子:0
- 作者:Choudhury, Pritam;Eades II, Harley;Eisenberg, Richard A.;Weirich, Stephanie
- 通讯作者:Weirich, Stephanie
{{
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 }}
Stephanie Weirich其他文献
Dependently typed programming with singletons
使用单例进行依赖类型编程
- DOI:
- 发表时间:
2013 - 期刊:
- 影响因子:0
- 作者:
R. Eisenberg;Stephanie Weirich - 通讯作者:
Stephanie Weirich
Combining proofs and programs in a dependently typed language
用依赖类型语言组合证明和程序
- DOI:
- 发表时间:
2014 - 期刊:
- 影响因子:0
- 作者:
Chris Casinghino;Vilhelm Sjöberg;Stephanie Weirich - 通讯作者:
Stephanie Weirich
RepLib: a library for derivable type classes
RepLib:可派生类型类的库
- DOI:
- 发表时间:
2006 - 期刊:
- 影响因子:0
- 作者:
Stephanie Weirich - 通讯作者:
Stephanie Weirich
Programming up to Congruence
编程达到一致性
- DOI:
- 发表时间:
2015 - 期刊:
- 影响因子:0
- 作者:
Vilhelm Sjöberg;Stephanie Weirich - 通讯作者:
Stephanie Weirich
Ready, Set, Verify!
准备、设置、验证!
- DOI:
- 发表时间:
2018 - 期刊:
- 影响因子:0
- 作者:
Joachim Breitner;Antal Spector;Li;C. Rizkallah;John Wiegley;Stephanie Weirich - 通讯作者:
Stephanie Weirich
Stephanie Weirich的其他文献
{{
item.title }}
{{ item.translation_title }}
- DOI:
{{ item.doi }} - 发表时间:
{{ item.publish_year }} - 期刊:
- 影响因子:{{ item.factor }}
- 作者:
{{ item.authors }} - 通讯作者:
{{ item.author }}
{{ truncateString('Stephanie Weirich', 18)}}的其他基金
SHF: SMALL:Dependency Tracking and Dependent Types
SHF:SMALL:依赖性跟踪和依赖性类型
- 批准号:
2327738 - 财政年份:2023
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
SHF: Small: Mechanized reasoning for functional programs
SHF:小型:函数式程序的机械化推理
- 批准号:
2006535 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
SHF: Medium: Collaborative Research: The Theory and Practice of Dependent Types in Haskell
SHF:媒介:协作研究:Haskell 中依赖类型的理论与实践
- 批准号:
1703835 - 财政年份:2017
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
STUDENT MENTORING WORKSHOP AT ICFP 2015
ICFP 2015 学生辅导研讨会
- 批准号:
1541646 - 财政年份:2015
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
CIF: Small: Rich Type Inference for Functional Programming
CIF:小型:函数式编程的丰富类型推理
- 批准号:
1319880 - 财政年份:2013
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
CCF-SHF Small: Beyond Algebraic Data Types: Combinatorial Species and Mathematically-Structured Programming
CCF-SHF Small:超越代数数据类型:组合种类和数学结构规划
- 批准号:
1218002 - 财政年份:2012
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
SHF: SMALL: Dependently-typed Haskell
SHF:小:依赖类型的 Haskell
- 批准号:
1116620 - 财政年份:2011
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
Student Travel Support for Programming Language Mentoring Workshop (PLMW 2012)
编程语言指导研讨会的学生旅行支持(PLMW 2012)
- 批准号:
1201858 - 财政年份:2011
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
SHF:Large:Collaborative Research:TRELLYS: Community-Based Design and Implementation of a Dependently Typed Programming Language
SHF:大型:协作研究:TRELLYS:基于社区的依赖类型编程语言的设计和实现
- 批准号:
0910786 - 财政年份:2009
- 资助金额:
$ 335.18万 - 项目类别:
Standard Grant
A Practical Dependently-Typed Functional Programming Language
一种实用的依赖类型函数编程语言
- 批准号:
0702545 - 财政年份:2007
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
相似国自然基金
Research on Quantum Field Theory without a Lagrangian Description
- 批准号:24ZR1403900
- 批准年份:2024
- 资助金额:0.0 万元
- 项目类别:省市级项目
Cell Research
- 批准号:31224802
- 批准年份:2012
- 资助金额:24.0 万元
- 项目类别:专项基金项目
Cell Research
- 批准号:31024804
- 批准年份:2010
- 资助金额:24.0 万元
- 项目类别:专项基金项目
Cell Research (细胞研究)
- 批准号:30824808
- 批准年份:2008
- 资助金额:24.0 万元
- 项目类别:专项基金项目
Research on the Rapid Growth Mechanism of KDP Crystal
- 批准号:10774081
- 批准年份:2007
- 资助金额:45.0 万元
- 项目类别:面上项目
相似海外基金
Expeditions: Collaborative Research: Global Pervasive Computational Epidemiology
探险:合作研究:全球普适计算流行病学
- 批准号:
2151597 - 财政年份:2021
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Understanding the World Through Code
探险:合作研究:通过代码了解世界
- 批准号:
1918839 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Global Pervasive Computational Epidemiology
探险:合作研究:全球普适计算流行病学
- 批准号:
1918614 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Global Pervasive Computational Epidemiology
探险:合作研究:全球普适计算流行病学
- 批准号:
1918626 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Understanding the World Through Code
探险:合作研究:通过代码了解世界
- 批准号:
1918651 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Global Pervasive Computational Epidemiology
探险:合作研究:全球普适计算流行病学
- 批准号:
1918784 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Understanding the World Through Code
探险:合作研究:通过代码了解世界
- 批准号:
1918771 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Understanding the World Through Code
探险:合作研究:通过代码了解世界
- 批准号:
1918889 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Global Pervasive Computational Epidemiology
探险:合作研究:全球普适计算流行病学
- 批准号:
1918770 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant
Expeditions: Collaborative Research: Understanding the World Through Code
探险:合作研究:通过代码了解世界
- 批准号:
1918865 - 财政年份:2020
- 资助金额:
$ 335.18万 - 项目类别:
Continuing Grant