How to contribute

You can contribute to the tool by adding support for a ledger, updating the mapping process for an existing ledger, or adding a new metric. In all cases, the information should be submitted via a GitHub PR.

Add support for ledgers

You can add support for a ledger that is not already supported as follows.

Mapping information

In the directory mapping_information/, there exist two folders: addresses and special_addresses.

addresses contains information about the owner or manager of an address. This information should be publicly available and verifiable, for example it may come from a public explorer, social media or forum posts, articles, etc. Each file in this folder is named <project_name>.jsonl (for the corresponding ledger) and contains a dictionary per line with the following information: (i) the address; (ii) the name of the entity (that controls the address); (iii) the source of the information (e.g., an explorer's URL); (iv) (optional) a boolean value is_contract (if omitted then it is assumed false); (v) (optional) extra_info that might be relevant or interesting (not used for the analysis).

special_addresses contains information about addresses that should be treated specially, e.g., excluded from the analysis. This includes burn addresses, protocol-related addresses (e.g., Ethereum's staking contract), treasury addresses, etc. Here each file is named <project_name>.json and contains a list of dictionaries with the following information: (i) the address; (ii) the source of the information; (iii) extra_info which describes the reason why the address is special.

To contribute mapping information you can either update an existing file, by changing and/or adding some entries, or create a new file for a newly-supported ledger.

Note: If you add an entry in mapping_addresses with a source that does not already exist, you should also add this source in the file mapping_information/sources.json. Specifically, if it comes from a publicly-available website you should add it under "Explorers", otherwise either use an existing appropriate keyword or create a new one. If you create a new one, make sure to also include it in the configuration file config.yaml and in the description of the Setup page).

Price information

The directory price_data/ contains information about the supported ledgers' market price. Each file in this folder is named <ledger>-USD.csv (for the corresponding ledger). The csv file has no header and each line contains two comma-separated values: (i) a day (in the form YYYY-MM-DD); (ii) the USD market price of the token on the set day (specifically its opening price).

All price information is currently obtained from CoinGecko.

To contribute price information you can either update an existing file, by adding entries for days where data is missing, or create a new file for a newly-supported ledger and add historical price data.

Add metrics

To add a new metric, you should do the following steps.

First, create a relevant function in the script tokenomics_decentralization/metrics.py. The function should be named compute_{metric_name} and is given two parameters: (i) a list of tuples, where each tuple's first value is a numeric type that defines the balance of an address; (ii) an integer that defines the circulation (that is the sum of all address balances).

Second, import this new function to tokenomics_decentralization/analyze.py. In this file, include the function as the value to the dictionary compute_functions of the analyze_snapshot function, using as a key the name of the function (which will be used in the config file).

Third, add the name of the metric (which was used as the key to the dictionary in analyze.py) to the file config.yaml under metrics. You can optionally also add it under the plot parameters, if you want it to be included in the plots by default.

Finally, you should add unit tests for the new metric here and update the corresponding documentation page