forked from Coq-zh/SF-zh
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Preface.html
555 lines (390 loc) · 24.5 KB
/
Preface.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link href="common/css/sf.css" rel="stylesheet" type="text/css" />
<title>Preface: 前言</title>
<link href="common/jquery-ui/jquery-ui.css" rel="stylesheet">
<script src="common/jquery-ui/external/jquery/jquery.js"></script>
<script src="common/jquery-ui/jquery-ui.js"></script>
<script src="common/toggleproofs.js"></script>
<link href="common/css/lf.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div id="page">
<div id="header">
<div id='logoinheader'><a href='https://coq-zh.github.io/SF-zh/'>
<img src='common/media/image/sf_logo_sm.png' alt='Software Foundations Logo'></a></div>
<div class='booktitleinheader'><a href='index.html'>Volume 1: 逻辑基础</a></div>
<ul id='menu'>
<li class='section_name'><a href='toc.html'>目录</a></li>
<li class='section_name'><a href='coqindex.html'>索引</a></li>
<li class='section_name'><a href='deps.html'>路线</a></li>
</ul>
</div>
<div id="main">
<h1 class="libtitle">Preface<span class="subtitle">前言</span></h1>
<div class="code">
</div>
<div class="doc">
<a name="lab1"></a><h1 class="section">欢迎</h1>
<div class="paragraph"> </div>
这里是<i>'软件基础'</i>系列书籍的起点,本书阐明了可靠软件背后的数学根基。
书中的主题包括基本的逻辑概念、计算机辅助定理证明、Coq 证明助理、
函数式编程、操作语义、用于论证软件的逻辑和技术、静态类型系统、基于性质的随机测试、
以及对实践中 C 代码的验证。
本书可供高年级本科生、研究生、科研工作者及同等学力的广大读者学习参考。
阅读本书无需具备逻辑学、程序语言等背景知识,但一定的数学基础有助于理解书中内容。
<div class="paragraph"> </div>
本书最大的创新之处在于,书中全文均已形式化并由机器检验。换言之,本书内容即为
Coq 脚本,可在 Coq 的交互界面下阅读。书中大部分习题也在 Coq 中完成。
<div class="paragraph"> </div>
本书中的文件都经过了精心组织:核心章节作为主线贯穿始终,涵盖了一学期的内容;
“支线”中则包含附加的主题。所有核心章节都适合高年级本科生和研究生学习。
<div class="paragraph"> </div>
本书为第一卷<i>'《逻辑基础》'</i>,它向读者介绍了函数式编程的基本概念、构造逻辑以及
Coq 证明助理,为其余诸卷的学习奠定了基础。
</div>
<div class="doc">
<a name="lab2"></a><h1 class="section">概览</h1>
<div class="paragraph"> </div>
构建可靠的软件非常,非常地困难。现代系统的规模、复杂度、参与构建过程的人数,
还有置于系统之上的需求范围,让构建或多或少地正确的软件变得极为困难,
更不用说百分之百地正确了。同时,由于信息处理技术继续渗透到社会的各个层面,
人们为程序错误和漏洞付出的代价变得越来越高昂。
<div class="paragraph"> </div>
为了应对这些挑战,计算机科学家和软件工程师们发展了一套完整的提升软件质量的方法,
从为管理软件项目的团队提供建议(如极限编程,Extreme Programming),
到库的设计原理(如模型-视图-控制器,Model-View-Controller;发布-订阅模式,
Publish-Subscribe)以及编程语言的设计哲学(面向对象编程,Object Oriented Programmin;
面向剖面编程,Aspect Oriented Programming;函数式编程,Functional Programming),
还有用于阐明和论证软件性质的数学技术,以及验证这些性质的工具。
<i>'《软件基础》'</i>系列着重于最后一种方法。
<div class="paragraph"> </div>
本书将以下三种概念穿插在一起:
<div class="paragraph"> </div>
(1)<i>'逻辑学'</i>中的基本工具,用于准确地提出并论证关于程序的假设;
<div class="paragraph"> </div>
(2)<i>'证明助理'</i>用于构造严谨的逻辑论据;
<div class="paragraph"> </div>
(3)<i>'函数式编程'</i>思想,同时作为一种编程方法来简化程序的论证,
以及架起程序和逻辑学之间的桥梁。
<div class="paragraph"> </div>
<a name="lab3"></a><h2 class="section">逻辑学</h2>
<div class="paragraph"> </div>
逻辑学是研究<i>'证明'</i>的领域,即对特定命题的真伪性进行不容置疑的论证。
有关逻辑学在计算机科学中核心作用的书卷汗牛充栋。Manna 和 Waldinger
称之为“计算机科学的微积分”,而 Halpern 的论文
<i>'On the Unusual Effectiveness of Logic in Computer Science'</i>
中则收录了大量逻辑学为计算机科学提供的洞察力和至关重要的工具。
的确,他们发现:“实际上,逻辑学对计算机科学来说远比在数学中更加有效。
这相当引人注目,特别是过去一百年来,逻辑学发展的动力大都来自于数学。”
<div class="paragraph"> </div>
具体来说,<i>'归纳证明'</i>的基本概念在计算机科学中无处不在。
你以前肯定见过它们,比如说在离散数学或算法分析中。不过在本课程中,
我们会在你未曾涉及的深度下对它进行探讨。
<div class="paragraph"> </div>
<a name="lab4"></a><h2 class="section">证明助理</h2>
<div class="paragraph"> </div>
逻辑学和计算机科学之间的思想交流并不是单向的,
计算机科学也为逻辑学做出了重要的贡献,
其中之一就是发展了帮助逻辑命题构造证明的软件工具。
这些工具分为两大类:
<div class="paragraph"> </div>
<ul class="doclist">
<li> <i>'自动定理证明器'</i> 提供了一键式操作:它们接受一个命题,
然后返回<i>'真'</i>或<i>'假'</i>(有时为<i>'未知:超时'</i> )。
尽管它们的能力仅限于特定种类的推理,然而在近几年却快速成熟,
并应用到了多种场景中。此类工具包括 SAT 求解器,SMT 求解器以及模型检查器
(Model Checker)。
<div class="paragraph"> </div>
</li>
<li> <i>'证明助理'</i> 是一种混合式工具,它能将证明的构建中比较常规的部分自动化,
而更加困难的部分则依赖人类来解决。广泛使用的证明助理包括
Isabelle、Agda、Twelf、ACL2、PVS 以及 Coq 等等。
</li>
</ul>
<div class="paragraph"> </div>
本课程围绕 Coq 展开,它是个自 1983 年以来主要在法国开发的证明助理,
近年来吸引了大量来自研究机构和业界的社区用户。
Coq 为机器验证的形式化论证的交互式开发提供了丰富的环境。Coq
系统的内核是一个简单的证明检查器,它保证只会执行正确的推理步骤。
在此内核之上,Coq 环境提供了高级的证明开发功能,包括一个庞大的库,
其中包含各种定义和引理;强大策略,用于半自动化构造证明;
还有一个专用的编程语言,能够为特殊情况定义新的自动证明策略。
<div class="paragraph"> </div>
Coq 已成为跨计算机科学和数学研究的关键推动者:
<div class="paragraph"> </div>
<ul class="doclist">
<li> 作为一个<i>'编程语言的建模平台'</i>,
Coq 成为了研究员对复杂的语言定义进行描述和论证的标准工具。
例如,它被用来检查 JavaCard 平台的安全性,得到了最高等级的通用准则验证,
它还被用在 x<sub>86</sub> 和 LLVM 指令集以及 C 等编程语言的形式化规范中。
<div class="paragraph"> </div>
</li>
<li> 作为一个<i>'形式化软件验证的开发环境'</i>,Coq 被用来构建:
CompCert,一个完全验证的 C 优化编译器;
CertiKos,一个完全验证的工具,用于证明涉及浮点数的精妙算法的正确性;
Coq 也是 CertiCrypt 的基础,一个用于论证密码学算法安全性的环境。
Coq 还被用来构建开源 RISC-V 处理器架构的验证实现。
<div class="paragraph"> </div>
</li>
<li> 作为一个<i>'依赖类型函数式编程的现实环境'</i>,Coq 激发了大量的创新。
例如 Ynot 系统嵌入了“关系式霍尔推理”(一个 <i>'霍尔逻辑'</i> 的扩展,
我们之后会看到它)。
<div class="paragraph"> </div>
</li>
<li> 作为一个<i>'高阶逻辑的证明助理'</i>,Coq 被用来验证数学中一些重要的结果。
例如 Coq 可在证明中包含复杂计算的能力,使其开发出了第一个形式化验证的四色定理证明。
此前数学家们对该证明颇有争议,因为它需要用程序对大量组态进行检验。
在 Coq 的形式化中,所有东西都被检验过,自然也包括计算的正确性。
近年来,Feit-Thompson 定理经过了更大的努力用 Coq 形式化了,
它是对有限单群进行分类的十分重要的第一步。
</li>
</ul>
<div class="paragraph"> </div>
顺便一提,如果你对 Coq 这个名字感到好奇,INRIA (法国国家研究实验室,Coq
主要在这里开发)上的 Coq 官方网站给出了解释:
“一些法国计算机科学家有用动物命名软件的传统:像 Caml、Elan、Foc、Phox
都心照不宣地遵循这种默契。在法国,“Coq”是雄鸡,发音也像构造演算
(Calculus of Constructions)的首字母缩写(CoC),它是 Coq 的基础。”
高卢雄鸡是法国的象征。C-o-q 还是 Thierry Coquand 名字的前三个字母,
他是 Coq 的早期开发者之一。
<div class="paragraph"> </div>
<a name="lab5"></a><h2 class="section">函数式编程</h2>
<div class="paragraph"> </div>
<i>'函数式编程'</i>不仅表示可以在几乎任何编程语言中使用的各种习语(Idiom),
还代表着一族以这些习语为侧重点设计的编程语言,包括
Haskell、OCaml、Standard ML、F#、Scala、Scheme、Racket、Common Lisp、Erlang
还有 Coq。
<div class="paragraph"> </div>
函数式编程已经有数十年的历史了--实际上,它甚至可以追溯到 1930
年代 Church 发明的 λ-演算,那时还没有电子计算机呢!自 90 年代初以来,
函数式编程激起了业内软件工程师和语言设计者浓厚的兴趣,它们还在
Jane Street Capital、Microsoft、Facebook、Twitter 和 Ericsson
等公司的高价值系统中发挥着关键的作用。
<div class="paragraph"> </div>
函数式编程最根本的原则是,计算应当尽可能地<i>'纯粹'</i>,也就是说,
执行代码的唯一作用应当是只产生一个结果。计算应当没有<i>'副作用'</i>,
即它与输入/输出、可变量的赋值、指针重定向等相分离。例如,<i>'指令式'</i>
的排序函数会接受一个数字列表,通过重组指针使列表得以排序;
而一个纯粹的排序函数则会接受一个列表,返回一个含有同样数字,
但是已经排序的新列表。
<div class="paragraph"> </div>
这种编程风格最明显的好处之一,就是它能让程序变得更容易理解和论证。
如果对某个数据结构的所有操作都会返回新的数据结构,而旧有的结构没有变动,
那么我们便无需担心它的共享方式,因为程序中一部分的改变并不会破坏另一部分的属性。
在并发程序中,线程间共享的每一个可变状态都是致命 Bug 的潜在来源,
因此这方面的考虑尤为关键。事实上,业界最近对函数式编程的兴趣大部分来源于此,
即它在并发中表现出的简单行为。
<div class="paragraph"> </div>
人们对函数式编程感到兴奋的另一原因与前文所述的原因相关:
函数式程序通常比指令式程序更容易并行化和物理分布式化。
如果一个计算除了产生结果之外没有其它的作用,那么它在 <i>'何时'</i>
执行便不再重要。同样,如果一个数据结构不会被破坏性地修改,
那么它可以跨核心或网络地被随意复制。其实,“映射-归约”(Map-Reduce)
的惯用法就是函数式编程的经典例子,它在大规模分布式查询处理器(如 Hadoop)
中处于核心地位,并被 Google 用来索引整个互联网。
<div class="paragraph"> </div>
对本课程而言,函数式编程还有另一个重要的吸引力:
它在逻辑和计算机科学之间架起了一座桥梁。事实上,Coq
本身即可视作一个小巧却有着极强表达能力的函数式编程语言,
以及一组用于陈述和证明逻辑断言的工具的结合体。进而言之,
当我们更加深入地审视它时,会发现 Coq 的这两方面其实基于完全相同的底层机制 --
<i>'命题即类型,程序即证明'</i>,可谓殊途同归。
</div>
<div class="doc">
<a name="lab6"></a><h2 class="section">扩展阅读</h2>
<div class="paragraph"> </div>
本书旨在自成一体,不过想要对特定主题进行深入研究的读者,可以在
<a href="Postscript.html"><span class="inlineref">Postscript</span></a> 一章中找到推荐的扩展阅读。所有引用的参考文献可在
<a href="Bib.html"><span class="inlineref">Bib</span></a> 文件中找到。
</div>
<div class="doc">
<a name="lab7"></a><h1 class="section">实践指南</h1>
<div class="paragraph"> </div>
<a name="lab8"></a><h2 class="section">系统要求</h2>
<div class="paragraph"> </div>
Coq 可以在 Windows、Linux 和 macOS 上运行。我们需要:
<div class="paragraph"> </div>
<ul class="doclist">
<li> 安装近期版本的 Coq,它可以从 Coq 主页获得。本书中的文件均已通过了
Coq 8.9.1 的测试。
<div class="paragraph"> </div>
</li>
<li> 一个能跟 Coq 交互的 IDE。目前有两种选择:
<div class="paragraph"> </div>
<ul class="doclist">
<li> Proof General 是一个基于 Emacs 的 IDE,Emacs 用户应该更喜欢这个。
它需要单独安装(Google 搜索“Proof General”)。
<div class="paragraph"> </div>
爱冒险的 Emacs 用户也可以试试 <span class="inlinecode"><span class="id" title="var">company</span>-<span class="id" title="var">coq</span></span> 和 <span class="inlinecode"><span class="id" title="var">control</span>-<span class="id" title="var">lock</span></span>
之类的扩展。
<div class="paragraph"> </div>
</li>
<li> CoqIDE 是个更加简单的独立 IDE。它随 Coq 一起发布,
所以如果你安装了 Coq,它应该就能用。你也可以从头编译安装它,
不过在某些平台上还需要额外安装 GUI 之类的库。
<div class="paragraph"> </div>
用户在运行 CoqIDE 时可以考虑关闭“异步”和“错误恢复”模式:
<br/>
<span class="inlinecode"> <span class="id" title="var">coqide</span> -<span class="id" title="var">async</span>-<span class="id" title="var">proofs</span> <span class="id" title="var">off</span> -<span class="id" title="var">async</span>-<span class="id" title="var">proofs</span>-<span class="id" title="var">command</span>-<span class="id" title="var">error</span>-<span class="id" title="var">resilience</span> <span class="id" title="var">off</span> <span class="id" title="var">Foo.v</span> &
<div class="paragraph"> </div>
</span>
</li>
</ul>
</li>
</ul>
<div class="paragraph"> </div>
<a name="lab9"></a><h2 class="section">练习</h2>
<div class="paragraph"> </div>
每一章都包含大量的习题。每个习题都有标有“星级”,其含义是:
<div class="paragraph"> </div>
<ul class="doclist">
<li> 一星:很简单习题,强调课程的重点。对于大部分读者而言,
一两分钟应该足够了。养成看到一个做一个的习惯。
<div class="paragraph"> </div>
</li>
<li> 二星:直截了当的习题(5 到 10 分钟)。
<div class="paragraph"> </div>
</li>
<li> 三星:需要一点思考的习题(10 分钟到半小时)。
<div class="paragraph"> </div>
</li>
<li> 四或五星:更加困难的习题(半小时以上)。
</li>
</ul>
<div class="paragraph"> </div>
Those using SF in a classroom setting should note that the autograder
assigns extra points to harder exercises:
<br/>
<span class="inlinecode"> 1 <span class="id" title="var">star</span> = 1 <span class="id" title="var">point</span><br/>
2 <span class="id" title="var">stars</span> = 2 <span class="id" title="var">points</span><br/>
3 <span class="id" title="var">stars</span> = 3 <span class="id" title="var">points</span><br/>
4 <span class="id" title="var">stars</span> = 6 <span class="id" title="var">points</span><br/>
5 <span class="id" title="var">stars</span> = 10 <span class="id" title="var">points</span>
<div class="paragraph"> </div>
</span> 有些习题标注为“进阶”,有些习题标注为“可选”。
只做非进阶、非可选的习题已经能将核心概念掌握得很不错了。
可选习题会对一些关键概念提供额外的练习,还有一些读者可能会感兴趣的次级主题。
进阶练习则留给想要更多挑战和更深理解的读者。
<div class="paragraph"> </div>
<span class="loud"> <i>'请勿公布习题解答!'</i> </span>
<div class="paragraph"> </div>
《软件基础》已被广泛地用作自学教程和大学课程。如果习题解答很容易获得,
那么本书的效用将大打折扣,对于会为作业评分的大学课程来说尤其如此。
我们特别请求读者,切勿将习题答案放在任何能够被搜索引擎找到的地方。
<div class="paragraph"> </div>
<a name="lab10"></a><h2 class="section">下载 Coq 文件</h2>
<div class="paragraph"> </div>
本书的“英文发布版”以及所有源代码的压缩包
(其中包含一组 Coq 脚本和 HTML 文件)可访问
<a href="https://softwarefoundations.cis.upenn.edu"><span class="inlineref">https://softwarefoundations.cis.upenn.edu</span></a> 获取。
<div class="paragraph"> </div>
本书的中文版和压缩包可访问 <a href="https://github.com/Coq-zh/SF-zh"><span class="inlineref">https://github.com/Coq-zh/SF-zh</span></a> 获取。
<div class="paragraph"> </div>
如果你是在一门课程中使用本书的,那么你的教授可能会让你使用本地的修改版,
此时你应当使用它们而非发布版,这样你可以获得所有该学期的本地更新。
<div class="paragraph"> </div>
<a name="lab11"></a><h2 class="section">章节依赖</h2>
<div class="paragraph"> </div>
章节之间的依赖关系图以及建议的学习路线可以在文件
<a href="deps.html"><span class="inlineref"><span class="inlinecode"><span class="id" title="var">deps.html</span></span></span></a>
中查看。
</div>
<div class="doc">
<a name="lab12"></a><h2 class="section">推荐的引用格式</h2>
<div class="paragraph"> </div>
如果你想在自己的作品中引用本书,请采用以下格式:
<br/>
<span class="inlinecode"> @<span class="id" title="var">book</span> {Pierce:<span class="id" title="var">SF</span>1,<br/>
<span class="id" title="var">author</span> = {Benjamin C. Pierce and Arthur Azevedo de Amorim and
Chris Casinghino and Marco Gaboardi and
Michael Greenberg and Cătălin Hriţcu and
Vilhelm Sjöberg and Brent Yorgey},<br/>
<span class="id" title="var">title</span> = "逻辑基础",<br/>
<span class="id" title="var">series</span> = "Software Foundations",<br/>
<span class="id" title="var">volume</span> = "1",<br/>
<span class="id" title="var">year</span> = "2021",<br/>
<span class="id" title="var">publisher</span> = "Electronic textbook",<br/>
<span class="id" title="var">note</span> = {<span class="id" title="var">Version</span> 5.7, \<span class="id" title="var">URL</span>{<span class="id" title="var">http</span>://<span class="id" title="var">softwarefoundations.cis.upenn.edu</span>} },<br/>
}
<div class="paragraph"> </div>
</span>
</div>
<div class="doc">
<a name="lab13"></a><h1 class="section">资源</h1>
<div class="paragraph"> </div>
<a name="lab14"></a><h2 class="section">模拟题</h2>
<div class="paragraph"> </div>
宾夕法尼亚大学的 CIS500(软件基础)课程提供了大量的考试大纲,可访问
<a href="https://www.seas.upenn.edu/~cis500/current/exams/index.html"><span class="inlineref">https://www.seas.upenn.edu/~cis500/current/exams/index.html</span></a> 获取。
近年来书中的记法有所变动,但大部分问题仍与本文对应。
<div class="paragraph"> </div>
<a name="lab15"></a><h2 class="section">课程视频</h2>
<div class="paragraph"> </div>
<i>'《逻辑基础》'</i>夏季加强班(DeepSpec 夏季班系列之一)的课程讲义可访问
<a href="https://deepspec.org/event/dsss17"><span class="inlineref">https://deepspec.org/event/dsss17</span></a> 和 <a href="https://deepspec.org/event/dsss18/"><span class="inlineref">https://deepspec.org/event/dsss18/</span></a>
获取。2017 年的视频清晰度不高,但在之后的课程中会更好。
</div>
<div class="doc">
<a name="lab16"></a><h1 class="section">对授课员的要求</h1>
<div class="paragraph"> </div>
如果您有意用这些课件授课,那肯定会发现希望改进、提高或增加的材料。
我们欢迎您的贡献!
<div class="paragraph"> </div>
为保证法律上的简单性和单一责任制,任何情况下都不应出现许可协议条款的的调整,
授权的转移等等,我们要求所有贡献者(即,任何可访问开发者仓库的人)根据
“作者记录”为他们的贡献赋予如下版权信息:
<div class="paragraph"> </div>
<ul class="doclist">
<li> I hereby assign copyright in my past and future contributions
to the Software Foundations project to the Author of Record of
each volume or component, to be licensed under the same terms
as the rest of Software Foundations. I understand that, at
present, the Authors of Record are as follows: For Volumes 1
and 2, known until 2016 as "Software Foundations" and from
2016 as (respectively) "Logical Foundations" and "Programming
Foundations," and for Volume 4, "QuickChick: Property-Based
Testing in Coq," the Author of Record is Benjamin C. Pierce.
For Volume 3, "Verified Functional Algorithms", the Author of
Record is Andrew W. Appel. For components outside of
designated volumes (e.g., typesetting and grading tools and
other software infrastructure), the Author of Record is
Benjamin Pierce.
</li>
</ul>
<div class="paragraph"> </div>
要参与贡献,请向 Benjamin Pierce 发送一封电子邮件,
介绍一下自己,说明你打算如何使用这些材料,信中需包含
(1) 上面的版权移交文本,以及 (2) 你的 Github 用户名。
<div class="paragraph"> </div>
我们会赋予你访问 Git 源码库和开发者邮件列表的权限。你可以在源码库中找到
<span class="inlinecode"><span class="id" title="var">INSTRUCTORS</span></span> 文件获取更多指示。
</div>
<div class="doc">
<a name="lab17"></a><h1 class="section">译本</h1>
<div class="paragraph"> </div>
感谢翻译志愿者团队的努力,<i>'《软件基础》'</i>
已有日文版可以享用 <a href="http://proofcafe.org/sf"><span class="inlineref">http://proofcafe.org/sf</span></a>。
中文版还在填坑= =||
</div>
<div class="doc">
<a name="lab18"></a><h1 class="section">鸣谢</h1>
<div class="paragraph"> </div>
<i>'《软件基础》'</i> 系列的开发,部分由国家科学基金会
(National Science Foundation)在 NSF 科研赞助 1521523 号
<i>'深度规范科学'</i> 下提供支持。
</div>
<div class="code">
<br/>
<span class="comment">(* 2021-08-22 05:49:25 (UTC+00) *)</span><br/>
</div>
</div>
<div id="footer">
<hr/><a href="coqindex.html">Index</a><hr/>This page has been generated by <a href="http://coq.inria.fr/">coqdoc</a>
</div>
</div>
</body>
</html>