mirror of
https://github.com/openai/openai-go.git
synced 2026-04-01 09:07:22 +09:00
153 lines
6.3 KiB
Go
153 lines
6.3 KiB
Go
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
|
|
package openai
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"fmt"
|
|
"net/http"
|
|
"net/url"
|
|
"slices"
|
|
|
|
"github.com/openai/openai-go/v3/internal/apijson"
|
|
"github.com/openai/openai-go/v3/internal/apiquery"
|
|
"github.com/openai/openai-go/v3/internal/requestconfig"
|
|
"github.com/openai/openai-go/v3/option"
|
|
"github.com/openai/openai-go/v3/packages/pagination"
|
|
"github.com/openai/openai-go/v3/packages/param"
|
|
"github.com/openai/openai-go/v3/packages/respjson"
|
|
"github.com/openai/openai-go/v3/shared/constant"
|
|
)
|
|
|
|
// Manage fine-tuning jobs to tailor a model to your specific training data.
|
|
//
|
|
// FineTuningJobCheckpointService contains methods and other services that help
|
|
// with interacting with the openai API.
|
|
//
|
|
// Note, unlike clients, this service does not read variables from the environment
|
|
// automatically. You should not instantiate this service directly, and instead use
|
|
// the [NewFineTuningJobCheckpointService] method instead.
|
|
type FineTuningJobCheckpointService struct {
|
|
Options []option.RequestOption
|
|
}
|
|
|
|
// NewFineTuningJobCheckpointService generates a new service that applies the given
|
|
// options to each request. These options are applied after the parent client's
|
|
// options (if there is one), and before any request-specific options.
|
|
func NewFineTuningJobCheckpointService(opts ...option.RequestOption) (r FineTuningJobCheckpointService) {
|
|
r = FineTuningJobCheckpointService{}
|
|
r.Options = opts
|
|
return
|
|
}
|
|
|
|
// List checkpoints for a fine-tuning job.
|
|
func (r *FineTuningJobCheckpointService) List(ctx context.Context, fineTuningJobID string, query FineTuningJobCheckpointListParams, opts ...option.RequestOption) (res *pagination.CursorPage[FineTuningJobCheckpoint], err error) {
|
|
var raw *http.Response
|
|
opts = slices.Concat(r.Options, opts)
|
|
opts = append([]option.RequestOption{option.WithResponseInto(&raw)}, opts...)
|
|
if fineTuningJobID == "" {
|
|
err = errors.New("missing required fine_tuning_job_id parameter")
|
|
return nil, err
|
|
}
|
|
path := fmt.Sprintf("fine_tuning/jobs/%s/checkpoints", fineTuningJobID)
|
|
cfg, err := requestconfig.NewRequestConfig(ctx, http.MethodGet, path, query, &res, opts...)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
err = cfg.Execute()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
res.SetPageConfig(cfg, raw)
|
|
return res, nil
|
|
}
|
|
|
|
// List checkpoints for a fine-tuning job.
|
|
func (r *FineTuningJobCheckpointService) ListAutoPaging(ctx context.Context, fineTuningJobID string, query FineTuningJobCheckpointListParams, opts ...option.RequestOption) *pagination.CursorPageAutoPager[FineTuningJobCheckpoint] {
|
|
return pagination.NewCursorPageAutoPager(r.List(ctx, fineTuningJobID, query, opts...))
|
|
}
|
|
|
|
// The `fine_tuning.job.checkpoint` object represents a model checkpoint for a
|
|
// fine-tuning job that is ready to use.
|
|
type FineTuningJobCheckpoint struct {
|
|
// The checkpoint identifier, which can be referenced in the API endpoints.
|
|
ID string `json:"id" api:"required"`
|
|
// The Unix timestamp (in seconds) for when the checkpoint was created.
|
|
CreatedAt int64 `json:"created_at" api:"required"`
|
|
// The name of the fine-tuned checkpoint model that is created.
|
|
FineTunedModelCheckpoint string `json:"fine_tuned_model_checkpoint" api:"required"`
|
|
// The name of the fine-tuning job that this checkpoint was created from.
|
|
FineTuningJobID string `json:"fine_tuning_job_id" api:"required"`
|
|
// Metrics at the step number during the fine-tuning job.
|
|
Metrics FineTuningJobCheckpointMetrics `json:"metrics" api:"required"`
|
|
// The object type, which is always "fine_tuning.job.checkpoint".
|
|
Object constant.FineTuningJobCheckpoint `json:"object" default:"fine_tuning.job.checkpoint"`
|
|
// The step number that the checkpoint was created at.
|
|
StepNumber int64 `json:"step_number" api:"required"`
|
|
// JSON contains metadata for fields, check presence with [respjson.Field.Valid].
|
|
JSON struct {
|
|
ID respjson.Field
|
|
CreatedAt respjson.Field
|
|
FineTunedModelCheckpoint respjson.Field
|
|
FineTuningJobID respjson.Field
|
|
Metrics respjson.Field
|
|
Object respjson.Field
|
|
StepNumber respjson.Field
|
|
ExtraFields map[string]respjson.Field
|
|
raw string
|
|
} `json:"-"`
|
|
}
|
|
|
|
// Returns the unmodified JSON received from the API
|
|
func (r FineTuningJobCheckpoint) RawJSON() string { return r.JSON.raw }
|
|
func (r *FineTuningJobCheckpoint) UnmarshalJSON(data []byte) error {
|
|
return apijson.UnmarshalRoot(data, r)
|
|
}
|
|
|
|
// Metrics at the step number during the fine-tuning job.
|
|
type FineTuningJobCheckpointMetrics struct {
|
|
FullValidLoss float64 `json:"full_valid_loss"`
|
|
FullValidMeanTokenAccuracy float64 `json:"full_valid_mean_token_accuracy"`
|
|
Step float64 `json:"step"`
|
|
TrainLoss float64 `json:"train_loss"`
|
|
TrainMeanTokenAccuracy float64 `json:"train_mean_token_accuracy"`
|
|
ValidLoss float64 `json:"valid_loss"`
|
|
ValidMeanTokenAccuracy float64 `json:"valid_mean_token_accuracy"`
|
|
// JSON contains metadata for fields, check presence with [respjson.Field.Valid].
|
|
JSON struct {
|
|
FullValidLoss respjson.Field
|
|
FullValidMeanTokenAccuracy respjson.Field
|
|
Step respjson.Field
|
|
TrainLoss respjson.Field
|
|
TrainMeanTokenAccuracy respjson.Field
|
|
ValidLoss respjson.Field
|
|
ValidMeanTokenAccuracy respjson.Field
|
|
ExtraFields map[string]respjson.Field
|
|
raw string
|
|
} `json:"-"`
|
|
}
|
|
|
|
// Returns the unmodified JSON received from the API
|
|
func (r FineTuningJobCheckpointMetrics) RawJSON() string { return r.JSON.raw }
|
|
func (r *FineTuningJobCheckpointMetrics) UnmarshalJSON(data []byte) error {
|
|
return apijson.UnmarshalRoot(data, r)
|
|
}
|
|
|
|
type FineTuningJobCheckpointListParams struct {
|
|
// Identifier for the last checkpoint ID from the previous pagination request.
|
|
After param.Opt[string] `query:"after,omitzero" json:"-"`
|
|
// Number of checkpoints to retrieve.
|
|
Limit param.Opt[int64] `query:"limit,omitzero" json:"-"`
|
|
paramObj
|
|
}
|
|
|
|
// URLQuery serializes [FineTuningJobCheckpointListParams]'s query parameters as
|
|
// `url.Values`.
|
|
func (r FineTuningJobCheckpointListParams) URLQuery() (v url.Values, err error) {
|
|
return apiquery.MarshalWithSettings(r, apiquery.QuerySettings{
|
|
ArrayFormat: apiquery.ArrayQueryFormatBrackets,
|
|
NestedFormat: apiquery.NestedQueryFormatBrackets,
|
|
})
|
|
}
|