forked from JoeOsborn/spcs-ai
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
118 lines (118 loc) · 7.71 KB
/
index.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
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="Content-Style-Type" content="text/css" />
<meta name="generator" content="pandoc" />
<meta name="author" content="Joseph C. Osborn" />
<title>AI, Knowledge Representation, and Machine Learning</title>
<style type="text/css">code{white-space: pre;}</style>
</head>
<body>
<div id="header">
<h1 class="title">AI, Knowledge Representation, and Machine Learning</h1>
<h2 class="author">Joseph C. Osborn</h2>
</div>
<div id="TOC">
<ul>
<li><a href="#objective">Objective</a></li>
<li><a href="#format">Format</a></li>
<li><a href="#topics">Topics</a></li>
<li><a href="#project-ideas">Project ideas</a></li>
<li><a href="#references">References</a></li>
</ul>
</div>
<blockquote>
<p>“It’s part of the history of the field of artificial intelligence that every time somebody figured out how to make a computer do something—play good checkers, solve simple but relatively informal problems—there was a chorus of critics to say,”that’s not thinking“… Practical AI successes, computational programs that actually achieved intelligent behavior, were soon assimilated into whatever application domain they were found to be useful in, and became silent partners alongside other problem-solving approaches, which left AI researchers to deal only with the”failures," the tough nuts that couldn’t yet be cracked." <span class="citation">(McCorduck 2004)</span></p>
</blockquote>
<p>This course surveys the field of artificial intelligence and its two main threads: symbolic/knowledge-based and statistical/machine-learning approaches. We will pay special attention to how AI systems reflect and reify not just the knowledge of their creators, but also their values and implicit biases. In recent years we have seen a proliferation of AI systems that filter news feeds, hyper-target advertisements, act as personal assistants, determine apartment rental rates, and even attempt to identify suspected terrorists or decide parole terms and sentencing. Whenever we build an AI system, we choose how to represent the world and the problem we want to solve, and this decision must consider ethics as much as the performance of the resulting algorithm. On the positive side, if AI systems can encode values, then we can also use them to creative or socially beneficial ends! AI systems can generate novel stories and works of art, provide compelling opponents in games, and personalize education for individual learners.</p>
<p>This course will engage with active research in deep learning, computational creativity, video game AI, natural language understanding, and the ethics of AI. Students will learn the core principles of AI with worked examples, writing programs in Prolog and Python to apply the techniques shown in lectures and readings. We will also critically analyze commercial and research AI projects to understand how they function (building smaller versions on the way), the extent to which they are successful at their stated aims, how they fit into the history of AI, and what they say about their creators and society at large.</p>
<h1 id="objective">Objective</h1>
<p>Students will finish the course with an appreciation of the ethical, social, and historical aspects of artificial intelligence, as well as concrete experience building small AI systems in two radically different programming environments. Automated algorithmic decision-making is only becoming more pervasive, and this course should prepare students to observe, critique, create, and (potentially) counteract such systems.</p>
<h1 id="format">Format</h1>
<p>Each day’s lecture will be broken up into three main topics. The morning schedule will generally follow this pattern:</p>
<ul>
<li>9:00-9:15: Introductions and logistics. Q&A for previous day’s reading or work.</li>
<li>9:15-9:35: The first topic of the morning.</li>
<li>9:35-9:45: A small group exercise, followed by a short break.</li>
<li>9:50-10:00: Review and discussion of the results of the exercise.</li>
<li>10:00-10:30: The second topic of the morning.</li>
<li>10:40-11:10: The third topic of the morning.</li>
<li>11:10-11:30: Introduction to the day’s assignment. Q&A.</li>
</ul>
<p>Each day will have a reading along with a programming assignment. There will also be a final project comprising either a larger AI programming project or a research paper deeply or broadly exploring some AI system(s), topic(s), or technique(s). This final project may be tackled alone or in a group of no more than 3 students.</p>
<p>Coursework will be submitted via GitHub, and on the first day we will ensure that all students have an account with the service. An understanding of version control is vital for working on software projects in teams, and this will also give us a persistent record of project work suitable for use in portfolios or to share with family and friends.</p>
<h1 id="topics">Topics</h1>
<p>This course will move very quickly. Each week we will consider four or five topics. Each topic stands as a milestone in a particular tradition, and most remain active research areas—in fact, each would justify a three-week course on its own!</p>
<ul>
<li>Foundations
<ul>
<li>What is AI?</li>
<li>Critical technical practice</li>
<li>Introduction to Python programming</li>
<li>State machines and basic CS theory</li>
<li>Search, planning, and game AI</li>
</ul></li>
<li>Statistical techniques
<ul>
<li>Probabilistic programming
<ul>
<li>Probabilistic inference</li>
<li>Bayes Theorem</li>
</ul></li>
<li>Machine learning as function approximation
<ul>
<li>Error minimization and regression</li>
<li>Perceptrons</li>
</ul></li>
<li>Deep Neural Networks</li>
<li>Recurrent Neural Networks</li>
</ul></li>
<li>Knowledge-based techniques
<ul>
<li>Introduction to logic and Prolog programming</li>
<li>Rule-based systems and grammars</li>
<li>Planning with logic</li>
<li>Non-monotonic logics</li>
</ul></li>
</ul>
<h1 id="project-ideas">Project ideas</h1>
<ul>
<li>Game-related AI
<ul>
<li>Video game character AI/social simulation</li>
<li>Automated “Heads Up” player</li>
<li>Realtime game AI</li>
<li>Guess game from level, generate level given game</li>
<li>GVGAI competition bot (or Arcade Learning Environment)</li>
<li>Learn game rules (GDL/VGDL) from forward model</li>
<li>Survey or deep-dive papers from recent AIIDE/EXAG/CIG/TCIAIG etc conferences/workshops/journals</li>
<li>Deep analysis/historical study/etc of some game AI system(s) or survey of techniques</li>
<li>…</li>
</ul></li>
<li>General AI
<ul>
<li>Source repository mining/bug prediction</li>
<li>Any Kaggle competition</li>
<li>An AI system (expert system or machine learning) for some diagnosis or support task
<ul>
<li>Or for playing Heads Up?</li>
</ul></li>
<li>Survey or deep-dive papers from recent AAAI/IJCAI/NIPS/etc conferences or arxiv publications in machine learning/AI/etc</li>
<li>Deep analysis/historical study/etc of some AI system(s) or survey of techniques</li>
<li>Use a probabilistic programming language to encode one or more interesting models
<ul>
<li>E.g. http://webppl.org (book at http://dippl.org), or PyMC3 for Python</li>
</ul></li>
<li>Program synthesis — given a specification or a set of examples or a partially implemented program, come up with a function implementing it</li>
<li>…</li>
</ul></li>
</ul>
<h1 id="references" class="unnumbered">References</h1>
<div id="refs" class="references">
<div id="ref-McCorduck:2004:MTP:983115">
<p>McCorduck, Pamela. 2004. <em>Machines Who Think: A Personal Inquiry into the History and Prospects of Artificial Intelligence</em>. AK Peters Ltd.</p>
</div>
</div>
</body>
</html>