This evolving book will teach you how to:
- Debug normal issues really fast
- Make complicated issues possible to debug
footnote: adapted from Perl's slogan: "Easy things should be easy and hard things should be possible".
This is a work-in-progress collection of methodologies and copy-n-paste recipes for successful debugging of simple and complicated software problems. Some sections are quite complete, while other will be finished at a later stage, and yet other haven't been started.
Besides debugging methodologies the second focus of this book is on sharing the best tools I have discovered to get the debugging job done successfully, while ideally "losing the least amount of hair" in the process.
I have been developing software since 1995 and a lot of this work involved debugging. Over the years I developed various efficient methodologies for discovering the source of the problem, which is the most difficult stage before it can be solved. Since after the problem is understood, typically its resolution is at easy reach.
Every so often someone I would be debugging some difficult problem with would suggest to share my approaches with the world. I always said that it'd be too difficult to generalize, but recently the planted seed seems to have sprouted and so in the following chapters I will try to share some of the insights to ease this very difficult at times process.
Writing about debugging in the void is very difficult and since I haven't been saving use cases, it will take some time to build this up, so expect these pages to be a Work In Progress (WIP) for many moons. But hopefully some ideas could be relayed to you sooner than later, and they would help to ease your burden of debugging in your professional and play projects.
-
Debugging Compiled Programs -
gdb,ldd,nm,LD_LIBRARY_PATH,LD_PRELOAD, etc. -
Debugging Python -
py-spy, paths, auto-print, etc. -
Debugging PyTorch - cpu and gpu memory, performance, models, tensors, etc.
-
Unix Tools For Debugging -
bash,strace,make, prompt,nohup, etc. -
Debugging Machine Learning Projects (external)
If you found a bug, typo or would like to propose an improvement please don't hesitate to open an Issue or contribute a PR.
The content of this site is distributed under Attribution-ShareAlike 4.0 International.
✔ Machine Learning: ML Engineering Online Book | ML ways | Porting
✔ Guides: The Art of Debugging
✔ Applications: ipyexperiments
✔ Tools and Cheatsheets: bash | conda | git | jupyter-notebook | make | python | tensorboard | unix