Skip to content

Commit

Permalink
fixes to code gen
Browse files Browse the repository at this point in the history
  • Loading branch information
Necr0x0Der committed Sep 6, 2024
1 parent f818f20 commit a34670f
Show file tree
Hide file tree
Showing 5 changed files with 50 additions and 54 deletions.
13 changes: 7 additions & 6 deletions python/sandbox/snet/snet/naint/code-generation.metta
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,10 @@
;)
)))

(: generate (-> String String))
(= (generate $request)
((code-generation) "generate" "Query"
(Kwargs (request $request))
)
)
; This should be generated automatically
;(: generate (-> String String))
;(= (generate $request)
; ((code-generation) "generate" "Query"
; (Kwargs (request $request))
; )
;)
21 changes: 11 additions & 10 deletions python/sandbox/snet/snet/naint/text-generation.metta
Original file line number Diff line number Diff line change
Expand Up @@ -16,16 +16,17 @@
(: top_k (-> Number int32))
(: length (-> Number int32))

(: gen_gpt_2 (-> String String Number Number Number String))
(= (gen_gpt_2 $start_text $run_name $temperature $top_k $length)
((text-generation) "gen_gpt_2" "Query"
(Kwargs (start_text $start_text)
(run_name $run_name)
(temperature $temperature)
(top_k $top_k)
(length $length))
)
)
; Should be generated automatically
;(: gen_gpt_2 (-> String String Number Number Number String))
;(= (gen_gpt_2 $start_text $run_name $temperature $top_k $length)
; ((text-generation) "gen_gpt_2" "Query"
; (Kwargs (start_text $start_text)
; (run_name $run_name)
; (temperature $temperature)
; (top_k $top_k)
; (length $length))
; )
;)

; A sketch of ontological relations
(:<proto AI:Text string)
Expand Down
58 changes: 23 additions & 35 deletions python/sandbox/snet/snet_io.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,9 +48,6 @@ def create_service_client(self, org_id, service_id,
free_call_token_expiry_block=free_call_token_expiry_block)
return ServiceCall(service_client)

def generate_metta_launch_code_atoms_wrapper(self, service_call):
return service_call.generate_metta_launch_code_atoms()

def _unwrap_atom(self, atom):
if isinstance(atom, GroundedAtom):
return atom.get_object().content
Expand All @@ -77,8 +74,8 @@ def __call__(self, command_a, *args_a):
return [E()]
if self.snet_sdk is None:
self.init_sdk()
if command == 'generate_metta_launch_code_atoms_wrapper':
return [self.generate_metta_launch_code_atoms_wrapper(*args, **kwargs)]
if command == 'get_service_callers':
return args[0].generate_callers()
if command == 'organization_list':
return list(map(lambda x: ValueAtom(x), self.organization_list()))
if command == 'service_list':
Expand Down Expand Up @@ -108,41 +105,31 @@ def __init__(self, service_client):

def __call__(self, method, input_type, **kwargs):
service_result = self.service_client.call_rpc(method, input_type, **kwargs)
res_tuple = ()
res_list = []
for output in self.outputs:
res_tuple+=getattr(service_result, output[1])
if (len(res_tuple) > 1):
return res_tuple
return res_tuple[0]
res_list += [getattr(service_result, output[1])]
if (len(res_list) > 1):
return res_list
return res_list[0]

def get_service_details(self):
return self.service_details

def get_service_messages(self):
return self.message_info

def generate_metta_launch_code_text(self):
service_id = self.service_details[1]
metta_fun_type = f'(: {self.func_name} (-> '
fun_header = f'({self.func_name} '
kwargs = '(Kwargs '
for var_tuple in self.inputs:
metta_fun_type += f'{var_tuple[0].capitalize()} '
fun_header += f'${var_tuple[1]} '
kwargs += f'({var_tuple[1]} ${var_tuple[1]}) '
if (len(self.outputs) > 1):
metta_fun_type += "("
for var_tuple in self.outputs:
metta_fun_type += f'{var_tuple[0].capitalize()} '
if (len(self.outputs) > 1):
metta_fun_type = metta_fun_type[:-1] + ")"
metta_fun_type = metta_fun_type[:-1] + '))'
kwargs = kwargs[:-1] + ')'
fun_header = fun_header[:-1] + ')'
result = f'''\n{metta_fun_type}\n( = {fun_header}\n\t(({service_id}) "{self.func_name}" "{self.keys[0]}"\n\t{kwargs}\n\t)\n)'''
return result
def generate_callers_text(self):
# TODO: pretty print
return "\n".join([repr(e) for e in self.generate_callers()])

def _map_type(self, t):
type_map = {'bool': 'Bool',
'string': 'String',
'int32': 'Number',
'float': 'Number'}
return type_map[t] if t in type_map else t

def generate_metta_launch_code_atoms(self):
def generate_callers(self):
service_id = self.service_details[1]
metta_fun_type = []
metta_fun_type.extend([S(':'), S(f'{self.func_name}')])
Expand All @@ -151,20 +138,21 @@ def generate_metta_launch_code_atoms(self):
fun_header = [S(f'{self.func_name}')]
kwargs = [S('Kwargs')]
for var_tuple in self.inputs:
type_symbols_in.append(S(f'{var_tuple[0].capitalize()}'))
type_symbols_in.append(S(self._map_type(var_tuple[0])))
fun_header.append(V(f'{var_tuple[1]}'))
kwargs.append(E(S(f'{var_tuple[1]}'), V(f'{var_tuple[1]}')))
for var_tuple in self.outputs:
type_symbols_out.append(S(f'{var_tuple[0].capitalize()}'))
type_symbols_out.append(S(self._map_type(var_tuple[0])))
if (len(self.outputs) > 1):
metta_fun_type.extend([E(S('->'), *(type_symbols_in), E(*(type_symbols_out)))])
else:
metta_fun_type.extend([E(S('->'), *(type_symbols_in), *(type_symbols_out))])
metta_fun_type = E(*(metta_fun_type))
kwargs = E(*kwargs)
fun_header = E(*fun_header)
function_expr = E(S('='), fun_header, E(E(S(f'{service_id}')), S(f'{self.func_name}'), S(f'{self.keys[0]}'), kwargs))
return E(metta_fun_type, function_expr)
function_expr = E(S('='), fun_header,
E(E(S(service_id)), ValueAtom(self.func_name), ValueAtom(self.keys[0]), kwargs))
return [metta_fun_type, function_expr]

@register_atoms()
def snet_atoms():
Expand Down
9 changes: 7 additions & 2 deletions python/sandbox/snet/test_snet_call.metta
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@

(include snet:naint:code-generation)
((py-dot (code-generation) get_service_messages))
; add a wrapper
(add-reduct &self
(snet-sdk get_service_callers (code-generation)))
; code-generation requires passing data in json format,
; so it will return a parse error
;!(generate "Write Hello World in C#")
Expand All @@ -23,5 +26,7 @@
((abstractive-summarisation)
"neural_summarisation" "Query" (Kwargs (text "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce ullamcorper vehicula augue. Curabitur maximus aliquet ex sed fringilla. Mauris id erat dolor.")))

(include snet:naint:text-generation)
(gen_gpt_2 "What was the largest dinosaur?" "universal" 0.5 2 100)
!(include snet:naint:text-generation)
!(add-reduct &self
(snet-sdk get_service_callers (text-generation)))
!(gen_gpt_2 "What was the largest dinosaur?" "universal" 0.5 2 100)
3 changes: 2 additions & 1 deletion python/sandbox/snet/test_snet_meta.metta
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,5 @@
; we use `include` here, so `snet-sdk` is accessible in the included file
!(include snet:naint:image-generation)
!((py-dot (image-generation) get_service_messages))

; turn service description in textual metta code
!((py-dot (image-generation) generate_callers_text))

0 comments on commit a34670f

Please sign in to comment.