One of the major goals of dlib is to have documentation that enables
someone to easily make use of its various components. Ideally,
you would read a short description of something, understand it immediately,
and begin using it in your application without any difficulty. Obviously, this
depends partly on the background of the user. For example, if you have
never written C++ software before then it probably isn't going to be this easy.
This page is meant to complement the main library documentation by providing
references to books, along with my commentary, which explain most of
the background material needed to understand the various parts of the library.
In most cases these are the books I learned from during the process
of creating dlib. As always, if you disagree with anything or think I have left out
an important text then shoot me an email.
General Programming
C++
- Programming: Principles and Practice Using C++ by Bjarne Stroustrup
This is the sort of book you would use in a freshman introduction-to-programming class.
So if you are just beginning to study programming and are interested in C++ then I think
it is probably safe to say this is one of the best books you could read.
- Accelerated C++: Practical Programming by Example by Andrew Koenig and Barbara E. Moo
If you are new to C++ but already know how to program then this is a great book. It's also
about one fourth the size of the Stroustrup book.
- Effective C++: 55 Specific Ways to Improve Your Programs and Designs (3rd Edition) by Scott Meyers
This is a great intermediate level C++ book. Most people have heard the jokes about
how easy it is to shoot yourself in the foot with C++. This book explains many things you
need to know about the language to avoid doing so on a regular basis. So if you are
writing C++ software then this is a must-read. I would even claim that
you are a danger to the C++ software you touch unless you know what is in this book.
I'm not kidding. Finally, the book isn't just about the quirks of C++. It also discusses many general
software engineering ideas which have wide applicability. So in this
respect it is a great book for any software developer to read.
- More Effective C++: 35 New Ways to Improve Your Programs and Designs by Scott Meyers
Consider this an expansion to Effective C++. If you are going to read the above
book then you would almost certainly benefit from reading this one as well.
- The C++ Standard Library: A Tutorial and Reference by Nicolai M. Josuttis
If you are going to buy a reference book on the C++ standard library then this
is the one to get. I think you
will find it is better than any of the available online references. So if you find
yourself frustrated with the online resources, then this is the book for you.
- Online C++ Standard Library Reference
What I said aside, this is a good online reference. I often find myself referring to it
when I do not have the Josuttis book on hand.
Multithreading
- Programming with POSIX Threads by David R. Butenhof
When I was an undergrad, this book was my main resource for learning about multithreading.
It was enjoyable to read, as are all the books on this list, and covered everything
in great depth without becoming overbearing. Also, despite what the title may suggest,
this book is useful for understanding multithreading broadly, not just multithreading
on POSIX systems.
Network Programming
- Unix Network Programming, Volume 1: The Sockets Networking API (3rd Edition)
by W. Richard Stevens
A lot of people call this book the network programming Bible and
this praise is well deserved. If you want a deep understanding of how computer networks
function, including the Internet, then this is the book to read. As with
the Butenhof book above, this is an excellent choice even for people who do not
intend to write software for Unix systems.
WIN32 Programming
It has been a long time since I needed to refer to these two books. However,
they contained information I couldn't find elsewhere no matter
how hard I looked. So I recommend them in case you need to create or understand
some low level win32 code.
- Win32 Programming by Brent E. Rector and Joseph M. Newcomer
- Programming Windows by Charles Petzold
- MSDN Library
This is Microsoft's online reference documentation. It is very large and sometimes
confusing. But at the end of the day you should be able to find the documentation
for just about every function in the entire Windows API.
Computer Science: Algorithms and Data Structures
- Introduction to Algorithms by Cormen, Leiserson, Rivest and Stein
You should get this book if you are looking for a good discussion of the classic computer science
algorithms and data structures (e.g. most of the components on the containers
page).
- Algorithms in C++, Parts 1-4: Fundamentals, Data Structure, Sorting, Searching
(3rd Edition) by Robert Sedgewick
This is another good algorithms book. If you are going to get only one book on this
subject then get the one above. However, when I was learning about these topics I
used both these books and on many occasions I found it helpful to read the description
of an algorithm or data structure in both. Where one description was a little vague or
confusing the other generally filled in the gaps.
Lossless Data Compression
- Text Compression by Bell, Cleary, and Witten
When I was studying data compression this was my most useful
resource. If you are looking to understand how lossless data compression
algorithms work then this is the book you want. It is completely self-contained
and an absolute joy to read. Note that contrary to one of the reviews on
amazon.com, the book Managing Gigabytes is not the second edition of this book;
if this topic interests you then be sure you get the 318 page
book published in 1990.
General Math
- Linear Algebra Done Right by Sheldon Jay Axler
If a matrix seems like an arbitrary grid of numbers or you find that
you are confused by vectors, matrices, and the various things
that get done with them then this book will change your whole view of this subject.
It doesn't teach you any algorithms. Instead, it will give you a general
framework in which to think about all this stuff. Once you have that down
everything else will start to make a lot more sense. If all goes well
you will even start to agree with the following: linear algebra is beautiful. :)
- Numerical Linear Algebra by Trefethen and Bau
While Linear Algebra Done Right is fairly abstract, this book by
Trefethen and Bau will
explain some of the actual algorithms that are often used.
This is a great second book if you find that you want to know more about
the SVD, LU decomposition, or various other algorithms involving linear algebra.
- Calculus: Single and Multivariable by Hughes-Hallett, Gleason, and McCallum
Some of the books below will require and understanding of basic calculus. So
I'm recommending this book. It was the book I used as an undergrad and I
remember it being alright. That isn't exactly a glowing review so if you
are really considering buying a calculus book you may want to check out
other reviews before picking this one.
- Introduction to Real Analysis (third edition) by Bartle and Sherbert
At some level real analysis is like a really rigorous repeat of calculus.
So if you already have an undergraduate education in calculus and
you are reading things that seem reminiscent of calculus but involve
stuff you haven't seen before (e.g. sup, inf, "sets of numbers", sequences of points)
then you may be in need of a real analysis book. This one is quite good and should
be accessible to someone with the usual undergraduate computer science math background.
Optimization
The subject of linear algebra is fundamental to optimization. So you must be familiar
with the contents of a book like
Linear Algebra Done Right if you are going to study
this area. You will also need to know how to find the derivative of a function and
understand what a derivative is all about. So you will need to know a little bit of
calculus. Finally, once in a while you will need to know a little bit about real
analysis. Ultimately, what you need all depends on how deep you want to go.
- Practical Methods of Optimization (second edition) by R. Fletcher 1987
I love this book. When I got it I literally spent my weekends sitting around
reading it for hours. It is a fascinating and well written introduction to
the subject of optimization. This has been my most valuable resource for
learning the fundamentals of optimization and I cannot recommend it highly enough.
- Numerical Optimization by Jorge Nocedal and Stephen Wright 2006
This is a more recent text on optimization that is also very good. It
covers many algorithms not covered by the above book.
- Introduction to Derivative-Free Optimization by Conn, Scheinberg, and Vicente
If you want to understand algorithms like BOBYQA
then this is a good recent book on the subject. Note that a book like Practical Methods of Optimization
is almost certainly a prerequisite for reading this book. As an aside, BOBYQA is not discussed in this book but
its predecessor, NEWUOA is.
Machine Learning
- Artificial Intelligence: A Modern Approach (3rd Edition) by Stuart Russell and Peter Norvig
This book is about the much broader field of AI but it contains an excellent introduction
to machine learning and it also covers other useful topics like bayesian networks.
Moreover, it is very well written and self-contained. So you don't need any particular
background to be able to learn from it apart from a typical undergraduate background
in computer science.
- Learning with Kernels: Support Vector Machines, Regularization, Optimization, and Beyond
by Bernhard Schlkopf and Alexander J. Smola
Most of the machine learning tools in dlib are implementations of various kernel methods.
So if you want a book that covers this topic in great depth as well as breadth then this is
probably the book for you. The most important prerequisite for this book is linear
algebra. Virtually everything in this book depends on linear algebra in a fundamental way.
The second important subject is optimization. Whenever you see the text
mention the KKT conditions, duality, "primal variables", or quadratic programming it
is talking about ideas from optimization. A good book which will explain all this to you
is Practical Methods of Optimization. Note that this book calls the KKT conditions
just the "KT" conditions. It is talking about the same thing. Also, duality
is something that comes up a lot in optimization but in the context of machine learning
usually people are talking about a particular form known as the Wolfe Dual.
It would also be good (but maybe not critical depending on which parts you want to read) to
be familiar with real analysis.
- Kernel Methods for Pattern Analysis by John Shawe-Taylor and Nello Cristianini
This is another good book about kernel methods. If you have to choose between
this book and Learning with Kernels I would go with Learning with Kernels. However, it is
good to have both since reading different presentations of difficult subjects
usually makes learning them easier.
- Structured Prediction and Learning in Computer Vision by Sebastian Nowozin and Christoph H. Lampert 2011
If you are looking for a book discussing the background material necessary
for understanding things like the Structural SVM
tools in dlib then this is a good book. It is also available online
in PDF form.
Image Processing
- Digital Image Processing by Rafael C. Gonzalez and Richard E. Woods
This is a terrific introduction to digital image processing.
By and large this book doesn't require any special prerequisites. Sometimes
calculus shows up, but not too much.