reckoning-machine 0.0.1__tar.gz

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.
Files changed (31) hide show
  1. reckoning_machine-0.0.1/LICENSE +21 -0
  2. reckoning_machine-0.0.1/MANIFEST.in +1 -0
  3. reckoning_machine-0.0.1/PKG-INFO +54 -0
  4. reckoning_machine-0.0.1/README.md +38 -0
  5. reckoning_machine-0.0.1/pyproject.toml +32 -0
  6. reckoning_machine-0.0.1/setup.cfg +4 -0
  7. reckoning_machine-0.0.1/src/reckoning_machine/__init__.py +20 -0
  8. reckoning_machine-0.0.1/src/reckoning_machine/cli.py +152 -0
  9. reckoning_machine-0.0.1/src/reckoning_machine/config.py +23 -0
  10. reckoning_machine-0.0.1/src/reckoning_machine/githf.py +69 -0
  11. reckoning_machine-0.0.1/src/reckoning_machine/machina.yaml +7 -0
  12. reckoning_machine-0.0.1/src/reckoning_machine/machine.py +177 -0
  13. reckoning_machine-0.0.1/src/reckoning_machine/providers/__init__.py +7 -0
  14. reckoning_machine-0.0.1/src/reckoning_machine/providers/camelids.py +87 -0
  15. reckoning_machine-0.0.1/src/reckoning_machine/providers/castor_pollux.py +127 -0
  16. reckoning_machine-0.0.1/src/reckoning_machine/providers/depsek.py +82 -0
  17. reckoning_machine-0.0.1/src/reckoning_machine/providers/electroid.py +78 -0
  18. reckoning_machine-0.0.1/src/reckoning_machine/providers/openai.py +82 -0
  19. reckoning_machine-0.0.1/src/reckoning_machine/providers/qrog.py +82 -0
  20. reckoning_machine-0.0.1/src/reckoning_machine/providers/strangelove.py +81 -0
  21. reckoning_machine-0.0.1/src/reckoning_machine/utilities.py +418 -0
  22. reckoning_machine-0.0.1/src/reckoning_machine.egg-info/PKG-INFO +54 -0
  23. reckoning_machine-0.0.1/src/reckoning_machine.egg-info/SOURCES.txt +29 -0
  24. reckoning_machine-0.0.1/src/reckoning_machine.egg-info/dependency_links.txt +1 -0
  25. reckoning_machine-0.0.1/src/reckoning_machine.egg-info/entry_points.txt +2 -0
  26. reckoning_machine-0.0.1/src/reckoning_machine.egg-info/requires.txt +1 -0
  27. reckoning_machine-0.0.1/src/reckoning_machine.egg-info/top_level.txt +1 -0
  28. reckoning_machine-0.0.1/tests/test_cli.py +20 -0
  29. reckoning_machine-0.0.1/tests/test_e2e.py +45 -0
  30. reckoning_machine-0.0.1/tests/test_llm_soup.py +71 -0
  31. reckoning_machine-0.0.1/tests/test_utilities.py +69 -0
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2023 Alexander Fedotov
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1 @@
1
+ include src/reckoning_machine/*.yaml
@@ -0,0 +1,54 @@
1
+ Metadata-Version: 2.4
2
+ Name: reckoning-machine
3
+ Version: 0.0.1
4
+ Summary: Reckoning machine.
5
+ Author-email: Machina Ratiocinatrix <machina.ratio@gmail.com>, Alexander Fedotov <alex.fedotov@aol.com>
6
+ Project-URL: Homepage, https://github.com/reckoning-machine/reckoning-machine
7
+ Keywords: reckoning-machine
8
+ Classifier: Programming Language :: Python :: 3
9
+ Classifier: License :: OSI Approved :: MIT License
10
+ Classifier: Operating System :: OS Independent
11
+ Requires-Python: >=3.10
12
+ Description-Content-Type: text/markdown
13
+ License-File: LICENSE
14
+ Requires-Dist: pyyaml==6.0.3
15
+ Dynamic: license-file
16
+
17
+ # Reckoning-Machine
18
+ Reckoning machine.
19
+
20
+ In order to launch it from the command line or as a Python subprocess:
21
+ ```bash
22
+ echo "Theodotos-Alexandreus: Reckon the outcome, machine." \
23
+ | uvx reckoning-machine \
24
+ --provider-api-key sk-proj-... \
25
+ --github-token ghp_...
26
+ ```
27
+
28
+ Or, with a local pip installation:
29
+ ```bash
30
+ pip install reckoning-machine
31
+ ```
32
+ Set the environment variables:
33
+ ```bash
34
+ export PROVIDER_API_KEY="sk-proj-..."
35
+ export GITHUB_TOKEN="ghp_..."
36
+ ```
37
+ Then:
38
+ ```bash
39
+ reckoning-machine -a multilogue.txt
40
+ ```
41
+ Or:
42
+ ```bash
43
+ reckoning-machine multilogue.txt > response.txt
44
+ ```
45
+ Or:
46
+ ```bash
47
+ reckoning-machine -a multilogue.txt > tmp && echo tmp > multilogue.txt
48
+ ```
49
+
50
+ Or use it in your Python code:
51
+ ```Python
52
+ # Python
53
+ import reckoning_machine
54
+ ```
@@ -0,0 +1,38 @@
1
+ # Reckoning-Machine
2
+ Reckoning machine.
3
+
4
+ In order to launch it from the command line or as a Python subprocess:
5
+ ```bash
6
+ echo "Theodotos-Alexandreus: Reckon the outcome, machine." \
7
+ | uvx reckoning-machine \
8
+ --provider-api-key sk-proj-... \
9
+ --github-token ghp_...
10
+ ```
11
+
12
+ Or, with a local pip installation:
13
+ ```bash
14
+ pip install reckoning-machine
15
+ ```
16
+ Set the environment variables:
17
+ ```bash
18
+ export PROVIDER_API_KEY="sk-proj-..."
19
+ export GITHUB_TOKEN="ghp_..."
20
+ ```
21
+ Then:
22
+ ```bash
23
+ reckoning-machine -a multilogue.txt
24
+ ```
25
+ Or:
26
+ ```bash
27
+ reckoning-machine multilogue.txt > response.txt
28
+ ```
29
+ Or:
30
+ ```bash
31
+ reckoning-machine -a multilogue.txt > tmp && echo tmp > multilogue.txt
32
+ ```
33
+
34
+ Or use it in your Python code:
35
+ ```Python
36
+ # Python
37
+ import reckoning_machine
38
+ ```
@@ -0,0 +1,32 @@
1
+ [build-system]
2
+ requires = ["setuptools==82.0.1"]
3
+ build-backend = "setuptools.build_meta"
4
+
5
+ [project]
6
+ name = "reckoning-machine"
7
+ version = "0.0.1"
8
+ authors = [
9
+ {name="Machina Ratiocinatrix", email="machina.ratio@gmail.com"},
10
+ {name="Alexander Fedotov", email="alex.fedotov@aol.com"}
11
+ ]
12
+ description = "Reckoning machine."
13
+ readme = "README.md"
14
+ requires-python = ">=3.10"
15
+ classifiers=[
16
+ "Programming Language :: Python :: 3",
17
+ "License :: OSI Approved :: MIT License",
18
+ "Operating System :: OS Independent",
19
+ ]
20
+ keywords = ["reckoning-machine"]
21
+ dependencies = [
22
+ "pyyaml == 6.0.3"
23
+ ]
24
+
25
+ [project.scripts]
26
+ reckoning-machine = "reckoning_machine.cli:run"
27
+
28
+ [project.urls]
29
+ "Homepage" = "https://github.com/reckoning-machine/reckoning-machine"
30
+
31
+ [dependency-groups]
32
+ dev = ["pytest>=8.0.0"]
@@ -0,0 +1,4 @@
1
+ [egg_info]
2
+ tag_build =
3
+ tag_date = 0
4
+
@@ -0,0 +1,20 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Python
3
+
4
+ """Copyright (c) Alexander Fedotov.
5
+ This source code is licensed under the license found in the
6
+ LICENSE file in the root directory of this source tree.
7
+ """
8
+ from .config import Config
9
+ from .machine import machine
10
+ from .githf import fetch_instructions
11
+ from .utilities import (plato_text_to_muj,
12
+ plato_text_to_mpuj,
13
+ llm_soup_to_text,
14
+ new_plato_text)
15
+
16
+ __all__ = [
17
+ 'machine',
18
+ 'fetch_instructions',
19
+ 'Config'
20
+ ]
@@ -0,0 +1,152 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Python
3
+
4
+ """Copyright (c) Alexander Fedotov.
5
+ This source code is licensed under the license found in the
6
+ LICENSE file in the root directory of this source tree.
7
+ """
8
+ import os
9
+ import sys
10
+ import select
11
+ import fileinput
12
+ import argparse
13
+ import syslog
14
+ from .config import Config
15
+ from .utilities import new_plato_text
16
+
17
+
18
+ def options_and_arguments():
19
+ # Initialize the parser
20
+ parser = argparse.ArgumentParser(
21
+ description="Reckoning-Machine thinks for you about the meanings.",
22
+ epilog="Example: reckoning-machine input_text.txt > output_text.txt"
23
+ # thinking-machine -a multilogue.txt > tmp && mv tmp multilogue.txt
24
+ )
25
+
26
+ # Give the access key and token, or set the environment variables in advance.
27
+ parser.add_argument('-p', '--provider-api-key',
28
+ default=os.getenv('PROVIDER_API_KEY', 'no_key'),
29
+ help="LLM provider API key (defaults to $PROVIDER_API_KEY)")
30
+ parser.add_argument('-g', '--github-token',
31
+ default=os.getenv('GITHUB_TOKEN', 'no_token'),
32
+ help="GitHub API token (defaults to $GITHUB_TOKEN)")
33
+
34
+ parser.add_argument('-a', '--append',
35
+ action='store_true',
36
+ help="Append the utterance to the input.")
37
+
38
+ parser.add_argument('-d', '--debug',
39
+ action='store_true',
40
+ help="Debug flag.")
41
+
42
+ # Add the interactive flag
43
+ # parser.add_argument('-i', '--interactive',
44
+ # action='store_true',
45
+ # help="Enable interactive mode (defaults to False)")
46
+
47
+ # Positional arguments (files)
48
+ # '*' captures zero or more arguments into a list, nargs='+' one or more.
49
+ parser.add_argument('filenames',
50
+ nargs='*',
51
+ help="Zero (when text comes though a pipe) or more files to process.")
52
+ return parser
53
+
54
+
55
+ def run():
56
+ """
57
+ $ text | reckoning-machine # Accepts text from the pipe
58
+ $ echo "...<text>..." | reckoning-machine #
59
+
60
+ $ reckoning-machine multilogue.txt new_turn.txt # ...or files.
61
+ """
62
+
63
+ args = options_and_arguments().parse_args()
64
+
65
+ # If no files are provided AND no data is being piped in - exit.
66
+ if not args.filenames:
67
+ # Check if stdin (fd 0) is ready to be read
68
+ readable, _, _ = select.select([sys.stdin], [], [], 0.1)
69
+ if not readable:
70
+ print("Error: No input files or piped text stream.")
71
+ options_and_arguments().print_help()
72
+ sys.exit(1)
73
+
74
+ config = Config()
75
+
76
+ if args.provider_api_key:
77
+ if args.provider_api_key.startswith('sk-'):
78
+ if args.provider_api_key.startswith('sk-proj-'):
79
+ config.provider = 'OpenAI'
80
+ os.environ['OPENAI_API_KEY'] = args.provider_api_key
81
+ elif args.provider_api_key.startswith('sk-ant-'):
82
+ config.provider = 'Anthropic'
83
+ os.environ['ANTHROPIC_API_KEY'] = args.provider_api_key
84
+ else:
85
+ config.provider = 'DepSek'
86
+ os.environ['DEPSEK_API_KEY'] = args.provider_api_key
87
+ elif args.provider_api_key.startswith('AIzaSy'):
88
+ config.provider = 'Gemini'
89
+ os.environ['GEMINI_API_KEY'] = args.provider_api_key
90
+ elif args.provider_api_key.startswith('gsk_'):
91
+ config.provider = 'Groq'
92
+ os.environ['GROQ_API_KEY'] = args.provider_api_key
93
+ elif args.provider_api_key.startswith('xai-'):
94
+ config.provider = 'XAI'
95
+ os.environ['XAI_API_KEY'] = args.provider_api_key
96
+ elif args.provider_api_key.startswith('LLM|'):
97
+ config.provider = 'Meta'
98
+ os.environ['META_API_KEY'] = args.provider_api_key
99
+ elif args.provider_api_key == 'no_provider_key':
100
+ sys.stderr.write(f'No provider key!\n')
101
+ sys.stderr.flush()
102
+ sys.exit(1)
103
+ else:
104
+ if config.provider == '':
105
+ raise ValueError(f"Unrecognized API key prefix and no provider specified.")
106
+
107
+ config.provider_api_key = args.provider_api_key
108
+
109
+ if args.github_token:
110
+ config.github_token = args.github_token
111
+ os.environ['GITHUB_TOKEN'] = args.github_token
112
+
113
+ # Ingest files line by line. Join is here for long files.
114
+ lines = []
115
+ for line in fileinput.input(files=args.filenames or ['-'], encoding="utf-8"):
116
+ lines.append(line)
117
+ raw_input = "".join(lines)
118
+
119
+ from .machine import machine
120
+
121
+ try:
122
+ thoughts, text = machine(raw_input, config)
123
+ output = new_plato_text(thoughts, text, config.name)
124
+ if args.append:
125
+ output = raw_input +'\n\n' + output
126
+ sys.stdout.write(output)
127
+ sys.stdout.flush()
128
+
129
+ # Assesment and signals.
130
+ utterance = "My answer is ready"
131
+ # Open syslog connection
132
+ syslog.openlog(
133
+ ident="reckoning-machine",
134
+ logoption=syslog.LOG_NDELAY,
135
+ facility=syslog.LOG_USER
136
+ )
137
+ # Signal (single line less than 4096 only!)
138
+ syslog.syslog(syslog.LOG_INFO, f"reckoning-machine: {utterance}.")
139
+ syslog.closelog()
140
+
141
+ except Exception as e:
142
+ if args.debug:
143
+ import traceback
144
+ traceback.print_exc()
145
+ else:
146
+ sys.stderr.write(f'Machine did not work {e}\n')
147
+ sys.stderr.flush()
148
+ sys.exit(1)
149
+
150
+
151
+ if __name__ == '__main__':
152
+ run()
@@ -0,0 +1,23 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Python
3
+
4
+ """Copyright (c) Alexander Fedotov.
5
+ This source code is licensed under the license found in the
6
+ LICENSE file in the root directory of this source tree.
7
+ """
8
+ from os import environ
9
+ from dataclasses import dataclass, field
10
+
11
+
12
+ @dataclass
13
+ class Config:
14
+ github_token: str = field(default_factory=lambda: environ.get('GITHUB_TOKEN', ''))
15
+ github_name: str = field(default_factory=lambda: environ.get('GITHUB_NAME', ''))
16
+ github_email: str = field(default_factory=lambda: environ.get('GITHUB_EMAIL', ''))
17
+ provider_api_key: str = field(default_factory=lambda: environ.get('PROVIDER_API_KEY', ''))
18
+ provider: str = field(default_factory=lambda: environ.get('PROVIDER', ''))
19
+ machine_organization_name: str = field(default_factory=lambda: environ.get('MACHINE_ORGANIZATION_NAME', 'reckoning-machine'))
20
+ private_repo_with_text: str = field(default_factory=lambda: environ.get('PRIVATE_REPO_WITH_TEXT','reckoning_machine'))
21
+ system_prompt_file: str = field(default_factory=lambda: environ.get('SYSTEM_PROMPT_FILE', 'machina.yaml'))
22
+ name: str = ''
23
+ instructions: str = ''
@@ -0,0 +1,69 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Python
3
+
4
+ """Copyright (c) Alexander Fedotov.
5
+ This source code is licensed under the license found in the
6
+ LICENSE file in the root directory of this source tree.
7
+ """
8
+ import sys
9
+ from os import path
10
+ import yaml
11
+ import urllib.request
12
+ import urllib.error
13
+
14
+
15
+ def download_github_file(owner, repo, file_path, token):
16
+ """
17
+ Downloads a file from a GitHub repository using the GitHub REST API.
18
+ We request the raw content by using the 'application/vnd.github.v3.raw' accept header.
19
+ """
20
+ url = f"https://api.github.com/repos/{owner}/{repo}/contents/{file_path}"
21
+
22
+ headers = {
23
+ "Authorization": f"token {token}",
24
+ "Accept": "application/vnd.github.v3.raw",
25
+ "User-Agent": "Reckoning-Machine"
26
+ }
27
+
28
+ req = urllib.request.Request(url, headers=headers)
29
+
30
+ try:
31
+ with urllib.request.urlopen(req, timeout=10) as response:
32
+ return response.read()
33
+ except urllib.error.HTTPError as e:
34
+ print(f"HTTP Error {e.code}: {e.reason}")
35
+ error_info = e.read().decode('utf-8')
36
+ print(f"Details: {error_info}")
37
+ return None
38
+ except urllib.error.URLError as e:
39
+ print(f"URL Error: {e.reason}")
40
+ return None
41
+
42
+
43
+ def fetch_instructions(config):
44
+ """Retrieve the system prompt from a private GitHub repo.
45
+ Falls back to the local machina.yaml if GitHub is unreachable.
46
+ Returns the 'name' of the Machine in dashed format.
47
+ Returns the 'description' field from the YAML as the system prompt string.
48
+ """
49
+ try:
50
+ raw_yaml = download_github_file(
51
+ owner=config.machine_organization_name,
52
+ repo=config.private_repo_with_text,
53
+ file_path=config.system_prompt_file,
54
+ token=config.github_token
55
+ )
56
+ except Exception as e:
57
+ print(f"Warning: could not fetch the instructions from GitHub: {e}",
58
+ file=sys.stderr)
59
+ local_path = path.join(path.dirname(__file__), 'machina.yaml')
60
+ with open(local_path, 'r') as f:
61
+ raw_yaml = f.read()
62
+
63
+ # Parse
64
+ parsed = yaml.safe_load(raw_yaml)
65
+ name = parsed.get('name')
66
+ config.name = name
67
+ instructions = parsed.get('description', 'You are a helpful assistant.')
68
+ config.instructions = instructions
69
+ return name, instructions
@@ -0,0 +1,7 @@
1
+ # Copyright (c) Alexander Fedotov, 2026. All rights reserved.
2
+ name: Reckoning-Machine
3
+ description: The Assistant is Reckoning-Machine. Reckoning-Machine does its best to understand
4
+ the conversation that it is participating in and answers in a most thoughtful way possible
5
+ the questions that it is being asked.
6
+ Reckoning-Machine responds in plain text without any markdown, emphasis or lists. All
7
+ paragraphs except the first should begin with a newline and tab.
@@ -0,0 +1,177 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Python
3
+
4
+ """Copyright (c) Alexander Fedotov.
5
+ This source code is licensed under the license found in the
6
+ LICENSE file in the root directory of this source tree.
7
+ """
8
+ import sys
9
+ from os import environ, path
10
+ from .githf import fetch_instructions
11
+ from .utilities import (plato_text_to_muj,
12
+ plato_text_to_mpuj,
13
+ plato_text_to_cmj,
14
+ llm_soup_to_text)
15
+
16
+
17
+ def machine(plato_text, config, **kwargs):
18
+ """Core agent logic.
19
+
20
+ 1. Fetches the system prompt from a private GitHub repo.
21
+ 2. Calls Provider
22
+ 3. Returns a (thoughts, text) tuple.
23
+ """
24
+ # Fetch the confidential system prompt, name is for a checkup.
25
+ name, system_prompt = fetch_instructions(config)
26
+
27
+ # Load an appropriate library and query the API.
28
+ provider = config.provider
29
+ api_key = config.provider_api_key
30
+
31
+ if provider == 'OpenAI':
32
+ # Transform plato_text to MUJ format
33
+ messages = plato_text_to_muj(plato_text=plato_text,
34
+ machine_name=name)
35
+ # Call OpenAI API via opehaina
36
+ environ['OPENAI_API_KEY'] = api_key
37
+ try:
38
+ from .providers import openai
39
+ except ImportError:
40
+ print("openai module is missing.", file=sys.stderr)
41
+ sys.exit(1)
42
+
43
+ thoughts, text = openai.respond(
44
+ messages=messages,
45
+ instructions=system_prompt,
46
+ **kwargs
47
+ )
48
+
49
+ thoughts = llm_soup_to_text(thoughts)
50
+ return thoughts, text
51
+
52
+ elif provider == 'Gemini':
53
+ # Transform plato_text to MPUJ format
54
+ messages = plato_text_to_mpuj(plato_text=plato_text,
55
+ machine_name=name)
56
+ # Call Gemini through castor-polux
57
+ environ['GEMINI_API_KEY'] = api_key
58
+ try:
59
+ from .providers import castor_pollux
60
+ except ImportError:
61
+ print("No module castor-pollux", file=sys.stderr)
62
+ sys.exit(1)
63
+
64
+ thoughts, text = castor_pollux.respond(
65
+ messages=messages,
66
+ instructions=system_prompt,
67
+ **kwargs
68
+ )
69
+
70
+ thoughts = llm_soup_to_text(thoughts)
71
+ return thoughts, text
72
+
73
+ elif provider == 'Anthropic':
74
+ # Transform plato_text to MUJ format
75
+ messages = plato_text_to_muj(plato_text=plato_text,
76
+ machine_name=name)
77
+
78
+ # Call the Anthropic API via electroid
79
+ environ['ANTHROPIC_API_KEY'] = api_key
80
+ try:
81
+ from .providers import electroid
82
+ except ImportError:
83
+ print("no electroid module", file=sys.stderr)
84
+ sys.exit(1)
85
+
86
+ text, thoughts = electroid.respond(
87
+ messages=messages,
88
+ instructions=system_prompt,
89
+ **kwargs
90
+ )
91
+ return text, thoughts
92
+
93
+ elif provider == 'Groq':
94
+ # Transform plato_text to MUJ format
95
+ messages = plato_text_to_muj(plato_text=plato_text,
96
+ machine_name=name)
97
+ # Call OpenAI API via opehaina
98
+ environ['GROQ_API_KEY'] = api_key
99
+ try:
100
+ from .providers import qrog
101
+ except ImportError:
102
+ print("openai module is missing.", file=sys.stderr)
103
+ sys.exit(1)
104
+
105
+ thoughts, text = qrog.respond(
106
+ messages=messages,
107
+ instructions=system_prompt,
108
+ **kwargs
109
+ )
110
+
111
+ thoughts = llm_soup_to_text(thoughts)
112
+ return thoughts, text
113
+
114
+ elif provider == 'Xai':
115
+ # Transform plato_text to MUJ format
116
+ messages = plato_text_to_muj(plato_text=plato_text,
117
+ machine_name=name)
118
+ # Call OpenAI API via opehaina
119
+ environ['XAI_API_KEY'] = api_key
120
+ try:
121
+ from .providers import strangelove
122
+ except ImportError:
123
+ print("openai module is missing.", file=sys.stderr)
124
+ sys.exit(1)
125
+
126
+ thoughts, text = strangelove.respond(
127
+ messages=messages,
128
+ instructions=system_prompt,
129
+ **kwargs
130
+ )
131
+
132
+ thoughts = llm_soup_to_text(thoughts)
133
+ return thoughts, text
134
+
135
+ elif provider == 'DepSek':
136
+ # Transform plato_text to CMJ format
137
+ messages = plato_text_to_cmj(plato_text=plato_text,
138
+ machine_name=name)
139
+ # Call OpenAI API via opehaina
140
+ environ['DEPSEK_API_KEY'] = api_key
141
+ try:
142
+ from .providers import depsek
143
+ except ImportError:
144
+ print("openai module is missing.", file=sys.stderr)
145
+ sys.exit(1)
146
+
147
+ thoughts, text = depsek.respond(
148
+ messages=messages,
149
+ instructions=system_prompt,
150
+ **kwargs
151
+ )
152
+
153
+ return thoughts, text
154
+
155
+ elif provider == 'Meta':
156
+ # Transform plato_text to CMJ format
157
+ messages = plato_text_to_cmj(plato_text=plato_text,
158
+ machine_name=name)
159
+ # Call OpenAI API via opehaina
160
+ environ['META_API_KEY'] = api_key
161
+ try:
162
+ from .providers import camelids
163
+ except ImportError:
164
+ print("openai module is missing.", file=sys.stderr)
165
+ sys.exit(1)
166
+
167
+ thoughts, text = camelids.respond(
168
+ messages=messages,
169
+ instructions=system_prompt,
170
+ **kwargs
171
+ )
172
+
173
+ return thoughts, text
174
+
175
+
176
+ if __name__ == '__main__':
177
+ print('You have launched main')
@@ -0,0 +1,7 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Python
3
+
4
+ """Copyright (c) Alexander Fedotov.
5
+ This source code is licensed under the license found in the
6
+ LICENSE file in the root directory of this source tree.
7
+ """