Skip to content

Community Graph Model

Reference for the data model that powers Communitas — entities, edges, weights, and the three internal models.

Communitas builds a living model of your community as a dynamic, weighted, typed graph. This page documents the entities, relationships, and internal models that make up that graph.

The graph is not a frozen snapshot. It updates as interactions happen, tracks how relationships form and weaken over time, and supports temporal queries — “what changed this month?” is a first-class question. This reflects research on dynamic social networks showing that communities form, split, and merge continuously.

The graph contains eight entity types. Each represents something a community produces or organizes around.

  • Member — A person in the community. Carries attributes like join date, activity level, and cluster membership over time.
  • Thread — A conversation container (a forum post, a Slack thread, a Discord channel discussion). Threads connect members to topics and to each other.
  • Message — A single contribution within a thread. The atomic unit of interaction.
  • Topic — A subject area or theme, derived from content analysis. Topics connect members who share interests but may not interact directly.
  • Event — A synchronous gathering (meeting, call, workshop, conference). Events create co-attendance edges that don’t appear in text-based interaction data.
  • Artifact — A document, code repository, resource, or shared output. Artifacts connect contributors and capture collaboration beyond conversation.
  • Policy/Norm — A community rule, guideline, or behavioral expectation. Policies connect to the members and threads they govern. See governance principles.
  • Intervention — A specific action taken by the system or a steward: an introduction, a prompt, a norms reminder. Interventions are first-class entities so their outcomes can be tracked. See the intervention taxonomy.

Edges represent relationships between entities. Each edge is typed, directed, weighted, and timestamped.

EdgeFromToWhat it captures
replies_toMessageMessageConversational structure and engagement
mentionsMessageMemberDirected attention and recognition
co_attendsMemberMemberShared presence at events
co_authorsMemberMemberJoint work on artifacts
endorsesMemberMemberExplicit support (reactions, upvotes, approvals)
moderatesMemberThreadGovernance activity and moderation load
introducesMemberMemberBrokered connections, tracked for outcomes
citesArtifactArtifactKnowledge lineage and influence
shares_topicMemberTopicInterest overlap, even without direct interaction
conflicts_withMemberMemberDisagreement or escalation patterns

Edges are not binary. A replies_to edge between two members who exchange messages daily carries different weight than one based on a single reply six months ago.

Edge weights combine multiple signals to reflect relationship strength and quality:

  • Recency-weighted frequency — Recent interactions count more than old ones. A burst of activity last week matters more than steady activity a year ago. Weights decay over time unless renewed.
  • Reciprocity — Bidirectional relationships are weighted higher than one-directional ones. If only one person initiates, the edge reflects that asymmetry.
  • Sentiment stability — Edges between members whose interactions are consistently constructive carry more weight than volatile relationships that swing between positive and negative.
  • Collaboration outcomes — Edges formed through successful joint work (merged pull requests, co-authored documents, completed projects) carry additional weight reflecting demonstrated trust.

Communitas maintains three complementary models, each serving a different function.

The primary model: a dynamic, weighted, typed graph as described above. It captures who interacts with whom, how, when, and through what. This model powers health metrics — bridge detection, fragmentation risk, newcomer integration, participation concentration.

The graph is temporal. You can query it at any point in time, compare windows, and detect structural changes: clusters forming, bridges weakening, newcomers integrating or dropping off.

A model of community communication patterns — not a chatbot, but an analytical layer. It captures style features (formality, tone, linguistic accommodation), discourse structure (how threads develop, where conversations stall or escalate), and topic-agnostic health predictors (conversational patterns that correlate with retention, satisfaction, or conflict regardless of subject matter).

This model draws on research into linguistic style matching and conversational structure as signals of community health.

A research knowledge graph built using GraphRAG patterns. It stores the community’s norms, decision logs, and the research corpus that grounds Communitas’s recommendations. The knowledge model connects papers to claims, claims to methods, methods to interventions, and interventions to outcomes.

When the system suggests an intervention, the knowledge model provides the citation trail: what evidence supports it, what mechanism it relies on, and where the evidence is weak or context-dependent.


These three models work together. The community graph tells you what’s happening structurally. The language model tells you what’s happening conversationally. The knowledge model tells you what the research says about what you’re seeing — and what to try next.