GitPedia

Reasoning from scratch

Implement a reasoning LLM in PyTorch from scratch, step by step

From rasbt·Updated June 18, 2026·View on GitHub·

This repository contains the code for developing an LLM reasoning model and is the official code repository for the book [*Build a Reasoning Model (From Scratch)*](https://mng.bz/lZ5B). The project is written primarily in Jupyter Notebook, distributed under the Apache License 2.0 license, first published in 2025. It has gained significant community traction with 4,534 stars and 668 forks on GitHub. Key topics include: ai, artificial-intelligence, chain-of-thought, deep-learning, distillation.

Latest release: v1.0
May 18, 2026View Changelog →

Build A Reasoning Model (From Scratch)

This repository contains the code for developing an LLM reasoning model and is the official code repository for the book Build a Reasoning Model (From Scratch).

<br> <br>

<a href="https://mng.bz/lZ5B"><img src="https://sebastianraschka.com/images/reasoning-from-scratch-images/cover.webp?123" width="250px"></a>

(Printed in color.)

<br>

In Build a Reasoning Model (From Scratch), you will learn and understand how a reasoning large language model (LLM) works.

Reasoning is one of the most exciting and important recent advances in improving LLMs, but it’s also one of the easiest to misunderstand if you only hear the term reasoning and read about it in theory. This is why this book takes a hands-on approach. We will start with a pre-trained base LLM and then add reasoning capabilities ourselves, step by step in code, so you can see exactly how it works.

The methods described in this book walk you through the process of developing your own small-but-functional reasoning model for educational purposes. It mirrors the approaches used in creating large-scale reasoning models such as DeepSeek R1, GPT-5 Thinking, and others. In addition, this book includes code for loading the weights of existing, pretrained models.

<br> <br>

To download a copy of this repository, click on the Download ZIP button or execute the following command in your terminal:

bash
git clone --depth 1 https://github.com/rasbt/reasoning-from-scratch.git
<br>

Tip:
Chapter 2 provides additional tips on installing Python, managing Python packages, and setting up your coding environment.

<br> <br>

Table of Contents (In Progress)

Code tests Linux
Code tests macOS
Code tests Windows

Chapter TitleMain Code
Ch 1: Understanding reasoning ModelsNo code
Ch 2: Generating Text with a Pre-trained LLM- ch02_main.ipynb<br/>- ch02_exercise-solutions.ipynb
Ch 3: Evaluating Reasoning Models- ch03_main.ipynb<br/>- ch03_exercise-solutions.ipynb
Ch 4: Improving Reasoning with Inference-Time Scaling- ch04_main.ipynb<br/>- ch04_exercise-solutions.ipynb
Ch 5: Inference-Time Scaling via Self-Refinement- ch05_main.ipynb<br/>- ch05_exercise-solutions.ipynb
Ch 6: Training Reasoning Models with Reinforcement Learning- ch06_main.ipynb<br/>- ch06_exercise-solutions.ipynb
Ch 7: Improving GRPO for Reinforcement Learning- ch07_main.ipynb<br/>- ch07_exercise-solutions.ipynb
Ch 8: Distilling Reasoning Models for Efficient Reasoning- ch08_main.ipynb<br/>- ch08_exercise-solutions.ipynb
Appendix A: References and Further ReadingNo code
Appendix B: Exercise SolutionsCode and solutions are in each chapter's subfolder
Appendix C: Qwen3 LLM Source Code- chC_main.ipynb
Appendix D: Using larger LLMs- chD_main.ipynb
Appendix E: Batching and throughput-oriented execution- chE_main.ipynb
Appendix F: Common Approaches to LLM Evaluation- chF_main.ipynb
Appendix G: Building a Chat Interface- chG
<br> &nbsp;

The mental model below summarizes the main techniques covered in this book.

<img src="https://sebastianraschka.com/images/reasoning-from-scratch-images/mental-model.webp" width="650px"> <br>

 

Companion Book

Please note that Build A Reasoning Model (From Scratch) is a standalone book focused on methods to improve LLM reasoning.

In this book, we work with a pre-trained open-source base LLM (Qwen3) on top of which we code apply reasoning methods from scratch. This includes inference-time scaling, reinforcement learning, and distillation.

However, if you are interested in understanding how a conventional base LLM is implemented, you may like my previous book, Build a Large Language Model (From Scratch).

<a href="https://amzn.to/4fqvn0D"><img src="https://sebastianraschka.com/images/LLMs-from-scratch-images/cover.jpg?123" width="120px"></a>

<br> &nbsp;

Hardware Requirements

The code in the main chapters of this book is designed to mostly run on consumer hardware within a reasonable timeframe and does not require specialized server hardware. This approach ensures that a wide audience can engage with the material. Additionally, the code automatically utilizes GPUs if they are available. That being said, chapters 2-4 will work well on CPUs and GPUs. For chapters 5 and 6, it is recommended to use a GPU if you want to replicate the results in the chapter.

(Please see the setup_tips doc for additional recommendations.)

 

Exercises

Each chapter of the book includes several exercises. The solutions are summarized in Appendix B, and the corresponding code notebooks are available in the main chapter folders of this repository (for example, ch02/01_main-chapter-code/ch02_exercise-solutions.ipynb).

 

Bonus Material

Several folders contain optional materials as a bonus for interested readers:

 

Questions, Feedback, and Contributing to This Repository

For common problems, please see the Troubleshooting Guide.

I welcome all sorts of feedback, best shared via the Manning Discussion Forum or GitHub Discussions. Likewise, if you have any questions or just want to bounce ideas off others, please don't hesitate to post these in the forum as well.

Please note that since this repository contains the code corresponding to a print book, I currently cannot accept contributions that would extend the contents of the main chapter code, as it would introduce deviations from the physical book. Keeping it consistent helps ensure a smooth experience for everyone.

 

Citation

If you find this book or code useful for your research, please consider citing it.

Chicago-style citation:

Raschka, Sebastian. Build A Reasoning Model (From Scratch). Manning, 2025. ISBN: 9781633434677.

BibTeX entry:

@book{build-llms-from-scratch-book,
  author       = {Sebastian Raschka},
  title        = {Build A Reasoning Model (From Scratch)},
  publisher    = {Manning},
  year         = {2025},
  isbn         = {9781633434677},
  url          = {https://mng.bz/lZ5B},
  github       = {https://github.com/rasbt/reasoning-from-scratch}
}

Contributors

Showing top 4 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from rasbt/reasoning-from-scratch via the GitHub API.Last fetched: 6/18/2026