Skip to main content

贡献者里程模型

贡献者可能基于上下游生态利益或个人发展等原因与开源项目产生共鸣,并进入社区参与贡献。他们可能长期留在社区,逐渐淡出,甚至再次被唤醒。基于这些情况,我们定义了贡献者在社区中的多种状态,构成了里程画像。这个模型受到状态机的启发,每个状态之间可以相互迁移,而贡献者同时只能处于一种状态。这样做可以确保行为的解耦,更有利于观察贡献者在社区中的行为。

image

我们根据贡献者在社区的贡献量、贡献频率、贡献类型以及他们的状态,将贡献者里程在考虑时间周期的同时,划分为如上 5 种状态:无状态、访客、常客、核心以及静默。以年度为例,这里给出五种状态的定义:

  • 核心: 指贡献者在本年度完成了所有领域贡献的 50%(不包括观察者类贡献,如 star、fork、watch)。这些贡献由最少得一组人完成,该组人被称为核心贡献者。所有领域贡献不进行加权处理,只统计次数。
  • 常客:排除核心贡献者所贡献的 50%之后,接下来的 30%贡献(不包括观察者类贡献,如 star、fork、watch),由至少一组人完成。这些人及在本年度中至少参与了 9 个月的贡献,被称为常客贡献者。
  • 访客:排除核心、常客贡献后,参与社区剩余贡献的人(包含观察者类贡献,即 star、fork、watch),称之为访客。
  • 静默:本年度之前活跃的核心、常客或者访客,本年度没有任何贡献的人。
  • 无状态:从未在本社区做出贡献的人。

评估模型中的指标

核心贡献者数量

  • 定义:在过去 90 天内有多少活跃的核心贡献者数量。
  • 权重:20%
  • 阈值:20

核心贡献次数

  • 定义:在过去 90 天内活跃核心贡献者的人均贡献次数。
  • 权重:30%
  • 阈值:200

常客贡献者数量

  • 定义:在过去 90 天内有多少活跃的常客贡献者数量。
  • 权重:12%
  • 阈值:100

常客贡献次数

  • 定义:在过去 90 天内活跃常客贡献者的人均贡献次数。
  • 权重:18%
  • 阈值:25

访客贡献者数量

  • 定义:在过去 90 天内有多少活跃的访客贡献者数量。
  • 权重:8%
  • 阈值:2000

访客贡献次数

  • 定义:在过去 90 天内活跃访客贡献者的人均贡献次数。
  • 权重:12%
  • 阈值:5

评估模型算法

权重

我们使用 AHP 来计算每个指标的权重。

AHP 输入数据

指标名称核心贡献者数量核心贡献次数常客贡献者数量常客贡献次数访客贡献者数量访客贡献次数
核心贡献者数量1.0000.6671.6671.1112.5001.667
核心贡献次数1.5001.0002.5001.6673.7502.500
常客贡献者数量0.6000.4001.0000.6671.5001.000
常客贡献次数0.9000.6001.5001.0002.2501.500
访客贡献者数量0.4000.2670.6670.4441.0000.667
访客贡献次数0.6000.4001.0000.6671.5001.000

AHP 分析结果

指标名称特征向量权重
核心贡献者数量1.20020.000%
核心贡献次数1.80030.000%
常客贡献者数量0.72012.000%
常客贡献次数1.08018.000%
访客贡献者数量0.4808.000%
访客贡献次数0.72012.000%

一致性检验结果

最大特征根CI 值RI 值CR 值一致性检验结果
6.0000.0001.2600.000PASS

阈值

我们选择的阈值是基于不同类型开源项目的大数据观测。

参考文献

贡献者

前端

  • Shengxiang Zhang
  • Feng Zhong
  • Xingyou Lai

后端

  • Yehui Wang
  • Shengxiang Zhang
  • Shengbao Li
  • Huatian Qin

评估模型

  • Yehui Wang
  • Liang Wang
  • Shengbao Li

Copyright © 2022 开源指南针。保留所有权利。