This document holds all teams in the DeepModeling projects and defines the governance policies of the teams.
Teams are groups that focus on individual parts of the DeepModeling projects. A team has its reviewer, committer, maintainer, and owns one or more repositories. Maintainers are responsible for team-level decision making.
The Technical Oversight Committee (TOC) is in charge of team creation, retirement, and arbitrates divergence between teams.
The current list of Team is as below.
Team | Team Leader | Team Projects | Maintainers |
---|---|---|---|
MD | Han Wang, Kuang Yu | DeePMD-kit, DP-GEN, DPdispatcher, DMFF | Jinzhe Zeng, Yuzhi Zhang, Denghui Lu, Fengbo Yuan, Yixiao Chen, Xinyan Wang, Yingze Wang, Jichen Li |
DFT | Mohan Chen | ABACUS, DeePKS | Daye Zheng, WenFei Li, Qi Ou, Tianqi Zhao, Xingliang Peng, Chun Cai, Yixiao Chen |
Combustion | Zhi Chen | DeepFlame | Tianhan Zhang, Zhiqin Xv, Runze Mao |
workflow | Xinzijian Liu | dflow | |
FEM | Huayi Wei | FEALPY | Chunyu Chen, Pengxiang Wang, Dong Wang, Tian Tian, Wei Wang |
Reviewers are individuals who actively make contributions and are willing to participate in the code review of new contributions. We identify reviewers from active contributors. The committers should explicitly solicit reviews from reviewers. High-quality code reviews prevent technical debt for the long term and are crucial to the success of the project. A pull request to the project has to be reviewed by at least one reviewer to be merged.
Access to review is by invitation only and must be approved by the consensus of the maintainers. By his/her/their declaration, a reviewer is considered emeritus. An emeritus reviewer may request reinstatement of review access from the maintainers, which will be sufficient to restore him or her to active reviewer status.
Review access can be revoked by consensus by the maintainers.
Committers are individuals who grant write access to the repositories that belong to the team. A committer is usually responsible for a certain area or several areas of the code where they oversee the code review process. The area of contribution can take all forms, including code contributions and code reviews, documents, education, and outreach. Committers are essential for high quality and healthy projects. Commit access is by invitation only and must be approved by the consensus of the maintainers. A committer is considered emeritus by their declaration. An emeritus committer may request reinstatement of commit access from the maintainers, which will be sufficient to restore him or her to active committer status. Commit access can be revoked by consensus by the maintainers.
The maintainers consist of a group of active committers that moderate the discussion, manage the project release, and propose new committers or maintainers. Potential candidates are usually proposed via an internal discussion among maintainers, followed by a consensus approval, i.e. a concrete number of approvals, and no vetoes. Any veto must be accompanied by reasoning. Maintainers should serve the community by upholding the community practices and guidelines DeepModeling a better community for everyone. Maintainers should nominate new reviewers, committers and maintainers, and should also strive to only nominate new candidates outside of their organization.
Membership of the maintainers is by invitation only and must be approved by a consensus of the maintainers. A maintainer is considered emeritus by their declaration. An emeritus member may request reinstatement to the maintainers, which will be sufficient to restore him or her to active maintainers. Membership of the maintainers can be revoked by a consensus vote of all the maintainers other than the member in question. Maintainers have the final decision right of the technical solutions to their projects.
Within the teams, different types of decisions require different forms of approvals. For example, the previous section describes decisions that require 'lazy consensus' approval. This section defines how voting is performed, the types of approvals, and which types of decisions require which type of approval.
Decisions regarding the community are made by votes on the community repository. Votes are indicated by pull requests adding an entry under the "votes" folder. Votes may contain multiple items for approval and these should be separated. Voting is carried out by replying to the vote pull request.
Voting must be open for at least 2 days, and the deadline should be clearly stated in the call to vote.
Voting may take three flavours:
- +1: 'Yes,' 'Agree,' or 'the action should be performed.'
- 0: Neutral about the proposed action (or mildly negative but not enough so to want to block it).
- -1: This is a negative vote. On issues where consensus is required, this vote counts as a veto. All vetoes must contain an explanation of why the veto is appropriate. Vetoes with no explanation are void. It may also be appropriate for a -1 vote to include an alternative course of action.
All participants in the DeepModeling community are encouraged to show their agreement or disagreement towards a particular action by voting. But only the votes of TOC members are binding. Non-binding votes are still useful for those with binding votes to understand the perception of an action in the wider community.
Only active (i.e. non-emeritus) TOC members have binding votes.
These are three types of approvals that can be sought. Different actions require different types of approvals.
- Consensus: Consensus requires 2 binding +1 votes and no binding vetoes.
- Lazy Majority: A lazy majority vote requires 2 binding +1 votes and more binding +1 votes than -1 votes.
- 2/3 Majority: Some actions require a 2/3 majority to pass. Such actions typically affect the foundation of the project (e.g. adopting a new codebase). The higher threshold is designed to ensure such changes are strongly supported. To pass this vote requires at least 2/3 of binding vote holders to vote +1.
To address the case of insufficient active binding voters to reach a 2/3 majority, one can follow the process below to exclude a binding vote from the counting of this particular voting thread.
- Wait until the minimum length of the voting passes.
- Publicly reach out via mentioned to the remaining binding voters in the voting pull request for at least 2 attempts with at least 7 days between two attempts.
- If the binding voter being contacted still failed to respond after all the attempts, the binding voter will be considered inactive for this particular voting.
A valid, binding veto cannot be overruled. If a veto is a cast, it must be accompanied by a valid reason explaining the reasons for the veto. The validity of a veto, if challenged, can be confirmed by anyone who has a binding vote. This does not necessarily signify agreement with the veto - merely that the veto is valid.
If you disagree with a valid veto, you must lobby the person casting the veto to withdraw their veto. If a veto is not withdrawn, the action that has been vetoed must be reversed promptly.
Actions | Description | Approval | Binding Voters | Minimum Length (days) |
---|---|---|---|---|
New Reviewer | When a new reviewer is proposed for the team, should be only nominated by a committer. | Lazy Majority | Active maintainers | 3 |
New Committer | When a new committer is proposed for the team, should be only nominated by a maintainer. | Consensus | Active maintainers | 6 |
New Maintainer | When a new maintainer is proposed for the team, should be only nominated by a maintainer. | Consensus | Active maintainers | 6 |
Reviewer Removal | When removal of review privileges is sought. | Consensus | Active maintainers | 6 |
Committer Removal | When removal of commit privileges is sought. | Consensus | Active maintainers | 6 |
Maintainer Removal | When removal of maintain privileges is sought. | Consensus | Active maintainers | 6 |