-
Notifications
You must be signed in to change notification settings - Fork 28
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Extensibility #5
Comments
Haha, I was hoping you would go down that path... I would propose a simple scheme where all classes that derive from NapariBaseTool are automatically discovered and |
I agree with @haesleinhuepf that it would be nice to be able to register tools without making a PR to
What do you think, @haesleinhuepf and @royerloic , are there other requirements we should consider? Are anyof those too strict/onerous? All of the discovery methods I am aware of using a base class (e.g., Would a .yaml file describing the available plugins be too much to ask of the developer? The implications here is that they would have to both define an entry point and make sure the yaml file is packaged. Another option that is similar to @haesleinhuepf 's PR is that developers could register a function that just returns the names/import paths of the available tools. We would then have to trust the developers to implement this in a way that doesn't cause a slow startup. Any other ideas? |
Fully agreed. Also let's avoid langchain if possible
Tricky. If possible, I would like to avoid an overengineered-solution like npe2. Maybe langchain has alternative solutions for this (docs).
I was also thinking of registering functions that consume |
I agree that we should avoid registering langchain tools. This feels too tied to the current implementation. Although, I think the information given to the langchain |
In terms of a path forward, I would propose the following:
I think the class LLMTool(ABC):
# we may want names that are separate from the function name
# to prevent namespace collision (e.g., "bia-bob:regionprops")
name: str
# I think it is nice to have a description field separate from
# the function docstring so that extra instructions can be given to the LLM
description: str
@abstractmethod
def function(self):
raise NotImplementedError In the example of bia-bob, a registration function could then look like: def register_llm_tool(tool_to_register: LLMTool):
new_tool = StructuredTool.from_function(
tool_to_register.function,
name = tool_to_register.name,
description=tool_to_register.description
)
_context.tools.append(new_tool)
# update agent if necessary |
Hi @royerloic ,
thanks again for paving this path. I played a bit with your code and found this place that could potentially profit from flexible extensibility. I'm wondering how you would approach this and if you're interested in a PR in that direction.
Use case: Assume someone has the napari-assistant installed. The assistant can list functions (sorted in categories such as denoising, segmentation, etc) and you can search in their docstrings for terms such as 'nuclei'. Combining it with Omega, one could then ask Omega
Which functions do you have available for segmenting nuclei?
and Omega could list these functions. We could then afterwards ask Omega to add one specific function as widget to the viewer or to execute it directly. This could lead to better code than random assemblies of scikit-image and opencv snippets. There are some hundred of these functions spread over the napari-assistant ecosystem and thus, I could imagine that this way of interacting with it might be useful.The question is: how should one add a napari-assistant extension to Omega? A PR is one option and I'm wondering if you thought about an alternate way for making Omega openly extensible.
Looking forward to hear what you think.
Best,
Robert
The text was updated successfully, but these errors were encountered: