The current folder contains a few C# Jupyter Notebooks that demonstrate how to get started with the Semantic Kernel. The notebooks are organized in order of increasing complexity.
To run the notebooks, we recommend the following steps:
- Install .NET 7
- Install Visual Studio Code (VS Code)
- Launch VS Code and install the "Polyglot" extension. Min version required: v1.0.4102020 (Feb 2022).
The steps above should be sufficient, you can now open all the C# notebooks in VS Code.
VS Code screenshot example:
To start using these notebooks, be sure to add the appropriate API keys to config/settings.json
.
You can create the file manually or run the Setup notebook.
For Azure OpenAI:
{
"type": "azure",
"model": "...", // Azure OpenAI Deployment Name
"endpoint": "...", // Azure OpenAI endpoint
"apikey": "..." // Azure OpenAI key
}
For OpenAI:
{
"type": "openai",
"model": "text-davinci-003", // OpenAI model name
"apikey": "...", // OpenAI API Key
"org": "" // only for OpenAI accounts with multiple orgs
}
If you need an Azure OpenAI key, go here. If you need an OpenAI key, go here
Before starting, make sure you configured config/settings.json
,
see the previous section.
For a quick dive, look at the getting started notebook.
- Loading and configuring Semantic Kernel
- Running AI prompts from file
- Creating Semantic Functions at runtime (i.e. inline functions)
- Using Context Variables to Build a Chat Experience
- Creating and Executing Plans
- Building Memory with Embeddings
- Creating images with DALL-E 2
- Chatting with ChatGPT and Images
You can run the notebooks also in the browser with JupyterLab. These steps should be sufficient to start:
Install Python 3, Pip and .NET 7 in your system, then:
pip install jupyterlab
dotnet tool install -g Microsoft.dotnet-interactive
dotnet tool update -g Microsoft.dotnet-interactive
dotnet interactive jupyter install
This command will confirm that Jupyter now supports C# notebooks:
jupyter kernelspec list
Enter the notebooks folder, and run this to launch the browser interface:
jupyter-lab
If you are unable to get the Nuget package, first list your Nuget sources:
dotnet nuget list source
If you see No sources found.
, add the NuGet official package source:
dotnet nuget add source "https://api.nuget.org/v3/index.json" --name "nuget.org"
Run dotnet nuget list source
again to verify the source was added.
If somehow the notebooks don't work, run these commands:
- Install .NET Interactive:
dotnet tool install -g Microsoft.dotnet-interactive
- Register .NET kernels into Jupyter:
dotnet interactive jupyter install
(this might return some errors, ignore them) - If you are still stuck, read the following pages:
- https://marketplace.visualstudio.com/items?itemName=ms-dotnettools.dotnet-interactive-vscode
- https://devblogs.microsoft.com/dotnet/net-core-with-juypter-notebooks-is-here-preview-1/
- https://docs.servicestack.net/jupyter-notebooks-csharp
- https://developers.refinitiv.com/en/article-catalog/article/using--net-core-in-jupyter-notebook
Note: "Polyglot Notebooks" used to be called ".NET Interactive Notebooks", so you might find online some documentation referencing the old name.