File: governance.rst

package info (click to toggle)
python-mne 1.9.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 131,492 kB
  • sloc: python: 213,302; javascript: 12,910; sh: 447; makefile: 144
file content (378 lines) | stat: -rw-r--r-- 17,412 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
.. _governance:

==================
Project Governance
==================

The purpose of this document is to formalize the governance process
used by the MNE-Python project in both ordinary and extraordinary
situations, and to clarify how decisions are made and how the various
elements of our community interact, including the relationship between
open source collaborative development and work that may be funded by
for-profit or non-profit entities.

The Project
===========

The MNE-Python Project (The Project) is an open source software project. The
goal of The Project is to develop open source software for analysis of
neuroscience data in Python. The Project is released under the BSD (or similar)
open source license, developed openly and is hosted publicly under the
``mne-tools`` GitHub organization.

The Project is developed by a team of distributed developers, called
Contributors. Contributors are individuals who have contributed code,
documentation, designs, or other work to the Project. Anyone can be a
Contributor. Contributors can be affiliated with any legal entity or
none. Contributors participate in the project by submitting, reviewing,
and discussing GitHub Pull Requests and Issues and participating in open
and public Project discussions on GitHub, Discourse, and other
channels. The foundation of Project participation is openness and
transparency.

The Project Community consists of all Contributors and Users of the
Project. Contributors work on behalf of and are responsible to the
larger Project Community and we strive to keep the barrier between
Contributors and Users as low as possible.

The Project is not a legal entity, nor does it currently have any formal
relationships with legal entities.

Governance Model
================

.. _leadership-roles:

Leadership Roles
^^^^^^^^^^^^^^^^

The MNE-Python leadership structure shall consist of:

Maintainer Team
---------------

The Maintainer Team is responsible for implementing changes to the software and
supporting the user community. Duties:

- Infrastructure/large-scale software decisions, in partnership with the Steering
  Council
- Reviewing and merging pull requests
- Responding to issues on GitHub
- Monitoring CI failures and addressing them
- Community maintenance: answering forum posts, holding office hours
- Community information: social media announcements (releases, new features, etc)
- Training new members of the Maintainer Team

*Note:* different permissions may be given to each maintainer based on the work they do
(e.g., GitHub repository triage/merge/admin permissions, social media account access,
Discord admin roles, forum admin rights). The role of maintainer does not confer these
automatically.

Steering Council
----------------

The Steering Council is responsible for guiding and shepherding the project on a
day-to-day basis. Duties:

- Obtaining funding (either by writing grants specifically for MNE development, or
  convincing others to include funds for MNE development in their research grants)
- Translating high-level roadmap guidance from the Advisory Board (e.g. “better support
  for OPMs”) into actionable roadmap items (e.g., “Add support for OPM manufacturers
  besides QuSpin, and add standard preprocessing routines for coreg and OPM-specific
  artifacts”)
- Coordination with the larger Scientific Python ecosystem
- Large-scale changes to the software (e.g., type hints, docdict, things that affect
  multiple submodules), in partnership with the Maintainer Team
- Infrastructure decisions (e.g., dependency version policy, release cadence, CI
  management, etc), in partnership with the Maintainer Team
- Any other governance task not mentioned elsewhere, and that falls outside of the
  responsibilities of other teams
- Attendance at Steering Council meetings (approx. every 2 weeks; time to be decided
  among SC members)
- Attendance at Advisory Board meetings (approx. every 1-2 years)
- Write funding proposals
- Communicate/coordinate with Maintainer Team

Members of the Steering Council shall additionally be considered as members of the
Maintainer Team, *ex officio*, and thus shall have the necessary rights and privileges
afforded to maintainers (passwords, merge rights, etc).

Chair of the Steering Council
-----------------------------

The Chair of the Steering Council is responsible for liaising between the Steering
Council and the community. Duties:

- Convening the Steering Council meetings
- Calling for votes when consensus fails
- Communicating important decisions (and the context for why those decisions were
  taken) to the community

External Advisory Board
-----------------------

The External Advisory Board is responsible for high-level roadmap and funding
guidance. Duties:

- Attendance at Advisory Board meetings (approx. every 1-2 years)
- Periodically communicating with Steering Council to impart guidance

Meetings
^^^^^^^^

Maintainer Meetings
-------------------

The Maintainer Team can decide if there should be maintainer meetings or not. These
could be either discussion meetings or social meetings to keep in touch with each other
(or something completely different!). Frequency and time could vary.

Steering Council Meetings
-------------------------

The Steering Council will have mandatory meetings every two weeks to discuss project
management and funding. The Steering Council may decide to change meeting time or
frequency at their discretion.

All-hands Meetings
------------------

At least once a year, all maintainers and Steering Council members should come together
in a (possibly virtual) meeting. Meeting time will be determined via poll. During this
meeting, any governance changes proposed since the prior meeting shall be discussed and
may be adopted by vote.

Population of Leadership Roles
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Maintainer Team
---------------

Appointment
~~~~~~~~~~~

- Once per year, before the annual all-hands meeting, the Maintainer Team shall assess
  their anticipated needs for the coming year. During the meeting, they shall decide how
  many new maintainers they want to add to their team. New maintainers are selected from
  applications by a vote of the currently-serving maintainers and the Steering Council.
- Ad-hoc additions are possible by initiative of the Steering Council for exceptional
  circumstances, e.g., hiring someone with grant funds to specifically do MNE
  maintenance. These ad-hoc additions do not necessarily require a vote from the
  Maintainer Team, as the job application procedures of the hiring institution are
  assumed to be sufficiently rigorous to avoid bias, nepotism, etc.

Duration of service
~~~~~~~~~~~~~~~~~~~

Appointment to the Maintainer Team is for an indefinite term.

Termination
~~~~~~~~~~~

Loss of maintainer status (and revocation of associated rights and
privileges, e.g., passwords, merge rights, etc) can occur under the following
circumstances:

- *Voluntary resignation*, at any time, for any reason.
- *Inactivity*. Once per year, before the annual all-hands meeting, the Steering Council
  shall assess maintainer activity for the preceding year. Any maintainers seeming to be
  inactive shall be contacted and given opportunity to dispute their inactivity (e.g.,
  by highlighting ways they have been working in the MNE community that may not be
  visible from simple metrics like GitHub or forum activity reports). Maintainers who do
  not dispute their inactivity (or fail to respond within 14 days, or longer at the
  discretion of the Steering Council) shall be removed from the Maintainer Team. In
  cases where the Steering Council and the maintainer still disagree about the alleged
  inactivity, removal may still occur by a two-thirds majority vote of the rest of the
  Maintainer Team.
- *Conduct*. At any time, a maintainer may be removed by unanimous vote of the
  code-of-conduct committee, for violations of our community guidelines (in accordance
  with the enforcement guidelines outlined therein).

*Reinstatement*. Maintainers who voluntarily resigned may be re-appointed on an ad-hoc
basis by a vote of the current Maintainer Team. Maintainers removed for inactivity may
re-apply to an annual call for new maintainers. Maintainers removed for reasons of
conduct may be reinstated only if their eligibility is allowed/restored by the
code-of-conduct committee in accordance with the enforcement section of our Community
Guidelines. In such cases the re-eligible former maintainer may re-apply through the
annual appointment process.

Steering Council
----------------

Appointment
~~~~~~~~~~~
A term on the Steering Council shall last approximately 2 years. Terms shall be
staggered such that no more than half of the seats shall be open for election in any
given year. Upon first constitution, the Steering Council decides which 50% of the
members shall be granted an initial three year term to initiate the staggering.

The Maintainer Team and current Steering Council will vote to fill the open seats on the
Steering Council. Candidates can be (self-)nominated from the current Maintainer Team
and Steering Council.

At any time, the Steering Council may increase the number of seats on the Council to
adapt to the Council’s workload and needs. New seats shall be filled in the same manner
as normal (re-)elections, i.e., by vote open to all members of the Maintainer Team and
Steering Council. Term length shall be set so as to maintain the 50/50 balance of
staggered re-election cycles as nearly as possible, and in cases where perfect balance
already exists, the term shall err towards being *longer*.

In the case of vacancies due to termination (see below), the Steering Council may call a
special election (following the same procedures as in a normal (re-)election), or may
choose to wait to fill the seat until the next scheduled election. For filled vacancies,
the term shall be the balance of the unserved term of the person vacating the seat,
unless the remaining time after the vacancy-filling election is 6 months or shorter, in
which case the term shall be for 2 years plus the remaining time on the vacant seat.

Termination
~~~~~~~~~~~

Loss of Steering Council status (and revocation of associated rights and privileges,
e.g., passwords, merge rights, etc) can occur under the following circumstances:

- *Voluntary resignation*, at any time, for any reason.
- *Conduct*. At any time, a member of the Steering Council may be removed by unanimous
  vote of the code-of-conduct committee, for violations of our community guidelines (in
  accordance with the enforcement guidelines outlined therein).

External Advisory Board
-----------------------

The External Advisory Board shall be populated by invitation from the Steering Council.
Anyone may propose individuals for potential invitation. Appointment and removal from
the External Advisory Board is determined by the Steering Council.

Decision Making Process
^^^^^^^^^^^^^^^^^^^^^^^

Announcement of Elections
-------------------------

All votes shall be open for at least ten days and shall be announced 14 days in advance
to all eligible voters by email. The voting deadline shall also be added to the core
team’s shared Google calendar. At least one reminder shall be sent out half-way through
the voting period.

Voting Mechanism
----------------

All elections shall be held as anonymous online votes using ElectionBuddy or a similar
service. Unless otherwise specified the mechanism shall be
`ranked choice voting <https://en.wikipedia.org/wiki/Instant-runoff_voting>`__
with a threshold of 50% + 1 vote. That means, everyone ranks those candidates (in order
of preference) that they could see filling the role in question. Note that it is
possible for a voter to reject all candidates by submitting a blank ballot, so that if a
single person is running for a seat it is still possible for them to fail to be elected
if enough voters cast blank ballots.

Voting for the Steering Council
-------------------------------

Votes for Steering Council membership shall be scheduled as-needed to address Steering
Council workload, and advertised to eligible candidates (i.e., the Maintainer Team) for
a minimum of 14 days, after which a vote of current maintainers and Steering Council
members shall be scheduled.

Voting for the Maintainer Team
------------------------------

Votes for additions to the Maintainer Team shall be scheduled promptly following the
annual all-hands meeting. The Maintainer Team shall advertise the open seats via online
MNE-Python channels. Applications (consisting of a short candidate statement) must be
open for a minimum of 14 days, after which a vote of the current maintainers and
Steering Council shall be scheduled. The Maintainer Team shall set up a confidential
submission system for applications (consisting of short candidate statements), such as a
dedicated email address, Google form, or similar confidential submission mechanism.

Institutional Partners and Funding
==================================

The leadership roles for the project are :ref:`defined above <leadership-roles>`. No
outside institution, individual, or legal entity has the ability to own,
control, usurp, or influence the project other than by participating in
the Project in one of those roles. However, because
institutions can be an important funding mechanism for the project, it
is important to formally acknowledge institutional participation in the
project. These are Institutional Partners.

An Institutional Contributor is any individual Project Contributor who
contributes to the project as part of their official duties at an
Institutional Partner. Likewise, an Institutional Project Leader is anyone
in a Project leadership role who contributes to the project as part
of their official duties at an Institutional Partner.

With these definitions, an Institutional Partner is any recognized legal
entity in any country that employs at least 1 Institutional Contributor or
Institutional Project Leader. Institutional Partners can be for-profit or
non-profit entities.

Institutions become eligible to become an Institutional Partner by
employing individuals who actively contribute to The Project as part of
their official duties. To state this another way, the only way for a
Partner to influence the project is by actively contributing to the open
development of the project, in equal terms to any other member of the
community of Contributors and Leaders. Merely using Project
Software in institutional context does not allow an entity to become an
Institutional Partner. Financial gifts do not enable an entity to become
an Institutional Partner. Once an institution becomes eligible for
Institutional Partnership, the Steering Council must nominate and
approve the Partnership.

If, at some point, an existing Institutional Partner stops having any
contributing employees, then a one year grace period commences. If, at
the end of this one-year period, they continue not to have any
contributing employees, then their Institutional Partnership will
lapse, and resuming it will require going through the normal process
for new Partnerships.

An Institutional Partner is free to pursue funding for their work on The
Project through any legal means. This could involve a non-profit
organization raising money from private foundations and donors or a
for-profit company building proprietary products and services that
leverage Project Software and Services. Funding acquired by
Institutional Partners to work on The Project is called Institutional
Funding. However, no funding obtained by an Institutional Partner can
override Project Leadership. If a Partner has funding to do MNE-Python work
and the Project Leadership decides to not pursue that work as a project, the
Partner is free to pursue it on their own. However, in this situation,
that part of the Partner’s work will not be under the MNE-Python umbrella and
cannot use the Project trademarks in any way that suggests a formal
relationship.

Institutional Partner benefits are:

- optional acknowledgement on the MNE-Python website and in talks
- ability to acknowledge their own funding sources on the MNE-Python
  website and in talks
- ability to influence the project through the participation of their
  Institutional Contributors and Institutional Project Leaders.
- invitation of the Council Members to MNE-Python Developer Meetings

A list of current Institutional Partners is maintained at the page
:ref:`supporting-institutions`.

Document History
================

https://github.com/mne-tools/mne-python/commits/main/doc/overview/governance.rst


Acknowledgements
================

Substantial portions of this document were adapted from the
`SciPy project's governance document
<https://github.com/scipy/scipy/blob/main/doc/source/dev/governance.rst>`_,
which in turn was adapted from
`Jupyter/IPython project's governance document
<https://github.com/jupyter/governance/blob/main/archive/governance.md>`_ and
`NumPy's governance document
<https://github.com/numpy/numpy/blob/master/doc/source/dev/governance/governance.rst>`_.

License
=======

To the extent possible under law, the authors have waived all
copyright and related or neighboring rights to the MNE-Python project
governance document, as per the `CC-0 public domain dedication / license
<https://creativecommons.org/publicdomain/zero/1.0/>`_.