Skip to content

veer66/cl-ollama

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cl-ollama

Vee Satayamas [email protected]

cl-ollama is an Ollama client for Common Lisp.

Prerequisitess

  • Ollama
  • SBCL
  • Quicklisp
  • Ultralisp

Example

Basic usage

CL-USER> (ql:quickload "cl-ollama")
To load "cl-ollama":
  Load 1 ASDF system:
    cl-ollama
; Loading "cl-ollama"
...................
("cl-ollama")
CL-USER> (cl-ollama:do-generate (r "What is an interpreter in computer science?") (print r))

(:DONE NIL :RESPONSE "In" :CREATED_AT "2024-10-20T14:31:18.642302463Z" :MODEL
 "llama3.1:8b")
...

Use suffix parameter

An example adapted from ollama/ollama#5207 (comment)

CL-USER> (setq cl-ollama::*model-name* "deepseek-coder-v2")
"deepseek-coder-v2"
CL-USER> (cl-ollama:do-generate (r "def add("
                                 :suffix "return c"
                                 :options (let ((h (make-hash-table)))
                                             (setf (gethash :temperature h) 0)
                                             h)
                                 :stream nil)
             (print r))

(:EVAL_DURATION 929000000 :EVAL_COUNT 14 :PROMPT_EVAL_DURATION 78000000
 :PROMPT_EVAL_COUNT 9 :LOAD_DURATION 90489362 :TOTAL_DURATION 1098952008
 :CONTEXT
 #(100003 1558 962 7 100002 2136 258 100004 64 11 65 1780 185 300 258 403 245
   919 270 185 251)
 :DONE_REASON "stop" :DONE T :RESPONSE "a,b):
    c = a + b
    "
 :CREATED_AT "2024-12-22T15:27:25.147572535Z" :MODEL "deepseek-coder-v2") 

How to switch to another model

CL-USER> (ql:quickload "cl-ollama" :silent t)
("cl-ollama")
CL-USER> (setq cl-ollama:*model-name* "phi3")
"phi3"
CL-USER> (cl-ollama:do-generate (r "What is an interpreter in computer science?") (print r))

(:DONE NIL :RESPONSE "An" :CREATED_AT "2024-10-20T14:35:46.316081045Z" :MODEL
 "phi3")
...

Chat

CL-USER> (ql:quickload "cl-ollama" :silent t)
("cl-ollama")
CL-USER> (cl-ollama::do-chat (r (list '(:role "user"
                                        :content "Why does the sky is yellow?")))
            (print r))

(:DONE NIL :MESSAGE (:CONTENT "The" :ROLE "assistant") :CREATED_AT
 "2024-10-20T14:37:17.289970817Z" :MODEL "llama3.1:8b")

...

Create a model

CL-USER> (cl-ollama:do-create-model (r "my-model-2" "FROM llama3.2")
       (print r))

(:STATUS
 "using existing layer sha256:dde5aa3fc5ffc17176b5e8bdc82f587b24b2678c6c66101bf7da77af9f7ccdff")
...

Create a Blob

CL-USER> (cl-ollama:create-blob #P"/a/path/to/llm/llama-2-7b.Q4_K_M.gguf" "sha256:4567208c2221da5a9f2ded6cc26ce58dd47d0410902c3f57a4a3ed104ce51b0b")
#()
201 (8 bits, #xC9, #o311, #b11001001)
#<HASH-TABLE :TEST EQUAL :COUNT 2 {1024CC3CF3}>
#<QURI.URI.HTTP:URI-HTTP http://localhost:11434/api/blobs/sha256:4567208c2221da5a9f2ded6cc26ce58dd47d0410902c3f57a4a3ed104ce51b0b>
NIL

List local models

CL-USER> (cl-ollama:list-local-models)
(:MODELS
 (:DETAILS
  (:QUANTIZATION_LEVEL "Q4_K_M" :PARAMETER_SIZE "3.2B" :FAMILIES #("llama")
   :FAMILY "llama" :FORMAT "gguf" :PARENT_MODEL "")
  :DIGEST "c8cb353161296fb7fd1a0507b8693bd0ab9f9dc066b3b55057032e5acbfa0911"
  :SIZE 2019393189 :MODIFIED_AT "2024-10-23T11:38:33.552233884+07:00" :MODEL
  "my-model-3:latest" :NAME "my-model-3:latest")
...

Show model information

CL-USER> (cl-ollama:show-model-information "llama3.2")
(:MODIFIED_AT "2024-10-23T10:54:07.678378774+07:00" :MODEL_INFO
 (:TOKENIZER.GGML.TOKENS NULL :TOKENIZER.GGML.TOKEN_TYPE NULL
  :TOKENIZER.GGML.PRE "llama-bpe" :TOKENIZER.GGML.MODEL "gpt2"
...

Copy a model

CL-USER> (cl-ollama:copy-model "llama3.2" "m2")
#()
200 (8 bits, #xC8, #o310, #b11001000)
#<HASH-TABLE :TEST EQUAL :COUNT 2 {1036E91C93}>
#<QURI.URI.HTTP:URI-HTTP http://localhost:11434/api/copy>
NIL

Delete a model

CL-USER> (cl-ollama:delete-model "m2")
#()
200 (8 bits, #xC8, #o310, #b11001000)
#<HASH-TABLE :TEST EQUAL :COUNT 2 {1028A53BF3}>
#<QURI.URI.HTTP:URI-HTTP http://localhost:11434/api/delete>
NIL

Pull a model

CL-USER> (cl-ollama:do-pull-model (r "phi3") (print r))

(:STATUS "pulling manifest") 
(:COMPLETED 2176177120 :TOTAL 2176177120 :DIGEST
 "sha256:633fc5be925f9a484b61d6f9b9a78021eeb462100bd557309f01ba84cac26adf"
 :STATUS "pulling 633fc5be925f") 
...

Push a model

Didn't test yet

Generate Embeddings

CL-USER> (cl-ollama:generate-embeddings "I saw a cat.")
(:PROMPT_EVAL_COUNT 5 :LOAD_DURATION 1475494 :TOTAL_DURATION 366785449
 :EMBEDDINGS
 #(#(-0.00517866d0 0.01042184d0 0.0022142697d0 -0.007714285d0 -0.0073792576d0
     -0.0058945795d0 0.013783175d0 0.012611829d0 3.306841d-4 -0.013258213d0
     0.019619025d0 -0.0069621354d0 0.008238591d0 0.016223108d0 -0.0037654745d0
...

License

APACHE-2.0

About

An Ollama client for Common Lisp

Resources

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

 

Packages

No packages published