Skip to content

Commit

Permalink
Merge pull request #639 from Chia-Network/proof_format_docs
Browse files Browse the repository at this point in the history
New proof format docs
  • Loading branch information
BrandtH22 authored Aug 8, 2024
2 parents e309af6 + b7987b5 commit d5e1972
Show file tree
Hide file tree
Showing 12 changed files with 383 additions and 0 deletions.
68 changes: 68 additions & 0 deletions docs/new-proof-format/new-proof-faq.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
---
sidebar_label: FAQ
title: FAQ
slug: /new-proof-faq
---

import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem';

This page will answer your most common questions. Expect it to grow with time.

### What will this break/change?

Initially nothing, to give everyone time to upgrade. When the hard fork becomes activated six months after the release of Chia 3.0 there will be changes to the blockchain consensus which will cause non-upgraded full nodes and wallets to break. The upgrades software vendors will need to make before then are small and will be included in the reference codebase. Farmers will have to replot during the transition period and use upgraded plotters and harvesters. The computational requirements for harvesting will be slightly larger than with the original plot file format but vastly less than for compressed plots.

### When will I be able to farm with new plots on mainnet?

After the hard fork date, currently expected Q4 2025 (see [timeline](/new-proof-timeline)).

### When will the old plot format be fully phased out?

By the end of the transition period, currently expected Q4 2026 (see [timeline](/new-proof-timeline)).

### When should I replot?

Sometime during the transition period. When will be best for you will depend on your setup, but there will be a long enough time that the plots compliant with the new format will be neutral in weight to your existing plots so you can do it at your leisure. We will provide guidelines on how to evaluate which time window would be ideal to transition for your setup.

### With a modern GPU such as a 4090, what will be my expected plot times?

Around 5 minutes for a k32 ~100GiB plot, but this may change depending on how the final parameters are tuned for the proof of space. See our table of [expected plot times](/new-proof-plotting-requirements#expected-plot-times).

### Will you also support CPU plotting, and if so, what will be my expected plot times?

CPU plotting will be supported but will not be recommended for plotting any significant amount. A single CPU thread will be about 1000x slower than a 4090, potentially completing a k30 in 3 hours. The more CPU threads and memory channels your system has will reduce this time. Current testing on a high-end multi-threaded system is about 40-50x slower than a 4090, and may produce a k32 in around 3 hours.

### What will the hardware requirements be for harvesters?

For a small farmer using unused disk space on their system, a CPU is sufficient. For harvesters with >100TB of spare space, a CPU is sufficient but a low-end GPU may be more efficient. For harvesters with >1PiB, a low-end GPU (e.g. 3060Ti) is recommended.

There will also be the option of adding a little more data to your plots (up to ~15% more space), so that CPU usage is almost completely idle and can support a large number of Petabytes even on a Raspberry Pi. How much a Raspberry Pi could support on default plots is still pending benchmarking from an optimized implementation.

See our [farming requirements](/new-proof-farming-requirements) for more detailed information.

### What is the difficulty level in the new format?

The new plot format allows us to tune a difficulty setting to directly influence plot time. The higher the plot time, the more compression resistant the format becomes. However, we need to balance the difficulty with what should be an acceptable plotting time for most farmers, yet still have enough difficulty for significant compression resistance. Currently, we are tuning difficulty so that a 3060Ti GPU can process the plot construction in about the same time it takes to write the data to HDD, which is around 11 minutes per k32 plot (100GiB).

### How do you know that compression won’t be possible with the new format?

Compression is always possible, but the incentive will be severely limited. For instance, you could compress 100% of the plot by constructing a plot on the fly in under 30 seconds when a challenge comes in. However, this would require a cluster of the latest GPU’s to achieve, and would cost hundreds of thousands of dollars, just to spoof the space taken up by less than a TB. Alternatively, a farmer could make a plot with just 1 bit dropped per entry, and save ~0.5% of space. However, even this could incur more energy per TiB than the honest farmer.

In the future we expect extremely high efficiency in compute, however, storage will also improve in cost and efficiency during that time. With the advent of extremely low power SSDs when on idle, most farmers will be better off staying with the default plot format. Those farmers looking to squeeze the most out of their system by bit-dropping for extra levels of compression might achieve marginal gains despite higher energy costs per eTiB, but risk needing to replot and adjust their systems based on price fluctuations. If compute efficiency significantly outpaces gains in storage cost and efficiency, we could see bit-dropping with recompute reaching up to 10% space savings with marginal extra % gains in net rewards.

### Will there still be a plot filter after the new format is available?

Yes, and there are also additional filters in play. However, these filters are not expected to vary on a timed schedule (we only propose changing them if/when needed, with plenty of advanced notice), so as a farmer you won’t need to plan for any pre-scheduled dates where the filter will change. It is possible, if there are no longer any HDDs in use, we could propose a fork to alter the plot filter to improve resistance further since the restriction on seek times for HDDs would be lifted. Also, if GPU efficiency increases substantially in the future, to 10x or 100x what it is today, we can apply a soft fork to increase the plot difficulty – this would affect plot times and allow the phase-in of new plots that would be resistant to the hardware specifications at that future point in time. Note, however, that as cost per TB and also idle storage Watts also decreases over time, this counterbalances with GPU efficiency. So, while we may see 10x more efficient GPUs in 5 years, it does not necessarily mean we already need to adjust plot difficulty since the economics of farming on cheaper storage with extremely low idle power usage will also be a factor.

### How many times will I have to replot?

Once for the foreseeable 5-year outlook, and possibly much longer. The security of the network against rental attacks should be very strong for at least 10 years.

### What's this about different HDD and SSD plot formats?

There will be a single proof format for the blockchain. There will be no way to tell which blocks came from which format. There will be a proof format available to SSD which is smaller than on HDD but which is impractical to make work on HDD because of the seek times required for the number of lookups.

### How much space will someone be able to save using GPU compression?

It will be possible to save a few percent of space using bit dropping but the costs will go up exponentially. Currently we expect a 4090 on a large farm may be incentivized to compress up to 2-3% of the plot size, although this is still subject to change based on the final tuning parameters for the proof of space.
25 changes: 25 additions & 0 deletions docs/new-proof-format/new-proof-farming-requirements.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
---
sidebar_label: Farming Requirements
title: Farming Requirements
slug: /new-proof-farming-requirements
---

import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem';

In general, the larger your farm, the more powerful your harvesters will need to be. However, keep in mind that one farm can be broken into multiple harvesters, so it it possible to run a large farm without any high-end equipment.

### Requirements by farm size

These are the current guidelines **per harvester** using the default compression for the plot format:

- `< 100 TiB`: For farmers using spare space on their machines, a modern consumer level CPU and < 1 GiB RAM should be sufficient and have negligible impact on their system.
- ` < 1 PiB`: For small farmers a modern consumer level CPU and 1GiB RAM should be sufficient.
- `1 PiB - 10 PiB`: Medium sized farms may benefit from an integrated GPU (e.g. Apple M-Series processor or Intel with onboard graphics), or some utilization on a GPU.
- `> 10 PiB`: a dedicated GPU is required and possibly more than 1GiB of motherboard RAM depending on the number of plots.

If using a GPU, the RAM requirement is currently expected to be less than 1 GiB.

### Raspberry Pi support

We are still pending benchmarks to assess how many plots a Raspberry Pi may support for default plot format settings. However, plots can be made with additional data (~10-15% more space), so that even a Raspberry Pi could support many PiB on a single harvester.
28 changes: 28 additions & 0 deletions docs/new-proof-format/new-proof-introduction.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
---
sidebar_label: Introduction
title: Introduction
slug: /new-proof-introduction
---

import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem';

## New Proof Format

In 2024 we announced that we were developing a new Proof of Space format. This is a long-term project which is not expected to be finalized until the end of 2026. All farmers will need to replot in the year leading up to that date. This will be a gradual process, so farmers will have plenty of time to plan ahead.

:::warning

The documents in this section describe a technology that is still being developed. Everything you read here is subject to change.

:::

While the development of this technology is ongoing, we have put together several documents to answer all of your questions:

- A [blog post](https://www.chia.net/2024/08/08/approaching-the-next-generation-of-proof-of-space/) by Dr. Nick, which takes a deep dive into our plans
- A list of the expected [plotting requirements](/new-proof-plotting-requirements)
- A list of the expected [farming requirements](/new-proof-farming-requirements)
- A [timeline](/new-proof-timeline) of when we expect to reach each milestone
- A list of [frequently asked questions](/new-proof-faq)
- An [overview](/new-proof-technical-overview) of the new format
- The [technical details](/new-proof-details/) of the new format
62 changes: 62 additions & 0 deletions docs/new-proof-format/new-proof-plotting-requirements.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
---
sidebar_label: Plotting Requirements
title: Plotting Requirements
slug: /new-proof-plotting-requirements
---

import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem';

## Memory

We have separated the memory requirements by RAM only (no disk needed) and RAM + disk (for systems with 32 GiB of RAM). We also break down these requirements for plots meant to be stored on HDDs and for those meant to be stored on SSDs.

### HDD

Technically, HDD plots will also work on SSDs, but we also have a format that is optimized to be stored on SSDs for farming.

#### RAM only

Memory requirements for full plotting in RAM for HDD friendly format:

- K30: less than 64GiB
- K31: less than 128GiB
- K32: less than 256GiB
- K33+: each increase in K will approximately double the previous K’s RAM requirements.

#### RAM + disk

We also expect to support partial plotting in RAM for all k sizes on 32 GiB RAM systems by writing to storage during plotting. This will add additional time compared to all RAM plotting, but won’t be as impactful as the previous plot format since compute takes a relatively large portion of the overall time.

### SSD optimized

Memory requirements for Benes compression used in the SSD-only format will likely require significantly more RAM and plotting time, exact details still to be determined.

## GPU versus CPU plotting

GPU plotting will be strongly recommended. Plotting times for a k32 format with a 3060 Ti nVidia GPU are expected to take about 11 minutes, and times for higher-end GPUs will scale down relative to their performance in memory bandwidth and compute. For each increase or decrease in k size, expect plotting time to double or half respectively.

:::info

Note that plot times are currently estimated and may still be adjusted depending on the final security and compression resistance requirements chosen at a later date.

:::

CPU plotting will be possible but slow and expensive, and thus only recommended for small numbers of plots. Expect a modern high-end multi-threaded cpu system to take about 10x longer than a 3060 Ti GPU, and a single processor with DDR4 RAM to take 60-70x times longer than a 3060 Ti GPU.

## Expected plot times

Some expected plot times according to size and format:

| Processor <br/> Type | Processor <br/> Model | Plot <br/> Size | Expected <br/> Plot Time |
| :------------------- | :-------------------- | :-------------- | :----------------------- |
| GPU | 4090 | k32 | 5 minutes |
| GPU | 3060 Ti | k32 | 11 minutes |
| CPU | High-end multi-thread | k30 | 30 minutes |
| CPU | High-end multi-thread | k31 | 1 hour |
| CPU | High-end multi-thread | k32 | 2 hours |
| CPU | Single-thread | k30 | 2.5 hours |
| CPU | Single-thread | k31 | 5 hours |
| CPU | Single-thread | k32 | 10 hours |

Eventual support for Apple M-Series and iGPU’s acceleration. First releases will support CPU plotting and nVidia GPUs, and later additional support for other chips will be included.
Loading

0 comments on commit d5e1972

Please sign in to comment.