-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathvkr.bib
591 lines (554 loc) · 20.9 KB
/
vkr.bib
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
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
% !TeX spellcheck = ru_RU
@online{koznov,
author = { Д.~В.~Кознов},
title = {Слайды},
url = {https://drive.google.com/drive/folders/1yyhnycFC-LpT6d6aIy9-lW7dM8lWkL7w?usp=sharing},
urldate = {\DTMdate{2023-12-16}},
language = {russian}
}
@incollection{SPJGreatTalk,
author = {Simon Peyton Jones},
title = {How to Give a Great Research Talk},
url = {https://www.microsoft.com/en-us/research/academic-program/give-great-research-talk/},
urldate ={\DTMdate{2021-11-21}},
}
@incollection{SPJGreatPaper,
author = {Simon Peyton Jones},
title = {How to Write a Great Research Paper},
url = {https://www.microsoft.com/en-us/research/academic-program/write-great-research-paper/},
urldate = {\DTMdate{2021-11-21}},
}
@incollection{DreyerYoutube2020,
author = {Derek Dreyer},
title = {How To Write Papers So People Can Read Them},
url = {https://www.youtube.com/watch?v=XpgJ31GKPWI},
urldate = {\DTMdate{2021-11-21}},
year = {2020},
}
@incollection{JhalaYoutube2020,
author = {Ranjit Jhala},
title = {How to Design Talks},
url = {https://www.youtube.com/watch?v=aFT79TmffPk},
urldate ={\DTMdate{2021-11-21}},
year = {2020},
}
@online{SemenI,
author = { С.~В.~Григорьев},
title = {Как (не)надо писать тексты ВКР},
url = {https://youtu.be/hRh-7iMVliY?si=aNIJUVwC7WBk7IKo},
urldate = {\DTMdate{2024-10-28}},
language = {russian}
}
@online{SemenII,
author = { С.~В.~Григорьев},
title = {Как готовить презентацию},
url = {https://www.youtube.com/watch?v=X1NF8QgssYc},
urldate = {\DTMdate{2024-10-28}},
language = {russian}
}
@online{SmirnovCheatsheet,
author = { К.~К.~Смирнов},
title = {Шпаргалка о проведении экспериментов},
url = {https://github.com/spbu-se/measurements},
urldate = {\DTMdate{2024-01-16}},
language = {russian}
}
@inproceedings{HC,
author = {Filli\^{a}tre, Jean-Christophe and Conchon, Sylvain},
title = {Type-safe Modular Hash-consing},
booktitle = {Proceedings of the 2006 Workshop on ML},
series = {ML '06},
year = {2006},
isbn = {1-59593-483-9},
location = {Portland, Oregon, USA},
pages = {12--19},
numpages = {8},
url = {http://doi.acm.org/10.1145/1159876.1159880},
doi = {10.1145/1159876.1159880},
acmid = {1159880},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {data structures, hash-consing, sharing},
}
@Inbook{CalculatingFP,
author="Gibbons, Jeremy",
editor="Backhouse, Roland
and Crole, Roy
and Gibbons, Jeremy",
title="Calculating Functional Programs",
bookTitle="Algebraic and Coalgebraic Methods in the Mathematics of Program Construction: International Summer School and Workshop Oxford, UK, April 10--14, 2000 Revised Lectures",
year="2002",
publisher="Springer Berlin Heidelberg",
address="Berlin, Heidelberg",
pages="151--203",
abstract="Functional programs are merely equations; they may be manipulated by straightforward equational reasoning. In particular, one can use this style of reasoning to calculate programs, in the same way that one calculates numeric values in arithmetic. Many useful theorems for such reasoning derive from an algebraic view of programs, built around datatypes and their operations. Traditional algebraic methods concentrate on initial algebras, constructors, and values; dual co-algebraic methods concentrate on final co-algebras, destructors, and processes. Both methods are elegant and powerful; they deserve to be combined.",
isbn="978-3-540-47797-6",
doi="10.1007/3-540-47797-7_5",
url="https://doi.org/10.1007/3-540-47797-7_5",
}
@book{MMM,
author = {Brooks,Jr., Frederick P.},
title = {The Mythical Man-month (Anniversary Ed.)},
year = {1995},
isbn = {0-201-83595-9},
publisher = {Addison-Wesley Longman Publishing Co., Inc.},
address = {Boston, MA, USA},
}
@misc{PPXLib,
title = {ppxlib},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/ocaml-ppx/ppxlib}}
}
@misc{Camlp5,
title = {camlp5},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://camlp5.github.io}}
}
@article{Staged,
author = {Yallop, Jeremy},
title = {Staged Generic Programming},
journal = {Proc. ACM Program. Lang.},
issue_date = {September 2017},
volume = {1},
number = {ICFP},
month = aug,
year = {2017},
issn = {2475-1421},
pages = {29:1--29:29},
articleno = {29},
numpages = {29},
url = {http://doi.acm.org/10.1145/3110273},
doi = {10.1145/3110273},
acmid = {3110273},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {generic programming, metaprogramming, multi-stage programming, partial evaluation},
}
@article{Visitors,
author = {Pottier, Fran\c{c}ois},
title = {Visitors Unchained},
journal = {Proc. ACM Program. Lang.},
issue_date = {September 2017},
volume = {1},
number = {ICFP},
month = aug,
year = {2017},
issn = {2475-1421},
pages = {28:1--28:28},
articleno = {28},
numpages = {28},
url = {http://doi.acm.org/10.1145/3110272},
doi = {10.1145/3110272},
acmid = {3110272},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {abstract syntax trees, binding constructs, boilerplate, names, traversals},
}
@Inproceedings{GenericOCaml,
author = {Balestrieri, Florent and Mauny, Michel},
year = {2018},
title = {Generic Programming in OCaml},
editor = {Asai, Kenichi and Shinwell, Mark},
booktitle = {{\rm Proceedings}
ML Family Workshop / OCaml Users and Developers workshops,
{\rm Nara, Japan, September 22-23, 2016}},
series = {Electronic Proceedings in Theoretical Computer Science},
volume = {285},
publisher = {Open Publishing Association},
pages = {59-100},
doi = {10.4204/EPTCS.285.3},
}
@inproceedings{Yallop,
author = {Yallop, Jeremy},
title = {Practical Generic Programming in OCaml},
booktitle = {Proceedings of the 2007 Workshop on Workshop on ML},
series = {ML '07},
year = {2007},
isbn = {978-1-59593-676-9},
location = {Freiburg, Germany},
pages = {83--94},
numpages = {12},
url = {http://doi.acm.org/10.1145/1292535.1292548},
doi = {10.1145/1292535.1292548},
acmid = {1292548},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {OCaml, deriving, generic programming},
}
@INPROCEEDINGS{PolyVar,
author = {Jacques Garrigue},
title = {Programming with Polymorphic Variants},
booktitle = {Workshop on ML},
year = {1998}
}
@INPROCEEDINGS{PolyVarReuse,
author = {Jacques Garrigue},
title = {Code reuse through polymorphic variants},
booktitle = {In Workshop on Foundations of Software Engineering},
year = {2000}
}
@InProceedings{OCamlRemy,
author="R{\'e}my, Didier",
editor="Barthe, Gilles
and Dybjer, Peter
and Pinto, Lu{\'i}s
and Saraiva, Jo{\~a}o",
title="Using, Understanding, and Unraveling the OCaml Language From Practice to Theory and Vice Versa",
booktitle="Applied Semantics",
year="2002",
publisher="Springer Berlin Heidelberg",
address="Berlin, Heidelberg",
pages="413--536",
abstract="These course notes are addressed to a wide audience of people interested in modern programming languages in general, ML-like languages in particular, or simply in OCaml, whether they are programmers or language designers, beginners or knowledgeable readers ---little pre-requiresite is actually assumed.",
isbn="978-3-540-45699-5"
}
@INPROCEEDINGS{Bananas,
author = {Erik Meijer and Maarten Fokkinga and Ross Paterson},
title = {Functional Programming with Bananas, Lenses, Envelopes and Barbed Wire},
booktitle = {},
year = {1991},
pages = {124--144},
publisher = {Springer-Verlag}
}
@Article{AGKnuth,
author="Knuth, Donald E.",
title="Semantics of context-free languages",
journal="Mathematical systems theory",
year="1968",
month="Jun",
day="01",
volume="2",
number="2",
pages="127--145",
abstract="``Meaning'' may be assigned to a string in a context-free language by defining ``attributes'' of the symbols in a derivation tree for that string. The attributes can be defined by functions associated with each production in the grammar. This paper examines the implications of this process when some of the attributes are ``synthesized'', i.e., defined solely in terms of attributes of thedescendants of the corresponding nonterminal symbol, while other attributes are ``inherited'', i.e., defined in terms of attributes of theancestors of the nonterminal symbol. An algorithm is given which detects when such semantic rules could possibly lead to circular definition of some attributes. An example is given of a simple programming language defined with both inherited and synthesized attributes, and the method of definition is compared to other techniques for formal specification of semantics which have appeared in the literature.",
issn="1433-0490",
doi="10.1007/BF01692511",
url="https://doi.org/10.1007/BF01692511"
}
@inproceedings{InstantGenerics,
title={Instant Generics : Fast and Easy},
author={Manuel M. T. Chakravarty and Gabriel Ditu and Roman Leshchinskiy},
year={2009}
}
@inproceedings{AGSwierstra,
author = {Viera, Marcos and Swierstra, S. Doaitse and Swierstra, Wouter},
title = {Attribute Grammars Fly First-class: How to Do Aspect Oriented Programming in Haskell},
booktitle = {Proceedings of the 14th ACM SIGPLAN International Conference on Functional Programming},
series = {ICFP '09},
year = {2009},
isbn = {978-1-60558-332-7},
location = {Edinburgh, Scotland},
pages = {245--256},
numpages = {12},
url = {http://doi.acm.org/10.1145/1596550.1596586},
doi = {10.1145/1596550.1596586},
acmid = {1596586},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {HList, Haskell, attribute grammars, class system, lazy evaluation, type-level programming},
}
@inproceedings{DGP,
author = {Gibbons, Jeremy},
title = {Datatype-generic Programming},
booktitle = {Proceedings of the 2006 International Conference on Datatype-generic Programming},
series = {SSDGP'06},
year = {2007},
isbn = {3-540-76785-1, 978-3-540-76785-5},
location = {Nottingham, UK},
pages = {1--71},
numpages = {71},
url = {http://dl.acm.org/citation.cfm?id=1782894.1782895},
acmid = {1782895},
publisher = {Springer-Verlag},
address = {Berlin, Heidelberg},
}
@article{ALaCarte,
author = {Swierstra, Wouter},
title = {Data Types \`{a} La Carte},
journal = {J. Funct. Program.},
issue_date = {July 2008},
volume = {18},
number = {4},
month = jul,
year = {2008},
issn = {0956-7968},
pages = {423--436},
numpages = {14},
url = {http://dx.doi.org/10.1017/S0956796808006758},
doi = {10.1017/S0956796808006758},
acmid = {1394795},
publisher = {Cambridge University Press},
address = {New York, NY, USA},
}
@incollection{Sestoft,
author = {Sestoft, Peter},
chapter = {Demonstrating Lambda Calculus Reduction},
title = {The Essence of Computation},
editor = {Mogensen, Torben \AE and Schmidt, David A. and Sudborough, I. Hal},
year = {2002},
isbn = {3-540-00326-6},
pages = {420--435},
numpages = {16},
url = {http://dl.acm.org/citation.cfm?id=860256.860276},
acmid = {860276},
publisher = {Springer-Verlag New York, Inc.},
address = {New York, NY, USA},
}
@article{Fold,
author = {Hutton, Graham},
title = {A Tutorial on the Universality and Expressiveness of Fold},
journal = {J. Funct. Program.},
issue_date = {July 1999},
volume = {9},
number = {4},
month = jul,
year = {1999},
issn = {0956-7968},
pages = {355--372},
numpages = {18},
url = {http://dx.doi.org/10.1017/S0956796899003500},
doi = {10.1017/S0956796899003500},
acmid = {968579},
publisher = {Cambridge University Press},
address = {New York, NY, USA},
}
@other{ExpressionProblem,
author = {Wadler, Philip},
title = {The Expression Problem},
misc = {Discussion on the Java-Genericity mailing list},
month = dec,
year = {1998}
}
@article{OOHaskell,
author = {Oleg Kiselyov and
Ralf L{\"{a}}mmel},
title = {Haskell's overlooked object system},
journal = {CoRR},
volume = {abs/cs/0509027},
year = {2005},
url = {http://arxiv.org/abs/cs/0509027},
archivePrefix = {arXiv},
eprint = {cs/0509027},
timestamp = {Mon, 13 Aug 2018 16:46:43 +0200},
biburl = {https://dblp.org/rec/bib/journals/corr/abs-cs-0509027},
bibsource = {dblp computer science bibliography, https://dblp.org}
}
@inproceedings{SYB1,
author = {L\"{a}mmel, Ralf and Jones, Simon Peyton},
title = {Scrap More Boilerplate: Reflection, Zips, and Generalised Casts},
booktitle = {Proceedings of the Ninth ACM SIGPLAN International Conference on Functional Programming},
series = {ICFP '04},
year = {2004},
isbn = {1-58113-905-5},
location = {Snow Bird, UT, USA},
pages = {244--255},
numpages = {12},
url = {http://doi.acm.org/10.1145/1016850.1016883},
doi = {10.1145/1016850.1016883},
acmid = {1016883},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {generic programming, reflection, type cast, zippers},
}
@article{SYB,
author = {L\"{a}mmel, Ralf and Jones, Simon Peyton},
title = {Scrap Your Boilerplate: A Practical Design Pattern for Generic Programming},
journal = {SIGPLAN Not.},
issue_date = {March 2003},
volume = {38},
number = {3},
month = jan,
year = {2003},
issn = {0362-1340},
pages = {26--37},
numpages = {12},
url = {http://doi.acm.org/10.1145/640136.604179},
doi = {10.1145/640136.604179},
acmid = {604179},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {generic programming, rank-2 types, traversal, type cast},
}
@article{SYB2,
author = {L\"{a}mmel, Ralf and Jones, Simon Peyton},
title = {Scrap Your Boilerplate with Class: Extensible Generic Functions},
journal = {SIGPLAN Not.},
issue_date = {September 2005},
volume = {40},
number = {9},
month = sep,
year = {2005},
issn = {0362-1340},
pages = {204--215},
numpages = {12},
url = {http://doi.acm.org/10.1145/1090189.1086391},
doi = {10.1145/1090189.1086391},
acmid = {1086391},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {extensibility, generic programming, recursive dictionaries, type classes, typecase},
}
@article{SCICO,
author = {Boulytchev, Dmitry},
title = {Combinators and Type-driven Transformers in Objective Caml},
journal = {Sci. Comput. Program.},
issue_date = {December 2015},
volume = {114},
number = {C},
month = dec,
year = {2015},
issn = {0167-6423},
pages = {57--73},
numpages = {17},
url = {https://doi.org/10.1016/j.scico.2015.07.008},
doi = {10.1016/j.scico.2015.07.008},
acmid = {2853599},
publisher = {Elsevier North-Holland, Inc.},
address = {Amsterdam, The Netherlands, The Netherlands},
keywords = {Combinators, Compilers, Datatype-generic programming, Functional programming, Modularization and code reuse},
}
@inproceedings{SYBOCaml,
author = {Boulytchev, Dmitry and Mechtaev, Sergey},
title = {Efficiently Scrapping Boilerplate Code in OCaml},
booktitle = {Workshop on ML},
series = {ML '11},
year = {2011},
location = {Tokyo, Japan},
}
@article{TransformationObjects,
author = {Dmitri Boulytchev},
title = {Code Reuse With Transformation Objects},
journal = {CoRR},
volume = {abs/1802.01930},
year = {2018},
url = {http://arxiv.org/abs/1802.01930},
archivePrefix = {arXiv},
eprint = {1802.01930},
timestamp = {Mon, 13 Aug 2018 16:46:56 +0200},
biburl = {https://dblp.org/rec/bib/journals/corr/abs-1802-01930},
bibsource = {dblp computer science bibliography, https://dblp.org}
}
@inproceedings{OCanren,
author = {Dmitry Kosarev and
Dmitry Boulytchev},
title = {Typed Embedding of a Relational Language in OCaml},
booktitle = {Proceedings {ML} Family Workshop / OCaml Users and Developers workshops,
{ML/OCAML} 2016, Nara, Japan, September 22-23, 2016.},
pages = {1--22},
year = {2016},
url = {https://doi.org/10.4204/EPTCS.285.1},
doi = {10.4204/EPTCS.285.1},
timestamp = {Fri, 04 Jan 2019 12:22:11 +0100},
biburl = {https://dblp.org/rec/bib/journals/corr/abs-1805-11006},
bibsource = {dblp computer science bibliography, https://dblp.org}
}
@article{ModularImplicits,
author = {White, Leo and Bour, Frédéric and Yallop, Jeremy},
year = {2015},
month = {12},
pages = {},
title = {Modular implicits},
volume = {198},
journal = {Electronic Proceedings in Theoretical Computer Science},
doi = {10.4204/EPTCS.198.2}
}
@inproceedings{ObjectAlgebras,
author = {Oliveira, Bruno C. d. S. and Cook, William R.},
title = {Extensibility for the Masses: Practical Extensibility with Object Algebras},
booktitle = {Proceedings of the 26th European Conference on Object-Oriented Programming},
series = {ECOOP'12},
year = {2012},
isbn = {978-3-642-31056-0},
location = {Beijing, China},
pages = {2--27},
numpages = {26},
url = {http://dx.doi.org/10.1007/978-3-642-31057-7_2},
doi = {10.1007/978-3-642-31057-7_2},
acmid = {2367167},
publisher = {Springer-Verlag},
address = {Berlin, Heidelberg},
}
@inproceedings{ObjectAlgebrasSYB,
TITLE = {{Scrap Your Boilerplate With Object Algebras}},
AUTHOR = {Zhang, Haoyuan and Chu, Zewei and Oliveira, Bruno C.d. S. and Storm, Tijs van der},
URL = {https://hal.inria.fr/hal-01261477},
BOOKTITLE = {{Proceedings of the Object-oriented Programming, Systems, Languages, and Applications (OOPSLA, 2015)}},
ADDRESS = {New York, United States},
YEAR = {2015},
KEYWORDS = {traversal ; object algebras ; extensibility},
HAL_ID = {hal-01261477},
HAL_VERSION = {v1},
}
@article{ObjectAlgebrasAttribute,
author = {Rendel, Tillmann and Brachth\"{a}user, Jonathan Immanuel and Ostermann, Klaus},
title = {From Object Algebras to Attribute Grammars},
journal = {SIGPLAN Not.},
issue_date = {October 2014},
volume = {49},
number = {10},
month = oct,
year = {2014},
issn = {0362-1340},
pages = {377--395},
numpages = {19},
url = {http://doi.acm.org/10.1145/2714064.2660237},
doi = {10.1145/2714064.2660237},
acmid = {2660237},
publisher = {ACM},
address = {New York, NY, USA},
keywords = {attribute grammars, church-encoding, embedded domain-specific languages, modularity, object algebras, one-pass compilers, scala, visitor pattern},
}
@article{Hinze,
author = {Hinze, Ralf},
title = {Generics for the Masses},
journal = {J. Funct. Program.},
issue_date = {July 2006},
volume = {16},
number = {4-5},
month = jul,
year = {2006},
issn = {0956-7968},
pages = {451--483},
numpages = {33},
url = {http://dx.doi.org/10.1017/S0956796806006022},
doi = {10.1017/S0956796806006022},
acmid = {1166021},
publisher = {Cambridge University Press},
address = {New York, NY, USA},
}
@inproceedings{TypeClasses,
author = {Wadler, P. and Blott, S.},
title = {How to Make Ad-hoc Polymorphism Less Ad Hoc},
booktitle = {Proceedings of the 16th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages},
series = {POPL '89},
year = {1989},
isbn = {0-89791-294-2},
location = {Austin, Texas, USA},
pages = {60--76},
numpages = {17},
url = {http://doi.acm.org/10.1145/75277.75283},
doi = {10.1145/75277.75283},
acmid = {75283},
publisher = {ACM},
address = {New York, NY, USA},
}
@Inbook{TypeFamilies,
author="Kiselyov, Oleg
and Jones, Simon Peyton
and Shan, Chung-chieh",
editor="Roscoe, A.W.
and Jones, Cliff B.
and Wood, Kenneth R.",
title="Fun with Type Functions",
bookTitle="Reflections on the Work of C.A.R. Hoare",
year="2010",
publisher="Springer London",
address="London",
pages="301--331",
abstract="Tony Hoare has always been a leader in writing down and proving properties of programs. To prove properties of programs automatically, the most widely used technology today is the ubiquitous type checker. Alas, static type systems inevitably exclude some good programs and allow some bad ones. Thus motivated, we describe some fun we have been having with Haskell, by making the type system more expressive without losing the benefits of automatic proof and compact expression. Specifically, we offer a programmer's tour of so-calledtype families, a recent extension to Haskell that allows functions on types to be expressed as straightforwardly as functions on values. This facility makes it easier for programmers to effectively extend the compiler by writing functional programs that execute during type checking. Source code for all the examples is available at http://research.microsoft.com/simonpj/papers/assoc-types/fun-with-type-funs.zip.",
isbn="978-1-84882-912-1",
doi="10.1007/978-1-84882-912-1_14",
url="https://doi.org/10.1007/978-1-84882-912-1_14"
}