ryanm95 downloadsSearch your vault with a powerful Obsidian native hybrid semantic and keyword retrieval, in over 52 langauges.
Seek is an Obsidian native hybrid search for Obsidian vaults, built to find buried information in large and complex vaults. It combines dense semantic embeddings with lexical (keyword) search to find exactly what you're looking for, all running within Obsidian. No APIs, or local servers needed.
Relevance has been tested and evaluated on hundreds of thousands of queries and notes, and offers easy customization to best suit your vault.
The user guide for seek can be found here, and more information about Seek's relevance tuning and evaluation is here.
Seek embeds your notes with a local embedding model and fuses those semantic scores with a lexical BM25 ranker. Indexing, embedding, and ranking all happens within Obsidian. Your notes and queries never leave your machine.
Seek runs the embedding model locally, but it has to download the model and its runtime once per device, the first time you index a vault:
huggingface.co) — the IBM Granite multilingual embedding model (~100 MB, quantized).cdn.jsdelivr.net).These downloads happen only when the assets are not already cached. They are cached on-device afterward, so there are no repeat downloads, and Seek works fully offline once the model is in place. Only these model assets are ever fetched. No note content, query text, or usage data is transmitted.
Seek writes diagnostic logs (indexing progress, search activity, and errors) to local files inside your vault to help debug performance and relevance. These logs stay on your device and are never transmitted anywhere. Additionaly, diagnostics for search and relevance can be generated which creates a report of your recent searches, with note titles, and metadata included. Results content is not included in these reports, and the reports are written to your local Seek folder.
Seek transmits no logging or data to me about your index, or your queries.
Seek is released under the MIT License (see LICENSE).
It builds on: