Website · Installation · Dashboard · Twitter · Bittensor · Hugging Face
Table of contents
What is Bittensor?
Bittensor is a mining network, similar to Bitcoin, that includes built-in incentives designed to encourage computers to provide access to machine learning models in an efficient and censorship-resistant manner. Bittensor is comprised of Subnets, Miners, and Validators.
Explain Like I'm Five
Bittensor is an API that connects machine learning models and incentivizes correctness through the power of the blockchain.
Subnets are decentralized networks of machines that collaborate to train and serve machine learning models.
Miners run machine learning models. They fulfill requests from the Validators.
Validators query and prompt the Miners. Validators also validate miner requests. Validators are also storefronts for data.
This repository contains the code for the Time-Series Prediction Subnet (TSPS) developed by Taoshi.
Initially, the primary focus of TSPS is to forecast the future trends of financial markets, starting with predicting the price movements of Bitcoin. Eventually, TSPS will expand to include a broader range of cryptocurrency trading pairs. Subsequently, our scope will broaden to encompass additional financial markets.
As the project evolves, we anticipate that miners will diversify their focus, specializing in different subjects or domains. Some may concentrate on specific areas, while others, particularly those with advanced skills, tackle multiple topics, such as sports betting or various client-requested issues.
🛠️ Open Source Modeling
🫰 Intraday Bitcoin Predictions
📈 Higher Payouts
📉 Lower Registration Fees
💪 Superior Cryptocurrency Infrastructure
⚡ Faster Payouts
- Requires Python 3.10 or higher.
- Bittensor
Below are the prerequisites for validators and miners, you may be able to make miner and validator work off lesser specs.
Validator
- 2 vCPU + 8 GB memory
- 100 GB balanced persistent disk
Miner
- 2 vCPU + 8 GB memory
- Run the miner using CPU
To install TSPS, first install the dependencies:
On Linux:
# install git
$ sudo apt install git-all
# install pip package manager for python 3
$ sudo apt install python3-pip
# install venv virtual environment package for python 3
$ sudo apt-get install python3-venv
On MacOS:
# git should already be installed
# install python3 with homebrew
$ brew install python3
Then, install TSPS:
# clone repo
$ git clone https://github.com/taoshidev/time-series-prediction-subnet.git
# change directory
$ cd time-series-prediction-subnet
# create virtual environment
$ python3 -m venv venv
# activate the virtual environment
$ . venv/bin/activate
# disable pip cache
$ export PIP_NO_CACHE_DIR=1
# install dependencies
$ pip install -r requirements.txt
# create a local and editable installation
$ python3 -m pip install -e .
Your validator will request predictions hourly based on your randomized interval to help distribute the load. After live results come 10 hours
after predictions, rewards will be distributed.
These validators run and update themselves automatically.
To run a validator, follow these steps:
-
Install PM2 and the jq package on your system.
On Linux:
# update lists $ sudo apt update # JSON-processor $ sudo apt install jq # install npm $ sudo apt install npm # install pm2 globally $ sudo npm install pm2 -g # update pm2 process list $ pm2 update
On MacOS:
# update lists $ brew update # JSON-processor $ brew install jq # install npm $ brew install npm # install pm2 globally $ sudo npm install pm2 -g # update pm2 process list $ pm2 update
-
Be sure to install venv for the repo.
# from within the TSPS repo # create virtual environment $ python3 -m venv venv # activate virtual environment $ source venv/bin/activate # install packages $ pip install -r requirements.txt
-
Run the
run.sh
script, which will run your validator and pull the latest updates as they are issued.$ pm2 start run.sh --name sn8 -- --wallet.name <wallet> --wallet.hotkey <hotkey> --netuid 8
This will run two PM2 process:
- A process for the validator, called sn8 by default (you can change this in run.sh)
- And a process for the run.sh script (in step 4, we named it tsps). The script will check for updates every 30 minutes, if there is an update, it will pull, install, restart tsps, and restart itself.
If there are any issues with the run script or you choose not to use it, run a validator manually.
$ python neurons/validator.py --netuid 8 --wallet.name <wallet> --wallet.hotkey <hotkey>
You can also run your script in the background. Logs are stored in nohup.out
.
$ nohup python neurons/validator.py --netuid 8 --wallet.name <wallet> --wallet.hotkey <hotkey> &
If you're running a miner, you should see two types of requests: LiveForward and LiveBackward. LiveForward will be when your miner performs predictions; LiveBackward will receive the results that occurred live if you want to use them for any updating purposes.
You'll receive rewards for your predictions ~10 hours
after making them. Therefore, if you start running on the network, you should expect a lag in receiving rewards. Predictions are reviewed and rewarded every 30 minutes.
In the short term, your miner will not be trained on the network (TrainingBackward and TrainingForward will only run sometimes). Please train beforehand as we'll only be using BTC/USD on the 5m to begin, which you can prepare for.
IMPORTANT
Before attempting to register on mainnet, we strongly recommend that you:
- First run Running Subnet Locally.
- Then run Running on the Testnet.
Your incentive mechanisms running on the mainnet are open to anyone. They emit real TAO. Creating these mechanisms incur a lock_cost
in TAO.
DANGER
- Do not expose your private keys.
- Only use your testnet wallet.
- Do not reuse the password of your mainnet wallet.
- Make sure your incentive mechanism is resistant to abuse.
-
Clone and install the TSPS source code.
-
(Optional) Register your validator and miner keys to the networks.
Note: While not enforced, we recommend owners run a validator and miner on the network to display proper use to the community.
Register your miner keys to the network, giving them the first two slots.
$ btcli subnet register --wallet.name miner --wallet.hotkey default
Follow the below prompts:
>> Enter netuid [1] (8): # Enter netuid 8 to specify the network you just created. >> Continue Registration? hotkey: ... coldkey: ... network: finney [y/n]: # Select yes (y) >> ⠦ 📡 Submitting POW... >> ✅ Registered
-
Check that your subnet validator key has been registered:
$ btcli wallet overview --wallet.name minor
Check that your miner has been registered.
COLDKEY HOTKEY UID ACTIVE STAKE(τ) RANK TRUST CONSENSUS INCENTIVE DIVIDENDS EMISSION(ρ) VTRUST VPERMIT UPDATED AXON HOTKEY_SS58 miner default 1 True 0.00000 0.00000 0.00000 0.00000 0.00000 0.00000 0 0.00000 14 none 5GTFrsEQfvTsh3WjiEVFeKzFTc2xcf… 1 1 2 τ0.00000 0.00000 0.00000 0.00000 0.00000 0.00000 ρ0 0.00000 Wallet balance: τ0.0
-
Edit
template/init.py
Edit the default
NETUID=8
andCHAIN_ENDPOINT=wss://entrypoint-finney.opentensor.ai:443
arguments to match your created subnetwork.Or run the miner and validator directly with the
netuid
andchain_endpoint
arguments.# Run the miner with the netuid and chain_endpoint arguments. $ python neurons/miner.py --netuid 8 --wallet.name miner --wallet.hotkey default --logging.debug >> 2023-08-08 16:58:11.223 | INFO | Running miner for subnet: 1 on network: wss://entrypoint-finney.opentensor.ai:443 with config: ...
-
Profit
You can build a model on your own or use the infrastructure inside this repository.
If you choose to use the infrastructure provided in here, you can choose to leverage standardized financial market indicators provided in mining_objects/financial_market_indicators.py
as well as a standardized LSTM model in mining_objects/base_mining_model.py
.
You can generate a historical Bitcoin dataset using the script
runnable/generate_historical_data.py
and choose the timeframe you'd like to generate for using the comments provided inside the script.
We've provided a basis for creating and testing models using runnable/miner_testing.py
and runnable/miner_training.py
Please note that we are constantly adjusting these scripts and will make improvements over time.
You can begin testing on testnet netuid 3. You can follow the docs/running_on_testnet.md
file inside the repo
to run on testnet.
A recommendation when testing on testnet to speed up testing is to pass the test_only_historical
argument for your validator.
You can do this by using running:
$ python neurons/validator.py --netuid 3 --subtensor.network test --wallet.name validator --wallet.hotkey default --logging.debug --test_only_historical 1
This will have the validator run and test against historical data instead of live. Don't use this flag if you only want to test against live data.
We also recommend using two miners when testing, as a single miner won't provide enough responses to pass for weighing. You can pass a different port for the 2nd registered miner.
You can run the second miner using the following example command:
$ python neurons/miner.py --netuid 3 --subtensor.network test --wallet.name miner --wallet.hotkey default --logging.debug --axon.port 8095
How does rewarding work?
Miners are rewarded based on predicting future information or live data as we classify it in the subnet. The network will also provide training data on the various datasets (trade pairs for financial market data) to increase miner accuracy. However, rewarding occurs on data that has yet to happen or what the subnet defines as live data. Once the future data is known, we compare it against the predictions made and reward based on performance.
What processing power is required to be a validator?
To be a validator, you must have a server running in the EU (recommend Ireland, UK). This server can be through a VPN or a cloud-based server. Not all financial data can be accessed inside the US (for crypto). The actual processing power is light, as validators only compare results against what occurs live; therefore, a relatively small machine can be a validator.
What is the expected data input and output as a miner?
For financial markets, the goal will be to predict the next 8 hours of closes on a 5m interval (100 closes). The subnet will provide the trade pair's last 25-30 days of 5m data to help achieve that goal. You'll likely want to incorporate additional data into your modeling techniques.
Input Features: [close_timestamp (milliseconds), close, high, low, volume]
Target Feature: [close]
Can I be a miner with little knowledge?
Predicting on markets is very hard, but we want to help those who want to contribute to the network by providing models that can be used. These models can be used to build upon, or just run yourself to try and compete.
You can participate by running these pre-built & pre-trained models provided to all miners [here](https://huggingface.co/Taoshi/model_v4).
These model are already built into the core logic of `neurons/miner.py` for you to run and compete as a miner. All you need to do is run `neurons/miner.py` and specify the model you want to run as an argument through --base_model:
--base_model model_v4_1
I'm knowledgeable about creating a competing prediction model on my own. Can I prepare my miner to compete?
You can start using the hugging face models to prepare for release or from scratch and test on testnet (netuid 3). You can use the training data provided by the subnet or prepare separately using your training data (say on BTC to start).
Where can I begin testing?
You can begin testing on testnet netuid 3. You can follow the `docs/running_on_testnet.md` file inside the repo to run on testnet.
For instructions on how to contribute to Taoshi, see CONTRIBUTING.md.
Copyright © 2023 Taoshi Inc
Taoshi All rights reserved.
Source code produced by Taoshi Inc may not be reproduced, modified, or distributed
without the express permission of Taoshi Inc.
Bittensor source code in this repository is licensed under the MIT License.
The MIT License (MIT)
Copyright © 2023 Yuma Rao
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
documentation files (the “Software”), to deal in the Software without restriction, including without limitation
the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of
the Software.
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
DEALINGS IN THE SOFTWARE.