← 返回 Skills 市场
athola

Nm Abstract Friction Detector

作者 athola · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ✓ 安全检测通过
32
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install nm-abstract-friction-detector
功能描述
Detect friction signals; graduate patterns into rules. Use for session retrospectives
使用说明 (SKILL.md)

Night Market Skill — ported from claude-night-market/abstract. For the full experience with agents, hooks, and commands, install the Claude Code plugin.

Friction-to-Learning Pipeline

Detect friction signals during agent execution, track them across sessions, and graduate recurring patterns into permanent guidance. Bridges the gap between ephemeral session friction and durable CLAUDE.md rules.

Research backing: Claude Coach (hook-based friction detection with SQLite storage), alirezarezvani's self-improving-agent (three-tier MEMORY to CLAUDE.md graduation), and the ACE framework (arXiv: evolving playbooks from execution feedback, +10.6% on agent tasks).

Current gap: LEARNINGS.md exists but requires manual aggregation via /abstract:aggregate-logs. This skill adds automatic friction detection and a structured promotion path.

Friction Signal Types

Signal Detection Method Weight
Repeated corrections User overrides same tool call 2+ times in session High
Command failures Exit code != 0 patterns (same command type fails repeatedly) Medium
Permission denials User denies tool call, indicating unexpected behavior High
Re-reads Same file read 3+ times in session (lost context) Low
Retry loops Same action attempted 3+ times with variations Medium
User frustration Explicit negative feedback or correction language High

Weight scoring: High = 3, Medium = 2, Low = 1 points per occurrence. Weighted score determines graduation velocity.

Three-Tier Storage Graduation

Tier 1: Friction Log (ephemeral, per-session)
  Location: ~/.claude/friction/sessions/{date}-{id}.json
  Retention: 30 days, then pruned
  Threshold: 1 occurrence, logged, no action

Tier 2: Pattern Candidate (persistent, LEARNINGS.md)
  Location: ~/.claude/skills/LEARNINGS.md (friction section)
  Threshold: 3+ occurrences across 2+ sessions
  Action: flagged for review in next friction report

Tier 3: Graduated Rule (CLAUDE.md or skill update)
  Threshold: reviewed + user-approved
  Action: permanent guidance added to project/user config
  Constraint: NEVER auto-modify CLAUDE.md

Graduation Formula

graduation_score = (weighted_count * recency_factor) / sessions_seen

recency_factor:
  last 7 days  = 1.0
  8-14 days    = 0.7
  15-30 days   = 0.4
  31+ days     = 0.1

Tier 2 threshold: graduation_score >= 6.0
Tier 3 proposal:  graduation_score >= 12.0

Detection Workflow

Run at session end, at 80% context usage (via conserve:clear-context), or after failed improvement cycles (when metacognitive-self-mod detects regression).

Step 1: Scan Session for Signals

For each friction indicator found, wrap it in the shared session-capture envelope (ADR-0011) so downstream readers can ingest friction signals and trace-capture entries through one parser:

{
  "schema_version": "session-capture/1",
  "session_id": "2026-04-14-abc12345",
  "timestamp": "2026-04-14T10:23:00Z",
  "source": "friction-detector",
  "payload": {
    "signal_type": "retry_loop",
    "description": "rg command failed 3x, fell back to grep",
    "context": "searching for pattern in node_modules",
    "weight": "medium"
  }
}

Legacy files written before envelope adoption are read as session-capture/0 (entire file treated as the payload). See docs/adr/0011-session-capture-envelope.md for the contract and migration path.

Step 2: Compare Against Existing Log

FRICTION_DIR=~/.claude/friction/sessions
mkdir -p "$FRICTION_DIR"

# Count prior occurrences of similar signals
if command -v rg &>/dev/null; then
  rg -c "$SIGNAL_TYPE" "$FRICTION_DIR"/*.json 2>/dev/null || echo "0"
else
  grep -rc "$SIGNAL_TYPE" "$FRICTION_DIR"/*.json 2>/dev/null || echo "0"
fi

Step 3: Calculate Graduation Score

Aggregate across session logs: sum weighted occurrences, apply recency decay, divide by session count, compare against tier thresholds.

Step 4: Propose Graduations

Tier 2 crossing: append to LEARNINGS.md friction section. Tier 3 crossing: present proposal with evidence to user, wait for explicit approval before any modification.

Step 5: Store Results

Write session log to ~/.claude/friction/sessions/{date}-{session_id}.json and update ~/.claude/friction/index.json.

Anti-Noise Rules

Ignore these signals:

  1. One-off failures: transient network/CI errors (unless they recur 3+ times)
  2. User-initiated exploration: deliberate experimentation is not agent error
  3. Already-graduated patterns: covered by existing CLAUDE.md rules or skill instructions
  4. External tool failures: MCP server crashes and similar tool bugs unrelated to agent behavior

Decay factor: signals older than 30 days contribute only 10% of their original weight (see graduation formula recency_factor).

Friction Report Format

## Friction Report -- Session {date}

### New Signals (Tier 1)
- [RETRY] `rg` command failed 3x, fell back to `grep`
- [RE-READ] Read SKILL.md 4 times (lost file structure context)

### Recurring Patterns (Tier 2 candidates)
- [CORRECTION] User corrected file path format 4x across 3 sessions
  Score: 8.4 (threshold: 6.0)
  Candidate: Add path format guidance to CLAUDE.md

### Graduation Proposals (Tier 3)
- [RULE] "Always use absolute paths in Read tool"
  Evidence: 7 corrections across 5 sessions
  Score: 14.2 (threshold: 12.0)
  Action: Approve / Reject / Defer

### Noise Filtered
- 2 transient network timeouts (ignored)
- 1 user-initiated deep exploration (ignored)

Integration

Feeds into: LEARNINGS.md (Tier 2 patterns, same format as /abstract:aggregate-logs), skill-improver (priority scoring), and metacognitive-self-mod (pipeline effectiveness).

Consumes from: session transcripts, aggregate_learnings_daily hook data, and the performance tracker for trend correlation.

When NOT to Use

  • Single isolated failures (wait for recurrence)
  • Skill authoring (use abstract:skill-authoring)
  • Routine log aggregation (use /abstract:aggregate-logs)

Related

  • abstract:metacognitive-self-mod: improvement analysis
  • abstract:skills-eval: evaluation criteria
  • /abstract:aggregate-logs: manual LEARNINGS.md generation
  • conserve:clear-context: triggers friction scan at 80%
安全使用建议
Install only if you are comfortable with the skill keeping local friction or learning notes across sessions. Review ~/.claude/friction and any related learning files periodically, and delete them if you do not want that history retained.
能力评估
Purpose & Capability
The reported capability is session/friction learning, and local retention of friction notes is coherent with that purpose.
Instruction Scope
The persistence behavior is described in the skill instructions, but the short user-facing description may not make the retention behavior obvious before install.
Install Mechanism
No executable install step, dependency install, binary, or automatic startup behavior was evidenced in the supplied scan context.
Credentials
Storing session-derived friction data under a Claude config area is proportionate for a learning skill, but it may include sensitive workflow or interaction context.
Persistence & Privilege
The skill uses persistent local storage under ~/.claude/friction and may update learning files; this is disclosed in the artifact context and not shown to be hidden, remote, or privileged.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install nm-abstract-friction-detector
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /nm-abstract-friction-detector 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.0
- Adds automated friction signal detection and structured pattern graduation for session retrospectives. - Implements a three-tier storage system: ephemeral friction logs, persistent pattern candidates (LEARNINGS.md), and user-approved rules (CLAUDE.md). - Introduces weighted scoring and recency-based thresholds for rule graduation. - Integrates an anti-noise filter to ignore non-actionable or already-addressed signals. - Provides a standardized friction report format and envelope for downstream integration.
元数据
Slug nm-abstract-friction-detector
版本 1.0.0
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 1
常见问题

Nm Abstract Friction Detector 是什么?

Detect friction signals; graduate patterns into rules. Use for session retrospectives. 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 32 次。

如何安装 Nm Abstract Friction Detector?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install nm-abstract-friction-detector」即可一键安装,无需额外配置。

Nm Abstract Friction Detector 是免费的吗?

是的,Nm Abstract Friction Detector 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

Nm Abstract Friction Detector 支持哪些平台?

Nm Abstract Friction Detector 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 Nm Abstract Friction Detector?

由 athola(@athola)开发并维护,当前版本 v1.0.0。

💬 留言讨论