Find what you are looking for based on what you mean. A new file switcher powered by OpenAI's embedding API and built using WASM and Rust.
- Setup OpenAI API key in plugin settings
- Run
Generate Input
command - Run
Generate Embedding
command - Run
Open Query Modal
command and start semantic searching!
mp4.mp4
Command | Description |
---|---|
Generate Input | Generate input csv based on sections of your notes. Currently, sections are defined as text blocks between headings. Prepared input is saved as input.csv in your root folder. |
Generate Embedding | Obtain embeddings via OpenAI's text-embedding-ada-002 embedding model (this requires that the generate input command was successfully executed). Generated embeddings is saved as embedding.csv in your root folder. |
Open Query Modal | Semantic search through your notes using generated embeddings. |
Recommend links using current selection | Uses current editor selection as query input, automatically creating a markdown link with your choice. Can also be triggered in the context menu using the mouse right-click. |
Setting | Description |
---|---|
API Key | Your OpenAI API key which can be found here. This gets stored into data.json as per all obsidian plugin settings data so make sure you do not commit this file to a repository. |
Section Delimeters | Regex used to determine if the current line is the start of a new section. Sections are used to group related content together. Defaults to . , meaning every line starts a new section. E.g. matching every heading: ^#{1,6} |
Folders to ignore | Folders to ignore when generating input. Enter folder paths separated by newlines. |
Number of batches | Number of batches used to call OpenAI's endpoint. If you have lots of data, and are facing invalid request errors, try increasing this number. |
Enable link recommendation using {{}} |
Use {{}} as a way to trigger semantic search suggestions for file linking. |
From Obsidian v1.0.0, this plugin can be activated from within Obsidian:
- Open Settings > Third-party plugin
- Make sure Safe mode is off
- Click Browse community plugins
- Search for "Semantic Search"
- Click the "Install" button
- Once installed, close the community plugins window
- Under the "Installed plugins" section, enable Semantic Search
From Github
- Download the latest release distribution
- Extract the the contents of the distribution zip file to your vault's plugins folder: /.obsidian/plugins/ Note: On MacOs the .obsidian folder may be hidden by default.
- Reload Obsidian
- Open Settings, third-party plugins, make sure safe mode is off and enable "Semantic Search" from there.
Contributions are welcome!
- Clone the repo
- cd into the newly created folder and run
yarn install
- Run
yarn run dev
This plugin is very much experimental at the moment, use it at your own risk. Testing is done on Windows.
Thanks to Robert's blog post for the idea and inspiration!