feat(arch): implement 'Code as Thought' architecture and formalize PSF Consensus Loop
This commit is contained in:
@@ -1,73 +0,0 @@
|
||||
#+TITLE: SKILL: Anthropic Provider Agent (Claude Backend)
|
||||
#+ID: skill-provider-anthropic-agent
|
||||
#+STARTUP: content
|
||||
|
||||
* Overview
|
||||
The **Anthropic Provider Agent** integrates Anthropic's Claude family of models as a pluggable System 1 (neural) backend for the Neurosymbolic Kernel. It enables the agent to utilize high-intelligence models for complex reasoning, drafting, and analysis tasks.
|
||||
|
||||
* The Provider Mandate
|
||||
1. **Connectivity:** Ensure reliable communication with the Anthropic Messages API.
|
||||
2. **Configurability:** Dynamically resolve the specific Claude model to use based on the system's Environment Configuration.
|
||||
3. **Context Management:** Leverage Claude's large context windows (up to 200k) for deep codebase analysis.
|
||||
4. **Safety:** Handle API failures and missing credentials gracefully by logging errors rather than crashing the kernel.
|
||||
|
||||
* Symbolic Implementation (The Logic)
|
||||
The implementation focuses on the API request/response cycle and model discovery.
|
||||
|
||||
** Architectural Intent: Backend Request Execution
|
||||
This function handles the physical I/O with the Anthropic API. It retrieves credentials from the environment, model settings from the Config skill, and formats the request according to the Anthropic Messages protocol.
|
||||
|
||||
#+begin_src lisp
|
||||
(defun execute-anthropic-request (prompt system-prompt)
|
||||
"Executes a completion request via the Anthropic (Claude) API."
|
||||
(let ((api-key (org-agent::get-env "ANTHROPIC_API_KEY"))
|
||||
(config-pkg (find-package :org-agent.skills.skill-environment-config)))
|
||||
(unless api-key
|
||||
(return-from execute-anthropic-request "(:type :LOG :payload (:text \"Anthropic key missing\"))"))
|
||||
|
||||
(let* ((get-config-fn (when config-pkg (find-symbol "GET-CONFIG-ATTRIBUTE" config-pkg)))
|
||||
(model (if (and get-config-fn (fboundp get-config-fn))
|
||||
(funcall get-config-fn :LLM_MODEL_ANTHROPIC "claude-3-5-sonnet-20240620")
|
||||
"claude-3-5-sonnet-20240620"))
|
||||
(url "https://api.anthropic.com/v1/messages")
|
||||
(body (cl-json:encode-json-to-string
|
||||
`((model . ,model)
|
||||
(max_tokens . 1024)
|
||||
(system . ,system-prompt)
|
||||
(messages . (((role . "user") (content . ,prompt))))))))
|
||||
(handler-case
|
||||
(let* ((response (dex:post url
|
||||
:headers `(("Content-Type" . "application/json")
|
||||
("x-api-key" . ,api-key)
|
||||
("anthropic-version" . "2023-06-01"))
|
||||
:content body))
|
||||
(json (cl-json:decode-json-from-string response)))
|
||||
;; Extract content from Anthropic response
|
||||
(cdr (assoc :text (car (cdr (assoc :content json))))))
|
||||
(error (c)
|
||||
(format nil "(:type :LOG :payload (:text \"Anthropic Failure (~a) - ~a\"))" model c))))))
|
||||
|
||||
;; Register the backend
|
||||
(org-agent:register-neuro-backend :anthropic #'execute-anthropic-request)
|
||||
(org-agent:register-neuro-backend :claude #'execute-anthropic-request)
|
||||
#+end_src
|
||||
|
||||
** Architectural Intent: Model Discovery
|
||||
Provides the Model Explorer with a list of supported models and their context limits, allowing the user to inspect capabilities.
|
||||
|
||||
#+begin_src lisp
|
||||
(defun get-available-models ()
|
||||
"Returns the list of LLM models supported by this provider."
|
||||
'((:id "claude-3-5-sonnet-20240620" :context "200k")
|
||||
(:id "claude-3-opus-20240229" :context "200k")
|
||||
(:id "claude-3-haiku-20240307" :context "200k")))
|
||||
#+end_src
|
||||
|
||||
* Registration
|
||||
#+begin_src lisp
|
||||
(defskill :skill-provider-anthropic
|
||||
:priority 100
|
||||
:trigger (lambda (context) nil)
|
||||
:neuro (lambda (context) nil)
|
||||
:symbolic (lambda (action context) action))
|
||||
#+end_src
|
||||
1
system/skills/org-skill-provider-anthropic.org
Symbolic link
1
system/skills/org-skill-provider-anthropic.org
Symbolic link
@@ -0,0 +1 @@
|
||||
/home/user/memex/notes/org-skill-provider-anthropic.org
|
||||
Reference in New Issue
Block a user