An MCP server for I Ching divination (Wilhelm-Baynes translation), compatible with Goose, Claude Code, and other MCP clients, plus a command-line utility.
- Three coins method divination following traditional practices
- Wilhelm-Baynes translation with complete hexagram meanings, judgments, and line interpretations
- Multiple interfaces: CLI tool, MCP server for Goose, Claude Code, and other MCP-compatible clients
- Flexible input formats: hexagram numbers, Unicode characters, line numbers, or changing hexagram notation
- Rich output formats: brief, full interpretations, JSON, and MOTD formats
- Changing line support with transformation interpretations
This tool provides three interfaces:
- CLI Tool - Command-line divination and interpretation
- Goose Extension - MCP server for Goose AI assistant
- Claude Code Plugin - Native plugin for Claude Code
All interfaces use the same binaries. Start with Installation below, then jump to your preferred interface.
This section covers installing the binaries needed for all interfaces (CLI, Goose, and Claude Code).
- Rust 1.85.1 or later (for 2024 edition support)
- Cargo (included with Rust)
cargo install i-chinggit clone https://github.com/threemachines/i-ching.git
cd i-ching
cargo install --path .git clone https://github.com/threemachines/i-ching.git
cd i-ching
cargo build --releaseBinaries will be in ./target/release/ directory.
All installation methods create two binaries:
i-ching- CLI tooli-ching-mcp-server- MCP server for Goose and Claude Code
The binaries include embedded data files, so they work anywhere without requiring external data files.
Important for MCP usage (Goose & Claude Code): The i-ching-mcp-server binary must be in your PATH.
Check if ~/.cargo/bin is in your PATH:
echo $PATH | grep -q "$HOME/.cargo/bin" && echo "✓ Cargo bin is in PATH" || echo "✗ Cargo bin is NOT in PATH"If it's not in your PATH, add it to your shell configuration:
# For zsh (macOS default)
echo 'export PATH="$HOME/.cargo/bin:$PATH"' >> ~/.zshrc
source ~/.zshrc
# For bash
echo 'export PATH="$HOME/.cargo/bin:$PATH"' >> ~/.bash_profile
source ~/.bash_profileNote: If you installed Rust via Homebrew (rather than rustup), cargo install still puts binaries in ~/.cargo/bin, which may not be in your PATH by default.
# Random reading using three coins method
i-ching
# Get help
i-ching --helpThe CLI supports multiple input formats via the --input flag:
# Hexagram number (1-64)
i-ching --input 1
# Unicode hexagram character
i-ching --input ䷀
# Line numbers (6,7,8,9 format)
i-ching --input "7,8,9,6,7,8"
# Changing hexagram notation
i-ching --input "32→34"
i-ching --input "32->34"
i-ching --input "䷟→䷡"Control output format with the --format flag:
# Brief format (default for quick reference)
i-ching --format brief --input 1
# Output: ䷀ 1 Initiating
# Full format with complete interpretations
i-ching --format full --input 1
# JSON format for programmatic use
i-ching --format json --input 1
# Numbers only (traditional line values)
i-ching --format numbers --input 1
# Output: [8, 8, 8, 8, 8, 8]
# MOTD format (all caps, for system messages)
i-ching --format motd --input 1
# Output: ䷀ 1 INITIATINGPrerequisites: Complete Installation above first.
-
Open Goose Desktop
-
Go to Extensions (top-level menu item)
-
Click Add Custom Extension
-
Fill in the extension details:
- ID:
i-ching(or your preferred identifier) - Name:
I Ching Divination - Description:
I Ching divination readings with Wilhelm-Baynes translation - Type:
STDIO - Command:
i-ching-mcp-server
- ID:
-
Click Save to add the extension
-
Enable the extension by toggling it on in the Extensions list
If the extension is enabled, Goose should be able to find and use it. The phrase "conduct a divination" or the keywords "augur" and "auspicious" seem to be enough in Claude models, while GPT seems to need you to more specifically namedrop the I Ching. (I would love more anecdata on how it works with different models - please open an issue or a PR modifying this README with your experiences.)
Prerequisites: Complete Installation above first, including the PATH verification step.
This repository includes a Claude Code plugin configuration (.claude-plugin/ and .mcp.json) that enables I Ching divination directly in Claude Code.
Start Claude Code with the plugin directory flag:
claude --plugin-dir /path/to/i-chingOr, if you cloned this repo to your home directory:
claude --plugin-dir ~/i-chingOn first use, Claude Code will ask for permission to:
- Load the plugin
- Use the MCP server tools (shown with a
plugin:i-ching:i-chingprefix)
This is normal security behavior. Grant both permissions to enable divination.
Once loaded, Claude Code can perform I Ching divinations. You can:
- Ask for divination: "Please conduct an I Ching reading for me"
- Request specific interpretations: "What does hexagram 1 mean?"
- Use traditional language: "I need an augury about my travel preparations"
The AI will automatically use the cast_hexagram tool to generate readings and interpret_reading to provide the complete Wilhelm-Baynes text and interpretation.
MCP server failed to start
If you see "1 MCP server failed" in Claude Code:
-
Verify the binary is in your PATH (see Installation - Verify PATH Configuration):
which i-ching-mcp-server
If this returns "not found", you need to add
~/.cargo/binto your PATH. -
Verify the binary was installed:
ls -la ~/.cargo/bin/i-ching-mcp-server -
Check Claude Code debug logs:
tail -100 ~/.claude/debug/latest | grep -i "i-ching\|mcp"
Plugin not loading
Make sure you're using the --plugin-dir flag when starting Claude Code and pointing it to the directory containing .claude-plugin/plugin.json.
The MCP server can be used directly with any MCP-compatible client:
./target/release/i-ching-mcp-server- Purpose: Cast a new I Ching reading
- Parameters:
lines(optional): Array of 6 line values [6,7,8,9] to specify exact readingmethod(optional): Divination method (currently only "coins" supported)
- Returns: Complete reading with hexagram details and interpretations
- Purpose: Get detailed interpretation of a hexagram
- Parameters:
hexagram: Primary hexagram number (1-64)changing_lines(optional): Array of changing line positions [1-6]transformed_hexagram(optional): Transformed hexagram number
- Returns: Detailed interpretation including meanings, judgments, and line interpretations
This tool uses the three coins method for divination, which has been widely used since the Song Dynasty (960-1279 CE). Each line is determined by tossing three coins:
- 3 heads (HHH): Old Yang (9) - changing line
- 2 heads, 1 tail: Young Yin (8) - stable line
- 1 head, 2 tails: Young Yang (7) - stable line
- 3 tails (TTT): Old Yin (6) - changing line
I chose to not support yarrow-stalk readings for several reasons:
- The separation of the stalks could be emulated with a probability curve, but I don't have any data I trust about how to calibrate that curve.
- The separation is a volitional act that presents some philosophical challenges for automating. I think there's an argument that, as the augur, Goose could "choose" how to divide the stalks by seeding the RNG, but this seems sketchy and would still need the abovementioned probability curve.
- Because this is written in Rust, I have some concerns that compiler optimizations could disrupt the form of the rites. For example, although the code could represent starting with 50 stalks and removing one at the beginning of the casting, the compiler might simplify this to simply starting with 49 stalks, which would be unacceptable.
Future versions could allow for an MCP user to conduct their own reading and merely input the numeric results for AI interpretation, if there's demand.
This project uses the Wilhelm-Baynes translation of the I Ching, which is considered one of the most authoritative English translations. The data includes:
- 64 hexagrams with names, Chinese characters, and pinyin
- Judgments with full commentary
- Images with interpretations
- Line interpretations for all 384 individual lines
- Trigram information and relationships
src/
├── lib.rs # Library root
├── cli.rs # CLI interface and formatting
├── bin/
│ ├── main.rs # CLI binary
│ └── mcp_server.rs # MCP server binary
└── core/
├── mod.rs # Core module exports
├── data.rs # Data loading and structures
├── divination.rs # Divination logic (coin tossing)
└── reading.rs # Reading representation and methods
cargo testUpdate the version in Cargo.toml. This version number is also published by the MCP itself.
This project is licensed under the MIT License - see the LICENSE file for details.
Lovingly vibecoded in Goose with claude-4-sonnet.
This project would not have been possible without adamblvck's dataset of the Wilhelm-Baynes text of the I Ching, and of course thanks are also due to Richard Wilhelm and Cary F. Baynes for producing their translation.
Special thanks to John Minford, whose I Ching translation I quite like, and which provided invaluable guidance on correctly enacting the rites. (Although I acknowledge his objection to digital methods.)
This project was originally inspired by a skeet from Hazel Weakly.
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
If you encounter any issues or have questions, please file an issue on the GitHub repository.


