add modelfamilies
This commit is contained in:
parent
2cb0fa7d40
commit
998f1785b6
1 changed files with 46 additions and 13 deletions
|
@ -19,6 +19,8 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"text/template"
|
"text/template"
|
||||||
|
|
||||||
|
"golang.org/x/exp/slices"
|
||||||
|
|
||||||
"github.com/jmorganca/ollama/api"
|
"github.com/jmorganca/ollama/api"
|
||||||
"github.com/jmorganca/ollama/llm"
|
"github.com/jmorganca/ollama/llm"
|
||||||
"github.com/jmorganca/ollama/parser"
|
"github.com/jmorganca/ollama/parser"
|
||||||
|
@ -133,6 +135,7 @@ type ManifestV2 struct {
|
||||||
type ConfigV2 struct {
|
type ConfigV2 struct {
|
||||||
ModelFormat string `json:"model_format"`
|
ModelFormat string `json:"model_format"`
|
||||||
ModelFamily string `json:"model_family"`
|
ModelFamily string `json:"model_family"`
|
||||||
|
ModelFamilies []string `json:"model_families"`
|
||||||
ModelType string `json:"model_type"`
|
ModelType string `json:"model_type"`
|
||||||
FileType string `json:"file_type"`
|
FileType string `json:"file_type"`
|
||||||
RootFS RootFS `json:"rootfs"`
|
RootFS RootFS `json:"rootfs"`
|
||||||
|
@ -142,6 +145,36 @@ type ConfigV2 struct {
|
||||||
OS string `json:"os"`
|
OS string `json:"os"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *ConfigV2) SetModelFormat(format string) {
|
||||||
|
if c.ModelFormat == "" {
|
||||||
|
c.ModelFormat = format
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *ConfigV2) SetModelFamily(families ...string) {
|
||||||
|
for _, family := range families {
|
||||||
|
if c.ModelFamily == "" {
|
||||||
|
c.ModelFamily = family
|
||||||
|
}
|
||||||
|
|
||||||
|
if !slices.Contains(c.ModelFamilies, family) {
|
||||||
|
c.ModelFamilies = append(c.ModelFamilies, family)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *ConfigV2) SetModelType(modelType string) {
|
||||||
|
if c.ModelType == "" {
|
||||||
|
c.ModelType = modelType
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *ConfigV2) SetFileType(fileType string) {
|
||||||
|
if c.FileType == "" {
|
||||||
|
c.FileType = fileType
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
type RootFS struct {
|
type RootFS struct {
|
||||||
Type string `json:"type"`
|
Type string `json:"type"`
|
||||||
DiffIDs []string `json:"diff_ids"`
|
DiffIDs []string `json:"diff_ids"`
|
||||||
|
@ -351,10 +384,10 @@ func CreateModel(ctx context.Context, name, modelFileDir string, commands []pars
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
config.ModelFormat = fromConfig.ModelFormat
|
config.SetModelFormat(fromConfig.ModelFormat)
|
||||||
config.ModelFamily = fromConfig.ModelFamily
|
config.SetModelFamily(append(fromConfig.ModelFamilies, fromConfig.ModelFamily)...)
|
||||||
config.ModelType = fromConfig.ModelType
|
config.SetModelType(fromConfig.ModelType)
|
||||||
config.FileType = fromConfig.FileType
|
config.SetFileType(fromConfig.FileType)
|
||||||
|
|
||||||
for _, layer := range manifest.Layers {
|
for _, layer := range manifest.Layers {
|
||||||
deleteMap[layer.Digest] = struct{}{}
|
deleteMap[layer.Digest] = struct{}{}
|
||||||
|
@ -400,10 +433,10 @@ func CreateModel(ctx context.Context, name, modelFileDir string, commands []pars
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
config.ModelFormat = ggml.Name()
|
config.SetModelFormat(ggml.Name())
|
||||||
config.ModelFamily = ggml.ModelFamily()
|
config.SetModelFamily(ggml.ModelFamily())
|
||||||
config.ModelType = ggml.ModelType()
|
config.SetModelType(ggml.ModelType())
|
||||||
config.FileType = ggml.FileType()
|
config.SetFileType(ggml.FileType())
|
||||||
|
|
||||||
mediatype := mediatype
|
mediatype := mediatype
|
||||||
if ggml.ModelFamily() == "clip" {
|
if ggml.ModelFamily() == "clip" {
|
||||||
|
|
Loading…
Reference in a new issue