parent
8113d6ddbc
commit
d5c0ca0128
@ -0,0 +1,142 @@
|
||||
from abc import ABC, abstractmethod
|
||||
|
||||
|
||||
class AbstractVectorDatabase(ABC):
|
||||
"""
|
||||
Abstract base class for a database.
|
||||
|
||||
This class defines the interface for interacting with a database.
|
||||
Subclasses must implement the abstract methods to provide the
|
||||
specific implementation details for connecting to a database,
|
||||
executing queries, and performing CRUD operations.
|
||||
|
||||
"""
|
||||
|
||||
@abstractmethod
|
||||
def connect(self):
|
||||
"""
|
||||
Connect to the database.
|
||||
|
||||
This method establishes a connection to the database.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def close(self):
|
||||
"""
|
||||
Close the database connection.
|
||||
|
||||
This method closes the connection to the database.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def query(self, query: str):
|
||||
"""
|
||||
Execute a database query.
|
||||
|
||||
This method executes the given query on the database.
|
||||
|
||||
Parameters:
|
||||
query (str): The query to be executed.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def fetch_all(self):
|
||||
"""
|
||||
Fetch all rows from the result set.
|
||||
|
||||
This method retrieves all rows from the result set of a query.
|
||||
|
||||
Returns:
|
||||
list: A list of dictionaries representing the rows.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def fetch_one(self):
|
||||
"""
|
||||
Fetch one row from the result set.
|
||||
|
||||
This method retrieves one row from the result set of a query.
|
||||
|
||||
Returns:
|
||||
dict: A dictionary representing the row.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def add(self, doc: str):
|
||||
"""
|
||||
Add a new record to the database.
|
||||
|
||||
This method adds a new record to the specified table in the database.
|
||||
|
||||
Parameters:
|
||||
table (str): The name of the table.
|
||||
data (dict): A dictionary representing the data to be added.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
|
||||
@abstractmethod
|
||||
def get(self, query: str):
|
||||
"""
|
||||
Get a record from the database.
|
||||
|
||||
This method retrieves a record from the specified table in the database based on the given ID.
|
||||
|
||||
Parameters:
|
||||
table (str): The name of the table.
|
||||
id (int): The ID of the record to be retrieved.
|
||||
|
||||
Returns:
|
||||
dict: A dictionary representing the retrieved record.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def update(self, doc):
|
||||
"""
|
||||
Update a record in the database.
|
||||
|
||||
This method updates a record in the specified table in the database based on the given ID.
|
||||
|
||||
Parameters:
|
||||
table (str): The name of the table.
|
||||
id (int): The ID of the record to be updated.
|
||||
data (dict): A dictionary representing the updated data.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def delete(self, message):
|
||||
"""
|
||||
Delete a record from the database.
|
||||
|
||||
This method deletes a record from the specified table in the database based on the given ID.
|
||||
|
||||
Parameters:
|
||||
table (str): The name of the table.
|
||||
id (int): The ID of the record to be deleted.
|
||||
|
||||
"""
|
||||
|
||||
pass
|
@ -1,58 +0,0 @@
|
||||
from abc import ABC, abstractmethod
|
||||
from typing import Any, Dict
|
||||
|
||||
|
||||
class VectorDatabase(ABC):
|
||||
@abstractmethod
|
||||
def add(
|
||||
self, vector: Dict[str, Any], metadata: Dict[str, Any]
|
||||
) -> None:
|
||||
"""
|
||||
add a vector into the database.
|
||||
|
||||
Args:
|
||||
vector (Dict[str, Any]): The vector to add.
|
||||
metadata (Dict[str, Any]): Metadata associated with the vector.
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def query(self, text: str, num_results: int) -> Dict[str, Any]:
|
||||
"""
|
||||
Query the database for vectors similar to the given vector.
|
||||
|
||||
Args:
|
||||
text (Dict[str, Any]): The vector to compare against.
|
||||
num_results (int): The number of similar vectors to return.
|
||||
|
||||
Returns:
|
||||
Dict[str, Any]: The most similar vectors and their associated metadata.
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def delete(self, vector_id: str) -> None:
|
||||
"""
|
||||
Delete a vector from the database.
|
||||
|
||||
Args:
|
||||
vector_id (str): The ID of the vector to delete.
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
def update(
|
||||
self,
|
||||
vector_id: str,
|
||||
vector: Dict[str, Any],
|
||||
metadata: Dict[str, Any],
|
||||
) -> None:
|
||||
"""
|
||||
Update a vector in the database.
|
||||
|
||||
Args:
|
||||
vector_id (str): The ID of the vector to update.
|
||||
vector (Dict[str, Any]): The new vector.
|
||||
metadata (Dict[str, Any]): The new metadata.
|
||||
"""
|
||||
pass
|
@ -0,0 +1,97 @@
|
||||
from dataclasses import dataclass
|
||||
from typing import List, Optional
|
||||
|
||||
from swarms.memory.base_vectordatabase import AbstractVectorDatabase
|
||||
from swarms.structs.agent import Agent
|
||||
|
||||
|
||||
@dataclass
|
||||
class MultiAgentRag:
|
||||
"""
|
||||
Represents a multi-agent RAG (Relational Agent Graph) structure.
|
||||
|
||||
Attributes:
|
||||
agents (List[Agent]): List of agents in the multi-agent RAG.
|
||||
db (AbstractVectorDatabase): Database used for querying.
|
||||
verbose (bool): Flag indicating whether to print verbose output.
|
||||
"""
|
||||
agents: List[Agent]
|
||||
db: AbstractVectorDatabase
|
||||
verbose: bool = False
|
||||
|
||||
|
||||
def query_database(self, query: str):
|
||||
"""
|
||||
Queries the database using the given query string.
|
||||
|
||||
Args:
|
||||
query (str): The query string.
|
||||
|
||||
Returns:
|
||||
List: The list of results from the database.
|
||||
"""
|
||||
results = []
|
||||
for agent in self.agents:
|
||||
agent_results = agent.long_term_memory_prompt(query)
|
||||
results.extend(agent_results)
|
||||
return results
|
||||
|
||||
|
||||
def get_agent_by_id(self, agent_id) -> Optional[Agent]:
|
||||
"""
|
||||
Retrieves an agent from the multi-agent RAG by its ID.
|
||||
|
||||
Args:
|
||||
agent_id: The ID of the agent to retrieve.
|
||||
|
||||
Returns:
|
||||
Agent or None: The agent with the specified ID, or None if not found.
|
||||
"""
|
||||
for agent in self.agents:
|
||||
if agent.agent_id == agent_id:
|
||||
return agent
|
||||
return None
|
||||
|
||||
def add_message(
|
||||
self,
|
||||
sender: Agent,
|
||||
message: str,
|
||||
*args,
|
||||
**kwargs
|
||||
):
|
||||
"""
|
||||
Adds a message to the database.
|
||||
|
||||
Args:
|
||||
sender (Agent): The agent sending the message.
|
||||
message (str): The message to add.
|
||||
*args: Additional positional arguments.
|
||||
**kwargs: Additional keyword arguments.
|
||||
|
||||
Returns:
|
||||
int: The ID of the added message.
|
||||
"""
|
||||
doc = f"{sender.ai_name}: {message}"
|
||||
|
||||
return self.db.add(doc)
|
||||
|
||||
def query(
|
||||
self,
|
||||
message: str,
|
||||
*args,
|
||||
**kwargs
|
||||
):
|
||||
"""
|
||||
Queries the database using the given message.
|
||||
|
||||
Args:
|
||||
message (str): The message to query.
|
||||
*args: Additional positional arguments.
|
||||
**kwargs: Additional keyword arguments.
|
||||
|
||||
Returns:
|
||||
List: The list of results from the database.
|
||||
"""
|
||||
return self.db.query(message)
|
||||
|
||||
|
Loading…
Reference in new issue