go-ml/cmd/cmd_seed_influx.go
Snider 812c926dac feat: migrate cmd/ml from CLI repo, resolve forge deps
Move all 40 ML command files from core/cli/cmd/ml to go-ml/cmd/.
Commands self-register via init() + cli.RegisterCommands().

- Fixed stale go-ai/ml import in cmd_ab.go (now uses go-ml + go-mlx)
- Disabled cmd_train.go (needs go-mlx training API export)
- Removed all local replace directives, deps resolve from forge
- go build ./... passes cleanly

Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-21 19:14:58 +00:00

49 lines
1.1 KiB
Go

package cmd
import (
"fmt"
"os"
"forge.lthn.ai/core/go/pkg/cli"
"forge.lthn.ai/core/go-ml"
)
var seedInfluxCmd = &cli.Command{
Use: "seed-influx",
Short: "Seed InfluxDB golden_gen from DuckDB golden_set",
Long: "One-time migration: batch-loads DuckDB golden_set records into InfluxDB golden_gen measurement.",
RunE: runSeedInflux,
}
var (
seedInfluxForce bool
seedInfluxBatchSize int
)
func init() {
seedInfluxCmd.Flags().BoolVar(&seedInfluxForce, "force", false, "Re-seed even if InfluxDB already has data")
seedInfluxCmd.Flags().IntVar(&seedInfluxBatchSize, "batch-size", 500, "Lines per InfluxDB write batch")
}
func runSeedInflux(cmd *cli.Command, args []string) error {
path := dbPath
if path == "" {
path = os.Getenv("LEM_DB")
}
if path == "" {
return fmt.Errorf("--db or LEM_DB required")
}
db, err := ml.OpenDB(path)
if err != nil {
return fmt.Errorf("open db: %w", err)
}
defer db.Close()
influx := ml.NewInfluxClient(influxURL, influxDB)
return ml.SeedInflux(db, influx, ml.SeedInfluxConfig{
Force: seedInfluxForce,
BatchSize: seedInfluxBatchSize,
}, os.Stdout)
}