Bitcoin Forum
May 05, 2024, 06:22:45 PM *
News: Latest Bitcoin Core release: 27.0 [Torrent]
 
   Home   Help Search Login Register More  
Pages: [1]
  Print  
Author Topic: Sending change to a different address, does it help much?  (Read 603 times)
tonych (OP)
Legendary
*
Offline Offline

Activity: 964
Merit: 1008


View Profile WWW
January 23, 2015, 03:05:45 PM
 #1

To protect your privacy, it is commonly recommended to send change to a new freshly generated address. It is argued that this makes it impossible to distinguish the payment from the change which makes it harder to group the transactions that belong to you.

Correct me if I'm wrong, I'm afraid it doesn't help in many cases. The reason is simple: payment value is usually smaller than the change.

When I spend money from my debit card, the payment amount is usually much smaller than the remaining balance. That's because I don't want to refill my card as often as I spend. The same spending habits applied to Bitcoin make transactions traceable.

If you have 10 BTC (say, you received it from an exchange) and want to pay 1 BTC, your transaction will have two outputs:
1 BTC - the payment,
9 BTC - the change to another your address.
Without any other knowledge, just by looking at the output values, it is usually safe to say that 1 BTC is the payment and 9 BTC is the change, and the address where the 9 BTC landed is again your address. Any other coins received to this address will be tracked to you. The subsequent transaction that spends the 9 BTC will be tracked to you.

Any thoughts how this situation is really often and how to protect one's privacy?

Simplicity is beauty
1714933365
Hero Member
*
Offline Offline

Posts: 1714933365

View Profile Personal Message (Offline)

Ignore
1714933365
Reply with quote  #2

1714933365
Report to moderator
"With e-currency based on cryptographic proof, without the need to trust a third party middleman, money can be secure and transactions effortless." -- Satoshi
Advertised sites are not endorsed by the Bitcoin Forum. They may be unsafe, untrustworthy, or illegal in your jurisdiction.
1714933365
Hero Member
*
Offline Offline

Posts: 1714933365

View Profile Personal Message (Offline)

Ignore
1714933365
Reply with quote  #2

1714933365
Report to moderator
CIYAM
Legendary
*
Offline Offline

Activity: 1890
Merit: 1075


Ian Knowles - CIYAM Lead Developer


View Profile WWW
January 23, 2015, 03:16:27 PM
 #2

Correct me if I'm wrong, I'm afraid it doesn't help in many cases. The reason is simple: payment value is usually smaller than the change.

Actually the opposite can be easily true with Bitcoin because if you were paid say 10 BTC at some time then you effectively have one 10 BTC "note" (the UTXO) rather than the same set of perhaps smaller notes the sender had used (the inputs).

Assuming you buy something for 1 BTC then your change is 9 BTC but I do guess that typical spending habits might be able to make analysis easier.

With CIYAM anyone can create 100% generated C++ web applications in literally minutes.

GPG Public Key | 1ciyam3htJit1feGa26p2wQ4aw6KFTejU
kolloh
Legendary
*
Offline Offline

Activity: 1736
Merit: 1023


View Profile
January 23, 2015, 03:28:35 PM
 #3

If you were worried about this, you could always split up the BTC before sending into equal amounts. If you wanted to make a payment of 1 BTC, you could always send 2 BTC to a new address, then send 1 BTC to another person, with 1 BTC going to a new change address.

Additionally, it would be difficult for someone to tell for sure that you made a 1 BTC payment vs a 9 BTC payment. They could assume but won't always be correct.
CIYAM
Legendary
*
Offline Offline

Activity: 1890
Merit: 1075


Ian Knowles - CIYAM Lead Developer


View Profile WWW
January 23, 2015, 03:50:39 PM
 #4

You should also note that you can switch on "coin control" to decide exactly which UTXOs to use for a transaction.

With CIYAM anyone can create 100% generated C++ web applications in literally minutes.

GPG Public Key | 1ciyam3htJit1feGa26p2wQ4aw6KFTejU
tonych (OP)
Legendary
*
Offline Offline

Activity: 964
Merit: 1008


View Profile WWW
January 23, 2015, 03:57:55 PM
 #5

If you were worried about this, you could always split up the BTC before sending into equal amounts. If you wanted to make a payment of 1 BTC, you could always send 2 BTC to a new address, then send 1 BTC to another person, with 1 BTC going to a new change address.

Then the 8 BTC change from the 1st transaction is still tracked to the payer.

Additionally, it would be difficult for someone to tell for sure that you made a 1 BTC payment vs a 9 BTC payment. They could assume but won't always be correct.

Of course, it is high probability rather than certainty.

Simplicity is beauty
CIYAM
Legendary
*
Offline Offline

Activity: 1890
Merit: 1075


Ian Knowles - CIYAM Lead Developer


View Profile WWW
January 23, 2015, 04:04:14 PM
Last edit: January 23, 2015, 04:17:43 PM by CIYAM
 #6

Then the 8 BTC change from the 1st transaction is still tracked to the payer.

The outputs always come from inputs if that is what you mean but whether any of the new UTXOs belong to the original party isn't something you can be certain of.

You might be interested in looking into things like CoinJoin in order to improve anonymity (another perhaps easier but generally not without fee approach is to move funds via crypto to crypto exchanges).

Also a CoinJoin type idea that would work across blockchains via AT is described here: https://bitcointalk.org/index.php?topic=893271.msg9844660#msg9844660

With CIYAM anyone can create 100% generated C++ web applications in literally minutes.

GPG Public Key | 1ciyam3htJit1feGa26p2wQ4aw6KFTejU
tonych (OP)
Legendary
*
Offline Offline

Activity: 964
Merit: 1008


View Profile WWW
January 23, 2015, 04:45:15 PM
 #7

I know about CoinJoin but not sure people will widely use it unless it is integrated in most wallets and on by default. The majority always tends to take the easiest path no matter what it means for security and privacy.

Simplicity is beauty
CIYAM
Legendary
*
Offline Offline

Activity: 1890
Merit: 1075


Ian Knowles - CIYAM Lead Developer


View Profile WWW
January 23, 2015, 04:50:41 PM
 #8

I know about CoinJoin but not sure people will widely use it unless it is integrated in most wallets and on by default. The majority always tends to take the easiest path no matter what it means for security and privacy.

If people aren't prepared to go to any efforts to get privacy then they are simply not going to get it (they'll probably just use something that "says it is anonymous" but in fact isn't).

With CIYAM anyone can create 100% generated C++ web applications in literally minutes.

GPG Public Key | 1ciyam3htJit1feGa26p2wQ4aw6KFTejU
DannyHamilton
Legendary
*
Offline Offline

Activity: 3388
Merit: 4616



View Profile
January 24, 2015, 08:58:19 AM
 #9

To protect your privacy, it is commonly recommended to send change to a new freshly generated address. It is argued that this makes it impossible to distinguish the payment from the change which makes it harder to group the transactions that belong to you.

Anyone that argues the underlined passage above is either intentionally misleading you or misunderstands what they've read.

It does however make it significantly more difficult.

Correct me if I'm wrong, I'm afraid it doesn't help in many cases. The reason is simple: payment value is usually smaller than the change.

When I spend money from my debit card, the payment amount is usually much smaller than the remaining balance. That's because I don't want to refill my card as often as I spend. The same spending habits applied to Bitcoin make transactions traceable.

Not exactly.  Bitcoin transactions don't work with a wallet "balance" or even an address "balance", they work with individual unspent outputs.  This is an important concept to understand well if you are going to try to discuss "change" at the transaction level.

If you have 10 BTC (say, you received it from an exchange) and want to pay 1 BTC, your transaction will have two outputs:
1 BTC - the payment,
9 BTC - the change to another your address.

And what if you have 10 BTC (say you received it from an exchange) and you want to pay 6 BTC?  Then how much will your change be?  Will it still be the largest output?

What if you received your 10 BTC in 3 separate transactions to 3 different addresses, first a transaction for 1.1 BTC, then a second transaction for 3.5 BTC, and finally a transaction for 5.4 BTC?

Without any other knowledge, just by looking at the output values, it is usually safe to say that 1 BTC is the payment and 9 BTC is the change, and the address where the 9 BTC landed is again your address.

No it really isn't.  Especially if you are using a new address for every transaction you receive (as you should be).  Then that 10 BTC "balance" could be made up of a dozen or more smaller individual outputs.  The total of any combination of those outputs might be less than 2 BTC, meaning any output will be LESS THAN half of the transaction value (the actual payment will be the BIGGER output).

Any thoughts how this situation is really often and how to protect one's privacy?

It is only possible if you are receiving your bitcoins in single large transactions and are then spending less than half of what you received every time you spend it.  Even then, the amount will eventually dwindle to the point where you can no longer assume that the larger output is the change.

To significantly improve your privacy, receive your transactions as smaller amounts and use a new address for every transaction.
botany
Legendary
*
Offline Offline

Activity: 1582
Merit: 1064


View Profile
January 24, 2015, 09:06:57 AM
 #10

In most cases, people receive bitcoins through multiple, small transactions. In that case, the way most wallets pick coins (to prevent destroying accumulated priority), the change is usually the smaller output.
tonych (OP)
Legendary
*
Offline Offline

Activity: 964
Merit: 1008


View Profile WWW
January 24, 2015, 10:39:47 AM
 #11


If you have 10 BTC (say, you received it from an exchange) and want to pay 1 BTC, your transaction will have two outputs:
1 BTC - the payment,
9 BTC - the change to another your address.

...

What if you received your 10 BTC in 3 separate transactions to 3 different addresses, first a transaction for 1.1 BTC, then a second transaction for 3.5 BTC, and finally a transaction for 5.4 BTC?

To make it clear, I am referring to a single 10 BTC UTXO.
This could be the case if you received it from an exchange.
This could be the case in the hypothetical world where bitcoin replaces fiat money: you would receive your pay in big chunks every week or two, then spend it for coffee, utility bills, etc.
This is not the case if you are a retail merchant: you would receive multiple small payments, then join them to pay to your wholesaler.


To significantly improve your privacy, receive your transactions as smaller amounts and use a new address for every transaction.

The new address part is easy. The problem is, when you receive a payment you rarely control how it is composed of smaller outputs.

Simplicity is beauty
DannyHamilton
Legendary
*
Offline Offline

Activity: 3388
Merit: 4616



View Profile
January 24, 2015, 11:09:55 AM
 #12

To significantly improve your privacy, receive your transactions as smaller amounts and use a new address for every transaction.
The new address part is easy. The problem is, when you receive a payment you rarely control how it is composed of smaller outputs.

In many cases you can ask the person paying you to split up the payment.  In other cases, you can split it up yourself.

In your example, you could have requested 10 separate withdrawals from the exchange at approximately 1 BTC each.

As for a salary, you can either request the the salary be paid in separate smaller payments or you can split it up yourself.

Lets say you receive a monthly salary of $2000 worth of BTC.  At an exchange rate of $235/BTC that would be about 8.51 BTC per month.

If you can get the employer to pay you weekly, you've already split it down to 1.96385 BTC per week (and per output).

Even if you can't get them to do that, you can create 2 new addresses and send 4.155 BTC to one address and 4.355 BTC to the other.  The employer (and everyone else) won't be able to tell if you made a payment for a bit less than 4.4 BTC or if you are just splitting up your bitcoins.  Additionally, if they think that you made a payment, they won't be able to tell which number is your "change".

Next you can split the 4.155 into two new addresses with 2.275 and 1.88, making it even more difficult for anyone to determine what (if anything) is change.
Next you can split the 4.355 into two new addresses with 2.47 and 1. 885 making it again more difficult for anyone to determine what (if anything) is change

After that you can use those outputs however your software would like.
medUSA
Legendary
*
Offline Offline

Activity: 952
Merit: 1003


--Signature Designs-- http://bit.ly/1Pjbx77


View Profile WWW
January 24, 2015, 11:22:08 AM
 #13

Whenever you look at one single transaction, I believe you can make a general guess which is the change address but you can never be sure.

If you analyse a group of these addresses in terms of the roundness of numbers, the size of each output, the previous transactions of the output addresses, join-spending of some these addresses, and so on... you can be more certain about which are change addresses.

I don't believe we should worry about "loss" of privacy via change addresses, because there wasn't much "privacy" anyway.
dserrano5
Legendary
*
Offline Offline

Activity: 1974
Merit: 1029



View Profile
January 24, 2015, 11:36:06 AM
 #14

you can create 2 new addresses and send 4.155 BTC to one address and 4.355 BTC to the other.  The employer (and everyone else) won't be able to tell if you made a payment for a bit less than 4.4 BTC or if you are just splitting up your bitcoins. […]

Next you can split the 4.155 into two new addresses with 2.275 and 1.88, making it even more difficult for anyone to determine what (if anything) is change.
Next you can split the 4.355 into two new addresses with 2.47 and 1. 885 making it again more difficult for anyone to determine what (if anything) is change

If you split the 8.51 output in two and afterwards you give the same treatment to both, then it's obvious that those two are yours, and one could reasonably expect that the final 4 outputs are yours as well. Adding a little bit of randomization to some of the paths wouldn't hurt here. Or just use a mixer.
tonych (OP)
Legendary
*
Offline Offline

Activity: 964
Merit: 1008


View Profile WWW
January 24, 2015, 03:19:06 PM
 #15

In many cases you can ask the person paying you to split up the payment.  In other cases, you can split it up yourself.

Well, asking the paying person to split the payment might not be practical as that would force him to pay higher transaction fees.
Splitting it up yourself, I agree that would work, at the expense of blockchain bloat and UTXO bloat though.

Simplicity is beauty
Pages: [1]
  Print  
 
Jump to:  

Powered by MySQL Powered by PHP Powered by SMF 1.1.19 | SMF © 2006-2009, Simple Machines Valid XHTML 1.0! Valid CSS!