Online Learning Resources
Here are some online learning resources for Artificial Intelligence: foundations of computational agents, 3rd edition by David L. Poole and Alan K. Mackworth, Cambridge University Press, 2023. All material is copyright, and most is released under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License and under the GPL.
Chapter 1: Artificial Intelligence and Agents
The AAAI AI Topics site provides a wealth of introductory material on AI.
Chapter 2: Agent Architectures and Hierarchical Control
See AIPython for Python implementations of the robot controllers:
- agents.py defines a simple agent
controller.
TP_env
andTP_agent
define the environment and agent for Examples 2.1 and 2.2. - agentEnv.py, agentMiddle.py, agentTop.py define the hierarchical agent of Section 2.2 (Examples 2.4, 2.5, 2.6).
Chapter 3: Searching for Solutions
See AIPython for Python implementations of search algorithms.
- searchProblem.py defines a
search problem in terms of the start nodes, a predicate to test if a
node is a goal, the
neighbors function, and an optional heuristic function.
simp_delivery_graph
is the graph of Figures 3.3 and 3.7.cyclic_simp_delivery_graph
is the graph of Figure 3.10. - searchGeneric.py the generic
search algorithm that implements both depth-first search
(
Searcher
) and A* search (AStarSearcher
). It does not do multi-path pruning or cycle checking. It is easy to modify to make other search algorithms. - searchMPP.py implements A* with multiple path pruning.
- searchBranchAndBound.py defines depth-first branch-and-bound search search. It does not do multi-path pruning or cycle checking.
Chapter 4: Reasoning With Constraints
See AIPython for Python implementations of the CSP algorithms. This includes:
- cspProblem.py defines a constraint satisfaction problem (CSP).
- cspExamples.py defines
example CSPs.
csp2
is the CSP of Examples 4.9, 4.19, and 4.23-4.28 and Figures 4.5 and 4.10.csp1s
is the CSP of Examples 4.12-4.14, 4.17, 4.18, 4.21, and 4.22.crossword1
andcrossword2
are two representations of Figure 4.15 (see Exercise 4.3) - cspDFS.py defines depth-first search for CSPs.
- cspSearch.py defines a searcher, which can use any of the searching techniques from Chapter 3, for CSPs that allows searches through the space of partial assignments.
- cspConsistency.py uses domain splitting and generalized arc consistency to solve CSPs.
- cspSLS.py uses stochastic local search, in particular a probabilistic mix of the variable with the most conflicts, any-conflict and a random variable, to solve CSPs. It only maintain the data structures needed for the algorithm (e.g., a priority queue when we need the best variable, but not when we do an any-conflict). Each step is at most logarithmic in the number of variables (to maintain the priority queue), but depends on the number of neighbors. It also plots runtime distributions (for number of steps only).
- cspSoft.py gives a representation for soft constraints an implements branch-and-bound search (Figure 4.1).
Chapter 5: Propositions and Inference
AIPython has Python implementations of the reasoners:
- logicProblem.py defines
definite clauses.
elect
implements Example 5.8 (Figure 5.2) - logicBottomUp.py bottom-up inference for definite clauses (Figure 5.3)
- logicTopDown.py top-down inference for definite clauses (Figure 5.4), including ask-the-user (Section 5.4)
- logicExplain.py knowledge-based debugging for definite clauses; see Figure 5.6 and 5.7 (Section 5.5)
- logicAssumables.py Horn
clauses for assumables, including consistency-based diagnosis
(Figure 5.10).
electa
implements Example 5.21 (Figure 5.8) - logicNegation.py implements negation-as-failure
(Figure 5.12).
beach_KB
is Example 5.28. - elect_bug2.py is the code referred to in
Excerise 5.6. (Try also
elect_bug
in logicProblem.py)
- elect_prop.pl electrical domain Example 5.8 (Figure 5.2)
- elect_naf.pl electrical domain with defaults (Example 5.27)
- beach.pl beach default example (Example 5.28)
Chapter 6: Deterministic Planning
See AIPython for Python implementations of the planners:
- stripsProblem.py defines
representations of actions using
STRIPS.
delivery_domain
implements Examples 6.1-6.6 (Figure 6.1). It also implements blocks-world domains. - stripsForwardPlanner.py implements forward planning (Section 6.2).
- stripsRegressionPlanner.py implements regression planning (Section 6.3).
- stripsHeuristics.py implements heuristic functions for the forward (Example 6.10) and regression planners.
- stripsCSPPlanner.py implements planning as a CSP (Section 6.4).
- stripsPOP.py implements partial-order planning (Section 6.5).
Chapter 7: Supervised Machine Learning
See AIPython for Python implementations of learning algorithms:
- learnProblem.py is the infrastructure assumed by the AIPython learning algorithms and features to allow for experimentation with various algorithms
- learnNoInputs.py lets you experiment with the simplest case of no input features (Section 7.2.2).
- learnDT.py implements decision-tree learning (Section 7.3.1)
- learnCrossValidation.py implements various techniques for cross validation (Section 7.4.3)
- learnLinear.py implements linear and logistic regression, including stochastic gradient descent (Section 7.3.2)
- learnBoosting.py implements gradient-boosted trees for classification (Section 7.5.2)
Chapter 8: Neural Networks and Deep Learning
See AIPython for Python implementations neural networks. This is meant to be runnable pseudo-code and is much less efficient than state-af-the-art systems such as Keras or PyTorch. If you want to use a library, use one of those. If you want to see how the underlying algorithms work, see:
- learnNN.py allows one to build and train feed-forward neural networks (Section 8.1), including stochastic gradient descent, momentum, and RMS-Prop [with Adam as a straightforward exercise] (Section 8.2) and dropout (Section 8.3).
- keras_mnist.py is Keras code to implement Figure 8.5.
- Annotated History of Modern AI and Deep Learning by Jürgen Schmidhuber. Provides a comprehensive history of neural networks and deep learning.
- Update to Figure 8.15 (statistics of pre-trained large language
models). Most information about recent models is not
public, however
Nemotron-4-340B (June 2024) has a context length (window size) of 4,096 tokens, has 3.4*1011 parameters, and was trained on 9 trillion tokens (about 54,000 GB = 54 TB).
Llama 3.1 (July 2024) has a context length (window size) of 128k, has 4.05*1011 parameters, and was trained on 15 trillion tokens (about 90,000 GB = 90 TB). See also Llama 3 Herd of Models.
Chapter 9: Reasoning with Uncertainty
AIPython contains Python implementations of probabilistic inference algorithms:
- probVariables.py defines random variables
- probFactors.py defines (probabilistic) factors and conditional probability distributions.
- probGraphicalModels.py defines graphical models (including belief networks)
- probRC.py implements recursive conditioning (Section 9.5.1)
- probVE.py implements variable elimination for graphical models (Section 9.5.2)
- probStochSim.py implements various stochastic simulation algorithms, including rejection sampling, likelihood weighting (a form of importance sampling), particle filtering, Gibbs sampling (a form of MCMC)
- probHMM.py implements algorithms for hidden Markov models (Section 9.6.2)
- probLocalization.py implements the localization of Example 9.32, and is used to generate Figure 8.19.
- probDBN.py implements dynamic belief networks (Section 9.6.4)
Chapter 10: Learning With Uncertainty
AIPython has Python implementations for learning with uncertainty
- learnKMeans.py implements the k-means algorithm (Section 10.3.1)
- learnEM.py implements the expectation maximization (EM) algorithm for soft clustering (Section 10.3.2)
Chapter 11: Causality
See AIPython for Python implementations of learning with uncertainty algorithms.
- probDo.py adds the do-operator to the probabilistic inference algorithms (Section 11.1.1)
- probCounterfactual.py implements some counterfactual reasoning examples (Section 11.5)
Chapter 12: Planning with Uncertainty
See AIPython for Python implementations of planning under uncertainty:
- decnNetworks.py implements decision networks (Sections 12.2 and 12.3.1), including search (Section 12.3.3) and variable elimination (Section 12.3.4)
- mdpProblem.py implements Markov decision processes (MDPs) (Section 12.5) including value iteration (Section 12.5.2) and asynchronous value iteration (Figure 12.8)
- mdpExamples.py implements example Markov decision processes (MDPs) (Section 12.5)
Chapter 13:Reinforcement Learning
See AIPython for Python implementations of reinforcement learning algorithms.
- rlProblem.py defines reinforcement learning (RL) problems, including from evironments fom MDPs and plotting the accumulated reward.
- rlExamples.py defined some of the RL problems (Example 12.29 an 13.2)
- rlQLearner.py implements Q-learning (Section 13.4.1)
- rlQExperienceReplay.py implements Q-learning with experience replay
- rlModelLearner.py model-based RL (Section 13.8)
- rlFeatures.py implements a feature-based reinforcement learner (Section 13.9.1); rlMonsterGameFeatures.py defines features for the monster game of Figure 13.2 and Example 13.6.
Chapter 14: Multiagent Systems
See AIPython for Python implementations of the following:
- masProblem.py defines two-player zero-sum games (Section 14.3)
- masMiniMax.py implements minimax with alpha-beta pruning (Section 14.3.1)
- masLearn.py implements multiagent reinforcement Learning with stochastic policies (Section 14.7.2)
Chapter 15: Individuals and Relations
The following code runs in Prolog:
- elect_reln.pl electrical wiring example from Example 15.11
- geography_DB.pl database of geography of some of South America; Figures 15.2 and 15.3
- geography_CFG.pl simple English grammar about the geography of some of South America; Figures 15.8 and 15.9
- geography_QA.pl can answer English questions about the geography of some of South America; Examples 15.35 and 15.36, and Figure 15.10
- geography_QA_query.pl building query first; Figures 15.11 and 15.12
Chapter 16: Knowledge Graphs and Ontologies
- Wikidata page on Christine Sinclair described in Examples 16.6 and 16.7 and Figure 16.1; also machine readable in RDF.
- sem_web.pl provides SWI Prolog code to query Wikidata (Examples 16.7)
- sem_web_scheme.pl provides SWI Prolog code to query Schema.org about type and subclass.
Chapter 17: Relational Learning and Probabilistic Reasoning
See AIPython for Python implementations of the following:
- relnCollFilt.py implements the collaborative filtering learning of Section 17.2.1
- relnProbModels.py converts relational belief networks into standard belief networks, given a population for each logical variable (plate). Any of the inference methods can be used on the resulting network; see Section 17.3
Chapter 18: The Social Impact of Artificial Intelligence
Some additional resources:- A proposal to encourage investigation of current harms of AI rather than existential risk concerns: AI Causes Real Harm. Let's Focus on That over the End-of-Humanity Hype - Scientific American
- An examination of the effects of technology change on employment patterns: The end of work: which jobs will survive the AI revolution?
- Consideration of how automation both eliminates old tasks and creates new ones: Automation and New Tasks: How Technology Displaces and Reinstates Labor - American Economic Association
- Prediction of how many crashes, injuries, and deaths intelligent driver assistance technologies are likely to prevent through year 2050: Examining the Safety Benefits of Partial Vehicle Automation Technologies in an Uncertain Future
- Case study of an AI funding ecosystem considering the roles of public investment and private companies: Artificial intelligence policy and funding in Canada: Public investments, private interests
- The United Nations is promoting and coordinating efforts towards global AI governance: UN AI Advisory Board's final report Governing AI for Humanity. UNSESO Ethics of Artificial Intelligence: The Recommendation.
- An annual index evaluating the impact of AI policies and practices on democratic values in countries around the world: Artificial Intelligence and Democratic Values
- AI for Africa: Use Cases Delivering Impact, July 2024
- As an update of Asimov's laws of robotic, Rodney Brooks in 2024 proposed three laws of robotics and three laws of AI.
Chapter 19: Retrospect and Prospect
Some additional resources:- A survey of predictions about AI societal harms, and benefits in health care, scientific advances and education: As AI Spreads, Experts Predict the Best and Worst Changes in Digital Life by 2035
- Rodney Brooks' Dated predictions with retrospective evaluations of their accuracy, and his 2025 update.
- Predictions about the future roles of AI in various industries based on a case study in finance: What the Finance Industry Tells Us About the Future of AI
- Desiderata for future AI, and advocating for a hybrid approach to AI: Getting from Generative AI to Trustworthy AI: What LLMs might learn from Cyc
- The role of AI in science:
AIPython and our other code is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License. Last updated 2023-08-24, David Poole, Alan Mackworth