![]() <!-- Thank you for your contribution! Please review https://microsoft.github.io/autogen/docs/Contribute before opening a pull request. --> <!-- Please add a reviewer to the assignee section when you create a PR. If you don't have the access to it, we will shortly find a reviewer and assign them to your PR. --> ## Why are these changes needed? <!-- Please give a short summary of the change and the problem this solves. --> ## Related issue number <!-- For example: "Closes #1234" --> ## Checks - [ ] I've included any doc changes needed for https://microsoft.github.io/autogen/. See https://microsoft.github.io/autogen/docs/Contribute#documentation to build and test documentation locally. - [ ] I've added tests (if relevant) corresponding to the changes introduced in this PR. - [ ] I've made sure all auto checks have passed. |
||
---|---|---|
.. | ||
.config | ||
.tools | ||
eng | ||
nuget | ||
resource/images | ||
samples | ||
src | ||
test | ||
website | ||
.editorconfig | ||
.gitattributes | ||
.gitignore | ||
AutoGen.sln | ||
AutoGen.v3.ncrunchsolution | ||
Directory.Build.props | ||
Directory.Build.targets | ||
Directory.Packages.props | ||
NuGet.config | ||
PACKAGING.md | ||
README.md | ||
global.json | ||
spelling.dic |
README.md
AutoGen for .NET
Thre are two sets of packages here: AutoGen.* the older packages derived from AutoGen 0.2 for .NET - these will gradually be deprecated and ported into the new packages Microsoft.AutoGen.* the new packages for .NET that use the event-driven model - These APIs are not yet stable and are subject to change.
To get started with the new packages, please see the samples and in particular the Hello sample.
You can install both new and old packages from the following feeds:
[!NOTE] Nightly build is available at:
Firstly, following the installation guide to install AutoGen packages.
Then you can start with the following code snippet to create a conversable agent and chat with it.
using AutoGen;
using AutoGen.OpenAI;
var openAIKey = Environment.GetEnvironmentVariable("OPENAI_API_KEY") ?? throw new Exception("Please set OPENAI_API_KEY environment variable.");
var gpt35Config = new OpenAIConfig(openAIKey, "gpt-3.5-turbo");
var assistantAgent = new AssistantAgent(
name: "assistant",
systemMessage: "You are an assistant that help user to do some tasks.",
llmConfig: new ConversableAgentConfig
{
Temperature = 0,
ConfigList = [gpt35Config],
})
.RegisterPrintMessage(); // register a hook to print message nicely to console
// set human input mode to ALWAYS so that user always provide input
var userProxyAgent = new UserProxyAgent(
name: "user",
humanInputMode: ConversableAgent.HumanInputMode.ALWAYS)
.RegisterPrintMessage();
// start the conversation
await userProxyAgent.InitiateChatAsync(
receiver: assistantAgent,
message: "Hey assistant, please do me a favor.",
maxRound: 10);
Samples
You can find more examples under the sample project.
Functionality
-
ConversableAgent
- function call
- code execution (dotnet only, powered by
dotnet-interactive
)
-
Agent communication
- Two-agent chat
- Group chat
-
Enhanced LLM Inferences
-
Exclusive for dotnet
- Source generator for type-safe function definition generation