Skip to content

Goose-friendly MCP server for conducting I Ching divinations

License

Notifications You must be signed in to change notification settings

threemachines/i-ching

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

I Ching Divination

An MCP server for I Ching divination (Wilhelm-Baynes translation), compatible with Goose, Claude Code, and other MCP clients, plus a command-line utility.

Screenshots

Claude Sonnet 4

claude-4-sonnet

Claude Sonnet 3.5

claude-3-5-sonnet

GPT 4.1

gpt-4-1

Features

  • 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

Quick Start

This tool provides three interfaces:

All interfaces use the same binaries. Start with Installation below, then jump to your preferred interface.

Installation

This section covers installing the binaries needed for all interfaces (CLI, Goose, and Claude Code).

Prerequisites

  • Rust 1.85.1 or later (for 2024 edition support)
  • Cargo (included with Rust)

Installing the Binaries

Option 1: From crates.io (recommended)

cargo install i-ching

Option 2: From source

git clone https://github.com/threemachines/i-ching.git
cd i-ching
cargo install --path .

Option 3: Build without installing (development)

git clone https://github.com/threemachines/i-ching.git
cd i-ching
cargo build --release

Binaries will be in ./target/release/ directory.

Binaries Created

All installation methods create two binaries:

  • i-ching - CLI tool
  • i-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.

Verify PATH Configuration

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_profile

Note: 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.

CLI Usage

Basic Usage

# Random reading using three coins method
i-ching

# Get help
i-ching --help

Input Formats

The 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 "䷟→䷡"

Output Formats

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 INITIATING

Goose Extension Setup

Prerequisites: Complete Installation above first.

Enable in Goose

  1. Open Goose Desktop

  2. Go to Extensions (top-level menu item)

  3. Click Add Custom Extension

  4. 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
  5. Click Save to add the extension

  6. Enable the extension by toggling it on in the Extensions list

Using in Goose

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.)

Claude Code Setup

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.

Load the Plugin

Start Claude Code with the plugin directory flag:

claude --plugin-dir /path/to/i-ching

Or, if you cloned this repo to your home directory:

claude --plugin-dir ~/i-ching

Grant Permissions

On first use, Claude Code will ask for permission to:

  1. Load the plugin
  2. Use the MCP server tools (shown with a plugin:i-ching:i-ching prefix)

This is normal security behavior. Grant both permissions to enable divination.

Using with Claude Code

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.

Troubleshooting

MCP server failed to start

If you see "1 MCP server failed" in Claude Code:

  1. 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/bin to your PATH.

  2. Verify the binary was installed:

    ls -la ~/.cargo/bin/i-ching-mcp-server
  3. 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.

MCP Server Usage

The MCP server can be used directly with any MCP-compatible client:

./target/release/i-ching-mcp-server

Available Tools

cast_hexagram

  • Purpose: Cast a new I Ching reading
  • Parameters:
    • lines (optional): Array of 6 line values [6,7,8,9] to specify exact reading
    • method (optional): Divination method (currently only "coins" supported)
  • Returns: Complete reading with hexagram details and interpretations

interpret_reading

  • 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

Divination Method

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

On Yarrow Stalks

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.

Data Source

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

Development

Project Structure

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

Running Tests

cargo test

Updating

Update the version in Cargo.toml. This version number is also published by the MCP itself.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgements

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.

Contributing

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.

Support

If you encounter any issues or have questions, please file an issue on the GitHub repository.

About

Goose-friendly MCP server for conducting I Ching divinations

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Contributors 2

  •  
  •  

Languages