Betalgo.OpenAI.GPT3
6.5.0
PackageId is updated to Betalgo.OpenAI, Please use the new packageId(Betalgo.OpenAI) to get the latest updates.
See the version list below for details.
dotnet add package Betalgo.OpenAI.GPT3 --version 6.5.0
NuGet\Install-Package Betalgo.OpenAI.GPT3 -Version 6.5.0
<PackageReference Include="Betalgo.OpenAI.GPT3" Version="6.5.0" />
paket add Betalgo.OpenAI.GPT3 --version 6.5.0
#r "nuget: Betalgo.OpenAI.GPT3, 6.5.0"
// Install Betalgo.OpenAI.GPT3 as a Cake Addin #addin nuget:?package=Betalgo.OpenAI.GPT3&version=6.5.0 // Install Betalgo.OpenAI.GPT3 as a Cake Tool #tool nuget:?package=Betalgo.OpenAI.GPT3&version=6.5.0
Dotnet SDK for OpenAI GTP-3 and DALL�E
Install-Package Betalgo.OpenAI.GPT3
Dotnet SDK for OpenAI GTP-3 and DALL�E </br> Unofficial. </br> GPT-3 doesn't have any official .Net SDK.
Features
- Image (DALL�E)
- Models
- Completions
- Edit
- Mars
- Embeddings
- Files
- Fine-tunes
- Moderation
For changelogs please go to end of the document.
Visit https://openai.com/ to get your API key. Also documentation with more detail is avaliable there.
Sample Usages
!! I would strongly suggest to use different account than your main account while you use playground.<br> Test methods could add or delete your files and models !!
The repository includes one sample project already "OpenAI.Playground" You can check playground project to see how I was testing it while I was developing the library. Be carefull while playing with it. Some test methods will delete your files or fine tunings. <br>
Without using dependcy injection:
var openAiService = new OpenAIService(new OpenAiOptions()
{
ApiKey = Environment.GetEnvironmentVariable("MY_OPEN_AI_API_KEY")
});
Using dependcy injection:
secrets.json:
"OpenAIServiceOptions": {
//"ApiKey":"Your api key goes here"
//,"Organization": "Your Organization Id goes here (optional)"
},
(How to use user secret ? <br> Right click your project name in "solution explorer" then click "Manage User Secret", it is a good way to keep your api keys)
Program.cs
serviceCollection.AddOpenAIService();
OR<br> Use it like below but do NOT put your API key directly to your source code.
Program.cs
serviceCollection.AddOpenAIService(settings => { settings.ApiKey = Environment.GetEnvironmentVariable("MY_OPEN_AI_API_KEY"); });
After injecting your service you will be able to get it from service provider
var openAiService = serviceProvider.GetRequiredService<IOpenAIService>();
You can set default engine(optional):
openAiService.SetDefaultEngineId(Engines.Davinci);
Completions Sample
var completionResult = await sdk.Completions.CreateCompletion(new CompletionCreateRequest()
{
Prompt = "Once upon a time",
MaxTokens = 5
}, Models.Davinci);
if (completionResult.Successful)
{
Console.WriteLine(completionResult.Choices.FirstOrDefault());
}
else
{
if (completionResult.Error == null)
{
throw new Exception("Unknown Error");
}
Console.WriteLine($"{completionResult.Error.Code}: {completionResult.Error.Message}");
}
Notes:
I couldn't find enough time to test all the methods or improve the documentation. My main target was to make fine-tuning available. If you hit any issue please report it or pull request always appreciated.
I was building an SDK for myself then I decide to share it, I hope it will be useful for you. I haven't maintained any open source projects before. Any help would be much appreciated. I am open to suggestions If you would like to contribute somehow.
I will be using the latest libraries all the time. Also, next releasing will include breaking changes frequently (as I mentioned before I was building the SDK for myself. Unfortunately I do not have time to plan these changes and support lower version apps). So please be aware of that before starting to use the library.
As you can guess I do not accept any damage caused by use of the library. You are always free to use other libraries or OpenAI Web-API.
Changelog
6.5.0
- OpenAI made a surprise release yesterday and they have announced DALL�E API. I needed to do other things but I couldn't resist. Because I was rushing, some methods and class names may will change in the next release. Until that day, enjoy your creative AI.
- This library now fully support all DALL�E features.
- I tried to complete Edit API too bu unfortunately something was wrong with the documentation, I need to ask some questions in the community forum.
6.4.1
- Bug-fixes
- FineTuneCreateRequest suffix json property name changed "Suffix" to "suffix"
- CompletionCreateRequest user json property name changed "User" to "user" (Thanks to @shaneqld), also now it is a nullable string
6.4.0
- I have good news and bad news
- Moderation feature implementation is done. Now we support Moderation.
- Updated some request and response models to catch up with changes in OpenAI API
- New version has some breaking changes. Because we are in the fall season I needed to do some cleanup. Sorry for breaking changes but most of them are just renaming. I believe they can be solved before your coffee finish.
- I am hoping to support Edit Feature in the next version.
6.3.0
- Thanks to @c-d and @sarilouis for their contributions to this version.
- Now we support Embedding endpoint. Thanks to @sarilouis
- Bug fixes and updates for Models
- Code clean-up
6.2.0
- Removed deprecated Answers, Classifications, and Search endpoints https://community.openai.com/t/answers-classification-search-endpoint-deprecation/18532. They will be still available until December at web-API. If you still need them please do not update to this version.
- Code clean-up
6.1.0
- Organization id is not a required value anymore, Thanks to @samuelnygaard
- Removed deprecated Engine Endpoint and replaced it with Models Endpoint. Now Model response has more fields.
- Regarding OpenAI Engine naming, I had to rename Engine Enum and static fields. They are quite similar but you have to replace them with new ones. Please use Models class instead of Engine class.
- To support fast engine name changing I have created a new Method,
Models.ModelNameBuilder()
you may consider using it.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net6.0
- Microsoft.AspNet.WebApi.Client (>= 5.2.9)
- Microsoft.Extensions.Http (>= 6.0.0)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 6.0.0)
NuGet packages (6)
Showing the top 5 NuGet packages that depend on Betalgo.OpenAI.GPT3:
Package | Downloads |
---|---|
BootstrapBlazor.OpenAI.GPT3
Bootstrap UI OpenAI GPT3 components experience |
|
Witrics.AI.Activities
UiPath AI activities for working with ChatGPT |
|
Senparc.Xncf.OpenAI
OpenAI 和 ChatGPT 接口 |
|
Luga
A Generative AI Agent Management framework for .NET. |
|
YKT.ChatGPT.AI
访问OpenAI ChatGPT模型api的库,OpenAI, ChatGPT |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated | |
---|---|---|---|
6.8.4 | 89,755 | 4/19/2023 | |
6.8.3 | 70,033 | 3/28/2023 | |
6.8.1 | 20,605 | 3/20/2023 | |
6.8.0 | 26,005 | 3/14/2023 | |
6.7.3 | 10,372 | 3/10/2023 | |
6.7.2 | 17,999 | 3/5/2023 | |
6.7.1 | 2,818 | 3/4/2023 | |
6.7.0 | 4,743 | 3/2/2023 | |
6.6.8 | 2,279 | 2/28/2023 | |
6.6.7 | 12,283 | 2/8/2023 | |
6.6.6 | 8,351 | 1/19/2023 | |
6.6.5 | 2,015 | 1/16/2023 | |
6.6.4 | 3,502 | 1/11/2023 | |
6.6.3 | 2,401 | 1/5/2023 | |
6.6.2 | 2,325 | 1/1/2023 | |
6.6.0 | 3,583 | 12/2/2022 | |
6.5.0 | 664 | 11/4/2022 | |
6.4.1 | 490 | 11/1/2022 | |
6.4.0 | 694 | 9/26/2022 | |
6.3.0 | 558 | 9/20/2022 | |
6.2.0 | 678 | 8/10/2022 | |
6.1.0 | 683 | 6/9/2022 | |
6.0.0 | 800 | 3/12/2022 | |
0.0.3 | 458 | 1/7/2022 | |
0.0.2 | 550 | 1/7/2022 | |
0.0.1 | 493 | 12/28/2021 |