<p align="center">
<img src="https://uploads-ssl.webflow.com/62dfa8e3960a6e2b47dc7fae/62fdf9cef684e6f16158b094_MARQO%20LOGO-UPDATED-GREEN.svg" width="50%" height="40%">
</p>
<p align="center">
<b><a href="https://www.marqo.ai">Website</a> | <a href="https://docs.marqo.ai">Documentation</a> | <a href="https://demo.marqo.ai">Demos</a> | <a href="https://community.marqo.ai">Discourse</a> | <a href="https://bit.ly/marqo-slack">Slack Community</a> | <a href="https://www.marqo.ai/cloud">Marqo Cloud</a>
</b>
</p>
<p align="center">
<a href="https://opensource.org/licenses/Apache-2.0"><img src="https://img.shields.io/badge/License-Apache%202.0-blue.svg"></a>
<a href="https://pypi.org/project/marqo/"><img src="https://img.shields.io/pypi/v/marqo?label=PyPI"></a>
<a href="https://github.com/marqo-ai/marqo/actions/workflows/unit_test_200gb_CI.yml"><img src="https://img.shields.io/github/actions/workflow/status/marqo-ai/marqo/unit_test_200gb_CI.yml?branch=mainline"></a>
<a align="center" href="https://bit.ly/marqo-slack"><img src="https://img.shields.io/badge/Slack-blueviolet?logo=slack&logoColor=white"></a>
## Marqo
Marqo is more than a vector database, it's an end-to-end vector search engine for both text and images. Vector generation, storage and retrieval are handled out of the box through a single API. No need to bring your own embeddings.
**Why Marqo?**
Vector similarity alone is not enough for vector search. Vector search requires more than a vector database - it also requires machine learning (ML) deployment and management, preprocessing and transformations of inputs as well as the ability to modify search behavior without retraining a model. Marqo contains all these pieces, enabling developers to build vector search into their application with minimal effort. A full list of features can be found [below](#-core-features).
**Why not X, Y, Z vector database?**
Vector databases are specialized components for vector similarity and only service one component of a vector search system. They are “vectors in - vectors out”. They still require the production of vectors, management of the ML models, associated orchestration and processing of the inputs. Marqo makes this easy by being “documents in, documents out”. Preprocessing of text and images, embedding the content, storing meta-data and deployment of inference and storage is all taken care of by Marqo.
**Quick start**
Here is a code snippet for a minimal example of vector search with Marqo (see [Getting Started](#getting-started)):
1. Use docker to run Marqo:
```bash
docker rm -f marqo
docker pull marqoai/marqo:latest
docker run --name marqo -it -p 8882:8882 marqoai/marqo:latest
```
Note: If your `marqo` container keeps getting killed, this is most likely due to a lack of memory being allocated to Docker. Increasing the memory limit for Docker to at least 6GB (8GB recommended) in your Docker settings may fix the problem.
2. Install the Marqo client:
```bash
pip install marqo
```
3. Start indexing and searching! Let's look at a simple example below:
```python
import marqo
mq = marqo.Client(url='http://localhost:8882')
mq.create_index("my-first-index")
mq.index("my-first-index").add_documents([
{
"Title": "The Travels of Marco Polo",
"Description": "A 13th-century travelogue describing Polo's travels"
},
{
"Title": "Extravehicular Mobility Unit (EMU)",
"Description": "The EMU is a spacesuit that provides environmental protection, "
"mobility, life support, and communications for astronauts",
"_id": "article_591"
}],
tensor_fields=["Description"]
)
results = mq.index("my-first-index").search(
q="What is the best outfit to wear on the moon?"
)
```
## ✨ Core Features
**🤖 State of the art embeddings**
- Use the latest machine learning models from PyTorch, Huggingface, OpenAI and more.
- Start with a pre-configured model or bring your own.
- Built-in ONNX support and conversion for faster inference and higher throughput.
- CPU and GPU support.
**⚡ Performance**
- Embeddings stored in in-memory HNSW indexes, achieving cutting edge search speeds.
- Scale to hundred-million document indexes with horizontal index sharding.
- Async and non-blocking data upload and search.
**🌌 Documents-in-documents-out**
- Vector generation, storage, and retrieval are provided out of the box.
- Build search, entity resolution, and data exploration application with using your text and images.
- Build complex semantic queries by combining weighted search terms.
- Filter search results using Marqo’s query DSL.
- Store unstructured data and semi-structured metadata together in documents, using a range of supported datatypes like bools, ints and keywords.
**🍱 Managed cloud**
- Low latency optimised deployment of Marqo.
- Scale inference at the click of a button.
- High availability.
- 24/7 support.
- Access control.
- Learn more [here](https://www.marqo.ai/cloud).
## Integrations
Marqo is integrated into popular AI and data processing frameworks, with more on the way.
**💙 [Haystack](https://github.com/deepset-ai/haystack)**
Haystack is an open-source framework for building applications that make use of NLP technology such as LLMs, embedding models and more. This [integration](https://haystack.deepset.ai/integrations/marqo-document-store) allows you to use Marqo as your Document Store for Haystack pipelines such as retrieval-augmentation, question answering, document search and more.
**🛹 [Griptape](https://github.com/griptape-ai/griptape)**
Griptape enables safe and reliable deployment of LLM-based agents for enterprise applications, the MarqoVectorStoreDriver gives these agents access to scalable search with your own data. This integration lets you leverage open source or custom fine-tuned models through Marqo to deliver relevant results to your LLMs.
**🦜🔗 [Langchain](https://github.com/langchain-ai/langchain)**
This integration lets you leverage open source or custom fine tuned models through Marqo for LangChain applications with a vector search component. The Marqo vector store implementation can plug into existing chains such as the Retrieval QA and Conversational Retrieval QA.
**⋙ [Hamilton](https://github.com/DAGWorks-Inc/hamilton/)**
This integration lets you leverage open source or custom fine tuned models through Marqo for Hamilton LLM applications.
## Learn more about Marqo
| | |
| --------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| 📗 [Quick start](#Getting-started)| Build your first application with Marqo in under 5 minutes. |
| 🖼 [Marqo for image data](https://www.marqo.ai/blog/context-is-all-you-need-multimodal-vector-search-with-personalization) | Building advanced image search with Marqo. |
| 📚 [Marqo for text](https://www.marqo.ai/blog/how-i-used-marqo-to-create-a-multilingual-legal-databse-in-5-key-lines-of-code) | Building a multilingual database in Marqo. |
| 🔮 [Integrating Marqo with GPT](https://www.marqo.ai/blog/from-iron-manual-to-ironman-augmenting-gpt-with-marqo-for-fast-editable-memory-to-enable-context-aware-question-answering) | Making GPT a subject matter expert by using Marqo as a knowledge base. |
| 🎨 [ Marqo for Creative AI](https://www.marqo.ai/blog/combining-stable-diffusion-with-semantic-search-generating-and-categorising-100k-hot-dogs) | Combining stable diffusion with semantic search to generate and categorise 100k images of hotdogs. |
| 🔊 [Marqo and Speech Data](https://www.marqo.ai/blog/speech-processing) | Add diarisation and transcription to preprocess audio for Q&A with Marqo and ChatGPT. |
| 🚫 [Marqo for content moderation](https://www.marqo.ai/blog/refining-image-quality-and-eliminating-nsfw-content-with-marqo) | Building advanced image search with Marqo to find and remove content. |
| ☁️ [Getting started with Marqo Cloud](https://github.com/marqo-ai/getting_started_marqo_cloud) | Go through how to get set up and running with Marqo Cloud starting from your first time login through to building your first application with Marqo|
| 👗 [Marqo for e-commerce](https://github.com/marqo-ai/getting_started_marqo_cloud/blob/main/e-commerce-demo/README.md) | This project is a web application with frontend and backend using Python, Flask, ReactJS, and Typescript. The frontend is a ReactJS application that makes requests to the backend which is a Flask application. The backend makes requests to your Marqo cloud API.|
| 🤖 [Marqo chatbot](https://github.com/marqo-ai/getting_started_marqo_cloud/tree/main/chatbot-demo) | In this guide we will build a chat bot application using Marqo and OpenAI's ChatGPT API. We will start with an existing code base and then walk through how to customise the behaviour.|
| 🦾 [Features](#-Core-Features) | Marqo's core features. |
## Getting started
1. Marqo requires docker. To install Docker go to the [Docker Official website](https://docs.docker.com/get-docker/). Ensure that docker has at least 8GB memory and 50GB storage.
2. Use docker to run Marqo:
```bash
docker rm -f marqo
docker pull marqoai/marqo:latest
docker run --name marqo -it --privileged -p 8882:8882 --add-host host.docker.internal:host-gateway marqoai/marqo:latest
```
Note: If your `marqo` container keeps getting killed, this is most likely due to a lack of memory being allocated to Docker. Increasing the memory limit for Docker to at least 6GB (8GB recommended) in your Docker settings may fix the problem.
3. Install the Marqo client:
```bash
pip install marqo
```
4. Start indexing and searching! Let's look at a simple example below:
```python
import marqo
mq = marqo.Client(url='http://localhost:8882')
mq.create_index("my-first-index")
mq.index("my-first-index").add_documents([
{
"Title": "The Travels of Marco Polo",
"Description": "A 13th-century travelogue describing Polo's travels"
},
{
"Title": "Extravehicular Mobility Unit (EMU)",
"Description": "The EMU is a spacesuit that provides environmental protection, "
"mobility, life support, and communications for astronauts",
"_id": "article_591"
}],
tensor_fields=["Description"]
)
results = mq.index("my-first-index").search(
q="What is the best outfit to wear on the moon?"
)
```
- `mq` is the client that wraps the `marqo` API.
- `create_index()` creates a new index with default settings. You have the option to specify what model to use. For example, `mq.create_index("my-first-index", model="hf/all_datasets_v4_MiniLM-L6")` will create an index with the default text model `hf/all_datasets_v4_MiniLM-L6`. Experimentation with different models is often required to achieve the best retrieval for your specific use case. Different models also offer a tradeoff between inference speed and relevancy. See [here](https://docs.marqo.ai/1.0.0/Models-Reference/dense_retrieval/) for the full list of models.
- `add_documents()` takes a list of documents, represented as python dicts for indexing.
- You can optionally set a document's ID with the special `_id` field. Otherwise, Marqo will generate one.
Let's have a look at the results:
```python
# let's print out the results:
import pprint
pprint.pprint(results)
{
'hits': [
{
'Title': 'Extravehicular Mobility Unit (EMU)',
'Description': 'The EMU is a spacesuit that provides environmental protection, mobility, life support, and'
'communications for astronauts',
'_highlights': [{
'Description': 'The EMU is a spacesuit that provides environmental protection, '
'mobility, life support, and communications for astronauts'
}],
'_id': 'article_591',
'_score': 0.61938936
},
{
'Title': 'The Travels of Marco Polo',
'Description': "A 13th-century travelogue describing Polo's travels",
'_highlights': [{'Title': 'The Travels of Marco Polo'}],
'_id': 'e00d1a8d-894c-41a1-8e3b-d8b2a8fce12a',
'_score': 0.60237324
}
],
'limit': 10,
'processingTimeMs': 49,
'query': 'What is the best outfit to wear on the moon?'
}
```
- Each hit corresponds to a document that matched the search query.
- They are ordered from most to least matching.
- `limit` is the maximum number of hits to be returned. This can be set as a parameter during search.
- Each hit has a `_highlights` field. This was the part of the document that matched the query the best.
## Other basic operations
### Get document
Retrieve a document by ID.
```python
result = mq.index("my-first-index").get_document(document_id="article_591")
```
Note that by adding the document using ```add_documents``` again using the same ```_id``` will cause a document to be updated.
### Get index stats
Get information about an index.
```python
results = mq.index("my-first-index").get_stats()
```
### Lexical search
Perform a keyword search.
```python
result = mq.index("my-first-index").search('marco polo', search_method=marqo.SearchMethods.LEXICAL)
```
### Multi modal and cross modal search
To power image and text search, Marqo allows users to plug and play with CLIP models from HuggingFace. **Note that if you do not configure multi modal search, image urls will be treated as strings.** To start indexing and searching with images, first create an index with a CLIP configuration, as below:
```python
settings = {
"treat_urls_and_pointers_as_images":True, # allows us to find an image file and index it
"model":"ViT-L/14"
}
response = mq.create_index("my-multimodal-index", **settings)
```
Images can then be added within documents as follows. You can use urls from the internet (for example S3) or from the disk of the machine:
```python
response = mq.index("my-multimodal-index").add_documents([{
"My_Image": "https://raw.githubusercontent.com/marqo-ai/marqo-api-tests/mainline/assets/ai_hippo_realistic.png",
"Description": "The hippopotamus, also called the common hippopotamus or river hippopotamus, is a large semiaquatic mammal native to sub-Saharan Africa",
"_id": "hippo-facts"
}], tensor_fields=["My_Image"])
```
You can then search the image field using text.
```python
results = mq.index("my-multimodal-index").search('animal')
```
### Searching using an image
Searching using an image can be achieved by providing the image link.
```python
results = mq.index("my-multimodal-index").search('https://raw.githubusercontent.com/marqo-ai/marqo-api-tests/mainline/assets/ai_hippo_statue.png')
```
### Searching using weights in queries
Queries can also be provided as dictionaries where each key is a query and their corresponding values are weights. This allows for more advanced queries consisting of multiple components with weightings towards or against them, queries can have negations via negative weighting.
The example below shows the application of this to a scenario where a user may want to ask a question but also negate results that match a certain semantic criterion.
```python
import marqo
import pprint
mq = marqo.Client(url="http://localhost:8882")
mq.create_index("my-weighted-query-index")
mq.index("my-weighted-query-index").add_documents(
[
{
"Title": "Smartphone",
"Description": "A smartphone is a portable computer device that combines mobile telephone "
"functions and computing functions into one unit.",
},
{
"Title": "Telephone",
"Description": "A telephone is a telecommunications device that permits two or more users to"
"conduct a conversation when they are too far apart to be easily heard directly.",
},
{
"Title": "Thylacine",
"Description": "The thylacine, also commonly known as the Tasmanian tiger or Tasmanian wolf, "
"is an extinct carnivorous marsupial."
"The last known of its species died in 1936.",
}
],
tensor_fields=["Description"]
)
# initially we ask for a type of communications device which is popular in the 21st century
query = {
# a weighting of 1.1 gives this query slightly more importance
"I need to buy a communications device, what should I get?": 1.1,
# a weighting of 1 gives this query a neutral importance
"Technology that became prevelant in the 21st century": 1.0
}
results = mq.index("my-weighted-query-index").search(q=query)
print("Query 1:")
pprint.pprint(results)
# now we ask for a type of communications which predates the 21st century
query = {
# a weighting of 1 gives this query a neutral importance
"I need to buy a communications device, what should I get?": 1.0,
# a weighting of -1 gives this query a negation effect
"Technology that became prevelant in the 21st century": -1.0
}
results = mq.index("my-weighted-query-index").search(q=query)
print("\nQuery 2:")
pprint.pprint(results)
```
### Creating and searching indexes with multimodal combination fields
Marqo lets you have indexes with multimodal combination fields. Multimodal combination fields can combine text and images into one field. This allows scoring of documents across the combined text and image fields together. It also allows for a single vector representation instead of needing many which saves on storage. The relative weighting of each component can be set per document.
The example below demonstrates this with retrieval of caption and image pairs using multiple types of queries.
```python
import marqo
import pprint
mq = marqo.Client(url="http://localhost:8882")
settings = {"treat_urls_and_pointers_as_images": True, "model": "ViT-L/14"}
mq.create_index("my-first-multimodal-index", **settings)
mq.index("my-first-multimodal-index").add_documents(
[
{
"Title": "Flying Plane",
"caption": "An image of a passenger plane flying in front of the moon.",
"image": "https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image2.jpg",
},
{
"Title": "Red Bus",
"caption": "A red double decker London bus traveling to Aldwych",
"image": "https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image4.jpg",
},
{
"Title": "Horse Jumping",
"caption": "A person riding a horse over a jump in a competition.",
"image": "https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image1.jpg",
},
],
# Create the mappings, here we define our captioned_image mapping
# which weights the image more heavily than the caption - these pairs
# will be represented by a single vector in the index
mappings={
"captioned_image": {
"type": "multimodal_combination",
"weights": {
"caption": 0.3,
"image": 0.7
}
}
},
# We specify which fields to create vectors for.
# Note that captioned_image is treated as a single field.
tensor_fields=["captioned_image"]
)
# Search this index with a simple text query
results = mq.index("my-first-multimodal-index").search(
q="Give me some images of vehicles and modes of transport. I am especially interested in air travel and commercial aeroplanes."
)
print("Query 1:")
pprint.pprint(results)
# search the index with a query that uses weighted components
results = mq.index("my-first-multimodal-index").search(
q={
"What are some vehicles and modes of transport?": 1.0,
"Aeroplanes and other things that fly": -1.0
},
)
print("\nQuery 2:")
pprint.pprint(results)
results = mq.index("my-first-multimodal-index").search(
q={"Animals of the Perissodactyla order": -1.0}
)
print("\nQuery 3:")
pprint.pprint(results)
```
### Delete documents
Delete documents.
```python
results = mq.index("my-first-index").delete_documents(ids=["article_591", "article_602"])
```
### Delete index
Delete an index.
```python
results = mq.index("my-first-index").delete()
```
## Documentation
The full documentation for Marqo can be found here [https://docs.marqo.ai/](https://docs.marqo.ai/).
## Warning
Note that you should not run other applications on Marqo's Opensearch cluster as Marqo automatically changes and adapts the settings on the cluster.
## Contributors
Marqo is a community project with the goal of making tensor search accessible to the wider developer community. We are glad that you are interested in helping out! Please read [this](./CONTRIBUTING.md) to get started.
## Dev set up
1. Create a virtual env ```python -m venv ./venv```.
2. Activate the virtual environment ```source ./venv/bin/activate```.
3. Install requirements from the requirements file: ```pip install -r requirements.txt```.
4. Run tests by running the tox file. CD into this dir and then run "tox".
5. If you update dependencies, make sure to delete the .tox dir and rerun.
## Merge instructions:
1. Run the full test suite (by using the command `tox` in this dir).
2. Create a pull request with an attached github issue.
## Support
- Ask questions and share your creations with the community on our [Discourse forum](https://community.marqo.ai).
- Join our [Slack community](https://bit.ly/marqo-slack) and chat with other community members about ideas.
Raw data
{
"_id": null,
"home_page": null,
"name": "marqo",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3",
"maintainer_email": null,
"keywords": "search python marqo opensearch tensor neural semantic vector embedding",
"author": "marqo org",
"author_email": "org@marqo.io",
"download_url": "https://files.pythonhosted.org/packages/1e/1e/8255467da06f9d3d8177dd9ca0bf661c0006d05eaa7986937d81b36cbd72/marqo-3.9.1.tar.gz",
"platform": null,
"description": "<p align=\"center\">\n<img src=\"https://uploads-ssl.webflow.com/62dfa8e3960a6e2b47dc7fae/62fdf9cef684e6f16158b094_MARQO%20LOGO-UPDATED-GREEN.svg\" width=\"50%\" height=\"40%\">\n</p>\n\n<p align=\"center\">\n<b><a href=\"https://www.marqo.ai\">Website</a> | <a href=\"https://docs.marqo.ai\">Documentation</a> | <a href=\"https://demo.marqo.ai\">Demos</a> | <a href=\"https://community.marqo.ai\">Discourse</a> | <a href=\"https://bit.ly/marqo-slack\">Slack Community</a> | <a href=\"https://www.marqo.ai/cloud\">Marqo Cloud</a>\n</b>\n</p>\n\n<p align=\"center\">\n<a href=\"https://opensource.org/licenses/Apache-2.0\"><img src=\"https://img.shields.io/badge/License-Apache%202.0-blue.svg\"></a>\n<a href=\"https://pypi.org/project/marqo/\"><img src=\"https://img.shields.io/pypi/v/marqo?label=PyPI\"></a>\n<a href=\"https://github.com/marqo-ai/marqo/actions/workflows/unit_test_200gb_CI.yml\"><img src=\"https://img.shields.io/github/actions/workflow/status/marqo-ai/marqo/unit_test_200gb_CI.yml?branch=mainline\"></a>\n<a align=\"center\" href=\"https://bit.ly/marqo-slack\"><img src=\"https://img.shields.io/badge/Slack-blueviolet?logo=slack&logoColor=white\"></a>\n\n## Marqo\n\nMarqo is more than a vector database, it's an end-to-end vector search engine for both text and images. Vector generation, storage and retrieval are handled out of the box through a single API. No need to bring your own embeddings. \n \n**Why Marqo?**\n\nVector similarity alone is not enough for vector search. Vector search requires more than a vector database - it also requires machine learning (ML) deployment and management, preprocessing and transformations of inputs as well as the ability to modify search behavior without retraining a model. Marqo contains all these pieces, enabling developers to build vector search into their application with minimal effort. A full list of features can be found [below](#-core-features).\n\n**Why not X, Y, Z vector database?** \n\nVector databases are specialized components for vector similarity and only service one component of a vector search system. They are \u201cvectors in - vectors out\u201d. They still require the production of vectors, management of the ML models, associated orchestration and processing of the inputs. Marqo makes this easy by being \u201cdocuments in, documents out\u201d. Preprocessing of text and images, embedding the content, storing meta-data and deployment of inference and storage is all taken care of by Marqo. \n\n**Quick start** \n\nHere is a code snippet for a minimal example of vector search with Marqo (see [Getting Started](#getting-started)):\n\n1. Use docker to run Marqo:\n\n```bash\n\ndocker rm -f marqo\ndocker pull marqoai/marqo:latest\ndocker run --name marqo -it -p 8882:8882 marqoai/marqo:latest\n\n```\n\nNote: If your `marqo` container keeps getting killed, this is most likely due to a lack of memory being allocated to Docker. Increasing the memory limit for Docker to at least 6GB (8GB recommended) in your Docker settings may fix the problem.\n\n2. Install the Marqo client:\n\n```bash\npip install marqo\n```\n\n3. Start indexing and searching! Let's look at a simple example below:\n\n```python\nimport marqo\n\nmq = marqo.Client(url='http://localhost:8882')\n\nmq.create_index(\"my-first-index\")\n\nmq.index(\"my-first-index\").add_documents([\n {\n \"Title\": \"The Travels of Marco Polo\",\n \"Description\": \"A 13th-century travelogue describing Polo's travels\"\n }, \n {\n \"Title\": \"Extravehicular Mobility Unit (EMU)\",\n \"Description\": \"The EMU is a spacesuit that provides environmental protection, \"\n \"mobility, life support, and communications for astronauts\",\n \"_id\": \"article_591\"\n }],\n tensor_fields=[\"Description\"]\n)\n\nresults = mq.index(\"my-first-index\").search(\n q=\"What is the best outfit to wear on the moon?\"\n)\n\n```\n\n## \u2728 Core Features\n\n**\ud83e\udd16 State of the art embeddings**\n- Use the latest machine learning models from PyTorch, Huggingface, OpenAI and more. \n- Start with a pre-configured model or bring your own.\n- Built-in ONNX support and conversion for faster inference and higher throughput.\n- CPU and GPU support.\n\n**\u26a1 Performance**\n- Embeddings stored in in-memory HNSW indexes, achieving cutting edge search speeds.\n- Scale to hundred-million document indexes with horizontal index sharding.\n- Async and non-blocking data upload and search.\n\n**\ud83c\udf0c Documents-in-documents-out**\n- Vector generation, storage, and retrieval are provided out of the box.\n- Build search, entity resolution, and data exploration application with using your text and images.\n- Build complex semantic queries by combining weighted search terms.\n- Filter search results using Marqo\u2019s query DSL.\n- Store unstructured data and semi-structured metadata together in documents, using a range of supported datatypes like bools, ints and keywords.\n\n**\ud83c\udf71 Managed cloud**\n- Low latency optimised deployment of Marqo.\n- Scale inference at the click of a button.\n- High availability.\n- 24/7 support.\n- Access control.\n- Learn more [here](https://www.marqo.ai/cloud).\n\n## Integrations\n\nMarqo is integrated into popular AI and data processing frameworks, with more on the way.\n\n**\ud83d\udc99 [Haystack](https://github.com/deepset-ai/haystack)**\n\nHaystack is an open-source framework for building applications that make use of NLP technology such as LLMs, embedding models and more. This [integration](https://haystack.deepset.ai/integrations/marqo-document-store) allows you to use Marqo as your Document Store for Haystack pipelines such as retrieval-augmentation, question answering, document search and more.\n\n**\ud83d\udef9 [Griptape](https://github.com/griptape-ai/griptape)**\n\nGriptape enables safe and reliable deployment of LLM-based agents for enterprise applications, the MarqoVectorStoreDriver gives these agents access to scalable search with your own data. This integration lets you leverage open source or custom fine-tuned models through Marqo to deliver relevant results to your LLMs.\n\n**\ud83e\udd9c\ud83d\udd17 [Langchain](https://github.com/langchain-ai/langchain)**\n\nThis integration lets you leverage open source or custom fine tuned models through Marqo for LangChain applications with a vector search component. The Marqo vector store implementation can plug into existing chains such as the Retrieval QA and Conversational Retrieval QA.\n\n**\u22d9 [Hamilton](https://github.com/DAGWorks-Inc/hamilton/)**\n\nThis integration lets you leverage open source or custom fine tuned models through Marqo for Hamilton LLM applications. \n\n## Learn more about Marqo\n \n| | |\n| --------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |\n| \ud83d\udcd7 [Quick start](#Getting-started)| Build your first application with Marqo in under 5 minutes. |\n| \ud83d\uddbc [Marqo for image data](https://www.marqo.ai/blog/context-is-all-you-need-multimodal-vector-search-with-personalization) | Building advanced image search with Marqo. |\n| \ud83d\udcda [Marqo for text](https://www.marqo.ai/blog/how-i-used-marqo-to-create-a-multilingual-legal-databse-in-5-key-lines-of-code) | Building a multilingual database in Marqo. |\n| \ud83d\udd2e [Integrating Marqo with GPT](https://www.marqo.ai/blog/from-iron-manual-to-ironman-augmenting-gpt-with-marqo-for-fast-editable-memory-to-enable-context-aware-question-answering) | Making GPT a subject matter expert by using Marqo as a knowledge base. |\n| \ud83c\udfa8 [ Marqo for Creative AI](https://www.marqo.ai/blog/combining-stable-diffusion-with-semantic-search-generating-and-categorising-100k-hot-dogs) | Combining stable diffusion with semantic search to generate and categorise 100k images of hotdogs. |\n| \ud83d\udd0a [Marqo and Speech Data](https://www.marqo.ai/blog/speech-processing) | Add diarisation and transcription to preprocess audio for Q&A with Marqo and ChatGPT. |\n| \ud83d\udeab [Marqo for content moderation](https://www.marqo.ai/blog/refining-image-quality-and-eliminating-nsfw-content-with-marqo) | Building advanced image search with Marqo to find and remove content. |\n| \u2601\ufe0f [Getting started with Marqo Cloud](https://github.com/marqo-ai/getting_started_marqo_cloud) | Go through how to get set up and running with Marqo Cloud starting from your first time login through to building your first application with Marqo|\n| \ud83d\udc57 [Marqo for e-commerce](https://github.com/marqo-ai/getting_started_marqo_cloud/blob/main/e-commerce-demo/README.md) | This project is a web application with frontend and backend using Python, Flask, ReactJS, and Typescript. The frontend is a ReactJS application that makes requests to the backend which is a Flask application. The backend makes requests to your Marqo cloud API.|\n| \ud83e\udd16 [Marqo chatbot](https://github.com/marqo-ai/getting_started_marqo_cloud/tree/main/chatbot-demo) | In this guide we will build a chat bot application using Marqo and OpenAI's ChatGPT API. We will start with an existing code base and then walk through how to customise the behaviour.|\n| \ud83e\uddbe [Features](#-Core-Features) | Marqo's core features. |\n\n\n\n\n## Getting started\n\n\n1. Marqo requires docker. To install Docker go to the [Docker Official website](https://docs.docker.com/get-docker/). Ensure that docker has at least 8GB memory and 50GB storage.\n\n2. Use docker to run Marqo:\n\n```bash\n\ndocker rm -f marqo\ndocker pull marqoai/marqo:latest\ndocker run --name marqo -it --privileged -p 8882:8882 --add-host host.docker.internal:host-gateway marqoai/marqo:latest\n\n```\n\nNote: If your `marqo` container keeps getting killed, this is most likely due to a lack of memory being allocated to Docker. Increasing the memory limit for Docker to at least 6GB (8GB recommended) in your Docker settings may fix the problem.\n\n3. Install the Marqo client:\n\n```bash\npip install marqo\n```\n\n4. Start indexing and searching! Let's look at a simple example below:\n\n```python\nimport marqo\n\nmq = marqo.Client(url='http://localhost:8882')\n\nmq.create_index(\"my-first-index\")\n\nmq.index(\"my-first-index\").add_documents([\n {\n \"Title\": \"The Travels of Marco Polo\",\n \"Description\": \"A 13th-century travelogue describing Polo's travels\"\n }, \n {\n \"Title\": \"Extravehicular Mobility Unit (EMU)\",\n \"Description\": \"The EMU is a spacesuit that provides environmental protection, \"\n \"mobility, life support, and communications for astronauts\",\n \"_id\": \"article_591\"\n }],\n tensor_fields=[\"Description\"]\n)\n\nresults = mq.index(\"my-first-index\").search(\n q=\"What is the best outfit to wear on the moon?\"\n)\n\n```\n\n- `mq` is the client that wraps the `marqo` API.\n- `create_index()` creates a new index with default settings. You have the option to specify what model to use. For example, `mq.create_index(\"my-first-index\", model=\"hf/all_datasets_v4_MiniLM-L6\")` will create an index with the default text model `hf/all_datasets_v4_MiniLM-L6`. Experimentation with different models is often required to achieve the best retrieval for your specific use case. Different models also offer a tradeoff between inference speed and relevancy. See [here](https://docs.marqo.ai/1.0.0/Models-Reference/dense_retrieval/) for the full list of models.\n- `add_documents()` takes a list of documents, represented as python dicts for indexing.\n- You can optionally set a document's ID with the special `_id` field. Otherwise, Marqo will generate one.\n\nLet's have a look at the results:\n\n```python\n# let's print out the results:\nimport pprint\npprint.pprint(results)\n\n{\n 'hits': [\n {\n 'Title': 'Extravehicular Mobility Unit (EMU)',\n 'Description': 'The EMU is a spacesuit that provides environmental protection, mobility, life support, and'\n 'communications for astronauts',\n '_highlights': [{\n 'Description': 'The EMU is a spacesuit that provides environmental protection, '\n 'mobility, life support, and communications for astronauts'\n }],\n '_id': 'article_591',\n '_score': 0.61938936\n },\n {\n 'Title': 'The Travels of Marco Polo',\n 'Description': \"A 13th-century travelogue describing Polo's travels\",\n '_highlights': [{'Title': 'The Travels of Marco Polo'}],\n '_id': 'e00d1a8d-894c-41a1-8e3b-d8b2a8fce12a',\n '_score': 0.60237324\n }\n ],\n 'limit': 10,\n 'processingTimeMs': 49,\n 'query': 'What is the best outfit to wear on the moon?'\n}\n```\n\n- Each hit corresponds to a document that matched the search query.\n- They are ordered from most to least matching.\n- `limit` is the maximum number of hits to be returned. This can be set as a parameter during search.\n- Each hit has a `_highlights` field. This was the part of the document that matched the query the best.\n\n## Other basic operations\n\n### Get document\n\nRetrieve a document by ID.\n\n```python\n\nresult = mq.index(\"my-first-index\").get_document(document_id=\"article_591\")\n\n```\n\nNote that by adding the document using ```add_documents``` again using the same ```_id``` will cause a document to be updated.\n\n### Get index stats\n\nGet information about an index.\n\n```python\n\nresults = mq.index(\"my-first-index\").get_stats()\n\n```\n\n### Lexical search\n\nPerform a keyword search.\n\n```python\n\nresult = mq.index(\"my-first-index\").search('marco polo', search_method=marqo.SearchMethods.LEXICAL)\n\n```\n\n### Multi modal and cross modal search\n\nTo power image and text search, Marqo allows users to plug and play with CLIP models from HuggingFace. **Note that if you do not configure multi modal search, image urls will be treated as strings.** To start indexing and searching with images, first create an index with a CLIP configuration, as below:\n\n```python\n\nsettings = {\n \"treat_urls_and_pointers_as_images\":True, # allows us to find an image file and index it \n \"model\":\"ViT-L/14\"\n}\nresponse = mq.create_index(\"my-multimodal-index\", **settings)\n\n```\n\nImages can then be added within documents as follows. You can use urls from the internet (for example S3) or from the disk of the machine:\n\n```python\n\nresponse = mq.index(\"my-multimodal-index\").add_documents([{\n \"My_Image\": \"https://raw.githubusercontent.com/marqo-ai/marqo-api-tests/mainline/assets/ai_hippo_realistic.png\",\n \"Description\": \"The hippopotamus, also called the common hippopotamus or river hippopotamus, is a large semiaquatic mammal native to sub-Saharan Africa\",\n \"_id\": \"hippo-facts\"\n}], tensor_fields=[\"My_Image\"])\n\n```\n\nYou can then search the image field using text.\n\n```python\n\nresults = mq.index(\"my-multimodal-index\").search('animal')\n\n```\n\n### Searching using an image\nSearching using an image can be achieved by providing the image link.\n\n```python\n\nresults = mq.index(\"my-multimodal-index\").search('https://raw.githubusercontent.com/marqo-ai/marqo-api-tests/mainline/assets/ai_hippo_statue.png')\n\n```\n\n### Searching using weights in queries\nQueries can also be provided as dictionaries where each key is a query and their corresponding values are weights. This allows for more advanced queries consisting of multiple components with weightings towards or against them, queries can have negations via negative weighting.\n\nThe example below shows the application of this to a scenario where a user may want to ask a question but also negate results that match a certain semantic criterion. \n\n```python\n\nimport marqo\nimport pprint\n\nmq = marqo.Client(url=\"http://localhost:8882\")\n\nmq.create_index(\"my-weighted-query-index\")\n\nmq.index(\"my-weighted-query-index\").add_documents(\n [\n {\n \"Title\": \"Smartphone\",\n \"Description\": \"A smartphone is a portable computer device that combines mobile telephone \"\n \"functions and computing functions into one unit.\",\n },\n {\n \"Title\": \"Telephone\",\n \"Description\": \"A telephone is a telecommunications device that permits two or more users to\"\n \"conduct a conversation when they are too far apart to be easily heard directly.\",\n },\n {\n \"Title\": \"Thylacine\",\n \"Description\": \"The thylacine, also commonly known as the Tasmanian tiger or Tasmanian wolf, \"\n \"is an extinct carnivorous marsupial.\"\n \"The last known of its species died in 1936.\",\n }\n ],\n tensor_fields=[\"Description\"]\n)\n\n# initially we ask for a type of communications device which is popular in the 21st century\nquery = {\n # a weighting of 1.1 gives this query slightly more importance\n \"I need to buy a communications device, what should I get?\": 1.1,\n # a weighting of 1 gives this query a neutral importance\n \"Technology that became prevelant in the 21st century\": 1.0\n}\n\nresults = mq.index(\"my-weighted-query-index\").search(q=query)\n\nprint(\"Query 1:\")\npprint.pprint(results)\n\n# now we ask for a type of communications which predates the 21st century\nquery = {\n # a weighting of 1 gives this query a neutral importance\n \"I need to buy a communications device, what should I get?\": 1.0,\n # a weighting of -1 gives this query a negation effect\n \"Technology that became prevelant in the 21st century\": -1.0\n}\n\nresults = mq.index(\"my-weighted-query-index\").search(q=query)\n\nprint(\"\\nQuery 2:\")\npprint.pprint(results)\n\n```\n\n### Creating and searching indexes with multimodal combination fields\nMarqo lets you have indexes with multimodal combination fields. Multimodal combination fields can combine text and images into one field. This allows scoring of documents across the combined text and image fields together. It also allows for a single vector representation instead of needing many which saves on storage. The relative weighting of each component can be set per document.\n\nThe example below demonstrates this with retrieval of caption and image pairs using multiple types of queries.\n\n```python\n\nimport marqo\nimport pprint\n\nmq = marqo.Client(url=\"http://localhost:8882\")\n\nsettings = {\"treat_urls_and_pointers_as_images\": True, \"model\": \"ViT-L/14\"}\n\nmq.create_index(\"my-first-multimodal-index\", **settings)\n\nmq.index(\"my-first-multimodal-index\").add_documents(\n [\n {\n \"Title\": \"Flying Plane\",\n \"caption\": \"An image of a passenger plane flying in front of the moon.\",\n \"image\": \"https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image2.jpg\",\n },\n {\n \"Title\": \"Red Bus\",\n \"caption\": \"A red double decker London bus traveling to Aldwych\",\n \"image\": \"https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image4.jpg\",\n },\n {\n \"Title\": \"Horse Jumping\",\n \"caption\": \"A person riding a horse over a jump in a competition.\",\n \"image\": \"https://raw.githubusercontent.com/marqo-ai/marqo/mainline/examples/ImageSearchGuide/data/image1.jpg\",\n },\n ],\n # Create the mappings, here we define our captioned_image mapping \n # which weights the image more heavily than the caption - these pairs \n # will be represented by a single vector in the index\n mappings={\n \"captioned_image\": {\n \"type\": \"multimodal_combination\",\n \"weights\": {\n \"caption\": 0.3,\n \"image\": 0.7\n }\n }\n },\n # We specify which fields to create vectors for. \n # Note that captioned_image is treated as a single field.\n tensor_fields=[\"captioned_image\"]\n)\n\n# Search this index with a simple text query\nresults = mq.index(\"my-first-multimodal-index\").search(\n q=\"Give me some images of vehicles and modes of transport. I am especially interested in air travel and commercial aeroplanes.\"\n)\n\nprint(\"Query 1:\")\npprint.pprint(results)\n\n# search the index with a query that uses weighted components\nresults = mq.index(\"my-first-multimodal-index\").search(\n q={\n \"What are some vehicles and modes of transport?\": 1.0,\n \"Aeroplanes and other things that fly\": -1.0\n },\n)\nprint(\"\\nQuery 2:\")\npprint.pprint(results)\n\nresults = mq.index(\"my-first-multimodal-index\").search(\n q={\"Animals of the Perissodactyla order\": -1.0}\n)\nprint(\"\\nQuery 3:\")\npprint.pprint(results)\n\n```\n\n### Delete documents\n\nDelete documents.\n\n```python\n\nresults = mq.index(\"my-first-index\").delete_documents(ids=[\"article_591\", \"article_602\"])\n\n```\n\n### Delete index\n\nDelete an index.\n\n```python\n\nresults = mq.index(\"my-first-index\").delete()\n\n```\n\n## Documentation\n\nThe full documentation for Marqo can be found here [https://docs.marqo.ai/](https://docs.marqo.ai/).\n\n## Warning\n\nNote that you should not run other applications on Marqo's Opensearch cluster as Marqo automatically changes and adapts the settings on the cluster.\n\n## Contributors\n\nMarqo is a community project with the goal of making tensor search accessible to the wider developer community. We are glad that you are interested in helping out! Please read [this](./CONTRIBUTING.md) to get started.\n\n## Dev set up\n\n1. Create a virtual env ```python -m venv ./venv```.\n\n2. Activate the virtual environment ```source ./venv/bin/activate```.\n\n3. Install requirements from the requirements file: ```pip install -r requirements.txt```.\n\n4. Run tests by running the tox file. CD into this dir and then run \"tox\".\n\n5. If you update dependencies, make sure to delete the .tox dir and rerun.\n\n## Merge instructions:\n\n1. Run the full test suite (by using the command `tox` in this dir).\n\n2. Create a pull request with an attached github issue.\n\n## Support\n\n- Ask questions and share your creations with the community on our [Discourse forum](https://community.marqo.ai).\n- Join our [Slack community](https://bit.ly/marqo-slack) and chat with other community members about ideas.\n\n\n",
"bugtrack_url": null,
"license": null,
"summary": "Tensor search for humans",
"version": "3.9.1",
"project_urls": null,
"split_keywords": [
"search",
"python",
"marqo",
"opensearch",
"tensor",
"neural",
"semantic",
"vector",
"embedding"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "a4576f3454c0834d9f201135b8233e4182b0eaae1c505dfc40e1c2934f84e859",
"md5": "64474c05b9399a0ea5ea859518e8f1eb",
"sha256": "d1d2ddfda3aaa72c4210b4fa0186d2be74780a4a261072cd934524a5d7142fd3"
},
"downloads": -1,
"filename": "marqo-3.9.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "64474c05b9399a0ea5ea859518e8f1eb",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3",
"size": 39169,
"upload_time": "2024-10-31T08:29:58",
"upload_time_iso_8601": "2024-10-31T08:29:58.549011Z",
"url": "https://files.pythonhosted.org/packages/a4/57/6f3454c0834d9f201135b8233e4182b0eaae1c505dfc40e1c2934f84e859/marqo-3.9.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "1e1e8255467da06f9d3d8177dd9ca0bf661c0006d05eaa7986937d81b36cbd72",
"md5": "07cbc81b4386a4af68a6001259bd0213",
"sha256": "81dfa2fc936d8e41a7ee7b24c9e3b68ca1eaade5d6534d876d33168d6dd20619"
},
"downloads": -1,
"filename": "marqo-3.9.1.tar.gz",
"has_sig": false,
"md5_digest": "07cbc81b4386a4af68a6001259bd0213",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3",
"size": 41489,
"upload_time": "2024-10-31T08:30:00",
"upload_time_iso_8601": "2024-10-31T08:30:00.022722Z",
"url": "https://files.pythonhosted.org/packages/1e/1e/8255467da06f9d3d8177dd9ca0bf661c0006d05eaa7986937d81b36cbd72/marqo-3.9.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-31 08:30:00",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "marqo"
}