ConvoKit is constantly growing, and we welcome outside contributions of all kinds, whether in the form of new datasets, code changes, or bug reports and suggestions for new features. This document details some of the ways in which you can lend a hand.
Please use the GitHub issue tracker to report any problems you encounter while using the toolkit. To help us find a fix faster, we ask that include the following details in your report:
- Steps to reproduce the error (this can be in written form, or you can provide a code snippet)
- Specifications of the system you were using when you encountered the error. Most importantly, provide your OS, Python version, and type of python installation (system-provided, downloaded from Python.org, or Anaconda)
- The name of the dataset you were using when encountering the error. If you were using a custom dataset, provide a link to it if possible (this includes the case where you have modified one of the provided datasets)
Feature requests and/or suggestions can also be submitted through the GitHub issue tracker; please use the "enhancement" tag when doing so. Keep in mind however that we may not be able to respond to all requests.
If you want to contribute directly to the toolkit, one way of doing so that doesn't require extensive coding knowledge is to supply new datasets for inclusion in the next release. ConvoKit provides methods for converting raw conversation data into its own Corpus format; see the example script for a walkthrough of how to do this.
Once you have created a Corpus representation of your dataset, follow these steps to request its inclusion in ConvoKit:
- Use
Corpus.dump()
to write the Corpus to disk - Locate the resulting folder and compress it into a zip file
- Open a new issue on GitHub with the "dataset" tag
- Include the following information in the issue: the name of the dataset, a brief description, licensing information, contact information (for acknowledgement purposes), and a way to access the zipped corpus itself (you can either upload the file to a public file-sharing website and provide the URL, or include the file as an attachment in the issue)
- (Optional, but recommended): Also tell us some statistics about your dataset (e.g., number of conversations and participants) that we can use to advertise it!
- (Optional, but recommended): You may also include an example script or Jupyter notebook demonstrating the use of the dataset. We will then include this in our examples directory.
If we decide to accept your dataset contribution, we will notify you on the submitted issue, and upon the next public release you will be able to access the dataset through convokit.download()
!
NOTE: the "datasets" issue tag should only be used for submitting completed datasets. Requests for new datasets should instead be submitted following the procedure for feature requests described in the previous section.
In general, code contributions will take one of 3 different forms:
- Edits to existing functions/classes to fix a bug or implement new behavior (possibly in response to an open issue)
- Changes to the core ConvoKit object model hierarchy (currently found in
model.py
) - A new module implementing some new conversational analysis behavior
There are a number of guidelines that contributors should follow for all types of code contributions, which will be listed below. There are also particular guidelines for implementing new modules, which we will cover at the end
Please ensure that your contributions adhere to the existing coding style used throughout the codebase, as we do want to maintain some level of consistency. Specific guidelines that should be followed include:
- Use 4 spaces (not tabs) for indentation
- Classes should be named in CamelCase, starting with an uppercase letter
- Functions and variables should be named in snake_case and should avoid uppercase letters (exceptions may be made for names that are acronyms, but only if this is done to be consistent with some preexisting literature)
Please ensure that all contributions have been tested for integration with existing ConvoKit code. This is particularly pertinent for contributions that make changes to existing functions or modules. At the moment, the best way to do this is to run the example scripts and notebooks in the examples directory and ensure that the output is either unchanged, or that any changes are consistent with your intentions. In the future, we hope to incorporate a unit testing framework to formalize this process.
All code changes should be fully documented. New public-facing classes or functions should have top-level docstrings written in Sphinx/RST syntax. If your contribution involves adding a new file, please make a corresponding RST file in the docs directory.
In addition to the above guidelines, there are also specific rules to be followed if your contribution involves a new module. They are as follows:
- What kinds of things belong in a new module?: In general, a ConvoKit module implements some specific operation that can be done on a conversation or set of conversations. More often than not, these are implementations of techniques introduced in research papers from the fields of natural language processing or computational social science. For example, the Hyperconvo module implements conversational graph features introduced in the paper Characterizing Online Public Discussions through Patterns of Participant Interactions. As a general rule, a new module should provide functionality that is standalone and not derivative of functionality that exists elsewhere in the toolkit. For example, if a paper comes out that introduces a new set of linguistic features representing politeness, and you want to implement this in ConvoKit, most likely you should implement the features as a change to the existing PolitenessStrategies module, not as a new module.
- New modules go in their own file: New modules should have their own dedicated files; you should not implement you module inside an already existing file even if you think the functionality is conceptually related.
- New modules should follow the Transformer API: The main idea behind ConvoKit is to provide a single unified object model and API for the many conversational analysis methods that have been devised over the years. In keeping with this goal, all new modules should implement the Transformer API. From a coding perspective, this consists simply of making sure your class inherits from Transformer, and implementing the core functionality in
fit
andtransform
. We are aware that the Transformer model is not the optimal interface for all techniques, but our main goal is ease of use, and this goal is well-served by having all modules look the same. - New modules should come with at least one example script: When submitting a new module, please also include at least one example script or Jupyter notebook that demonstrates how to use it. This script or notebook should be documented in a way that a newcomer can use it as a tutorial to learn how to use your new module. The presence of an example script for every module also serves as a way to ensure test coverage.
Once you have ensured that your changes are consistent with the above criteria, you can submit a pull request! In the pull request, please provide a description of the changes that it makes, a brief justification of the change, any expected changes in output to existing example/test scripts, and (if applicable) a link to the issue or feature request that the change responds to.
Thanks for your interest in contributing to ConvoKit!