定制 capevace/laravel-gpt 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

capevace/laravel-gpt

最新稳定版本:v1.0.1

Composer 安装命令:

composer require capevace/laravel-gpt

包简介

A Laravel package for interacting with OpenAI's GPT-3.

README 文档

README

laravel-gpt

This package provides a type-safe interface for making requests to the GPT-3 API.

Latest Version on Packagist GitHub Tests Action Status Total Downloads

use Capevace\GPT\Facades\GPT;

$response = GPT::generate(
    'Name a thing that is blue.',
    model: 'text-davinci-003',
    maxTokens: 400,
    frequencyPenalty: 1.0,
);

echo $response->first(); // "The sky"

Installation

You can install the package via composer:

composer require capevace/laravel-gpt

Configuration

You will need an API key for the OpenAI GPT-3 API. Once you have obtained an API key, you can configure it in your .env file by adding the following line:

OPENAI_API_KEY=your-api-key-here

You could also publish the config file directly, but this really probably isn't necessary:

php artisan vendor:publish --tag="laravel-gpt-config"

Usage

The Capevace\GPT\GPTService class provides methods for making requests to the GPT-3 API. You can inject it into controllers or use the Facade to access the container.

# Access via injection

use Capevace\GPT\GPTService;

class MyController extends Controller {
    protected GPTService $gpt;

    public function __construct(GPTService $gpt) {
        $this->gpt = $gpt;
    }

    public function index() {
        $this->gpt->generate(
            // ..
        );
    }

}

# Access via Facade

use Capevace\GPT\Facades\GPT;

GPT::generate(/* .. */);

GPT::generate(<prompt>, [...options])

The generate method returns a GPTResponse object that contains the response from the GPT-3 API. If no text is returned (empty string), the method will throw an error.

generate takes the following arguments:

  • prompt (required): the prompt to send to the GPT-3 API
  • model: the GPT-3 model to use (defaults to text-davinci-003)
  • temperature: a value between 0 and 1 that determines how "creative" the response will be (defaults to 0.83)
  • maxTokens: the maximum number of tokens (i.e., words) to return in the response (defaults to 1200)
  • stop: a string that, when encountered in the response, will cause the response to end (defaults to null)
  • frequencyPenalty: a value between 0 and 1 that determines how much the model will penalize frequent words (defaults to 0.11)
  • presencePenalty: a value between 0 and 1 that determines how much the model will penalize words that don't appear in the prompt (defaults to 0.03)

Example

use Capevace\GPT\Facades\GPT;

$response = GPT::generate(
    'Generate a list of things that are blue.',
    model: 'text-davinci-003',
    maxTokens: 400,
    frequencyPenalty: 1.0,
);

Handling responses

The generate method returns a GPTResponse object that contains the response from the GPT-3 API.

It has two methods:

  • $response->first() (string): returns the first text suggested by GPT-3
  • $response->all() (array): returns a list of all the text choices suggested by GPT-3

Example

use Capevace\GPT\Facades\GPT;

$response = GPT::generate(
    'Name a thing that is blue.',
    model: 'text-davinci-003',
    maxTokens: 400,
    frequencyPenalty: 1.0,
);

$firstChoice = $response->first(); // "the sky"

$allChoices = $response->all(); // ["the sky", "the ocean" ...]

Error handling

If an error occurs while making a request to the GPT-3 API, the generate() method will throw a Capevace\GPT\Support\GPTException exception.

laravel-gpt will also throw an error, if a response does not contain any text (empty string).

Example

use Capevace\GPT\Facades\GPT;
use Capevace\GPT\Support\GPTException;
use Exception;

try {
    $response = GPT::generate('Do nothing.');
} catch (GPTException $e) {
    // Exception will be thrown, as the response text is ""
} catch (Exception $e) {
    // Catch connectivity errors etc.
}

Changelog

Please see CHANGELOG for more information on what has changed recently.

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 131
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 12
  • 点击次数: 4
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 12
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-12-13

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固