augustocroppo
VIP
Hero Member
Offline
Activity: 742


December 15, 2012, 03:38:39 PM 

That is an excellent paper discussing the hashrate with a very straight mathematical explanation. I appreciated very much. Only this part I could not understand completely: A more accurate model might take into account that generating blocks costs more to the attacker than their reward, and that he would not have mined them at all (or procured the necessary computing resources) if he did not want to doublespend. Such a model could obviate the need to choose a value for q, by posing limits on the hashrate an attacker would obtain to perform attacks of a given value. However, once the focus of the security is the cost of neutrally mining, the number of confirmations required becomes linear, not logarithmic, in the transaction value; this is very poor security, hence in a situation where this is relevant, we have already lost anyway.
What did you mean by 'cost of neutrally mining' and how the 'number of confirmations required becomes linear'?







Advertised sites are not endorsed by the Bitcoin Forum. They may be unsafe, untrustworthy, or illegal in your jurisdiction. Advertise here.




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


December 15, 2012, 04:22:11 PM 

That is an excellent paper discussing the hashrate with a very straight mathematical explanation. I appreciated very much. Only this part I could not understand completely: A more accurate model might take into account that generating blocks costs more to the attacker than their reward, and that he would not have mined them at all (or procured the necessary computing resources) if he did not want to doublespend. Such a model could obviate the need to choose a value for q, by posing limits on the hashrate an attacker would obtain to perform attacks of a given value. However, once the focus of the security is the cost of neutrally mining, the number of confirmations required becomes linear, not logarithmic, in the transaction value; this is very poor security, hence in a situation where this is relevant, we have already lost anyway.
What did you mean by 'cost of neutrally mining' and how the 'number of confirmations required becomes linear'? 'Cost of neutrally mining' = how much it costs to mine each block without trying to doublespend. The cost of doublespending is roughly inversely proportional to the probability of success. If the hashrate isn't too high, the probability is exponentially decreasing with the number of confirmations, hence the cost is exponentially increasing. So the needed number of confirmations is logarithmic in the value of the transaction. If the attacker has majority hashrate, the probability of success is essentially 1, so it cannot help us make the attack expensive. The cost to doublespend in this case is roughly proportional to n/(2q1), where n is the number of confirmations and q is the attacker's hashrate. Thus the number of confirmations needed is linear in the value of the transaction.




clone4501


December 20, 2012, 04:05:11 AM 

Meni R.,
I ready your paper and got most of it. I have to admit my knowledge of binomial distributions and such is a little rusty, but I get your points. Of course, rhetorically speaking, what is the optimal balance between the proof of work difficulty and the target time between blocks? Why not reduce the target time to 30 seconds instead of 10 minutes? Great paper, though, and thank you for your contribution, certainly worth a donation.




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


December 20, 2012, 06:22:36 AM 

I ready your paper and got most of it. I have to admit my knowledge of binomial distributions and such is a little rusty, but I get your points. Of course, rhetorically speaking, what is the optimal balance between the proof of work difficulty and the target time between blocks? Why not reduce the target time to 30 seconds instead of 10 minutes? Great paper, though, and thank you for your contribution, certainly worth a donation.
Finding out an optimal tradeoff would require more analysis. Essentially, about t/T of the honest network's total hashrate is lost due to forking, where T is the time between blocks and t is the typical time to propagate a block on the network. If we assume t = 10 sec, then for T=10 min 1.7% is wasted, and for T=30 sec 33% is wasted. How this compares with the ability to get more confirmations in a unit of time depends on the specific scenario. The additional resource cost to SPV clients (inversely proportional to T) should also be considered. I had a suggestion once for selfadjusting dynamic block frequency but I don't think it's really going to work. Even with a static system 23 minutes is probably better than 10, but I doubt this will be changed for Bitcoin. Thank you for the donation.




Maged
Legendary
Offline
Activity: 1260


January 03, 2013, 10:01:53 PM 

DAG stands for Directed Acyclic Graph. The PoS article you linked to mentions this once, not going into detail. I think it refers to the structure of the block relations. The blockchain currently forms a tree, where different branches are not reconcilable, with one having to be eventually forfeighted. I guess the proposal is to make it possible for branches to join back. I don't know of any such proposals though.
Thanks. It's probably the blocktree thing then. This is indeed what a DAG is and I think we're thinking about the same proposal. I might try linking to it sometime. I guess this is Maged proposal, isn't it? https://bitcointalk.org/index.php?topic=57647.msg686497#msg686497That's the one. I haven't spent time thinking about it in a while, AFAIR it's not completely fleshed out yet, but I think these ideas are the key to preventing a majority attack that rejects all transactions. The few major issues I've come to realize with that proposal are: 1) It will most likely require cementing at some level so that miners don't "save up" their mined blocks to guarantee themselves a block in the main chain that won't be kicked out by someone else by chance. 2) On a similar note, Finney attacks are guaranteed to be successful, unless some form of block discouraging is used. This wouldn't be that big of a deal if the main chain gets extended every few seconds, though. 3) Any currentlybackwardscompatible change that only requires a majority of the miners to upgrade to go into effect would require a hard fork if this were used. This might not be that much of a problem once the Bitcoin network is more mature. Speaking of #3, that directly relates to that whole contract thing theymos brought up recently: it would truly become impossible to make lost coins unspendable if ECDSA is ever broken, so that would have to be considered too. Anyway, that's the update on that.




Boussac
Legendary
Offline
Activity: 1174
educat.fr


January 04, 2013, 04:07:06 PM 

Inetresting paper for the modelling part but rather weak in dealing with the economics of the doublespend. A thorough economic analysis of the doublespend cannot go very far without game theory (Nash equilibrium in particular).
For example "An attacker with majority hashrate can not only doublespend any trans action at no cost (above the cost of running the mining hardware normally)"
Wrong: the attacker can only doublespend his own coins, meaning he must earn or buy a stash of coins upfront. As a result of his attack, his cost includes the initial value of the coins (before the attack) minus whatever value is reached after the attack is stopped by countermeasures (like new check points in the blockchain or merchants temporarily holding deliveries on bitcoin payments).
Also, the cost of performing a criminal activity (theft from merchants) with serious legal consequences (financial dammage to the stakeholders) must be factored in unless your assumption is the perfect crime (the promoters of the attack remain perfectly anonymous: a fairly aggressive assumption).
In short, if Visa or a similar organisation (incumbent stakeholder) were to engage in such attack, it would not be long before a disgruntled employee aired the story. Harnessing enough power to perform a serious attack is not something that could go unnoticed.
The same flaw (silo thinking) was found in the microsoft paper that dealt with bitcoin endogenous inventives (algorithmic rewards) while ignoring completely exogenous incentives (contractual rewards).




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


January 05, 2013, 04:20:16 PM 

Inetresting paper for the modelling part but rather weak in dealing with the economics of the doublespend.
I tend to agree, the economics part is not meant to be conclusive, rather act as a starting point for how an analysis could be done. For example "An attacker with majority hashrate can not only doublespend any trans action at no cost (above the cost of running the mining hardware normally)"
Wrong: the attacker can only doublespend his own coins, meaning he must earn or buy a stash of coins upfront. As a result of his attack, his cost includes the initial value of the coins (before the attack) minus whatever value is reached after the attack is stopped by countermeasures (like new check points in the blockchain or merchants temporarily holding deliveries on bitcoin payments).
This cost exists but as I explicitly stated, I don't think it's significant since other factors limit the possible scale of attack. More generally, you can include most "practical" costs as terms in the model. Future work will include formulating a model that can encompass most such things and be tractable to solve. Then it's just a matter of figuring out all the costs and plugging them in. The same flaw (silo thinking) was found in the microsoft paper that dealt with bitcoin endogenous inventives (algorithmic rewards) while ignoring completely exogenous incentives (contractual rewards).
There's something very basic about research papers that some people seem not to get. You can't give and solve a model that 100% accurately reflects reality. You need to make some simplifying assumptions and even if those assumptions aren't correct per se, they often have less effect on the final conclusions as it seems; even if the effect is significant, the more accurate model will rely on the intuitions of the simpler case. You don't formulate general relativity without first having a firm grasp of Newtonian mechanics. A big part of the trick is knowing when the assumptions are adequate, and how to refine them when they are not.




BitThink
Legendary
Offline
Activity: 882


June 09, 2014, 05:03:54 AM 

I have a question about this paper.
We will not use this assumption, but rather model m more accurately as a negative binomial variable; it is the number of successes (blocks found by the attacker) before n failures (blocks found by the honest network), with a probability q of success. The probability for a given value of m is P(m) = (m + n − 1) p ^n * q ^m m
I doubt this is correct. When the attacker is preparing a fork, he is not competing with the others. There are two completely independent mining process. I don't know why this can be modelled as a negative binomial variable.
When others find a block, it's not the attacker's failure. He will not restart a mining based on other's block, but has to continue mining based on his own previous block.




BitThink
Legendary
Offline
Activity: 882


June 09, 2014, 05:58:37 AM 

Moreover
"We will denote by az the probability that the attacker will be able to catch up when he is currently z blocks behind. Clearly, if z < 0 then az = 1 as the attacker already has a longer branch. To ﬁnd az when z ≥ 0, we condition on the ﬁrst step. If the next block found will be by the honest network, which happens with probability p, the attacker will now be z + 1 blocks behind and his probability of success will be az+1. If the next block found will be by the attacker, which happens with probability q, his probability of success will be az−1. It follows that az satisﬁes the recurrence relation az = paz+1 + qaz−1."
This is also not so straightforward. As I said, there's no competition, so what's the meaning of 'next block'. They are working on two different chains. When you find a block earlier, your opponents do not need to start from the scratch. They keep on working on their current block, on which they have spent , so the probability for they to get the next block earlier than you is much much higher than 'p'.
It seems that if all these words in this paper make sense, actually the author assumes the mining block is a memoryless process. It means no matter how much time you have spent on mining the current block, the expecting time from now to the moment you get the block is always the same (around 10 minutes). Begin computing early does not bring you any advantage. This is quite counterintuitive.
Therefore, now I really doubt the correctness of this paper.




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


June 09, 2014, 06:25:04 AM 

When you find a block earlier, your opponents do not need to start from the scratch. They keep on working on their current block, on which they have spent , so the probability for they to get the next block earlier than you is much much higher than 'p'.
It seems that if all these words in this paper make sense, actually the author assumes the mining block is a memoryless process. It means no matter how much time you have spent on mining the current block, the expecting time from now to the moment you get the block is always the same (around 10 minutes). Begin computing early does not bring you any advantage. This is quite counterintuitive.
Therefore, now I really doubt the correctness of this paper.
It's a wellknown fact that block finding is memoryless. Miners "start from scratch" every fraction of a second. They try a hash, and it being a valid block is completely random and independent. If the hash is not valid, it does not make the next hashes any more likely to be valid. If a miner mines for 20 minutes and finds no block, he is not any closer to finding one than when he began. I have a question about this paper.
We will not use this assumption, but rather model m more accurately as a negative binomial variable; it is the number of successes (blocks found by the attacker) before n failures (blocks found by the honest network), with a probability q of success. The probability for a given value of m is P(m) = (m + n − 1) p ^n * q ^m m
I doubt this is correct. When the attacker is preparing a fork, he is not competing with the others. There are two completely independent mining process. I don't know why this can be modelled as a negative binomial variable.
When others find a block, it's not the attacker's failure. He will not restart a mining based on other's block, but has to continue mining based on his own previous block.
Moreover
"We will denote by az the probability that the attacker will be able to catch up when he is currently z blocks behind. Clearly, if z < 0 then az = 1 as the attacker already has a longer branch. To ﬁnd az when z ≥ 0, we condition on the ﬁrst step. If the next block found will be by the honest network, which happens with probability p, the attacker will now be z + 1 blocks behind and his probability of success will be az+1. If the next block found will be by the attacker, which happens with probability q, his probability of success will be az−1. It follows that az satisﬁes the recurrence relation az = paz+1 + qaz−1."
This is also not so straightforward. As I said, there's no competition, so what's the meaning of 'next block'. They are working on two different chains.
"Failure" is the standard term used when discussing negative binomial distributions. It doesn't mean anything. If you look at continuous time these are two separate process. However, we are certainly allowed to introduce an abstraction that puts all the blocks found in a sequence. Each such block will have probability p to be honest and q to be the attackers (independent of other blocks). The rest of the analysis follows.




BitThink
Legendary
Offline
Activity: 882


June 09, 2014, 07:24:04 AM 

When you find a block earlier, your opponents do not need to start from the scratch. They keep on working on their current block, on which they have spent , so the probability for they to get the next block earlier than you is much much higher than 'p'.
It seems that if all these words in this paper make sense, actually the author assumes the mining block is a memoryless process. It means no matter how much time you have spent on mining the current block, the expecting time from now to the moment you get the block is always the same (around 10 minutes). Begin computing early does not bring you any advantage. This is quite counterintuitive.
Therefore, now I really doubt the correctness of this paper.
It's a wellknown fact that block finding is memoryless. Miners "start from scratch" every fraction of a second. They try a hash, and it being a valid block is completely random and independent. If the hash is not valid, it does not make the next hashes any more likely to be valid. If a miner mines for 20 minutes and finds no block, he is not any closer to finding one than when he began. I have a question about this paper.
We will not use this assumption, but rather model m more accurately as a negative binomial variable; it is the number of successes (blocks found by the attacker) before n failures (blocks found by the honest network), with a probability q of success. The probability for a given value of m is P(m) = (m + n − 1) p ^n * q ^m m
I doubt this is correct. When the attacker is preparing a fork, he is not competing with the others. There are two completely independent mining process. I don't know why this can be modelled as a negative binomial variable.
When others find a block, it's not the attacker's failure. He will not restart a mining based on other's block, but has to continue mining based on his own previous block.
Moreover
"We will denote by az the probability that the attacker will be able to catch up when he is currently z blocks behind. Clearly, if z < 0 then az = 1 as the attacker already has a longer branch. To ﬁnd az when z ≥ 0, we condition on the ﬁrst step. If the next block found will be by the honest network, which happens with probability p, the attacker will now be z + 1 blocks behind and his probability of success will be az+1. If the next block found will be by the attacker, which happens with probability q, his probability of success will be az−1. It follows that az satisﬁes the recurrence relation az = paz+1 + qaz−1."
This is also not so straightforward. As I said, there's no competition, so what's the meaning of 'next block'. They are working on two different chains.
"Failure" is the standard term used when discussing negative binomial distributions. It doesn't mean anything. If you look at continuous time these are two separate process. However, we are certainly allowed to introduce an abstraction that puts all the blocks found in a sequence. Each such block will have probability p to be honest and q to be the attackers (independent of other blocks). The rest of the analysis follows. Yes, if the mining is really memoryless, then I agree that everything makes sense. So it means because the nonce space is almost infinite, excluding part of it does not help at all. If the mining is memoryless, then does it make another popular paper published last year less meaningful? ( http://arxiv.org/abs/1311.0243). They argue that if a selfish miner get a block, they can hide it and starts to mine the next block based on it earlier than others so they can have an advantage. What's the advantage then? The only advantage is that they have a slight chance to find the block before others having a chance to work on it. If they publish the block before finding the next one, then no matter how long they have worked on it, they don't have any advantage.




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


June 09, 2014, 07:25:34 PM 

If the mining is memoryless, then does it make another popular paper published last year less meaningful? ( http://arxiv.org/abs/1311.0243). They argue that if a selfish miner get a block, they can hide it and starts to mine the next block based on it earlier than others so they can have an advantage. What's the advantage then? The only advantage is that they have a slight chance to find the block before others having a chance to work on it. If they publish the block before finding the next one, then no matter how long they have worked on it, they don't have any advantage. That paper correctly treats block finding as memoryless (it may or may not be correct about other things). You'd need to examine their analysis to understand why the attack works. The basic idea is that the attackers are attempting to build a long chain which is unknown to the network. If they manage to find 2 blocks in a row, they have the ability to evaporate a block found by the honest network, by releasing their longer, previously hidden chain.




ShakyhandsBTCer


June 13, 2014, 12:29:45 AM 

Myth. Doublespending requires having more than half of the network hashrate.
As long as the attacker can use their hashpower to confirm a block that contains the double spend then the attack will be successful. The success rate of executing this attack increases as your hashrate increases until being 100% success when you control more then 1/2 the network. Myth. The important factor is the amount of time spent waiting for confirmations, rather than the number of blocks. (Still a myth if instead of actual time you look at #blocks * average time per block). This could be true if the seller was willing to accept a 0/unconfirmed transaction. A seller would want to wait some time for the transaction to propagate throughout the network prior to releasing gods as an attacker could potentially release a TX to a very well connected node then one second later release a transaction to a poorly connected node that the "attackee" is suppose to believe will go through. For some period of time both transactions will appear to be valid on some parts of the network but after some time the TX will likely fall out of the pending pool on nodes.




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


June 13, 2014, 11:58:34 AM 

Myth. Doublespending requires having more than half of the network hashrate.
As long as the attacker can use their hashpower to confirm a block that contains the double spend then the attack will be successful. The success rate of executing this attack increases as your hashrate increases until being 100% success when you control more then 1/2 the network. Are you agreeing this is a myth or disagreeing? Anyway, it's not just "confirm a block", it's make an alternative longer chain after the seller waited for n confirmation. Myth. The important factor is the amount of time spent waiting for confirmations, rather than the number of blocks. (Still a myth if instead of actual time you look at #blocks * average time per block). This could be true if the seller was willing to accept a 0/unconfirmed transaction. A seller would want to wait some time for the transaction to propagate throughout the network prior to releasing gods as an attacker could potentially release a TX to a very well connected node then one second later release a transaction to a poorly connected node that the "attackee" is suppose to believe will go through. For some period of time both transactions will appear to be valid on some parts of the network but after some time the TX will likely fall out of the pending pool on nodes. Note that this is an analysis of hashratebased double spending, not doublespends of 0conf based on network topology.




ShakyhandsBTCer


June 14, 2014, 02:05:56 AM 

Myth. Doublespending requires having more than half of the network hashrate.
As long as the attacker can use their hashpower to confirm a block that contains the double spend then the attack will be successful. The success rate of executing this attack increases as your hashrate increases until being 100% success when you control more then 1/2 the network. Are you agreeing this is a myth or disagreeing? Anyway, it's not just "confirm a block", it's make an alternative longer chain after the seller waited for n confirmation. Myth. The important factor is the amount of time spent waiting for confirmations, rather than the number of blocks. (Still a myth if instead of actual time you look at #blocks * average time per block). This could be true if the seller was willing to accept a 0/unconfirmed transaction. A seller would want to wait some time for the transaction to propagate throughout the network prior to releasing gods as an attacker could potentially release a TX to a very well connected node then one second later release a transaction to a poorly connected node that the "attackee" is suppose to believe will go through. For some period of time both transactions will appear to be valid on some parts of the network but after some time the TX will likely fall out of the pending pool on nodes. Note that this is an analysis of hashratebased double spending, not doublespends of 0conf based on network topology. I am trying to give clarity to the facts that contradict the myth. You don't need 51% to be successful in double spending coins but the more hashpower you have the more effective this attack will be.




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


June 14, 2014, 09:15:04 PM 

I am trying to give clarity to the facts that contradict the myth. You don't need 51% to be successful in double spending coins but the more hashpower you have the more effective this attack will be.
Well, clarifying the facts is what the titular paper is about...




unexecuted


June 15, 2014, 07:46:09 AM 

No, the security comes from the average hashpower needed to produce a block. If you adjust the difficulty down, you reduce the security one block provides.




pastet89


June 15, 2014, 08:52:21 AM 

Due to similar flaws, even put into account while projecting I believe PoS coins are the future. Yes, bitcoin will still stay the king, however, if more people vote, why not turn BTC into PoS??




Meni Rosenfeld
Donator
Legendary
Offline
Activity: 2002


June 15, 2014, 04:45:11 PM 

No, the security comes from the average hashpower needed to produce a block. If you adjust the difficulty down, you reduce the security one block provides.
That's the myth that I'm refuting. Though to be accurate  reducing the time per block does reduce the security one confirmation provides, but not in the way you think.




