Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
OpenDAS
ollama
Commits
4730762e
Commit
4730762e
authored
Apr 24, 2024
by
Patrick Devine
Committed by
Michael Yang
May 20, 2024
Browse files
add safetensors version
parent
d88582df
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
20 additions
and
4 deletions
+20
-4
convert/llama.go
convert/llama.go
+11
-4
convert/safetensors.go
convert/safetensors.go
+9
-0
No files found.
convert/llama.go
View file @
4730762e
...
@@ -20,7 +20,7 @@ type LlamaModel struct {
...
@@ -20,7 +20,7 @@ type LlamaModel struct {
ModelData
ModelData
}
}
func
llamaLayerHandler
(
w
io
.
Writer
,
r
torchWriterTo
)
error
{
func
llama
Torch
LayerHandler
(
w
io
.
Writer
,
r
torchWriterTo
)
error
{
slog
.
Debug
(
fmt
.
Sprintf
(
"repacking layer '%s'"
,
r
.
t
.
Name
))
slog
.
Debug
(
fmt
.
Sprintf
(
"repacking layer '%s'"
,
r
.
t
.
Name
))
data
:=
r
.
storage
.
(
*
pytorch
.
HalfStorage
)
.
Data
data
:=
r
.
storage
.
(
*
pytorch
.
HalfStorage
)
.
Data
...
@@ -105,9 +105,16 @@ func (m *LlamaModel) GetTensors() error {
...
@@ -105,9 +105,16 @@ func (m *LlamaModel) GetTensors() error {
matches
:=
re
.
FindAllStringSubmatch
(
l
.
Name
,
-
1
)
matches
:=
re
.
FindAllStringSubmatch
(
l
.
Name
,
-
1
)
if
len
(
matches
)
>
0
{
if
len
(
matches
)
>
0
{
slog
.
Debug
(
fmt
.
Sprintf
(
"setting handler for: %s"
,
l
.
Name
))
slog
.
Debug
(
fmt
.
Sprintf
(
"setting handler for: %s"
,
l
.
Name
))
wt
:=
l
.
WriterTo
.
(
torchWriterTo
)
switch
l
.
WriterTo
.
(
type
)
{
wt
.
handler
=
llamaLayerHandler
case
torchWriterTo
:
l
.
WriterTo
=
wt
wt
:=
l
.
WriterTo
.
(
torchWriterTo
)
wt
.
handler
=
llamaTorchLayerHandler
l
.
WriterTo
=
wt
case
safetensorWriterTo
:
wt
:=
l
.
WriterTo
.
(
safetensorWriterTo
)
wt
.
handler
=
mistralLayerHandler
l
.
WriterTo
=
wt
}
}
}
m
.
Tensors
=
append
(
m
.
Tensors
,
l
)
m
.
Tensors
=
append
(
m
.
Tensors
,
l
)
}
}
...
...
convert/safetensors.go
View file @
4730762e
...
@@ -281,6 +281,15 @@ func (m *SafetensorFormat) GetModelArch(name, dirPath string, params *Params) (M
...
@@ -281,6 +281,15 @@ func (m *SafetensorFormat) GetModelArch(name, dirPath string, params *Params) (M
return
nil
,
fmt
.
Errorf
(
"No architecture specified to convert"
)
return
nil
,
fmt
.
Errorf
(
"No architecture specified to convert"
)
case
1
:
case
1
:
switch
params
.
Architectures
[
0
]
{
switch
params
.
Architectures
[
0
]
{
case
"LlamaForCausalLM"
:
return
&
LlamaModel
{
ModelData
{
Name
:
name
,
Path
:
dirPath
,
Params
:
params
,
Format
:
m
,
},
},
nil
case
"MistralForCausalLM"
:
case
"MistralForCausalLM"
:
return
&
MistralModel
{
return
&
MistralModel
{
ModelData
{
ModelData
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment