Skip to content

Commit

Permalink
Added src to docs retriever import
Browse files Browse the repository at this point in the history
  • Loading branch information
willtai committed May 3, 2024
1 parent eda12a4 commit dabe620
Show file tree
Hide file tree
Showing 8 changed files with 102 additions and 14 deletions.
6 changes: 4 additions & 2 deletions docs/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
#

# You can set these variables from the command line.
VERSION = 0.1.2
PRODUCT = neo4j-genai-python
SPHINXOPTS =
SPHINXBUILD = sphinx-build
PAPER =
Expand Down Expand Up @@ -52,9 +54,9 @@ clean:
rm -rf $(BUILDDIR)/*

html:
$(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html
$(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/$(PRODUCT)/$(VERSION)
@echo
@echo "Build finished. The HTML pages are in $(BUILDDIR)/html."
@echo "Build finished. The HTML pages are in $(BUILDDIR)/$(PRODUCT)/$(VERSION)."

dirhtml:
$(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml
Expand Down
11 changes: 10 additions & 1 deletion docs/source/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@ VectorRetriever
.. autoclass:: neo4j_genai.retrievers.vector.VectorRetriever
:members:


VectorCypherRetriever
=====================

Expand All @@ -41,3 +40,13 @@ HybridCypherRetriever

.. autoclass:: neo4j_genai.retrievers.hybrid.HybridCypherRetriever
:members:



**********
Data Types
**********

.. include:: types/_vector-search-record-types.rst

See topic :ref:`vector-search-record-types` for more details.
45 changes: 45 additions & 0 deletions docs/source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,13 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import os
import sys
import typing

# Add the root of the project to the path so that Sphinx can find the Python sources
sys.path.append(os.path.join(os.path.dirname(__file__), "..", ".."))

# Configuration file for the Sphinx documentation builder.
#
# For the full list of built-in configuration values, see the documentation:
Expand All @@ -35,8 +42,14 @@
"sphinx.ext.coverage",
"sphinx.ext.ifconfig",
"sphinx.ext.intersphinx",
"sphinx.ext.napoleon",
"sphinx.ext.viewcode",
]

intersphinx_mapping = {
"python": ("https://docs.python.org/3", None),
}

templates_path = ["_templates"]
exclude_patterns = ["_build", "Thumbs.db", ".DS_Store"]

Expand All @@ -46,3 +59,35 @@

html_theme = "neo4j"
html_theme_path = ["themes"]

# The name of the Pygments (syntax highlighting) style to use.
# pygments_style = "sphinx"
pygments_style = "friendly"

autodoc_type_aliases = {
# The code-base uses `import typing_extensions as te`.
# Re-write these to use `typing` instead, as Sphinx always resolves against
# the latest version of the `typing` module.
# This is a work-around to make Sphinx resolve type hints correctly, even
# though we're using `from __future__ import annotations`.
"te": typing,
# Type alias that's only defined and imported if `typing.TYPE_CHECKING`
# is `True`.
"_TAuth": "typing.Tuple[typing.Any, typing.Any] | Auth | None",
}


# Theme options are theme-specific and customize the look and feel of a theme
# further. For a list of options available for each theme, see the
# documentation.
html_theme_options = {
"sidebar_includehidden": True,
"sidebar_collapse": True,
}

autodoc_default_options = {
"member-order": "bysource",
# 'special-members': '__init__',
"undoc-members": True,
"exclude-members": "__weakref__",
}
7 changes: 6 additions & 1 deletion docs/source/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,16 @@ fast to ship new features and high performing patterns and methods.
Topics
******

+ :ref:`api-documentation`
+ :ref:`vector-search-record-types`

.. toctree::
:maxdepth: 2
:maxdepth: 3
:caption: Contents:
:hidden:

api.rst
types/vector.rst


Usage
Expand Down
11 changes: 11 additions & 0 deletions docs/source/types/vector.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
.. _vector-search-record-types:

*************************
Vector Search Record Type
*************************


VectorSearchRecord
==================

.. autoclass:: neo4j_genai.types.VectorSearchRecord
6 changes: 3 additions & 3 deletions src/neo4j_genai/retrievers/hybrid.py
Original file line number Diff line number Diff line change
Expand Up @@ -127,9 +127,9 @@ def search(
Args:
query_text (str): The text to get the closest neighbors of.
query_vector (Optional[list[float]], optional): The vector embeddings to get the closest neighbors of. Defaults to None.
top_k (int, optional): The number of neighbors to return. Defaults to 5.
query_params (Optional[dict[str, Any]], optional): Parameters for the Cypher query. Defaults to None.
query_vector (Optional[list[float]]): The vector embeddings to get the closest neighbors of. Defaults to None.
top_k (int): The number of neighbors to return. Defaults to 5.
query_params (Optional[dict[str, Any]]): Parameters for the Cypher query. Defaults to None.
Raises:
ValueError: If validation of the input arguments fail.
Expand Down
22 changes: 15 additions & 7 deletions src/neo4j_genai/retrievers/vector.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,14 @@ class VectorRetriever(Retriever):
"""
Provides retrieval method using vector search over embeddings.
If an embedder is provided, it needs to have the required Embedder type.
Example:
.. code-block:: python
retriever = VectorRetriever(driver, "vector-index-name", custom_embedder)
retriever.search(query_text="Find me a book about Fremen", top_k=top_k)
"""

def __init__(
Expand Down Expand Up @@ -59,9 +67,9 @@ def search(
- `db.index.vector.queryNodes() <https://neo4j.com/docs/operations-manual/5/reference/procedures/#procedure_db_index_vector_queryNodes>`_
Args:
query_vector (Optional[list[float]], optional): The vector embeddings to get the closest neighbors of. Defaults to None.
query_text (Optional[str], optional): The text to get the closest neighbors of. Defaults to None.
top_k (int, optional): The number of neighbors to return. Defaults to 5.
query_vector (Optional[list[float]]): The vector embeddings to get the closest neighbors of. Defaults to None.
query_text (Optional[str]): The text to get the closest neighbors of. Defaults to None.
top_k (int): The number of neighbors to return. Defaults to 5.
Raises:
ValueError: If validation of the input arguments fail.
Expand Down Expand Up @@ -138,10 +146,10 @@ def search(
- `db.index.vector.queryNodes() <https://neo4j.com/docs/operations-manual/5/reference/procedures/#procedure_db_index_vector_queryNodes>`_
Args:
query_vector (Optional[list[float]], optional): The vector embeddings to get the closest neighbors of. Defaults to None.
query_text (Optional[str], optional): The text to get the closest neighbors of. Defaults to None.
top_k (int, optional): The number of neighbors to return. Defaults to 5.
query_params (Optional[dict[str, Any]], optional): Parameters for the Cypher query. Defaults to None.
query_vector (Optional[list[float]]): The vector embeddings to get the closest neighbors of. Defaults to None.
query_text (Optional[str]): The text to get the closest neighbors of. Defaults to None.
top_k (int): The number of neighbors to return. Defaults to 5.
query_params (Optional[dict[str, Any]]): Parameters for the Cypher query. Defaults to None.
Raises:
ValueError: If validation of the input arguments fail.
Expand Down
8 changes: 8 additions & 0 deletions src/neo4j_genai/types.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,14 @@


class VectorSearchRecord(BaseModel):
"""
Represents a record returned from a vector search.
Attributes:
node (Any): The node data retrieved by the search.
score (float): The similarity score of the retrieved embedding.
"""

node: Any
score: float

Expand Down

0 comments on commit dabe620

Please sign in to comment.