From ef2f745ff5499f93aa260462883d7a0250b89273 Mon Sep 17 00:00:00 2001 From: Kye Date: Fri, 17 Nov 2023 20:04:15 -0800 Subject: [PATCH] no griptape, no artifacts, cleanup --- mkdocs.yml | 6 +- pyproject.toml | 1 - requirements.txt | 1 - sequential_workflow_example.py | 6 +- swarms/__init__.py | 2 +- swarms/artifacts/__init__.py | 0 swarms/artifacts/base.py | 81 -------- swarms/artifacts/error_artifact.py | 19 -- swarms/artifacts/main.py | 74 ------- swarms/models/simple_ada.py | 1 + swarms/structs/__init__.py | 6 +- swarms/structs/task.py | 320 ++++++++++++++--------------- swarms/structs/workflow.py | 161 +++++++-------- swarms/swarms/autoscaler.py | 4 +- 14 files changed, 253 insertions(+), 429 deletions(-) delete mode 100644 swarms/artifacts/__init__.py delete mode 100644 swarms/artifacts/base.py delete mode 100644 swarms/artifacts/error_artifact.py delete mode 100644 swarms/artifacts/main.py diff --git a/mkdocs.yml b/mkdocs.yml index 7b331f02..f33c71dc 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -104,9 +104,9 @@ nav: - swarms.memory: - PineconeVectorStoreStore: "swarms/memory/pinecone.md" - PGVectorStore: "swarms/memory/pg.md" - - swarms.chunkers: - - BaseChunker: "swarms/chunkers/basechunker.md" - - PdfChunker: "swarms/chunkers/pdf_chunker.md" + # - swarms.chunkers: + # - BaseChunker: "swarms/chunkers/basechunker.md" + # - PdfChunker: "swarms/chunkers/pdf_chunker.md" - Guides: - Overview: "examples/index.md" - Agents: diff --git a/pyproject.toml b/pyproject.toml index 2c521530..04bdfe2f 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -42,7 +42,6 @@ diffusers = "*" accelerate = "*" sentencepiece = "*" wget = "*" -griptape = "*" httpx = "*" tiktoken = "*" safetensors = "*" diff --git a/requirements.txt b/requirements.txt index 6d542159..8dad8dc6 100644 --- a/requirements.txt +++ b/requirements.txt @@ -33,7 +33,6 @@ chromadb tiktoken tabulate colored -griptape addict backoff ratelimit diff --git a/sequential_workflow_example.py b/sequential_workflow_example.py index 9c17a072..76c17ab2 100644 --- a/sequential_workflow_example.py +++ b/sequential_workflow_example.py @@ -4,9 +4,7 @@ from swarms.structs.sequential_workflow import SequentialWorkflow # Example usage -api_key = ( - "" # Your actual API key here -) +api_key = "" # Your actual API key here # Initialize the language flow llm = OpenAIChat( @@ -47,4 +45,4 @@ workflow.run() # Output the results for task in workflow.tasks: - print(f"Task: {task.description}, Result: {task.result}") \ No newline at end of file + print(f"Task: {task.description}, Result: {task.result}") diff --git a/swarms/__init__.py b/swarms/__init__.py index 338cc8f9..0fd05d72 100644 --- a/swarms/__init__.py +++ b/swarms/__init__.py @@ -8,4 +8,4 @@ os.environ["TF_CPP_MIN_LOG_LEVEL"] = "2" from swarms.agents import * # noqa: E402, F403 from swarms.swarms import * # noqa: E402, F403 from swarms.structs import * # noqa: E402, F403 -from swarms.models import * # noqa: E402, F403 \ No newline at end of file +from swarms.models import * # noqa: E402, F403 diff --git a/swarms/artifacts/__init__.py b/swarms/artifacts/__init__.py deleted file mode 100644 index e69de29b..00000000 diff --git a/swarms/artifacts/base.py b/swarms/artifacts/base.py deleted file mode 100644 index dac7a523..00000000 --- a/swarms/artifacts/base.py +++ /dev/null @@ -1,81 +0,0 @@ -from __future__ import annotations -import json -import uuid -from abc import ABC, abstractmethod -from attr import define, field, Factory -from marshmallow import class_registry -from marshmallow.exceptions import RegistryError - - -@define -class BaseArtifact(ABC): - id: str = field(default=Factory(lambda: uuid.uuid4().hex), kw_only=True) - name: str = field( - default=Factory(lambda self: self.id, takes_self=True), kw_only=True - ) - value: any = field() - type: str = field( - default=Factory(lambda self: self.__class__.__name__, takes_self=True), - kw_only=True, - ) - - @classmethod - def value_to_bytes(cls, value: any) -> bytes: - if isinstance(value, bytes): - return value - else: - return str(value).encode() - - @classmethod - def value_to_dict(cls, value: any) -> dict: - if isinstance(value, dict): - dict_value = value - else: - dict_value = json.loads(value) - - return {k: v for k, v in dict_value.items()} - - @classmethod - def from_dict(cls, artifact_dict: dict) -> BaseArtifact: - from griptape.schemas import ( - TextArtifactSchema, - InfoArtifactSchema, - ErrorArtifactSchema, - BlobArtifactSchema, - CsvRowArtifactSchema, - ListArtifactSchema, - ) - - class_registry.register("TextArtifact", TextArtifactSchema) - class_registry.register("InfoArtifact", InfoArtifactSchema) - class_registry.register("ErrorArtifact", ErrorArtifactSchema) - class_registry.register("BlobArtifact", BlobArtifactSchema) - class_registry.register("CsvRowArtifact", CsvRowArtifactSchema) - class_registry.register("ListArtifact", ListArtifactSchema) - - try: - return class_registry.get_class(artifact_dict["type"])().load(artifact_dict) - except RegistryError: - raise ValueError("Unsupported artifact type") - - @classmethod - def from_json(cls, artifact_str: str) -> BaseArtifact: - return cls.from_dict(json.loads(artifact_str)) - - def __str__(self): - return json.dumps(self.to_dict()) - - def to_json(self) -> str: - return json.dumps(self.to_dict()) - - @abstractmethod - def to_text(self) -> str: - ... - - @abstractmethod - def to_dict(self) -> dict: - ... - - @abstractmethod - def __add__(self, other: BaseArtifact) -> BaseArtifact: - ... diff --git a/swarms/artifacts/error_artifact.py b/swarms/artifacts/error_artifact.py deleted file mode 100644 index 0bee1aa9..00000000 --- a/swarms/artifacts/error_artifact.py +++ /dev/null @@ -1,19 +0,0 @@ -from __future__ import annotations -from attr import define, field -from swarms.artifacts.base import BaseArtifact - - -@define(frozen=True) -class ErrorArtifact(BaseArtifact): - value: str = field(converter=str) - - def __add__(self, other: ErrorArtifact) -> ErrorArtifact: - return ErrorArtifact(self.value + other.value) - - def to_text(self) -> str: - return self.value - - def to_dict(self) -> dict: - from griptape.schemas import ErrorArtifactSchema - - return dict(ErrorArtifactSchema().dump(self)) diff --git a/swarms/artifacts/main.py b/swarms/artifacts/main.py deleted file mode 100644 index 075cd34d..00000000 --- a/swarms/artifacts/main.py +++ /dev/null @@ -1,74 +0,0 @@ -from __future__ import annotations -import pprint -import json - -from typing import Optional -from pydantic import BaseModel, Field, StrictStr - - -class Artifact(BaseModel): - """ - - Artifact that has the task has been produced - - Attributes: - ----------- - - artifact_id: str - ID of the artifact - - file_name: str - Filename of the artifact - - relative_path: str - Relative path of the artifact - - - """ - - artifact_id: StrictStr = Field(..., description="ID of the artifact") - file_name: StrictStr = Field(..., description="Filename of the artifact") - relative_path: Optional[StrictStr] = Field( - None, description="Relative path of the artifact" - ) - __properties = ["artifact_id", "file_name", "relative_path"] - - class Config: - """Pydantic configuration""" - - allow_population_by_field_name = True - validate_assignment = True - - def to_str(self) -> str: - """Returns the string representation of the model using alias""" - return pprint.pformat(self.dict(by_alias=True)) - - @classmethod - def from_json(cls, json_str: str) -> Artifact: - """Create an instance of Artifact from a json string""" - return cls.from_dict(json.loads(json_str)) - - def to_dict(self): - """Returns the dict representation of the model""" - _dict = self.dict(by_alias=True, exclude={}, exclude_none=True) - return _dict - - @classmethod - def from_dict(cls, obj: dict) -> Artifact: - """Create an instance of Artifact from a dict""" - - if obj is None: - return None - - if not isinstance(obj, dict): - return Artifact.parse_obj(obj) - - _obj = Artifact.parse_obj( - { - "artifact_id": obj.get("artifact_id"), - "file_name": obj.get("file_name"), - "relative_path": obj.get("relative_path"), - } - ) - - return _obj diff --git a/swarms/models/simple_ada.py b/swarms/models/simple_ada.py index 6a0dbcc9..3662dda2 100644 --- a/swarms/models/simple_ada.py +++ b/swarms/models/simple_ada.py @@ -1,3 +1,4 @@ +import os from openai import OpenAI client = OpenAI() diff --git a/swarms/structs/__init__.py b/swarms/structs/__init__.py index a842359c..1c66de94 100644 --- a/swarms/structs/__init__.py +++ b/swarms/structs/__init__.py @@ -1,6 +1,6 @@ -from swarms.structs.workflow import Workflow -from swarms.structs.task import Task +# from swarms.structs.workflow import Workflow +# from swarms.structs.task import Task from swarms.structs.flow import Flow from swarms.structs.sequential_workflow import SequentialWorkflow -__all__ = ["Workflow", "Task", "Flow", "SequentialWorkflow"] +__all__ = ["Flow", "SequentialWorkflow"] diff --git a/swarms/structs/task.py b/swarms/structs/task.py index 80f95d4d..3d479c43 100644 --- a/swarms/structs/task.py +++ b/swarms/structs/task.py @@ -1,174 +1,174 @@ -from __future__ import annotations +# from __future__ import annotations -import json -import pprint -import uuid -from abc import ABC, abstractmethod -from enum import Enum -from typing import Any, List, Optional, Union +# import json +# import pprint +# import uuid +# from abc import ABC, abstractmethod +# from enum import Enum +# from typing import Any, List, Optional, Union -from pydantic import BaseModel, Field, StrictStr -from swarms.artifacts.main import Artifact -from swarms.artifacts.error_artifact import ErrorArtifact +# from pydantic import BaseModel, Field, StrictStr +# # from swarms.artifacts.main import Artifact +# # from swarms.artifacts.error_artifact import ErrorArtifact -class BaseTask(ABC): - class State(Enum): - PENDING = 1 - EXECUTING = 2 - FINISHED = 3 +# class BaseTask(ABC): +# class State(Enum): +# PENDING = 1 +# EXECUTING = 2 +# FINISHED = 3 - def __init__(self): - self.id: str = uuid.uuid4().hex - self.state: BaseTask.State = self.State.PENDING - self.parent_ids: List[str] = [] - self.child_ids: List[str] = [] - self.output: Optional[Union[Artifact, ErrorArtifact]] = None - self.structure = None +# def __init__(self): +# self.id: str = uuid.uuid4().hex +# self.state: BaseTask.State = self.State.PENDING +# self.parent_ids: List[str] = [] +# self.child_ids: List[str] = [] +# self.output = None +# self.structure = None - @property - @abstractmethod - def input(self) -> Any: - pass +# @property +# @abstractmethod +# def input(self) -> Any: +# pass - @property - def parents(self) -> List[BaseTask]: - return [self.structure.find_task(parent_id) for parent_id in self.parent_ids] +# @property +# def parents(self) -> List[BaseTask]: +# return [self.structure.find_task(parent_id) for parent_id in self.parent_ids] - @property - def children(self) -> List[BaseTask]: - return [self.structure.find_task(child_id) for child_id in self.child_ids] +# @property +# def children(self) -> List[BaseTask]: +# return [self.structure.find_task(child_id) for child_id in self.child_ids] - def __rshift__(self, child: BaseTask) -> BaseTask: - return self.add_child(child) +# def __rshift__(self, child: BaseTask) -> BaseTask: +# return self.add_child(child) - def __lshift__(self, child: BaseTask) -> BaseTask: - return self.add_parent(child) +# def __lshift__(self, child: BaseTask) -> BaseTask: +# return self.add_parent(child) - def preprocess(self, structure) -> BaseTask: - self.structure = structure - return self +# def preprocess(self, structure) -> BaseTask: +# self.structure = structure +# return self - def add_child(self, child: BaseTask) -> BaseTask: - if self.structure: - child.structure = self.structure - elif child.structure: - self.structure = child.structure +# def add_child(self, child: BaseTask) -> BaseTask: +# if self.structure: +# child.structure = self.structure +# elif child.structure: +# self.structure = child.structure - if child not in self.structure.tasks: - self.structure.tasks.append(child) - - if self not in self.structure.tasks: - self.structure.tasks.append(self) +# if child not in self.structure.tasks: +# self.structure.tasks.append(child) + +# if self not in self.structure.tasks: +# self.structure.tasks.append(self) - if child.id not in self.child_ids: - self.child_ids.append(child.id) - - if self.id not in child.parent_ids: - child.parent_ids.append(self.id) - - return child - - def add_parent(self, parent: BaseTask) -> BaseTask: - if self.structure: - parent.structure = self.structure - elif parent.structure: - self.structure = parent.structure - - if parent not in self.structure.tasks: - self.structure.tasks.append(parent) - - if self not in self.structure.tasks: - self.structure.tasks.append(self) - - if parent.id not in self.parent_ids: - self.parent_ids.append(parent.id) - - if self.id not in parent.child_ids: - parent.child_ids.append(self.id) - - return parent - - def is_pending(self) -> bool: - return self.state == self.State.PENDING - - def is_finished(self) -> bool: - return self.state == self.State.FINISHED - - def is_executing(self) -> bool: - return self.state == self.State.EXECUTING - - def before_run(self) -> None: - pass - - def after_run(self) -> None: - pass - - def execute(self) -> Optional[Union[Artifact, ErrorArtifact]]: - try: - self.state = self.State.EXECUTING - self.before_run() - self.output = self.run() - self.after_run() - except Exception as e: - self.output = ErrorArtifact(str(e)) - finally: - self.state = self.State.FINISHED - return self.output - - def can_execute(self) -> bool: - return self.state == self.State.PENDING and all( - parent.is_finished() for parent in self.parents - ) - - def reset(self) -> BaseTask: - self.state = self.State.PENDING - self.output = None - return self - - @abstractmethod - def run(self) -> Optional[Union[Artifact, ErrorArtifact]]: - pass - - -class Task(BaseModel): - input: Optional[StrictStr] = Field(None, description="Input prompt for the task") - additional_input: Optional[Any] = Field( - None, description="Input parameters for the task. Any value is allowed" - ) - task_id: StrictStr = Field(..., description="ID of the task") - - class Config: - allow_population_by_field_name = True - validate_assignment = True - - def to_str(self) -> str: - return pprint.pformat(self.dict(by_alias=True)) - - def to_json(self) -> str: - return json.dumps(self.dict(by_alias=True, exclude_none=True)) - - @classmethod - def from_json(cls, json_str: str) -> "Task": - return cls.parse_raw(json_str) - - def to_dict(self) -> dict: - _dict = self.dict(by_alias=True, exclude_none=True) - if self.artifacts: - _dict["artifacts"] = [ - artifact.dict(by_alias=True, exclude_none=True) - for artifact in self.artifacts - ] - return _dict - - @classmethod - def from_dict(cls, obj: dict) -> "Task": - if obj is None: - return None - if not isinstance(obj, dict): - raise ValueError("Input must be a dictionary.") - if "artifacts" in obj: - obj["artifacts"] = [ - Artifact.parse_obj(artifact) for artifact in obj["artifacts"] - ] - return cls.parse_obj(obj) +# if child.id not in self.child_ids: +# self.child_ids.append(child.id) + +# if self.id not in child.parent_ids: +# child.parent_ids.append(self.id) + +# return child + +# def add_parent(self, parent: BaseTask) -> BaseTask: +# if self.structure: +# parent.structure = self.structure +# elif parent.structure: +# self.structure = parent.structure + +# if parent not in self.structure.tasks: +# self.structure.tasks.append(parent) + +# if self not in self.structure.tasks: +# self.structure.tasks.append(self) + +# if parent.id not in self.parent_ids: +# self.parent_ids.append(parent.id) + +# if self.id not in parent.child_ids: +# parent.child_ids.append(self.id) + +# return parent + +# def is_pending(self) -> bool: +# return self.state == self.State.PENDING + +# def is_finished(self) -> bool: +# return self.state == self.State.FINISHED + +# def is_executing(self) -> bool: +# return self.state == self.State.EXECUTING + +# def before_run(self) -> None: +# pass + +# def after_run(self) -> None: +# pass + +# def execute(self) -> Optional[Union[Artifact, ErrorArtifact]]: +# try: +# self.state = self.State.EXECUTING +# self.before_run() +# self.output = self.run() +# self.after_run() +# except Exception as e: +# self.output = ErrorArtifact(str(e)) +# finally: +# self.state = self.State.FINISHED +# return self.output + +# def can_execute(self) -> bool: +# return self.state == self.State.PENDING and all( +# parent.is_finished() for parent in self.parents +# ) + +# def reset(self) -> BaseTask: +# self.state = self.State.PENDING +# self.output = None +# return self + +# @abstractmethod +# def run(self) -> Optional[Union[Artifact, ErrorArtifact]]: +# pass + + +# class Task(BaseModel): +# input: Optional[StrictStr] = Field(None, description="Input prompt for the task") +# additional_input: Optional[Any] = Field( +# None, description="Input parameters for the task. Any value is allowed" +# ) +# task_id: StrictStr = Field(..., description="ID of the task") + +# class Config: +# allow_population_by_field_name = True +# validate_assignment = True + +# def to_str(self) -> str: +# return pprint.pformat(self.dict(by_alias=True)) + +# def to_json(self) -> str: +# return json.dumps(self.dict(by_alias=True, exclude_none=True)) + +# @classmethod +# def from_json(cls, json_str: str) -> "Task": +# return cls.parse_raw(json_str) + +# def to_dict(self) -> dict: +# _dict = self.dict(by_alias=True, exclude_none=True) +# if self.artifacts: +# _dict["artifacts"] = [ +# artifact.dict(by_alias=True, exclude_none=True) +# for artifact in self.artifacts +# ] +# return _dict + +# @classmethod +# def from_dict(cls, obj: dict) -> "Task": +# if obj is None: +# return None +# if not isinstance(obj, dict): +# raise ValueError("Input must be a dictionary.") +# if "artifacts" in obj: +# obj["artifacts"] = [ +# Artifact.parse_obj(artifact) for artifact in obj["artifacts"] +# ] +# return cls.parse_obj(obj) diff --git a/swarms/structs/workflow.py b/swarms/structs/workflow.py index 762ee6cc..31c95144 100644 --- a/swarms/structs/workflow.py +++ b/swarms/structs/workflow.py @@ -1,83 +1,84 @@ from __future__ import annotations import uuid -from concurrent.futures import ThreadPoolExecutor -from typing import Any, Dict, List, Optional -from swarms.structs.task import Task - - -class Workflow: - """ - Workflows are ideal for prescriptive processes that need to be executed - sequentially. - They string together multiple tasks of varying types, and can use Short-Term Memory - or pass specific arguments downstream. - - Usage - llm = LLM() - workflow = Workflow(llm) - - workflow.add("What's the weather in miami") - workflow.add("Provide details for {{ parent_output }}") - workflow.add("Summarize the above information: {{ parent_output}}) - - workflow.run() - - """ - - def __init__(self, agent, parallel: bool = False): - """__init__""" - self.agent = agent - self.tasks: List[Task] = [] - self.parallel = parallel - - def add(self, task: str) -> Task: - """Add a task""" - task = Task(task_id=uuid.uuid4().hex, input=task) - - if self.last_task(): - self.last_task().add_child(task) - else: - task.structure = self - self.tasks.append(task) - return task - - def first_task(self) -> Optional[Task]: - """Add first task""" - return self.tasks[0] if self.tasks else None - - def last_task(self) -> Optional[Task]: - """Last task""" - return self.tasks[-1] if self.tasks else None - - def run(self, task: str) -> Task: - """Run tasks""" - self.add(task) - - if self.parallel: - with ThreadPoolExecutor() as executor: - list(executor.map(self.__run_from_task, [self.first_task])) - else: - self.__run_from_task(self.first_task()) - - return self.last_task() - - def context(self, task: Task) -> Dict[str, Any]: - """Context in tasks""" - return { - "parent_output": task.parents[0].output - if task.parents and task.parents[0].output - else None, - "parent": task.parents[0] if task.parents else None, - "child": task.children[0] if task.children else None, - } - - def __run_from_task(self, task: Optional[Task]) -> None: - """Run from task""" - if task is None: - return - else: - if isinstance(task.execute(), Exception): - return - else: - self.__run_from_task(next(iter(task.children), None)) + +# from concurrent.futures import ThreadPoolExecutor +# from typing import Any, Dict, List, Optional +# # from swarms.structs.task import Task + + +# class Workflow: +# """ +# Workflows are ideal for prescriptive processes that need to be executed +# sequentially. +# They string together multiple tasks of varying types, and can use Short-Term Memory +# or pass specific arguments downstream. + +# Usage +# llm = LLM() +# workflow = Workflow(llm) + +# workflow.add("What's the weather in miami") +# workflow.add("Provide details for {{ parent_output }}") +# workflow.add("Summarize the above information: {{ parent_output}}) + +# workflow.run() + +# """ + +# def __init__(self, agent, parallel: bool = False): +# """__init__""" +# self.agent = agent +# self.tasks: List[Task] = [] +# self.parallel = parallel + +# def add(self, task: str) -> Task: +# """Add a task""" +# task = Task(task_id=uuid.uuid4().hex, input=task) + +# if self.last_task(): +# self.last_task().add_child(task) +# else: +# task.structure = self +# self.tasks.append(task) +# return task + +# def first_task(self) -> Optional[Task]: +# """Add first task""" +# return self.tasks[0] if self.tasks else None + +# def last_task(self) -> Optional[Task]: +# """Last task""" +# return self.tasks[-1] if self.tasks else None + +# def run(self, task: str) -> Task: +# """Run tasks""" +# self.add(task) + +# if self.parallel: +# with ThreadPoolExecutor() as executor: +# list(executor.map(self.__run_from_task, [self.first_task])) +# else: +# self.__run_from_task(self.first_task()) + +# return self.last_task() + +# def context(self, task: Task) -> Dict[str, Any]: +# """Context in tasks""" +# return { +# "parent_output": task.parents[0].output +# if task.parents and task.parents[0].output +# else None, +# "parent": task.parents[0] if task.parents else None, +# "child": task.children[0] if task.children else None, +# } + +# def __run_from_task(self, task: Optional[Task]) -> None: +# """Run from task""" +# if task is None: +# return +# else: +# if isinstance(task.execute(), Exception): +# return +# else: +# self.__run_from_task(next(iter(task.children), None)) diff --git a/swarms/swarms/autoscaler.py b/swarms/swarms/autoscaler.py index 48b3aa97..be79a860 100644 --- a/swarms/swarms/autoscaler.py +++ b/swarms/swarms/autoscaler.py @@ -14,8 +14,8 @@ class AutoScaler: """ The AutoScaler is like a kubernetes pod, that autoscales an agent or worker or boss! - Wraps around a structure like SequentialWorkflow - and or Flow and parallelizes them on multiple threads so they're split across devices + Wraps around a structure like SequentialWorkflow + and or Flow and parallelizes them on multiple threads so they're split across devices and you can use them like that Args: