William E. Byrd, Daniel P. Friedman, Ramana Kumar, and Joseph P. Near.
A Shallow Scheme Embedding of Bottom-Avoiding Streams.
To appear in a special issue of Higher-Order and Symbolic Computation, in honor of Mitchell Wand's 60th birthday.
[Preprint (PDF file)]
Lisa Zhang, Gregory Rosenblatt, Ethan Fetaya, Renjie Liao, William E. Byrd, Matthew Might, Raquel Urtasun, Richard Zemel.
Neural Guided Constraint Logic Programming for Program Synthesis.
In Advances in Neural Information Processing Systems 31 (NeurIPS 2018), 2018.
[Paper and poster]
[Full proceedings]
Christina M. Woo, Alejandra Felix, William E. Byrd, Devon K. Zuegel, Mayumi Ishihara, Parastoo Azadi, Anthony T. Iavarone, Sharon J. Pitteri, and Carolyn R. Bertozzi.
Development of IsoTaG, a Chemical Glycoproteomics Technique for Profiling Intact N- and O-Glycopeptides from Whole Cell Proteomes.
Journal of Proteome Research, 2017, 16(4), pp 1706--1718. Paper (ACS Publications)
Jason Hemann, Dan Friedman, William E. Byrd, Matt Might.
A Small Embedding of Logic Programming with a Simple Complete Search.
In Proceedings of the Dynamic Languages Symposium 2016 (DLS '16), Amsterdam, 2016.
[Paper (ACM Digital Library)]
Dakota Fisher, Matthew Hammer, William E. Byrd, Matthew Might.
miniAdapton: A Minimal Implementation of Incremental Computation in Scheme.
In Proceedings of the 2016 Workshop on Scheme and Functional Programming, Nara, Japan, 2016.
[Full paper (PDF file)]
[Complete source code--R6RS Scheme (GitHub)]
Steven Lyde, William E. Byrd, Matthew Might.
Control-Flow of Dynamic Languages via Pointer Analysis.
In the 11th Dynamic Languages Symposium (DLS) at SPLASH 2015, October 27th, 2015.
William E. Byrd, Eric Holk, and Daniel P. Friedman.
miniKanren, Live and Untagged: Quine Generation via Relational Interpreters (Programming Pearl).
In the Proceedings of the 2012 Workshop on Scheme and Functional Programming, Copenhagen, Denmark, 2012.
[Full paper (PDF file)]
[Complete source code--R6RS Scheme (GitHub)]
Claire E. Alvis, Jeremiah J. Willcock, Kyle M. Carter, William E. Byrd, and Daniel P. Friedman.
cKanren: miniKanren with Constraints.
In Proceedings of the 2011 Workshop on Scheme and Functional Programming (Scheme '11), Portland, OR, 2011.
[Full paper (PDF file)]
[Complete source code--R6RS Scheme (GitHub)]
Eric Holk, William E. Byrd, Nilesh Mahajan, Jeremiah Willcock, Arun Chauhan, and Andrew Lumsdaine.
Declarative Parallel Programming for GPUs.
In Proceedings of the International Conference on Parallel Computing (ParCo), Ghent, Belgium, 2011.
[Complete source code--R6RS Scheme (GitHub)]
[Full paper (PDF file)]
Eric Holk, William E. Byrd, Jeremiah Willcock, Torsten Hoefler, Arun Chauhan, and Andrew Lumsdaine.
Kanor: A Declarative Language for Explicit Communication.
In Proceedings of the Thirteenth International Symposium on the Practical Aspects of Declarative Languages (PADL),
Austin, TX, pp. 190-204, 2011.
[Full paper (PDF file)]
Andrew W. Keep, Michael D. Adams, Lindsey Kuper, William E. Byrd, and Daniel P. Friedman.
A Pattern-matcher for miniKanren -or- How to Get into Trouble with CPS Macros
In Proceedings of the 2009 Workshop on Scheme and Functional Programming,
Cal Poly Technical Report CPSLO-CSC-09-03, pp. 37-45, 2009.
[Full proceedings (PDF file)]
Joseph P. Near, William E. Byrd and Daniel P. Friedman.
alphaleanTAP: A Declarative Theorem Prover for First-Order Classical Logic
In Proceedings of the 24th International Conference on Logic Programming (ICLP 2008),
LNCS vol. 5366, Springer-Verlag, Heidelberg, pp. 238-252, 2008.
[Full paper (PDF file)]
[Complete source code--R6RS Scheme and Prolog (.zip file)]
Oleg Kiselyov, William E. Byrd, Daniel P. Friedman and Chung-chieh Shan
Pure, declarative, and constructive arithmetic relations (declarative pearl)
In Proceedings of the 9th international symposium on functional and logic programming,
ed. Jacques Garrigue and Manuel Hermenegildo, pp. 64-80.
LNCS vol. 4989, Springer, 2008.
[Full paper (PDF file)]
William E. Byrd and Daniel P. Friedman
From Variadic Functions to Variadic Relations: A miniKanren Perspective.
Proceedings of the 2006 Scheme and Functional Programming Workshop,
University of Chicago Technical Report TR-2006-06, 2006, pp. 105-117.
[Full paper (PDF file)]
Upcoming Talks
Recent Talks, Tutorials, and Summer Schools
Lessons from Building an Interactive Biomedical Reasoning System (hosted by Kanae Tsushima)
National Institute of Informatics, Tokyo, Japan, December 18, 2018.
CLP(SMT) (talk written with Nada Amin, based on joint work)
Domain Specific Language Design & Implementation (DSLDI 2018), Boston, MA, November 6, 2018.
Part of the ACM SIGPLAN conference on Systems, Programming, Languages and Applications: Software for Humanity (SPLASH 2018).
Recent Research on miniKanren (hosted by Dmitri Boulytchev)
Boulytchev Lab, St. Petersburg State University, St. Petersburg, Russia, October 15, 2018.
Relational Programming in miniKanren: an Interactive Tutorial (arranged by Haochen Xie and Sicss Society; hosted by Atsushi Igarashi)
Kyoto, Japan, May 15--16, 2018.
Taught a two-day interactive mini-course on miniKanren and relational programming at the University of Kyoto.
Topics included: introduction to relational programming, translating functions to relations, relational interpreters in miniKanren, program synthesis via relational interpreter, and implementing microKanren.
Computer Science and My Life (arranged by Haochen Xie and Sicss Society; hosted and translated by Haochen Xie)
Keynote to open the Nagoya University Programming Seminar & Competition, Nagoya University, Nagoya, Japan, May 13, 2018.
miniKanren: a Family of Languages for Relational Programming (arranged by Haochen Xie and Sicss Society; hosted by Yasuhiko Minamide)
Tokyo Institute of Technology (Titech), Tokyo, Japan, May 7, 2018.
miniKanren, Live and Untagged: Quine Generation via Relational Interpreters
Scheme and Functional Programming Workshop, Copenhagen, Denmark, September 9, 2012.
Declarative Parallel Programming
Computer Science Department, Colorado State University, Ft. Collins, CO, February 29, 2012.
3D Printing, Open Hardware, and the DIY Revolution
CATALYST, Informatics and Computing Student Association, Indiana University, Bloomington, IN, February 18, 2012.
3D Printing, Open Hardware, and the DIY Revolution
Technology Management Club, Kelley School of Business, Indiana University, Bloomington, IN, February 7, 2012.
miniKanren ("Untalk", with Daniel P. Friedman)
Clojure/conj, Raleigh, NC, November 10, 2011.
3D Printing, Open Hardware, and the DIY Revolution
Mechanical Engineering Technology (MET) Department, Purdue University, West Lafayette, IN, October 12, 2011.
C211 Introduction to Computer Science (undergraduate)
Course Instructor, Fall 2011 (Honors Section), Fall 2010 (Honors Section), Summer 2005
Associate Instructor, Honors Section, Fall 2003
C311 Programming Languages (undergraduate)
Associate Instructor, Spring 2009, Fall 2008, Spring 2008, Fall 2007, Spring 2007, Fall 2006, Spring 2006, Fall 2005, Spring 2005, Fall 2004, Spring 2004
B521 Programming Languages (graduate)
Associate Instructor, Fall 2008, Fall 2007, Fall 2006, Fall 2005, Fall 2004
A290 Tools for Computing: Arduino Development
Course Instructor, Spring 2012