mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
feat(nodes): primitives have value
instead of a
as field names
This commit is contained in:
parent
cd9baf8092
commit
484b572023
@ -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))
|
||||||
|
@ -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")
|
||||||
|
@ -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")],
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user