llamafile 0.3.9 → 0.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 5f3686b69a33f6422b291c25dff604a5dc8175ad2e20d1dc3702a1e5532c76c1
4
- data.tar.gz: f4bb41a795d358c09d06f03c72db44851c2b88ba2615dcdf4a0e4f8bf79c3341
3
+ metadata.gz: ecc7265e061f8bc2abedbb40ae7642590d640285b67610a6832ecf9712c9debe
4
+ data.tar.gz: 8210a87d0facedfa9c8a1d7cfb4ded91231935716d1c244a03f47097c60dc603
5
5
  SHA512:
6
- metadata.gz: f91f2bd7d09782a430dad150af2b3acf4e2552ad56738f97045e7584f6360a6ce4eafbca6f350d0cebb139f14c690c6c256a4c913111018df0cbf006331de434
7
- data.tar.gz: 030e39dcb743f45512512399c3a1eed818ec73356abb0b6f94107e50bae801e905cc027220939f9dc294cb5b91879c3127c9f03a64c43be7de668ed7fa35a2f4
6
+ metadata.gz: b6c5e65dd402325172b92b363d94cc3c3640036e6bc18390979516b0b4624d14d84a19c61a5af54c8670eba30eaf5c1eedf29147a3a8f83e15bf16deea76dda3
7
+ data.tar.gz: 35f791caed2c0e5f4f19ed38e56cbe2d0c64497720fd7d961364f13b23affabe8e5757a468f6c1930d0127a6c2ca1112ccf73404fc37fccbb728a156ec2746d7
@@ -27,7 +27,7 @@ module LLAMA
27
27
  base_uri ENV['LLAMA']
28
28
  #default_timeout 120
29
29
  end
30
- def self.post h={}
30
+ def self.post h={}, &b
31
31
  #puts %[LLAMA IN: #{h}]
32
32
  hh = {
33
33
  headers: {
@@ -38,18 +38,26 @@ module LLAMA
38
38
  body: JSON.generate(DEF.merge(h))
39
39
  }
40
40
  #puts %[LLAMA PACK: #{hh}]
41
- begin
42
- r = Llama.post('/completion', hh)
43
- #puts %[LLAMA CODE: #{r.code}]
44
- if r.code == 200
45
- return r['content'].gsub(/<.+>/, "").gsub(/\s\s+/, " ").gsub(/\n+/, "\n");
46
- else
47
- return false
41
+ fiber = Fiber.new do |hhh|
42
+ begin
43
+ r = Llama.post('/completion', hhh)
44
+ #puts %[LLAMA CODE: #{r.code}]
45
+ if r.code == 200
46
+ rr = r['content'].gsub(/<.+>/, "").gsub(/\s\s+/, " ").gsub(/\n+/, "\n");
47
+ if block_given?
48
+ Fiber.yield b.call(rr);
49
+ else
50
+ Fiber.yield rr;
51
+ end
52
+ else
53
+ Fiber.yield false
54
+ end
55
+ rescue => err
56
+ puts %[LLAMA POST ERR: #{err}]
57
+ Fiber.yield false
48
58
  end
49
- rescue => err
50
- puts %[LLAMA POST ERR: #{err}]
51
- return false
52
59
  end
60
+ fiber.resume(hh)
53
61
  end
54
62
 
55
63
  def self.make h={}
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Llamafile
4
- VERSION = "0.3.9"
4
+ VERSION = "0.4.1"
5
5
  end
data/lib/llamafile.rb CHANGED
@@ -10,11 +10,46 @@ require_relative "llamafile/grammar"
10
10
  #require_relative "llamafile/voice"
11
11
 
12
12
  module Lf
13
- def self.make h={}
14
- LLAMA.make h
13
+ AI = %[a helpful artificial intelligence who responds accurately and truthfully to User.]
14
+ AND_YN = %[ Respond yes or no.]
15
+ @@CHAR = AI
16
+ def self.character
17
+ @@CHAR
15
18
  end
16
- def self.if? h={}
17
- LLAMA.if?(h)
19
+ def self.inspector
20
+ %[#{@@CHAR} #{AND_YN}]
21
+ end
22
+
23
+ @@TMPL = {
24
+ does: %[AI is <%= Lf.inspector %>\nUser: Does "<%= response %>" <%= condition %> "<%= query %>"\nAI: ],
25
+ user: %[AI is <%= Lf.character %>\nUser: <%= query %>\nAI: ],
26
+ task: %[AI is <%= Lf.character %>\nUser: <%= inst %>\n<%= query %>\nAI: ],
27
+ }
28
+ def self.template
29
+ @@TMPL
30
+ end
31
+
32
+ def self.erb s, params={}
33
+ ERB.new(s).result(binding)
34
+ end
35
+
36
+ def self.does? query, response, condition
37
+ LLAMA.post(n_predict: 4, grammar: GRAMMAR[:bool], prompt: Lf.erb(Lf.template[:does])) == yes;
38
+ end
39
+ def self.number query
40
+ LLAMA.post(grammar: GRAMMAR[:number], prompt: Lf.erb(Lf.template[:user]));
41
+ end
42
+ def self.word query
43
+ LLAMA.post(grammar: GRAMMAR[:word], prompt: Lf.erb(Lf.template[:user]));
44
+ end
45
+ def self.user query
46
+ LLAMA.post(grammar: GRAMMAR[:string], prompt: Lf.erb(Lf.template[:user]));
47
+ end
48
+ def self.list query
49
+ LLAMA.post(grammar: GRAMMAR[:list], prompt: Lf.erb(Lf.template[:user]));
50
+ end
51
+ def self.task inst, query
52
+ LLAMA.post(grammar: GRAMMAR[:steps], prompt: Lf.erb(Lf.template[:task]));
18
53
  end
19
54
  end
20
55
 
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: llamafile
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.9
4
+ version: 0.4.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Erik Olson