skills/embedding-fusion-strategy/SKILL.md
Designs embedding strategies that combine semantic (text-based) and structural (graph-based) information at node, edge, path, and subgraph levels for knowledge graphs. Use when selecting embedding granularity, choosing complementary semantic and structural approaches, designing fusion strategies (concatenation, attention, contrastive alignment), or when user mentions node embeddings, embedding fusion, vector representations for graphs, or combining text and graph signals.
npx skillsauth add lyndonkl/claude embedding-fusion-strategyInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Copy this checklist and work through each step:
Embedding Fusion Strategy Progress:
- [ ] Step 1: Identify available features and data sources
- [ ] Step 2: Determine task requirements and success criteria
- [ ] Step 3: Select granularity level(s)
- [ ] Step 4: Choose semantic embedding approach
- [ ] Step 5: Choose structural embedding approach
- [ ] Step 6: Design fusion strategy
- [ ] Step 7: Produce embedding strategy specification
Step 1: Identify available features and data sources
Inventory what signals exist in the knowledge graph: node text attributes (names, descriptions, types), edge labels and properties, graph topology (density, diameter, heterogeneity), any external text corpora or pre-trained models available. Understanding the raw material determines what embeddings are feasible. See resources/methodology.md for the full taxonomy of embedding types.
Step 2: Determine task requirements and success criteria
Clarify the downstream task: entity retrieval, link prediction, question answering, node classification, recommendation, or subgraph matching. Each task favors different granularities and fusion approaches. Establish evaluation metrics (MRR, Hits@K, F1, latency budgets). See resources/methodology.md for task-to-approach mapping and selection criteria.
Step 3: Select granularity level(s)
Choose which levels of the graph to embed using the Granularity Selection Guide. Many strategies combine multiple granularities (e.g., node embeddings for retrieval plus subgraph embeddings for re-ranking). See resources/embedding-catalog.md for specific techniques at each level.
Step 4: Choose semantic embedding approach
Select how to capture text-based meaning: LLM encoder for rich contextual embeddings, Sentence-BERT for efficient sentence-level similarity, or text descriptions of neighborhoods for context-aware semantics. Match the approach to your computational budget and freshness requirements. See resources/methodology.md for semantic approach details and trade-offs.
Step 5: Choose structural embedding approach
Select how to capture graph topology: Node2Vec for flexible neighborhood sampling, DeepWalk for uniform random walks, GraphSAGE for inductive learning on unseen nodes, or positional encodings for capturing graph roles. Match the approach to your graph density and update frequency. See resources/embedding-catalog.md for the full structural technique catalog.
Step 6: Design fusion strategy
Combine semantic and structural embeddings using one of the Fusion Approaches. Key decisions: early vs. late fusion, alignment training, dimensionality management, and whether to maintain multiple vectors per entity. See resources/methodology.md for detailed fusion design methodology, including dynamic vs. static trade-offs and storage considerations.
Step 7: Produce embedding strategy specification
Document the complete design using the Output Template. Include embedding dimensions, training procedures, indexing strategy, and update mechanisms. Self-assess using resources/evaluators/rubric_embedding_strategy.json. Minimum standard: Average score >= 3.0.
| Granularity | Description | Use Cases | |-------------|-------------|-----------| | Node | Embed individual entities combining their text attributes with local structural context | Entity retrieval, node classification, entity linking, recommendation | | Edge | Embed relationships including relation type, endpoint context, and edge properties | Link prediction, relation classification, triple verification | | Path | Embed sequences of nodes and edges capturing multi-hop patterns and metapath semantics | Multi-hop reasoning, pathway discovery, explainable retrieval | | Subgraph | Embed local neighborhoods (ego-networks, motifs) capturing community structure | Subgraph matching, anomaly detection, community-aware retrieval | | Community | Embed clusters or partitions summarizing high-level graph regions | Topic modeling, coarse-grained search, hierarchical navigation |
Combine semantic and structural vectors by concatenation: v_fused = [v_semantic; v_structural]. Simple and preserves all information, but doubles dimensionality and treats both signals as independent.
When to use: Baseline approach, fast prototyping, when downstream model can learn weighting.
Learn a weighting over semantic and structural components: v_fused = alpha * v_semantic + (1 - alpha) * v_structural, where alpha is learned per entity or per query. Allows the model to emphasize the most informative signal.
When to use: When relative importance of semantic vs. structural varies across entities or queries.
Train semantic and structural embeddings to coincide for the same entity using contrastive loss (e.g., InfoNCE). Produces a shared embedding space where both views agree. Enables cross-modal retrieval.
When to use: When you want a single unified space, cross-modal search, or when training data for alignment is available.
Use bi-encoder (separate semantic and structural retrieval) followed by cross-encoder re-ranking that considers both signals jointly. Separates fast candidate generation from precise scoring.
When to use: Large-scale retrieval where full fusion at query time is too expensive; when latency budget allows two-stage pipeline.
Maintain multiple embeddings per entity (semantic facets, structural roles, contextual variants). Match queries against the most relevant facet using max-sim or attention pooling.
When to use: Entities with multiple roles or meanings, faceted search, when a single vector loses too much information.
EMBEDDING STRATEGY SPECIFICATION
=================================
Domain: [Knowledge graph domain and scale]
Task: [Primary downstream task(s)]
Success Metrics: [MRR, Hits@K, latency, etc.]
Granularity Level(s): [Node / Edge / Path / Subgraph / Community]
Semantic Approach:
- Method: [LLM encoder / Sentence-BERT / Description-based / etc.]
- Input: [What text is embedded]
- Dimension: [embedding size]
- Model: [specific model name/version]
- Update frequency: [static / periodic / real-time]
Structural Approach:
- Method: [Node2Vec / DeepWalk / GraphSAGE / Positional / etc.]
- Parameters: [walk length, dimensions, neighborhood size, etc.]
- Dimension: [embedding size]
- Update frequency: [static / periodic / incremental]
Fusion Strategy:
- Method: [Concatenation / Attention / Contrastive / Late Fusion / Multi-Vector]
- Final dimension: [fused embedding size]
- Alignment training: [loss function, training procedure if applicable]
- Rationale: [why this fusion approach for this task]
Indexing & Storage:
- Index type: [HNSW / IVF / flat / etc.]
- Vector database: [if applicable]
- Approximate nearest neighbor parameters: [ef, nprobe, etc.]
- Storage estimate: [total size]
Update & Maintenance:
- Recomputation strategy: [full retrain / incremental / streaming]
- Staleness tolerance: [how old before recompute]
- Incremental update mechanism: [if applicable]
NEXT STEPS:
- Implement embedding pipeline
- Train fusion/alignment if applicable
- Build ANN index and benchmark retrieval quality
- Validate end-to-end on downstream task
- Monitor embedding drift in production
testing
--- name: advisory-edit description: A strict advisory-only editing discipline for a writer who dictates ("speaks out") essays and wants help WITHOUT having their voice changed. The editor directs structure, flags grammar, and suggests strategic language — but never modifies the writer's text unless the writer explicitly says "apply" / "make that change" / "rewrite this." Produces a line-referenced, suggestion-only critique where every item is marked the writer's call. Four passes: structural, l
testing
Provides the house style for analyst-grade strategist writing — third-person register with sparing first-person, no em dashes, no "not X, not Y, not Z" negation cascades, numbered footnote citations rather than inline source parentheticals, specific opinion-signaling phrases, and topic-forward paragraph structure modeled on voice patterns observed in Damodaran's Musings on Markets and Thompson's Stratechery. Use when consolidating working notes into a finished long-form strategist or analyst report that must read as written by a senior human analyst rather than an AI assistant.
testing
Renders a markdown report to a PDF using pandoc with xelatex (11pt serif body, 1-inch margins, numbered footnotes, formal heading hierarchy). Requires a one-time install of pandoc and a LaTeX engine on the user's machine — basictex on macOS or texlive-xetex on Linux. Does not attempt automatic install. Fails loudly with the exact install commands if pandoc or xelatex is missing on the user's PATH. Use when producing a finished strategist or analyst report PDF from a polished markdown source.
testing
Produces step-by-step computational walkthroughs of vector and matrix operations as a sequence of numbered "frames", showing the explicit state at each step. The text-equivalent of a 3Blue1Brown animation — each frame shows what changed and why, so the learner can re-trace the operation by hand. Use when the learner needs to *see* a computation unfold (eigenvalue computation, attention with 3 tokens, gradient descent step, SVD on a 2×2, layer norm on a 3-vector, softmax of a small input), when an explanation has been given but the learner needs to ground it in a worked example, or when introducing an operation that's intimidating in symbol form but trivial in pencil-and-paper form.