Note: This README is for authors, developers, and anyone interested in creating or updating RC bootcamp or contributing to the project. If you want to access RC bootcamp materials, see https://rc-bootcamp.github.io/.
RC bootcamp is a platform to create introductory materials for reservoir computing (RC). We use Jupyter Notebooks and Python so newcomers to coding can learn RC from basics to advanced topics through hands-on exercises. Key features of this platform are listed below.
-
Multi-language support: Use language tags in markdown cells to put multiple languages into the same notebook. When building, the
Makefileextracts only the sections tagged for the chosen language. Those pieces are then combined into per-language notebooks, so a single source notebook can produce versions for different languages. English (en) and Japanese (ja) are supported now; you can add other languages by adding tags and translations and updatingLANGUAGESin theMakefile. -
Automatic fill-in-the-blank exercise generation: Add special markers in code cells and the build will replace those parts with placeholders (
...) to create exercises. You can also generate solution versions automatically, so authors manage exercises and solutions in the same notebook. This cuts down on work and makes updating materials easier. -
Answer checking and display: We provide a simple tester (
test_func) that runs learners' code on prepared datasets to automatically verify correctness. This goes beyond running example code and helps learners build coding skills and a deeper understanding of RC. We also provideshow_solution, which prints model answers so learners can check solutions when stuck. -
High extensibility: Each chapter is a standalone notebook, so adding or editing chapters is easy. RC moves fast, and new topics pop up often, so this layout helps keep the content current. After chapter 9 the material shifts toward more advanced research topics, and we may add more chapters later.
Clone the repo and change into it:
git clone https://github.com/rc-bootcamp/rc_bootcamp.git
cd rc_bootcampWe use uv and VSCode for development.
Install uv and then sync project dependencies with:
uv sync --group build --extra gpuUse --extra gpu only for notebooks that need a GPU (e.g., chapter 7, 11); otherwise omit it.
After syncing, install Playwright browsers with:
playwright installwhich is required to convert some notebooks to markdown (.md) and PDF during the build.
Activate the virtualenv and run make to test the build (the first line assumes bash/zsh; on Windows use .venv\Scripts\activate instead):
source .venv/bin/activate
makeOr run the build with uv:
uv run makeA successful build creates product/rc_bootcamp_[LANG][MODE_SUFFIX]/ directories for each language and mode.
By default the build creates four product folders:
product/rc_bootcamp_en: English exercise version.product/rc_bootcamp_en_sol: English solution version.product/rc_bootcamp_ja: Japanese exercise version.product/rc_bootcamp_ja_sol: Japanese solution version.
Below are guidelines for editing notebooks (.ipynb files).
All notebooks are under src/.
Use language tags such as [en]: # and [ja]: # to include multiple languages in the same markdown cell.
Use [END]: # to end language-specific sections for shared content (e.g., math or figures).
The example below shows a markdown cell with English and Japanese parts, plus shared math.
[en]: #
Hello, this is an English sentence.
[ja]: #
こんにちは、これは日本語の文章です。
[END]: #
$$
a + b = c
$$
[en]: #
where $a$, $b$, and $c$ are variables.
[ja]: #
ここで$a$、$b$、$c$は変数です。During build, the English version (en) will include only the [en]: # sections and the shared content, while the blocks for other languages are omitted.
In this case, the English version becomes:
Hello, this is an English sentence.
$$
a + b = c,
$$
where $a$, $b$, and $c$ are variables.The Japanese version (ja) will be:
こんにちは、これは日本語の文章です。
$$
a + b = c,
$$
ここで$a$、$b$、$c$は変数です。To add another language, append its language tag and content in the same way.
The new language tag should be appended to LANGUAGES in Makefile.
Use language tags following ISO 639-1 (e.g., es for Spanish, zh for Chinese).
Put images in assets/ and link them from notebooks in src/ using a relative path like ../assets/example_image.webp.
The build embeds images as base64.
For example, write:
This will be embedded in the built notebook like:
<img src="..." alt="example_image.webp"/>You can use several other markers in markdown cells.
Content wrapped with tips markers becomes a collapsible widget.
[tips]: #
This is a tip.
[/tips]: #It expands during build to:
<details><summary>tips</summary>
This is a tip.
</details>Content wrapped with figc is treated as a figure caption.

[figc]: #
This is a caption for the figure.
[/figc]: #It expands during build to:

<figcaption align="center">
This is a caption for the figure.
</figcaption>You can combine figc with language tags, but you must end each language block with [END]: # so the closing [/figc]: # applies to all languages.
[figc]: #
[en]: #
Fig. 1: An example caption.
[ja]: #
図1: キャプションの例。
[END]: #
[/tips]: #Several markers and helper functions are provided to create fill-in-the-blank exercises and check answers.
Put the following special markers in code cells and the build will replace those parts with ....
Content between them is replaced by ....
Example:
def solution(year: int):
# BEGIN Check if the year is a leap year.
if (year % 4 == 0 and year % 100 != 0) or (year % 400 == 0):
return True
else:
return False
# ENDBuild result:
def solution(year: int):
# TODO: Check if the year is a leap year.
...It replaces the whole expression on the line with ....
Example:
def solution(x):
y = x ** 2
print(y) # BLANK Print the processed value
return yBuild result:
def solution(x):
y = x ** 2
... # TODO Print the processed value
return yIt replaces the right-hand side expression with ....
Example:
def solution(a, b, c):
"""Multiply (a + 5), (b + 2) and 3 * c and return the result."""
a = a + 5 # RIGHT Add 5 to a
b += 2 # RIGHT Add 2 to b
c *= 3 # RIGHT Multiply c by 3
return a * b * cBuild result:
def solution(a, b, c):
"""Multiply (a + 5), (b + 2) and 3 * c and return the result."""
a = ... # TODO Add 5 to a
b += ... # TODO Add 2 to b
c *= ... # TODO Multiply c by 3
return a * b * cIt replaces right-hand side expressions inside the block with ....
Example:
def solution(x, y, z, a=10, b=28, c=8.0 / 3.0):
# RIGHT_B Implement the Lorenz system differential equations.
x_dot = a * (y - x) # NOTE: The comment is omitted.
y_dot = x * (b - z) - y
z_dot = x * y - c * z
# RIGHT_E
return x_dot, y_dot, z_dotBuild result:
def solution(x, y, z, a=10, b=28, c=8.0 / 3.0):
# TODO Implement the Lorenz system differential equations.
x_dot = ...
y_dot = ...
z_dot = ...
# end of TODO
return x_dot, y_dot, z_dottest_func and show_solution help test learner's code.
Example: load them from a chapter in src:
from utils.tester import load_from_chapter_name
test_func, show_solution = load_from_chapter_name("SAMPLE_CHAPTER")Put datasets and model answers under src/data/SAMPLE_CHAPTER/.
For a simple addition problem sample_problem, the problem cell can be:
def solution(a, b):
# BEGIN Implement addition of a and b.
ans = a + b
return ans
# END
test_func(solution, "sample_problem")
show_solution("sample_problem", "solution")The dataset and solution should be written in src/data/SAMPLE_CHAPTER/sample_problem.py.
Example:
import random
from utils.tester import to_args
def solution(a, b):
"""
This is the expected solution for addition of a and b.
"""
ans = a + b
return ans
def dataset():
random.seed(1234) # Change seed as needed
yield to_args(3, 5)
yield to_args(-1, 1)
for _ in range(18):
a = random.randint(-10000, 10000)
b = random.randint(-10000, 10000)
yield to_args(a, b)solution is the expected answer and dataset yields test cases.
test_func(solution, "sample_problem") runs the learner's code on each case.
If all pass it prints OK! (pass all cases).
If any fail it prints Failed! with input, expected, and actual outputs.
For multiple return values use multiple_return=True.
Pass a non-zero integer to debug_mode to see more details:
debug_mode=0(default): only show pass/fail.debug_mode=1: show execution time per case.debug_mode=2: show inputs per case.debug_mode=3: show expected vs actual outputs.debug_mode=-1: show execution time only.debug_mode=-2: show execution time and inputs.debug_mode=-3: show time, inputs, and outputs.
show_solution("sample_problem", "solution") prints the solution function from sample_problem.py.
For the example it prints:
def solution(a, b):
"""
This is the expected solution for addition of a and b.
"""
ans = a + b
return ans
To show another function, pass its name as the second argument.
These markers are replaced during build with the [LANG][MODE_SUFFIX] (e.g., en, ja_sol) and project name (rc_bootcamp).
{ These markers are replaced during the build by the language+mode tag [LANG][MODE_SUFFIX] (e.g., en, ja_sol) and the project name (rc_bootcamp). }
The Makefile defines build behavior.
Below are main and helper targets.
[LANG] is a language code (e.g., en or ja) and [MODE] is ex (exercise, [MODE_SUFFIX] is "") or sol (solution, [MODE_SUFFIX] is "_sol").
Running make defaults to make deploy.
The make deploy command builds the project using the steps below.
- Run tests on all original source files (
.ipynband.py) insrc/. - Create the
build/directory. - Split notebooks in
src/by language tags intobuild/rc_bootcamp_[LANG][MODE_SUFFIX]/. - Run syntax checks on all built
.ipynbfiles inbuild/rc_bootcamp_[LANG][MODE_SUFFIX]/. - Convert selected notebooks (README.ipynb by default) to markdown (
.md) and PDF (.pdf). - Copy built notebooks, converted files, and required root settings and libraries into
product/rc_bootcamp_[LANG][MODE_SUFFIX]/.
make deploy builds all languages in LANGUAGES (default: en ja) and modes in MODES (default: ex sol), producing four output folders.
To build a single language or mode, run make [LANG] or make [LANG]_[MODE] (e.g., make en or make ja_ex).
You can include or exclude targets with [LANG]_include and [LANG]_exclude variables, which accept space-separated glob patterns for notebook filenames (without extensions).
For example, to build only chapters 1-5 and README in English exercise mode, run:
make en_ex en_include="01* 02* 03* 04* 05* README"To build all chapters except chapters 7 and 11 in Japanese solution mode, run:
make ja_sol ja_exclude="07* 11*"You can set these variables in the Makefile to avoid repeating them.
The [LANG]_include and [LANG]_exclude variables also work with make dist and make test, which is handy for building only part of the notebooks during translation.
make dist does the same as make deploy but creates a zip archive at product/rc_bootcamp_[LANG][MODE_SUFFIX].zip in stead of a folder in step 6.
For example, run make en-dist or make ja_ex-dist to archive a specific build.
make mark runs only steps 2, 3 and 5 of make deploy (Run test on source files, create the build dir, split notebooks by language tags, and convert notebooks to .md/.pdf).
It skips syntax checks and copying to product/.
make test runs only steps 1, 2, 3, and 4 of make deploy (Create the build dir, split notebooks by language tags, and run syntax checks).
It does not convert notebooks to .md/.pdf or expand outputs under product/.
Tests use tool/check_and_fix_notebook.py and nbqa ruff; the lint rules come from [tool.ruff.lint] in .pyproject.toml.
Checks are as follows ( [VERSION] is the version in the .python-version file ).
-
Metadata:
- Whole notebook:
- Check that
kernelspecis set correctly.display_nameshould berc-bootcamp ([VERSION]).languageshould bepython.nameshould bepython3.
- Check that
language_infois set correctly.nameshould bepython.versionshould be[VERSION].
- Check that
- For each cell:
- Ensure there are no unnecessary fields in cell metadata.
- Whole notebook:
-
For both code and markdown cells:
- Ensure there are no empty cells.
- Ensure there are no unnecessary leading blank lines (*).
- Ensure there are no unnecessary trailing blank lines (*).
- Ensure there are no trailing spaces at the end of lines (*).
-
For markdown cells:
- Header cells (
#, ##, ###, ####, etc.) must not contain non-heading content (**)- This enhances readability and navigation.
- Avoid two or more consecutive blank lines (*).
- Do not leave a stray
[END]: #marker at the end of a markdown cell.
- Header cells (
-
For code cells:
- Ensure the execution count is null.
- Ensure the cell output is cleared.
- Ensure there are no ruff lint errors:
flake8-bugbear (B): Find likely bugs and design problems in your program.pycodestyle (E, W): Check your Python code against some of the style conventions in PEP 8.isort (I): Check that imports are sorted correctly.Pyflakes (F): Detect various errors in Python code.numpy (NPY): Check for NumPy-specific coding issues.
These checks apply to notebooks under src/ and build/.
Items marked with (*) are auto-fixed for notebooks in build/ by tool/check_and_fix_notebook.py during make test, but those in src/ must be fixed before building.
Items marked with (**) are not auto-fixed by make beautify and must be fixed manually.
The following rules are ignored during all tests:
B018: Found useless expression. Either assign it to a variable or remove it.E402: Module level import not at top of cell.E501: Line too long ({width} > {limit})
In ex (exercise) mode, the following rules are additionally ignored:
B007: Checks for unused variables in loops (e.g., for and while statements).F401: Checks for unused imports.F841: Checks for the presence of unused variables in function scopes.
Makefile provides several helper targets.
Creates product/rc_bootcamp_base.zip using git archive of HEAD.
Formats notebooks under src/ with tool/check_and_fix_notebook.py and nbqa ruff, fixing most issues reported by make test except markdown heading problems.
Removes build artifacts and intermediate files.
make clear: deletesproduct/.make clean: deletesproduct/andbuild/.
Lists available make targets.
Available make targets:
archive
beautify
clean
clear
deploy
dist
en
en-dist
en_ex
en_ex-dist
en_ex-test
en_sol
en_sol-dist
en_sol-test
en-test
help
ja
ja-dist
ja_ex
ja_ex-dist
ja_ex-test
ja_sol
ja_sol-dist
ja_sol-test
ja-test
test
test-src
We welcome contributions from everyone. To contribute to RC bootcamp, follow these steps.
Report bugs or feature requests on GitHub Issues: https://github.com/rc-bootcamp/rc_bootcamp/issues.
Fork the repo, apply your changes, and open a pull request (PR) to the main branch.
Do not open PRs to other branches; those are auto-generated by the build.
GitHub Actions runs make test on every PR.
Run make test locally before submitting, or run make beautify to auto-format your changes so they pass most checks.
In the PR description, briefly explain what you changed and why.
Maintainers will review PRs, give feedback, and approve, decline, or request changes.
If accepted, the PR is squashed and merged into main, the version is bumped, and a new release is released.
If you use RC bootcamp in your research or publications, please cite the following paper (coming soon).
@article{inoue2025rcbootcamp,
title = {Reservoir computing bootcamp---from Python/NumPy tutorial for the complete beginners to cutting-edge research topics of reservoir computing},
author = {Inoue, Katsuma and Kubota, Tomoyuki and Tran, Quoc Hoan and Akashi, Nozomi and Terajima, Ryo and Kabayama, Tempei and Guan, JingChuan and Nakajima, Kohei},
year = 2025,
month = XX,
journal = {XX},
volume = {XX},
number = {X},
pages = {XXXXXX},
issn = {XXXX-XXXX},
doi = {xxxxxx/xxxxxx}
}For questions or feedback contact k-inoue[at]isi.imi.i.u-tokyo.ac.jp.