TARGON (Bittensor Subnet 4) is a redundant deterministic verification mechanism that can be used to interpret and analyze ground truth sources and a query.
NOTICE: Using this software, you must agree to the Terms and Agreements provided in the terms and conditions document. By downloading and running this software, you implicitly agree to these terms and conditions.
v1.0.6 - Runpod is now supported 🎉. Check out the runpod docs in docs/runpod/verifier.md and docs/runpod/prover.md for more information.
v1.0.0 - Runpod is not currently supported on this version of TARGON for verifiers. An easy alternative can be found in the Running on TensorDock section.
Currently supporting python>=3.9,<3.11.
Note: The storage subnet is in an alpha stage and is subject to rapid development.
- Compute Requirements
- Roadmap
- Installation
- What is a Redundant Deterministic Verification Network?
- Features of TARGON
- How to Run TARGON
- Reward System
- How to Contribute
The following table shows the VRAM, Storage, RAM, and CPU minimum requirements for running a verifier or prover.
GPU - A100
Provider | VRAM | Storage | RAM | CPU |
---|---|---|---|---|
TensorDock | 40GB | 100GB | 16GB | 4 |
Latitude | 40GB | 100GB | 16GB | 4 |
Paperspace | 40GB | 100GB | 16GB | 4 |
GCP | 40GB | 100GB | 16GB | 4 |
Azure | 40GB | 100GB | 16GB | 4 |
AWS | 40GB | 100GB | 16GB | 4 |
Runpod | 40GB | 100GB | 16GB | 4 |
The following table shows the suggested compute providers for running a verifier or prover.
Provider | Cost | Location | Machine Type | Rating |
---|---|---|---|---|
TensorDock | Low | Global | VM & Container | 4/5 |
Latitude | Medium | Global | Bare Metal | 5/5 |
Paperspace | High | Global | VM & Bare Metal | 4.5/5 |
GCP | High | Global | VM & Bare Metal | 3/5 |
Azure | High | Global | VM & Bare Metal | 3/5 |
AWS | High | Global | VM & Bare Metal | 3/5 |
Runpod | Low | Global | VM & Container | 5/5 |
Completed
- Challenge Request
- Reward System
- Bonding
- Database
- Auto Update
- Forwarding
In Progress
- [] Tiered Requests to match throughput
- [] Inference Request
- [] Metapool
- [] flashbots' style block space for verifier bandwidth
- [] metrics dashboard
In order to run TARGON, you need to install Docker, PM2, and TARGON package. The following instructions apply only to Ubuntu OSes. For your specific OS, please refer to the official documentation.
Install Docker
Install docker on your machine. Follow the instructions here. The following instructions apply only to Ubuntu OSes.
Before you install Docker Engine for the first time on a new host machine, you need to set up the Docker repository. Afterward, you can install and update Docker from the repository.x
# Add Docker's official GPG key:
sudo apt-get update
sudo apt-get install ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc
# Add the repository to Apt sources:
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
$(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
To install the latest version, run:
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
To run docker commands without sudo, create a docker group and add your user.
sudo groupadd docker
sudo usermod -aG docker $USER
exit
Log back in and run the following command to verify that you can run docker commands without sudo.
docker ps
You have now installed Docker.
Install PM2
Install PM2 on your machine.
To install or update nvm, you should run the install script. To do that, you may either download and run the script manually, or use the following cURL or Wget command:
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
Running either of the above commands downloads a script and runs it. The script clones the nvm repository to /.nvm, and attempts to add the source lines from the snippet below to the correct profile file (/.bash_profile, ~/.zshrc, ~/.profile, or ~/.bashrc).
export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
nvm install node
npm install pm2@latest -g
You have now installed PM2.
git clone https://github.com/manifold-inc/targon.git
cd targon
pip install -e .
You have now installed TARGON. You can now run a prover or verifier.
Using existing datasets that are public poses certain challenges to rewarding models for work. Those who seek to win overfit their models on these inputs, or can front run the input by using a lookup for the output. A solution to this challenge can be done using prompt generation using a query generation model, and a private input.
The private input will be sourced from an api ran by Manifold, and this input is rotated every twelve seconds, and is authenticated with a signature using the validator’s keys. The private input is fed into the query generation model, which can be run by the validator or as a light client by manifold. The data source can be either from a crawl or from RedPajama.
The query, private input, and a deterministic seed are used to generate a ground truth output with the specified model, which can be run by the validator or as a light client. The validator then sends requests to miners with the query, private input, and deterministic seed. The miner output are compared to the ground truth output. If the tokens are equal, the miner has successfully completed the challenge.
A prover is a node that is responsible for generating a output from a query, private input, and a deterministic sampling params.
A verifier is a node that is responsible for verifying a prover's output. The verifier will send a request to a prover with a query, private input, and deterministic sampling params. The miner will then send back a response with the output. The verifier will then compare the output to the ground truth output. If the outputs are equal, then the prover has completed the challenge.
A challenge request is a request sent by a verifier to a prover. The challenge request contains a query, private input, and deterministic sampling params. The prover will then generate an output from the query, private input, and deterministic sampling params. The prover will then send the output back to the verifier.
An inference request is a request sent by a verifier to a prover. The inference request contains a query, private input, and inference sampling params. The prover will then generate an output from the query, private input, and deterministic sampling params. The prover will then stream the output back to the verifier.
CAVEAT: Every Interval (360 blocks) there will be a random amount of inference samples by the verifier. The verifier will then compare the outputs to the ground truth outputs. The cosine similarity of the outputs will be used to determine the reward for the prover. Failing to do an inference request will result in a 5x penalty.
To get started running a prover, you will need to be running the docker containers for the requirements of the prover. To do this, run the following command:
cp neurons/prover/docker-compose.example.yml neurons/prover/docker-compose.yml
docker compose -f neurons/prover/docker-compose.yml up -d
this includes the following containers:
- TGI Inference Node
- Subtensor
- Prover (optional)
experimental optionally, you can edit the docker-compose.yml file to include the proving container, but you will need to edit the docker-compose.yml file and uncomment out the prover container. Otherwise you can run the prover with PM2.
Run with Docker
prover:
build:
context: .
dockerfile: Dockerfile
ports:
- "8091:8091"
command: ./entrypoint.sh
volumes:
- ~/.bittensor/wallets:/root/.bittensor/wallets
and then edit the entrypoint.sh file to include the args specific for your prover.
python app.py --wallet.name WALLET_NAME --wallet.hotkey WALLET_HOTKEY --logging.debug --logging.trace --subtensor.chain_endpoint 0.0.0.0:9944
replace the wallet name and wallet hotkey with your wallet name and wallet hotkey. You can also change the subtensor chain endpoint to your own chain endpoint if you perfer.
Run with PM2
cd neurons/prover
pm2 start app.py --name prover -- --wallet.name WALLET_NAME --wallet.hotkey WALLET_HOTKEY --logging.debug --logging.trace --subtensor.chain_endpoint 0.0.0.0:9944
replace the wallet name and wallet hotkey with your wallet name and wallet hotkey. You can also change the subtensor chain endpoint to your own chain endpoint if you perfer.
The add_prover_args function in the targon/utils/config.py file is used to add command-line arguments specific to the prover. Here are the options it provides:
-
--neuron.name: This is a string argument that specifies the name of the neuron. The default value is 'prover'.
-
--blacklist.force_verifier_permit: This is a boolean argument that, if set, forces incoming requests to have a permit. The default value is False.
-
--blacklist.allow_non_registered: This is a boolean argument that, if set, allows provers to accept queries from non-registered entities. This is considered dangerous and its default value is False.
-
--neuron.tgi_endpoint: This is a string argument that specifies the endpoint to use for the TGI client. The default value is "http://0.0.0.0:8080".
To get started running a verifier, you will need to be running the docker containers for the requirements of the verifier. To do this, run the following command:
cp neurons/verifier/docker-compose.example.yml neurons/verifier/docker-compose.yml
./scripts/generate_redis_password.sh
vim neurons/verifier/docker-compose.yml # replace YOUR_PASSWORD_HERE with the password generated by the script
docker compose -f neurons/verifier/docker-compose.yml up -d
this includes the following containers:
- Redis
- TGI Inference Node
- Subtensor
- Verifier (optional)
IMPORTANT: You will need to edit the docker-compose.yml file with your new password. You can do this by:
./scripts/generate_redis_password.sh
this will output a secure password for you to use. You will then need to edit the docker-compose.yml file and replace the password with your new password.
first use vim to edit the docker-compose.yml file:
vim neurons/verifier/docker-compose.yml
then replace the password with your new password:
redis:
image: redis:latest
command: redis-server --requirepass YOUR_PASSWORD_HERE
ports:
- "6379:6379"
experimental optionally, you can edit the docker-compose.yml file to include the verifier container, but you will need to edit the docker-compose.yml file and uncomment out the verifier container. Otherwise you can run the verifier with PM2.
Run with Docker
verifier:
build:
context: .
dockerfile: Dockerfile
ports:
- "8091:8091"
command: ./entrypoint.sh
volumes:
- ~/.bittensor/wallets:/root/.bittensor/wallets
and then edit the entrypoint.sh file to include the args specific for your prover.
python app.py --wallet.name WALLET_NAME --wallet.hotkey WALLET_HOTKEY --logging.debug --logging.trace --subtensor.chain_endpoint 0.0.0.0:9944 --database.password YOUR_PASSWORD_HERE
replace the wallet name, wallet hotkey, and db pass with your wallet name, wallet hotkey and pass. You can also change the subtensor chain endpoint to your own chain endpoint if you perfer.
Run with PM2
Run the following command to start the verifier with PM2:cd neurons/verifier
pm2 start app.py --name verifier -- --wallet.name WALLET_NAME --wallet.hotkey WALLET_HOTKEY --logging.debug --logging.trace --subtensor.chain_endpoint
0.0.0.0:9944 --database.password YOUR_PASSWORD_HERE
The add_verifier_args function in the targon/utils/config.py file is used to add command-line arguments specific to the verifier. Here are the options it provides:
-
--neuron.sample_size: The number of provers to query in a single step. Default is 10.
-
--neuron.disable_set_weights: A flag that disables setting weights. Default is False.
-
--neuron.moving_average_alpha: Moving average alpha parameter, how much to add of the new observation. Default is 0.05.
-
--neuron.axon_off or --axon_off: A flag to not attempt to serve an Axon. Default is False.
-
--neuron.vpermit_tao_limit: The maximum number of TAO allowed to query a verifier with a vpermit. Default is 4096.
-
--neuron.tgi_endpoint: The endpoint to use for the TGI client. Default is "http://0.0.0.0:8080".
-
--database.host: The path to write debug logs to. Default is "127.0.0.1".
-
--database.port: The path to write debug logs to. Default is 6379.
-
--database.index: The path to write debug logs to. Default is 1.
-
--database.password: The password to use for the redis database. Default is None.
-
--neuron.compute_stats_interval: The interval at which to compute statistics. Default is 360.
These options can be used to customize the behavior of the verifier when it is run.
Refer to the code here:
replace the wallet name and wallet hotkey with your wallet name and wallet hotkey. You can also change the subtensor chain endpoint to your own chain endpoint if you perfer.
Inspired by FileTAO's reputation system, the reward system is based on the complete correct answer being responded consistently over time. If a ground truth hash and the prover output hash are equal, then the reward is performing these challenges and inference requests over time will result in a multiplication of your reward based off the tier.
The tier system classifies miners into five distinct categories, each with specific requirements and request limits. These tiers are designed to reward miners based on their performance, reliability, and the total volume of requests they can fulfill.
The updated tier system introduces a refined classification for miners, with expanded categories to more precisely reward performance, reliability, and the total volume of requests they can handle. Each tier now includes not only the request success rate and request limits but also incorporates a reward factor and a similarity threshold for more nuanced performance assessment.
V1.1.1 Tiers:
1.) Challenger Tier
- Success Rate: 98%
- Request Limit: 25,000
- Reward Factor: 1.0
- Similarity Threshold: 0.95
2.) Grandmaster Tier
- Success Rate: 92%
- Request Limit: 22,500
- Reward Factor: 0.980
- Similarity Threshold: 0.92
3.) Master Tier
- Success Rate: 88%
- Request Limit: 20,000
- Reward Factor: 0.960
- Similarity Threshold: 0.88
4.) Jade Tier
- Success Rate: 84%
- Request Limit: 17,500
- Reward Factor: 0.940
- Similarity Threshold: 0.84
5.) Ruby Tier
- Success Rate: 82%
- Request Limit: 15,000
- Reward Factor: 0.920
- Similarity Threshold: 0.82
6.) Emerald Tier
- Success Rate: 80%
- Request Limit: 12,500
- Reward Factor: 0.900
- Similarity Threshold: 0.80
7.) Diamond Tier
- Success Rate: 78%
- Request Limit: 10,000
- Reward Factor: 0.888
- Similarity Threshold: 0.78
8.) Platinum Tier
- Success Rate: 76%
- Request Limit: 7,500
- Reward Factor: 0.777
- Similarity Threshold: 0.76
9.) Gold Tier
- Success Rate: 74%
- Request Limit: 5,000
- Reward Factor: 0.666
- Similarity Threshold: 0.74
10.) Silver Tier
- Success Rate: 72%
- Request Limit: 1,000
- Reward Factor: 0.555
- Similarity Threshold: 0.72
11.) Bronze Tier
- Success Rate: 70%
- Request Limit: 500
- Reward Factor: 0.444
- Similarity Threshold: 0.70
Miners will be promoted or relegated based on their performance over the last 360 blocks. The promotion/relegation computation will be done every 360 blocks. In order to be promoted to a tier, you must satisfy the tier success rate requirements and the minimum successful requests required. In order to be relegated to a tier, you must fail to satisfy the tier success rate requirements, leading to a demotion to the lower tier.
If you experience downtime as a challenger UID, you will be demoted down, however you will not have to satisfy the minimum successful requests required. You will be instantly promoted back to the tier if you satisfy the tier success rate requirements.
Statistics for inference_attempts/attempts, challenge_attempts/successes are reset every interval, while the total_successes are carried over for accurate tier computation. This "sliding window" of the previous 360 blocks of N successes vs M attempts effectively resets the N / Mratio. This facilitates a less punishing tier calculation for early failures that then have to be "outpaced", while simultaneously discouraging grandfathering in of older miners who were able to succeed early and cement their status in a higher tier. The net effect is greater mobility across the tiers, keeping the network competitive while incentivizing reliability and consistency.
Project maintainers reserve the right to weigh the opinions of peer reviewers using common sense judgement and may also weigh based on merit. Reviewers that have demonstrated a deeper commitment and understanding of the project over time or who have clear domain expertise may naturally have more weight, as one would expect in all walks of life.
Where a patch set affects consensus-critical code, the bar will be much higher in terms of discussion and peer review requirements, keeping in mind that mistakes could be very costly to the wider community. This includes refactoring of consensus-critical code.
Where a patch set proposes to change the TARGON subnet, it must have been discussed extensively on the discord server and other channels, be accompanied by a widely discussed BIP and have a generally widely perceived technical consensus of being a worthwhile change based on the judgement of the maintainers.
As most reviewers are themselves developers with their own projects, the review process can be quite lengthy, and some amount of patience is required. If you find that you've been waiting for a pull request to be given attention for several months, there may be a number of reasons for this, some of which you can do something about: