feat(nodes): primitives have value instead of a as field names

This commit is contained in:
psychedelicious 2023-08-18 20:17:21 +10:00
parent cd9baf8092
commit 484b572023
3 changed files with 27 additions and 27 deletions

View File

@ -21,7 +21,7 @@ class AddInvocation(BaseInvocation):
b: int = InputField(default=0, description=FieldDescriptions.num_2) b: int = InputField(default=0, description=FieldDescriptions.num_2)
def invoke(self, context: InvocationContext) -> IntegerOutput: def invoke(self, context: InvocationContext) -> IntegerOutput:
return IntegerOutput(a=self.a + self.b) return IntegerOutput(value=self.a + self.b)
@title("Subtract Integers") @title("Subtract Integers")
@ -36,7 +36,7 @@ class SubtractInvocation(BaseInvocation):
b: int = InputField(default=0, description=FieldDescriptions.num_2) b: int = InputField(default=0, description=FieldDescriptions.num_2)
def invoke(self, context: InvocationContext) -> IntegerOutput: def invoke(self, context: InvocationContext) -> IntegerOutput:
return IntegerOutput(a=self.a - self.b) return IntegerOutput(value=self.a - self.b)
@title("Multiply Integers") @title("Multiply Integers")
@ -51,7 +51,7 @@ class MultiplyInvocation(BaseInvocation):
b: int = InputField(default=0, description=FieldDescriptions.num_2) b: int = InputField(default=0, description=FieldDescriptions.num_2)
def invoke(self, context: InvocationContext) -> IntegerOutput: def invoke(self, context: InvocationContext) -> IntegerOutput:
return IntegerOutput(a=self.a * self.b) return IntegerOutput(value=self.a * self.b)
@title("Divide Integers") @title("Divide Integers")
@ -66,7 +66,7 @@ class DivideInvocation(BaseInvocation):
b: int = InputField(default=0, description=FieldDescriptions.num_2) b: int = InputField(default=0, description=FieldDescriptions.num_2)
def invoke(self, context: InvocationContext) -> IntegerOutput: def invoke(self, context: InvocationContext) -> IntegerOutput:
return IntegerOutput(a=int(self.a / self.b)) return IntegerOutput(value=int(self.a / self.b))
@title("Random Integer") @title("Random Integer")
@ -81,4 +81,4 @@ class RandomIntInvocation(BaseInvocation):
high: int = InputField(default=np.iinfo(np.int32).max, description="The exclusive high value") high: int = InputField(default=np.iinfo(np.int32).max, description="The exclusive high value")
def invoke(self, context: InvocationContext) -> IntegerOutput: def invoke(self, context: InvocationContext) -> IntegerOutput:
return IntegerOutput(a=np.random.randint(self.low, self.high)) return IntegerOutput(value=np.random.randint(self.low, self.high))

View File

@ -2,8 +2,8 @@
from typing import Literal, Optional, Tuple from typing import Literal, Optional, Tuple
from pydantic import BaseModel, Field
import torch import torch
from pydantic import BaseModel, Field
from .baseinvocation import ( from .baseinvocation import (
BaseInvocation, BaseInvocation,
@ -33,7 +33,7 @@ class BooleanOutput(BaseInvocationOutput):
"""Base class for nodes that output a single boolean""" """Base class for nodes that output a single boolean"""
type: Literal["boolean_output"] = "boolean_output" type: Literal["boolean_output"] = "boolean_output"
a: bool = OutputField(description="The output boolean") value: bool = OutputField(description="The output boolean")
class BooleanCollectionOutput(BaseInvocationOutput): class BooleanCollectionOutput(BaseInvocationOutput):
@ -55,10 +55,10 @@ class BooleanInvocation(BaseInvocation):
type: Literal["boolean"] = "boolean" type: Literal["boolean"] = "boolean"
# Inputs # Inputs
a: bool = InputField(default=False, description="The boolean value") value: bool = InputField(default=False, description="The boolean value")
def invoke(self, context: InvocationContext) -> BooleanOutput: def invoke(self, context: InvocationContext) -> BooleanOutput:
return BooleanOutput(a=self.a) return BooleanOutput(value=self.value)
@title("Boolean Primitive Collection") @title("Boolean Primitive Collection")
@ -86,7 +86,7 @@ class IntegerOutput(BaseInvocationOutput):
"""Base class for nodes that output a single integer""" """Base class for nodes that output a single integer"""
type: Literal["integer_output"] = "integer_output" type: Literal["integer_output"] = "integer_output"
a: int = OutputField(description="The output integer") value: int = OutputField(description="The output integer")
class IntegerCollectionOutput(BaseInvocationOutput): class IntegerCollectionOutput(BaseInvocationOutput):
@ -108,10 +108,10 @@ class IntegerInvocation(BaseInvocation):
type: Literal["integer"] = "integer" type: Literal["integer"] = "integer"
# Inputs # Inputs
a: int = InputField(default=0, description="The integer value") value: int = InputField(default=0, description="The integer value")
def invoke(self, context: InvocationContext) -> IntegerOutput: def invoke(self, context: InvocationContext) -> IntegerOutput:
return IntegerOutput(a=self.a) return IntegerOutput(value=self.value)
@title("Integer Primitive Collection") @title("Integer Primitive Collection")
@ -139,7 +139,7 @@ class FloatOutput(BaseInvocationOutput):
"""Base class for nodes that output a single float""" """Base class for nodes that output a single float"""
type: Literal["float_output"] = "float_output" type: Literal["float_output"] = "float_output"
a: float = OutputField(description="The output float") value: float = OutputField(description="The output float")
class FloatCollectionOutput(BaseInvocationOutput): class FloatCollectionOutput(BaseInvocationOutput):
@ -161,10 +161,10 @@ class FloatInvocation(BaseInvocation):
type: Literal["float"] = "float" type: Literal["float"] = "float"
# Inputs # Inputs
param: float = InputField(default=0.0, description="The float value") value: float = InputField(default=0.0, description="The float value")
def invoke(self, context: InvocationContext) -> FloatOutput: def invoke(self, context: InvocationContext) -> FloatOutput:
return FloatOutput(a=self.param) return FloatOutput(value=self.value)
@title("Float Primitive Collection") @title("Float Primitive Collection")
@ -192,7 +192,7 @@ class StringOutput(BaseInvocationOutput):
"""Base class for nodes that output a single string""" """Base class for nodes that output a single string"""
type: Literal["string_output"] = "string_output" type: Literal["string_output"] = "string_output"
text: str = OutputField(description="The output string") value: str = OutputField(description="The output string")
class StringCollectionOutput(BaseInvocationOutput): class StringCollectionOutput(BaseInvocationOutput):
@ -214,10 +214,10 @@ class StringInvocation(BaseInvocation):
type: Literal["string"] = "string" type: Literal["string"] = "string"
# Inputs # Inputs
text: str = InputField(default="", description="The string value", ui_component=UIComponent.Textarea) value: str = InputField(default="", description="The string value", ui_component=UIComponent.Textarea)
def invoke(self, context: InvocationContext) -> StringOutput: def invoke(self, context: InvocationContext) -> StringOutput:
return StringOutput(text=self.text) return StringOutput(value=self.value)
@title("String Primitive Collection") @title("String Primitive Collection")

View File

@ -17,9 +17,9 @@ def create_text_to_image() -> LibraryGraph:
description="Converts text to an image", description="Converts text to an image",
graph=Graph( graph=Graph(
nodes={ nodes={
"width": IntegerInvocation(id="width", a=512), "width": IntegerInvocation(id="width", value=512),
"height": IntegerInvocation(id="height", a=512), "height": IntegerInvocation(id="height", value=512),
"seed": IntegerInvocation(id="seed", a=-1), "seed": IntegerInvocation(id="seed", value=-1),
"3": NoiseInvocation(id="3"), "3": NoiseInvocation(id="3"),
"4": CompelInvocation(id="4"), "4": CompelInvocation(id="4"),
"5": CompelInvocation(id="5"), "5": CompelInvocation(id="5"),
@ -29,15 +29,15 @@ def create_text_to_image() -> LibraryGraph:
}, },
edges=[ edges=[
Edge( Edge(
source=EdgeConnection(node_id="width", field="a"), source=EdgeConnection(node_id="width", field="value"),
destination=EdgeConnection(node_id="3", field="width"), destination=EdgeConnection(node_id="3", field="width"),
), ),
Edge( Edge(
source=EdgeConnection(node_id="height", field="a"), source=EdgeConnection(node_id="height", field="value"),
destination=EdgeConnection(node_id="3", field="height"), destination=EdgeConnection(node_id="3", field="height"),
), ),
Edge( Edge(
source=EdgeConnection(node_id="seed", field="a"), source=EdgeConnection(node_id="seed", field="value"),
destination=EdgeConnection(node_id="3", field="seed"), destination=EdgeConnection(node_id="3", field="seed"),
), ),
Edge( Edge(
@ -65,9 +65,9 @@ def create_text_to_image() -> LibraryGraph:
exposed_inputs=[ exposed_inputs=[
ExposedNodeInput(node_path="4", field="prompt", alias="positive_prompt"), ExposedNodeInput(node_path="4", field="prompt", alias="positive_prompt"),
ExposedNodeInput(node_path="5", field="prompt", alias="negative_prompt"), ExposedNodeInput(node_path="5", field="prompt", alias="negative_prompt"),
ExposedNodeInput(node_path="width", field="a", alias="width"), ExposedNodeInput(node_path="width", field="value", alias="width"),
ExposedNodeInput(node_path="height", field="a", alias="height"), ExposedNodeInput(node_path="height", field="value", alias="height"),
ExposedNodeInput(node_path="seed", field="a", alias="seed"), ExposedNodeInput(node_path="seed", field="value", alias="seed"),
], ],
exposed_outputs=[ExposedNodeOutput(node_path="8", field="image", alias="image")], exposed_outputs=[ExposedNodeOutput(node_path="8", field="image", alias="image")],
) )