DreamCoder: Growing generalizable, interpretable knowledge with wake-sleep Bayesian program learning

June 15, 2020 · 🏛 Philosophical Transactions of the Royal Society A

✨ This Paper Lives!
Code has been found and verified.

"No code URL or promise found in abstract"
"HuggingFace models found (backfill)"

Evidence collected by the PWNC Scanner

Authors Kevin Ellis, Catherine Wong, Maxwell Nye, Mathias Sable-Meyer, Luc Cary, Lucas Morales, Luke Hewitt, Armando Solar-Lezama, Joshua B. Tenenbaum arXiv ID 2006.08381 Category cs.AI: Artificial Intelligence Cross-listed cs.LG Citations 230 Venue Philosophical Transactions of the Royal Society A Repository https://huggingface.co/ryanyen22/reason-first-program Last Checked 14 days ago
Abstract
Expert problem-solving is driven by powerful languages for thinking about problems and their solutions. Acquiring expertise means learning these languages -- systems of concepts, alongside the skills to use them. We present DreamCoder, a system that learns to solve problems by writing programs. It builds expertise by creating programming languages for expressing domain concepts, together with neural networks to guide the search for programs within these languages. A ``wake-sleep'' learning algorithm alternately extends the language with new symbolic abstractions and trains the neural network on imagined and replayed problems. DreamCoder solves both classic inductive programming tasks and creative tasks such as drawing pictures and building scenes. It rediscovers the basics of modern functional programming, vector algebra and classical physics, including Newton's and Coulomb's laws. Concepts are built compositionally from those learned earlier, yielding multi-layered symbolic representations that are interpretable and transferrable to new tasks, while still growing scalably and flexibly with experience.
Community shame:
Not yet rated
Community Contributions

Found the code? Know the venue? Think something is wrong? Let us know!

📜 Similar Papers

In the same crypt — Artificial Intelligence