Skip to content

dAppCore/go-inference

Repository files navigation

Go Reference Licence: EUPL-1.2 Go Version

go-inference

Shared interface contract for text generation backends in the Core Go ecosystem. Defines TextModel, Backend, Token, Message, and associated configuration types that GPU-specific backends implement and consumers depend on. Zero external dependencies — stdlib only — and compiles on all platforms regardless of GPU availability. The backend registry supports automatic selection (Metal preferred on macOS, ROCm on Linux) and explicit pinning.

Module: dappco.re/go/core/inference Licence: EUPL-1.2 Language: Go 1.26

Quick Start

import (
    "dappco.re/go/core/inference"
    _ "dappco.re/go/core/mlx"   // registers "metal" backend on darwin/arm64
)

model, err := inference.LoadModel("/path/to/safetensors/model/")
defer model.Close()

for tok := range model.Generate(ctx, "Hello", inference.WithMaxTokens(256)) {
    fmt.Print(tok.Text)
}

Documentation

  • Architecture — interfaces, registry, options, stability contract, ecosystem position
  • Development Guide — prerequisites, build, test patterns, coding standards
  • Project History — completed phases, commit log, known limitations

Build & Test

go test ./...
go vet ./...
go build ./...

Licence

European Union Public Licence 1.2 — see LICENCE for details.

About

Core ecosystem — go-inference

Resources

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages