High-performance ISCC similarity search engine
Project description
iscc-search
[!WARNING] BETA - This project is under active development. The API is not yet stable and may change without notice. Use at your own risk.
High-performance similarity search engine for ISCC (International Standard Content Code). Ships as a Python package, a CLI, and a FastAPI REST server, with pluggable backends for in-memory, LMDB, and HNSW-accelerated indexes.
- Github repository: https://github.com/iscc/iscc-search/
- Documentation https://search.iscc.codes/
Note: iscc-usearch is a separate project - a patched fork of the usearch vector search library that provides the NPHD metric and low-level vector indexes. iscc-search uses it internally as one of its backends. Most users only need to install iscc-search.
Features
- REST API server (FastAPI) for indexing and searching ISCC assets
- CLI (
iscc-search) for managing multiple local or remote indexes and ingesting assets - Protocol-based backend abstraction with three implementations:
memory://— in-memory, no persistence (tests and demos)lmdb:///path— LMDB-backed persistent storage with bidirectional prefix searchusearch:///path— HNSW + LMDB for high-performance approximate nearest neighbor search
- Variable-length ISCC-UNIT indexing using the NPHD metric (via iscc-usearch)
- Granular ISCC-SIMPRINT search for fine-grained content matching
- Cross-platform (Linux, macOS, Windows)
- Python 3.10–3.13
What is ISCC?
The International Standard Content Code (ISCC) is a similarity-preserving content identifier for digital media. ISCC codes are variable-length binary vectors that enable efficient similarity search across different media types. This project provides the indexing and search engine for those codes.
Installation
pip install iscc-search
For development:
git clone https://github.com/iscc/iscc-search.git
cd iscc-search
uv sync
Quick Start
Run the server
# Start the REST API server (development mode with auto-reload)
iscc-search serve --dev
# Or production mode
iscc-search serve --host 0.0.0.0 --port 8000
Interactive API docs are available at http://localhost:8000/docs.
Use the CLI
# Register an index configuration (local or remote)
iscc-search index add my-index --uri usearch:///path/to/data
iscc-search index use my-index
# Add assets, search, retrieve
iscc-search add asset.json
iscc-search search asset.json
iscc-search get ISCC:KACYPXW557...
Configure the server
The server reads its configuration from environment variables prefixed with ISCC_SEARCH_ (or a .env file):
| Variable | Default | Description |
|---|---|---|
ISCC_SEARCH_INDEX_URI |
usearch:///... |
Backend URI (memory://, lmdb:///path, usearch:///path) |
ISCC_SEARCH_HOST |
0.0.0.0 |
Server bind host |
ISCC_SEARCH_PORT |
8000 |
Server bind port |
ISCC_SEARCH_API_SECRET |
(unset) | Optional API key; when unset the API is public |
ISCC_SEARCH_CORS_ORIGINS |
* |
Comma-separated CORS origins |
ISCC_SEARCH_LOG_LEVEL |
info |
Loguru log level |
Additional knobs control HNSW parameters, shard sizes, match thresholds, and scoring — see
iscc_search/options.py or the deployment guide for the full list.
Architecture
iscc-search uses a protocol-based design so the CLI, REST API, and library users all talk to the same
IsccIndexProtocol interface regardless of backend:
CLI / REST API / Remote client
│
▼
IsccIndexProtocol
│
┌─────────┼─────────┐
▼ ▼ ▼
memory lmdb usearch
(LMDB) (HNSW + LMDB)
See docs/architecture.md for the full picture.
Development
This project uses uv for package management and poethepoet for task automation.
Prerequisites
- Python 3.10 or higher
- uv package manager
Common tasks
uv run poe build # Rebuild schema.py + openapi.json and validate
uv run poe format # Format code and markdown
uv run poe test # Run tests with coverage (must stay at 100%)
uv run poe check-complexity # Radon complexity report
uv run poe precommit # Run pre-commit hooks
uv run poe all # Build, format, test, and complexity
Running tests
# Run full test suite in parallel with coverage
uv run poe test
# Run a single test
uv run pytest tests/test_indexes_usearch_index.py::test_foo
Technical Notes
NPHD Metric
The Normalized Prefix Hamming Distance (NPHD) is a valid metric specifically designed for variable-length prefix-compatible codes like ISCC. Unlike standard Hamming distance, NPHD:
- Correctly handles variable-length comparisons
- Normalizes over the common prefix length
- Satisfies all metric axioms (non-negativity, identity, symmetry, triangle inequality)
The implementation lives in the external iscc-usearch package, which iscc-search depends on for its HNSW backend.
Storage
- LMDB is used for durable key-value storage: ISCC entries, metadata, and the inverted prefix-search index.
- usearch (HNSW) is used for approximate nearest-neighbor search over ISCC-UNITs and ISCC-SIMPRINTS.
- Multi-worker deployments are not supported with the usearch backend — see docs/deployment.md for details.
License
Apache License 2.0 - see LICENSE file for details.
Contributing
Contributions are welcome! Please ensure:
- All tests pass (
uv run poe test) - Code is formatted (
uv run poe format) - Coverage remains at 100%
- Changes are documented
See CONTRIBUTING.md for details.
Repository initiated with fpgmaas/cookiecutter-uv.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file iscc_search-0.1.1.tar.gz.
File metadata
- Download URL: iscc_search-0.1.1.tar.gz
- Upload date:
- Size: 663.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e7f5370ab8f37b4d10905d877b640a4b88f95c83569d62ab35a3b70bba00b59b
|
|
| MD5 |
1e123e1d316d106473578ab8ba44735c
|
|
| BLAKE2b-256 |
948fc8e4d9e5e3bc1393c67f99c7e3242bd07f607a0e7c0df540b7c27d09055b
|
File details
Details for the file iscc_search-0.1.1-py3-none-any.whl.
File metadata
- Download URL: iscc_search-0.1.1-py3-none-any.whl
- Upload date:
- Size: 146.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c27e15b986909f9f2fe2704ccb9c409044491fd654313e0aa24d90622d7aebb9
|
|
| MD5 |
d8fbfb716c38d139450c8f4b00f1de8a
|
|
| BLAKE2b-256 |
8fa996a52f323524b37b2fe26c7e48327bf00628c74c83aeb9c69c30b3193f5e
|