6a1e57656c636f6d6520746f20426c6f636b636861696e20416e616c79736973

Tag: Bitcoin

Bitcoin Fees

Bitcoin is frequently criticised for having high transaction fees but this month saw Paxos pay a fee over $500,000 for a transaction of a mere $2,000 in BTC. Fortunately for Paxos, F2Pool, the miner of block 807,057 which contained the transaction acknowledged the error and agreed to refund the fees in full a few days later in block 807,732.

It just goes to show that no matter whether you’re new to crypto or are in the business costly mistakes can happen.


But is this the largest fee paid for any transaction in Bitcoin’s history? In terms of BTC no, that honour goes to a transaction in 2016 when a fee of over 291 BTC was paid to transfer a mere 0.0001 BTC! Around this time BTC was around $460, therefore this fee was worth approximately $133,860; all to transfer just 50c in Bitcoin.


Over the course of Bitcoin’s history there has been four transactions with fees higher than 100 BTC, the previously mentioned example as well as one on the 12th December 2011 (block 157235; fee almost 172 BTC), another on 10th January 2013 (block 215936; fee 111 BTC) and 28th August 2013 (block 254642; 200 BTC).


The table below provides the highest fees paid per year since Bitcoin’s genesis block.

2010201120122013201420152016
4.32171.7967.5020027.7285.89291.24
2017201820192020202120222023 (Partial)
504.701.993.491.833.4519.82
All fees are in BTC

How are Ordinals impacting the transaction per second rate?

Since the introduction of Ordinals onto the Bitcoin network in January 2023 there has been criticism of them clogging up the network and resulting in higher fees for users. Large image files are often shown as examples of taking the majority of the size of a block but there are a large number of text based ordinals which consume significantly less space.

I consider the transactions per second throughput of the Bitcoin network from 2021 to the present to establish if ordinals were impacting the network.


Originally I intended only to consider 2022 and 2023 but on an initial review of the data the results were unexpected; the throughput was greater in 2023 despite ordinals being introduced. This is discussed later.


Mean Transactions Per Second

Month202120222023
January13.778.588.63
February13.417.9610.27
March14.958.5912.31
April13.129.3614.97
May10.578.8231.17 (Partial)
June9.848.73
July6.337.90
August7.128.41
September9.478.93
October8.907.42
November8.648.91
December8.728.86

Median Transactions Per Second

Month202120222023
January4.702.993.39
February4.713.104.05
March4.243.144.41
April4.053.174.97
May3.473.219.62 (Partial)
June2.853.12
July2.652.94
August2.822.98
September3.003.10
October3.253.08
November3.333.39
December3.183.17

To my surprise, the transactions per second have increased, on average, since the introduction of ordinals onto the Bitcoin network when compared to the same months in 2022. I extended my analysis to include 2021 to establish if this was consistent behaviour. The figures between 2023 and 2021 were more similar to that of 2022. I suggest that this is due to the bull market of 2021 vs the bear market of 2022 resulting in there being significantly fewer transactions on the network in 2022.

Reviewing the mempool transaction account chart on Blockchain.info lends support to this.


Considering the results, the conclusion appears to be that ordinals haven’t negatively impacted the transactions per second throughput of the Bitcoin network, however, it must be considered that this is during a bear market. If the ordinals remain popular during the next bull market where transaction volumes increase there is a realistic prospect of the network becoming saturated leading to higher transaction fees and longer waits for users before transactions are included in a block.


Note the above figures are based on inverting negative time values where a higher block is timestamped before the previous block. This is discussed in more detail in https://blockchainanalysis.co.uk/bitcoin-transactions-per-second-tps/. Furthermore, this is based on the embedded timestamps within the blocks which may not be accurate; see https://blockchainanalysis.co.uk/bitcoin-block-time-consistency/

SegWit Adoption

In the previous post I touched upon SegWit and how it was used to fit almost 4MB of data within the 1MB block size limit present in Bitcoin.


SegWit was introduced to the Bitcoin network in 2017 and removed (segregated) the witness data from the transactions’ inputs and moved them to a separate structure within the blockchain. This had the effect of reducing the block size requirements for transactions (and therefore the often the transaction costs) and protecting against transaction malleability.

The move also brought in a means to increase the storage potential as seen in the previous post relating to ordinals of around 3.9MB being stored on chain. This is due to a move from bytes to Work Units (wu) for calculating the size. Since the SegWit update, blocks are limited to 4 million weight units, with 1 byte in a legacy transaction being 4wu, but 1 byte in a SegWit transaction being 1wu.

Native SegWit addresses can be identified as starting bc1 on the mainnet, or tb1 for the test net. P2SH (Pay to Script Hash) addresses can also be used for SegWit transactions which start with ‘3’.

The adoption of SegWit for transactions appears pretty rapid, perhaps not unexpected given the savings made in fees by users. In 2018, approximately 1/3rd of transactions used SegWit. By 2019 this was around 43% and by 2022 approximately 87% of transactions used SegWit. Impressively, in 2023 SegWit usage appears to continue to rise with 86.5% of transactions using SegWit.


The table below summarises the quantity and percentage of SegWit transactions each year.

YearNo of
SegWit

Transactions
No of Legacy
Transaction
s
Total No of
Transactions
Percentage
SegWit
Percentage
Normal
2009032708327080100.00
201001853051853050100.00
20110190176519017650100.00
20120845305084530500100.00
2013019643241196432410100.00
2014025263720252637200100.00
2015045674023456740230100.00
2016082626623826266230100.00
201733742151006890141040632293.2496.76
201826599771547958658139563632.6867.32
2019510861026869754511978364742.6557.35
2020551791305737436811255349849.0250.98
202163919480338769739779645365.3634.64
202277594859155115199310637883.3416.66
20231444662522544831670110886.5013.50

Bitcoin – Transactions Per Second (TPS)

Transactions per second (TPS) is an important metric when comparing Blockchains and features in the Blockchain trilemma (security, scalability, decentralisation). Bitcoin is heavily criticised for its low throughput which is often suggested to be approximately 7 transactions per second. This would equate to approximately 4200 transactions of around 250 bytes in each block (based on a 10-minute block time). This size of the transaction appears optimistic given recent average transactions, meaning the actual performance is lower.


The Bitcoin network’s TPS is frequently compared to VISA, with a figure of 24000 oft-cited for their payment service. VISA themselves claim a capacity of 65,000 transaction messages per second (it is unclear if each transaction required more than one message). It is important to note that this is a suggested capacity of their network, not how many occur. Based on VISA financial reports, the average (mean) transaction throughput in recent years was between approximately 4500 (2020) and 6100 (2022).

But I digress…


The typical calculation for a Blockchain’s throughput is (block size/transaction size) / block time

In Bitcoin, in its current configuration (as based on target block time), this would be (1MB / transaction size) / 600.

The transaction size on the Bitcoin network is variable and therefore this isn’t a constant. Bitcoin Visuals (bitcoinvisuals.com) assesses the average Bitcoin transaction size in recent years (2017 to 2022) to be between 455 and 636 bytes. This would equate to a transactions throughput of between 2.75 and 3.84 transactions per second based on the target 10-minute block time.

As I’ve written previously, the 10-minute block time is a target and is most frequently beaten. This has an impact on the calculation of transactions per second. There are instances where blocks are found within a second of the previous block. If the mempool (where pending transactions wait to be included in a block) is full, or near capacity at this time then the spot transactions per second value could be very high.

I reviewed the block headers for all blocks up till block 772089 (15th January 2023) and calculated the spot transactions per second for each block. In instances where a block was recorded as being mined earlier than its predecessor, the time difference was considered as a positive value.

Since the genesis block, Bitcoin has achieved approximately 5.7 transactions per second on average. The peak value I identified was 3087 transactions per second when block 572037 (16:02:17 17th April 2019) contained 3087 transactions, and was mined within 1 second of block 572036 (16:02:17 17th April 2019). It should be noted that this is one of the examples where the block height is positive, but the higher block is recorded as being mined earlier than the lower block emphasising the problems with the timing on the Bitcoin network.

The highest ‘non-negative’ time was in 2020 when block 649548 contained 3058 transactions and was mined one (1) second after block 649547 resulting in 3058 tps.


The table below summarises the last 12 years; in each of these years, there was at least one transaction a day.

Year201120122013201420152016
Max140387652766821.831795
Block Height of Max155293203685224618323678364691442517
Average (Mean)0.150.711.371.512.706.17
Year201720182019202020212022
Max285627863087305829402398
Block Height of Max465972549076572037649548687073752998
Average (Mean)13.057.9314.9713.6610.868.71

If negative time values are ignored, rather than being inverted, the figures change slightly. These results are summarised below:

Year201120122013201420152016
Max42278558766821.831382
Block Height of Max133623191425216547323678364691442239
Average (Mean)0.130.611.231.332.335.88
Year201720182019202020212022
Max285624933041305829402398
Block Height of Max465972556417565275649548687073752998
Average (Mean)12.077.2513.3012.8110.378.54

The increase in TPS from 2017 is expected, in part, the introduction of segwit to the Bitcoin protocol. By moving the witness data out of the block this allowed more transactions to be fitted within the 1MB block size.

Based on my previous experimentation with the accuracy of block timing where the average time between time in the block header and the time identified on my full node was 21 seconds then despite the findings above, they may not represent the throughput of the Bitcoin network. For example, if the timestamp of block 572037 was off by 21 seconds, then the TPS would go from 3087 to just 140. Still significantly higher than the expected throughput but lower than the summary figures would suggest.

Empty Bitcoin Transactions

During my usual browsing of various resources this morning I spotted an article on Cointelegraph entitled “You don’t see that every day: Empty Bitcoin block found”. This piqued by interest and in true ‘trust but verify’ mentality I thought I’d look into how frequently this occurs.


The Cointelegraph article focuses on block 776,339 which was the most recent zero transaction as of the time of the article. Since then there has been another zero transaction at block 776,521.

At the time of writing (17:00 14th February 2023) so far in 2023 there have been 13 blocks with no transactions (other than the coinbase) present in them; 770100, 770404, 770952, 771087, 773011, 773329, 773966, 774234, 774486, 774845, 775654, 776339 and 776521.

Since the genesis block, there has been a total of 89,453 blocks with zero-transactions. This is greatly influenced by the first two years which account for 88% of the zero-transaction blocks. Overall approximately 11.5% of blocks have contained no transactions, but in recent years this has been consistently under 1%.


The table below provides the total number of zero transaction blocks per year since the genesis block.

Year20092010201120122013201420152016
Number of Zero
Transaction Blocks
3231146489358515264205471701977
Percentage99.4568.456.012.800.660.933.131.78
Year2017201820192020202120222023 (Partial)
Number of Zero
Transaction Blocks
52843831424022114413
Percentage0.940.800.580.450.420.270.19

The graph below shows the last 10 years:


In writing this I noted that the Cointelegraph article reports that prior to block 776,339 the previous empty block was 774,486 a little over two weeks before. In analysing empty blocks I noted that there were two blocks closer to 776,339 which were empty (blocks 774,845 and 775,654). I’ve e-mailed the Cointelegraph editor and hopefully this will be corrected.

EDIT: The author reached out to me after my e-mail but as of 26th February 2023 the article remains uncorrected.

Bitcoin’s final block reward

I’ve previously looked at block timing against the target 10-minute time and we have seen that since 2010 the Bitcoin network, despite the difficulty retargeting every two weeks, has consistently beaten, on average, the target time.

With that in mind, when will the final block reward be granted? It is often cited that this will be 2140, but could the current trajectory bring this significantly sooner?


The Bitcoin network halves the miner’s reward every 210000 blocks, which should equate to 4 years. The block reward for the first 210000 blocks was 50 BTC, or 5000000000 Satoshis. This halves every 4 years until block 6,720,000 when the reward will be 1 Satoshi for each of the next 210000 blocks. At the next halving, the value falls below 1 Satoshi which is the minimum representable amount within Bitcoin and therefore no block rewards will be offered; miners will be rewarded transaction fees only.

The table below summarises the block rewards:

Block HeightBlock Reward (Sats)
05000000000
2100002500000000
4200001250000000
630000625000000
840000312500000
1050000156250000
126000078125000
147000039062500
168000019531250
18900009765625
21000004882813
23100002441406
25200001220703
2730000610352
2940000305176
3150000152588
336000076294
357000038147
378000019073
39900009537
42000004768
44100002384
46200001192
4830000596
5040000298
5250000149
546000075
567000037
588000019
60900009
63000005
65100002
67200001
69300000

If the block time was a consistent 10-minutes from the genesis block (3rd January 2009 at 18:15:05) onward, block 6930000 would be expected on 8th October 2040.

Based on the average (mean) block time from the genesis block to block 762150, block 6930000 would be expected on 1st December 2137, just over three years ahead of the expected date.


Is this realistic? I would not expect so.

The first 10 years of Bitcoin’s existence saw huge gains in hashing power from general purpose processors (CPUs) to more specialist graphics processing units (GPUs) to specific hardware being designed with the sole purpose of hashing (Application Specific Integrated Circuits; ASICs). It has also seen a large increase in the number of individuals and companies investing resources into mining bitcoin, although less so in recent years due to the difficulty targets and the cost of hardware and electricity.

This growth has resulted in similarly huge variations of the difficulty target but with only two week of granularity, the protocol is relatively slow to change to accommodate the increased hashing power.

I would expect that in time, the advances and investment into increasing hash rates will decrease, especially in later years where the block reward is very small. However, this depends on the value of bitcoin and the transaction fee values rewarded to the miner. This stabilisation of hashing power will allow the Bitcoin protocol’s difficulty retargeting to be more effective and I would expect it will drift closer to the 10-minute mark over time. It does not negate, however, that we are ahead at this point, as the retargeting only takes into account the previous 2016 blocks and not all previously existing blocks, and therefore I would expect that we will ‘beat’ the target of 8th October 2040.

Bitcoin Block Time Consistency 3

In a previous post, I summarised that the block time recorded for any Bitcoin block could be as much as 1 hour earlier or 2 hours later than the actual time, under the ideal timing of 10-minute blocks.

This is theoretical, based on what block validators would accept, but I was curious as to the actual time inaccuracy present within blocks. Between blocks 765069 (28th November 2022) and 765873 (4th December 2022) I sampled 100 blocks, comparing their timing to when my full node received and exposed those blocks via the RPC API.

A simple python script was written that continuously polled my full node for the current block height. This was compared to the previous response and if it differed, a new block had been found. On a new block being identified, the script obtained the local machine’s time (which is synchronised via NTP, Network Time Protocol, daily) and logged it against the block number and block time. These were then compared to establish the offset.

The following should be noted when considering this data:

  • It does not account for the time taken for my node to be updated by peers as to a new block being found. This is expected to be variable but within a few seconds, depending on the peering of the miner and my node. The node reported a maximum latency of 281ms for peers when reviewed; this will be variable, however.
  • It does not account for any delay in my node exposing a new block via the RPC API. This is expected to be minimal as once the block is validated it is expected to be exposed. Validation requires minimal resources and the node is operating on a modern multicore system with ample RAM.
  • The block samples were taken during the period 09:00 to 20:00 UTC; it does not, therefore, account for variations relating to timezones/blocks found outside of these hours. This is considered to be negligible as most miners and nodes will operate 24/7 (bar maintenance) and therefore are not affected by the time of day.
  • The script polled was configured to query the node every 50ms. This rate was chosen so as not to overload the RPC server, or delay/block the processing of a new block. In addition, the code’s overhead means that additional time is required to perform the checks and logging as well as network latency. From the output, this appears to be around 50-70ms.
  • Block header times being in Unix time are only as precise as 1 second. This analysis does not seek to determine accuracy to 10s of ms but rather provides an overview.

Overall I would expect the local time to be within 1-4 seconds of the block creation, but this is unproven. This may be considered further with an experiment on the Bitcoin Testnet.

The results were somewhat unspectacular; the largest difference was 51 seconds, the smallest -16 with an average (mean and median) of 21 seconds. Based on the sample, a tolerance of +/- 60 seconds appears reasonable when considering block times.

The full captured data is below:

Block HeightDetected New Block (Readable)Detected New Block (Unix)Block Time (Unix)Time Difference (seconds)
76506928/11/22 17:24:361669656276166965624828
76507028/11/22 17:42:17166965733716696573370
76507128/11/22 17:42:491669657369166965733732
76507228/11/22 17:43:231669657403166965736835
76507328/11/22 17:47:341669657654166965762430
76507428/11/22 17:49:461669657786166965777412
76507528/11/22 17:54:361669658076166965804828
76507628/11/22 18:07:371669658857166965881839
76507728/11/22 18:15:571669659357166965932433
76507828/11/22 18:19:351669659575166965956015
76507928/11/22 18:25:541669659954166965992034
76508028/11/22 18:27:04166966002416696600159
76508128/11/22 18:58:211669661901166966188219
76508228/11/22 19:04:531669662293166966226429
76530330/11/22 09:12:131669799533166979949340
76530430/11/22 09:22:141669800134166980009836
76530530/11/22 09:35:161669800916166980089620
76530630/11/22 09:35:381669800938166980091622
76530730/11/22 09:37:091669801029166980097851
76530830/11/22 09:38:34166980111416698011104
76530930/11/22 09:40:12166980121216698012048
76531030/11/22 10:12:19166980313916698031345
76531130/11/22 10:19:101669803550166980353020
76531230/11/22 10:22:221669803742166980372022
76531330/11/22 10:28:26166980410616698041051
76531430/11/22 11:23:031669807383166980735825
76531530/11/22 12:22:141669810934166981091816
76531630/11/22 12:34:401669811680166981164931
76531730/11/22 12:43:181669812198166981217226
76531830/11/22 12:49:201669812560166981252040
76531930/11/22 12:51:411669812701166981266239
76532030/11/22 12:52:251669812745166981272223
76533630/11/22 17:01:231669827683166982767211
76533730/11/22 17:04:00166982784016698278328
76533830/11/22 17:09:201669828160166982814119
76533930/11/22 17:10:191669828219166982818237
76534030/11/22 17:33:331669829613166982958627
76534130/11/22 17:37:531669829873166982983934
76534230/11/22 17:45:151669830315166983028233
76544901/12/22 09:09:591669885799166988575247
76545001/12/22 09:23:441669886624166988661410
76545101/12/22 09:26:541669886814166988678727
76545201/12/22 09:34:531669887293166988726627
76545301/12/22 09:44:25166988786516698878632
76545401/12/22 10:03:221669889002166988898418
76545501/12/22 10:22:071669890127166989008839
76545601/12/22 10:31:0816698906681669890684-16
76545701/12/22 10:47:091669891629166989160227
76545801/12/22 10:56:48166989220816698922008
76545901/12/22 11:04:53166989269316698926894
76546001/12/22 11:05:25166989272516698927232
76546101/12/22 11:15:02166989330216698932948
76546201/12/22 11:28:461669894126166989411313
76546301/12/22 11:38:08166989468816698946835
76546401/12/22 11:40:481669894848166989482919
76546501/12/22 11:57:311669895851166989583120
76546601/12/22 11:57:441669895864166989585113
76546701/12/22 12:21:481669897308166989726543
76546801/12/22 12:25:171669897517166989748928
76549201/12/22 17:38:10166991629016699162828
76549301/12/22 17:42:121669916532166991650725
76549401/12/22 17:43:301669916610166991657634
76549501/12/22 18:01:501669917710166991768921
76549601/12/22 18:02:501669917770166991773436
76549701/12/22 18:14:01166991844116699184347
76549801/12/22 18:18:351669918715166991868134
76558402/12/22 09:11:29166997228916699722818
76558502/12/22 09:12:091669972329166997231910
76558602/12/22 09:12:521669972372166997235913
76558702/12/22 09:42:201669974140166997412812
76558802/12/22 10:48:371669978117166997810611
76558902/12/22 11:01:441669978904166997887529
76559002/12/22 11:07:431669979263166997923231
76559102/12/22 11:10:531669979453166997943716
76559202/12/22 11:43:521669981432166998141517
76559302/12/22 11:49:531669981793166998176429
76559402/12/22 12:46:131669985173166998513637
76559502/12/22 13:01:571669986117166998609027
76559602/12/22 13:02:41166998616116699861529
76559702/12/22 13:04:071669986247166998620245
76559802/12/22 13:06:29166998638916699863836
76559902/12/22 13:11:0216699866621669986665-3
76560002/12/22 13:30:13166998781316699878103
76560102/12/22 13:31:081669987868166998784424
76560202/12/22 13:32:53166998797316699879694
76560302/12/22 13:47:451669988865166998885411
76575803/12/22 18:07:121670090832167009081121
76575903/12/22 18:42:511670092971167009294526
76576003/12/22 18:45:111670093111167009307239
76586304/12/22 12:57:031670158623167015861211
76586404/12/22 13:17:571670159877167015986017
76586504/12/22 13:24:471670160287167016026423
76586604/12/22 13:37:481670161068167016104028
76586704/12/22 13:39:411670161181167016114932
76586804/12/22 14:05:38167016273816701627326
76586904/12/22 14:22:541670163774167016375519
76587004/12/22 14:49:311670165371167016532150
76587104/12/22 15:04:39167016627916701662736
76587204/12/22 15:15:311670166931167016691021
76587304/12/22 15:37:561670168276167016825719

Bitcoin Block Time Consistency 2

In the previous post, I explored the timing of individual blocks. Generally, 6 blocks are used to confirm a transaction. This attempts to mitigate the possibility of the transaction being included in an orphaned block as a result of a fork caused by two blocks being found concurrently and to act as security against a malicious actor with considerable hashing power reverting previously mined blocks. A block is considered immutable after 6 confirmations.

While the previous analysis showed blocks in recent years may take up to 2 hours and 19 minutes, the chances of 6 constitutive blocks taking a similar amount of time is considered highly unlikely.


A snapshot of block headers was taken at block 763308 (15th November 2022) and an analysis of rolling 6 block timing was completed.

The average 6-block confirmation time over the entire history of the blockchain was 3436 seconds (57 minutes, 16 seconds). Closely aligned to the target time of 3600 seconds (60 minutes); 6x target block time of 10 minutes.

Over the past 5 full years – 2016 to 2021 – the longest 6-block confirmation time was just over 6 hours in 2021. This was exceptional, with other years being around 4 hours. If you were lucky enough to be awaiting your transaction confirmation during the shortest period in these years you could have been waiting for as little as 2 minutes (2020)!

Year2009201020112012201320142015
Block Range0-6 74637-74643149092-149098208508-208514215900-215906297493-297499386679-386685
Max
(seconds)
465284267891562414392120421351414428
Max (HH:MM:SS)09:14:4407:26:2904:20:2403:59:5203:20:4203:45:1404:00:28
Year2016201720182019202020212022 (Partial)
Block Range425375-425381494062-494068514763-514769578632-578638622894-622890688986-688992760246-760252
Max
(seconds)
13922139411497212057150752176013434
Max (HH:MM:SS)03:52:0203:52:2104:09:3203:20:5704:11:1506:02:4003:43:54
Maximum 6-block confirmation time per year

Overall, 75% of transactions awaiting 6 block confirmations would be expected to be confirmed within approximately 1 hour and 10 minutes, with 95% being confirmed within approximately 1 hour and 45 minutes.

Bitcoin Block Time Consistency

Bitcoin has a target block time of 10 minutes. Due to the hashing mechanism, it is unknown when a target hash will be achieved; it may be a second or it may be several hours but on average it is aimed to be 10 minutes. The greater the hashing power of the network, assuming a static target difficulty, the quicker a block would be expected to be mined, but due to the randomness of finding a solution the network hashing power is not directly correlated to the block time.

To achieve the 10-minute target block time, the difficulty of the target hash is altered every 2016 blocks, approximately 2 weeks. This re-targeting considers the time taken to mine those 2016 blocks and compares that to the expected time of 20160 minutes (2 weeks). The Bitcoin network then changes the difficulty appropriately; if the 2016 blocks were mined in under 20160 minutes the difficulty target will increase. If the 2016 blocks were mined in over 20160 minutes, the difficulty target will decrease.

The block header contains both the target difficulty and the time the miner reports to have mined the block. The target difficulty is calculated and checked by all verifying nodes on the network. It is therefore considered accurate.

The time, however, is not always accurate, but it is checked that it is greater than the median time of the previous 11 blocks, and not over two hours ahead of the current time as agreed by the connected nodes. In ideal circumstances (11 blocks of exactly 10 minutes each), the median would be 3600 seconds (60 minutes/1 hour). A valid timestamp would therefore be accepted if it were T-60/+120 – a three-hour window, under ideal conditions.


A snapshot of the Bitcoin network’s block headers was taken on 7th November 2022 at block height 762150. The average (mean) block time from the genesis block (3rd January 2009) to block 762150 was 587 seconds; 9 minutes and 47 seconds.

The data was then aggregated by year to give a summary of the Bitcoin’s network performance over that year.

Since 2015, the performance has been impressively consistent; the yearly average (mean) ranged from 563 to 598 seconds; 09:23 to 09:58. In 2010, 2011, 2013, and 2014, the average (mean) time was all under 9 minutes; 07:44, 08:48, 08:17 and 08:55 (respectively). 2012 was an exception during this period with an average block time of 09:39, more aligned with 2015 to 2022 values. Not surprisingly, given the introduction of the Bitcoin network that year and limited adoption, in 2009 the average block time exceeded the target considerably, achieving an average block time of 16:03.

The table below summarises the average (mean) block time per year since Bitcoin’s inception.

Year2009201020112012201320142015
Mean
(Seconds)
963464528579497535580
Mean
(HH:MM:SS)
00:16:0300:07:4400:08:4800:09:3900:08:1700:08:5500:09:40
Year2016201720182019202020212022 (Partial)
Mean
(Seconds)
576563578581594598589
Mean
(HH:MM:SS)
00:09:3600:09:2300:09:3800:09:4100:09:5400:09:5800:09:49
Average Block Time Aggregated By Year

Overall, the Bitcoin network has adapted well to the significant increases in hashing power over its lifetime.


The average, however, doesn’t tell the whole picture. Whilst the time required for a 6-block confirmation for transactions may be considered acceptable based on the average block time, on occasions the block time is significantly greater than 10 minutes.

The table below summarises the longest block times in a given year for the past 5 complete years.

YearBlockTimePrevious
Block
Time
Time
Difference
(HH:MM:SS)
202168930112:46:53
07/01/2021
10:27:39
07/01/2021
02:19:14
202062170108:39:25
15/03/2020
06:46:15
15/03/2020
01:53:10
201959727317:07:42
30/09/2019
15:08:45
30/09/2019
01:58:57
201855432308:06:20
18/12/2018
06:27:32
18/12/2018
01:38:48
201745185821:10:52
06/02/2017
19:31:38
06/02/2017
01:39:14
Longest Block Time 2017 to 2021

These represent the longest blocks, however. Analysis indicates that 95% of blocks will be mined within around 30 minutes of the previous block.