Install
openclaw skills install crabpathMemory graph engine with caller-provided embed and LLM callbacks; core is pure, with real-time correction flow and optional OpenAI integration.
openclaw skills install crabpathPure graph core: zero required deps and no network calls. Caller provides callbacks.
state.json)from crabpath import split_workspace, HashEmbedder, VectorIndex
graph, texts = split_workspace("./workspace")
embedder = HashEmbedder()
index = VectorIndex()
for nid, content in texts.items():
index.upsert(nid, embedder.embed(content))
HashEmbedder (hash-v1, 1024-dim)embed_fn / embed_batch_fn (e.g., text-embedding-3-small)llm_fn using gpt-5-mini (example)replay_queries(graph, queries) can warm-start from historical turns.
--state is preferred:
crabpath query TEXT --state S [--top N] [--json]
crabpath query TEXT --state S --chat-id CID
crabpath doctor --state S
crabpath info --state S
crabpath init --workspace W --output O --embedder openai
crabpath query TEXT --state S --llm openai
crabpath inject --state S --type TEACHING [--type DIRECTIVE]
Real-time correction flow:
python3 query_brain.py --chat-id CHAT_ID
python3 learn_correction.py --chat-id CHAT_ID
crabpath init/query/learn/inject/health/doctor/infoquery_brain.py --chat-id and learn_correction.py for real-time correction pipelinesquery_brain.py traversal limits: beam_width=8, max_hops=30, fire_threshold=0.01max_fired_nodes and max_context_chars (defaults None; query_brain.py defaults max_context_chars=20000)examples/correction_flow/, examples/cold_start/, examples/openai_embedder/split_workspaceload_statesave_stateManagedStateVectorIndextraverseTraversalConfigTraversalConfig.beam_width, .max_hops, .fire_threshold, .max_fired_nodes, .max_context_chars, .reflex_threshold, .habitual_range, .inhibitory_thresholdTraversalResultapply_outcomeinject_nodeinject_correctioninject_batchsuggest_connections, apply_connectionssuggest_merges, apply_mergemeasure_health, autotune, replay_queriesHashEmbedderOpenAIEmbedderdefault_embeddefault_embed_batchopenai_llm_fnchat_completionNodeEdgeGraphsplit_workspacegenerate_summariescrabpath init --workspace W --output O [--sessions S] [--embedder openai]crabpath query TEXT --state S [--top N] [--json] [--chat-id CHAT_ID]crabpath learn --state S --outcome N --fired-ids a,b,c [--json]crabpath inject --state S --id NODE_ID --content TEXT [--type CORRECTION|TEACHING|DIRECTIVE] [--json] [--connect-min-sim 0.0]crabpath inject --state S --id NODE_ID --content TEXT --type TEACHINGcrabpath inject --state S --id NODE_ID --content TEXT --type DIRECTIVEcrabpath health --state Scrabpath doctor --state Scrabpath info --state Scrabpath replay --state S --sessions Scrabpath merge --state S [--llm openai]crabpath connect --state S [--llm openai]crabpath journal [--stats]query_brain.py --chat-id CHAT_IDlearn_correction.py --chat-id CHAT_IDbeam_width=8max_hops=30fire_threshold=0.01reflex_threshold=0.6habitual_range=0.2-0.6inhibitory_threshold=-0.01max_fired_nodes (hard node-count cap, default None)max_context_chars (hard context cap, default None; query_brain.py default is 20000)