Received: from sog-mx-4.v43.ch3.sourceforge.com ([172.29.43.194] helo=mx.sourceforge.net) by sfs-ml-1.v29.ch3.sourceforge.com with esmtp (Exim 4.76) (envelope-from ) id 1TtW2S-0000lQ-Id for bitcoin-development@lists.sourceforge.net; Fri, 11 Jan 2013 04:16:16 +0000 Received-SPF: pass (sog-mx-4.v43.ch3.sourceforge.com: domain of bluematt.me designates 173.246.101.161 as permitted sender) client-ip=173.246.101.161; envelope-from=bitcoin-list@bluematt.me; helo=mail.bluematt.me; Received: from vps.bluematt.me ([173.246.101.161] helo=mail.bluematt.me) by sog-mx-4.v43.ch3.sourceforge.com with esmtp (Exim 4.76) id 1TtW2O-00088U-AT for bitcoin-development@lists.sourceforge.net; Fri, 11 Jan 2013 04:16:16 +0000 Received: from [192.168.1.3] (dhcp00757.north-resnet.unc.edu [152.23.202.249]) by mail.bluematt.me (Postfix) with ESMTPSA id 0452E557D; Fri, 11 Jan 2013 03:59:11 +0000 (UTC) Message-ID: <1357876751.1740.4.camel@localhost.localdomain> From: Matt Corallo To: Mike Hearn Date: Thu, 10 Jan 2013 22:59:11 -0500 In-Reply-To: References: <20121121151534.GA5540@vps7135.xlshosting.net> <1353523117.1085.14.camel@localhost.localdomain> <20121127211019.GA22701@vps7135.xlshosting.net> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.6.2 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit X-Spam-Score: -1.5 (-) X-Spam-Report: Spam Filtering performed by mx.sourceforge.net. See http://spamassassin.org/tag/ for more details. -1.5 SPF_CHECK_PASS SPF reports sender host as permitted sender for sender-domain -0.0 SPF_PASS SPF: sender matches SPF record 0.0 RP_MATCHES_RCVD Envelope sender domain matches handover relay domain X-Headers-End: 1TtW2O-00088U-AT Cc: Bitcoin Dev Subject: Re: [Bitcoin-development] Draft BIP for Bloom filtering X-BeenThere: bitcoin-development@lists.sourceforge.net X-Mailman-Version: 2.1.9 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 11 Jan 2013 04:16:16 -0000 On Thu, 2013-01-10 at 16:21 +0100, Mike Hearn wrote: > Here's a quick update on where we're up to. > > Thanks to Matts excellent work, I was able to test his bitcoinj and > bitcoin-qt work together today. There are a few minor tweaks needed, > but I feel like we're maybe a week away from having all the code in a > mergeable state. Here is the remaining work: > > - There are a couple of bugfixes needed on the bitcoinj side: the > fallback to downloading full blocks is problematic and needs to be > deleted, there's an API change we want First of the two is done. > > - Adjust the default FP rate requested by BCJ to be 0.0001, this is > appropriate for the latest blocks in the chain and yields 0-5 false > positives per block Is a part of the larger API changes mentioned above. > > - Introduce a new part to the filter protocol that allows clients to > control auto-expansion. This turned out to be very volatile, we saw > jumps from 0-3 FPs per block to 500 in the space of 1 block, perhaps > if a SatoshiDice transaction got into the filter. A simple yes/no flag > can suffice for now, but a better solution would be for the client to > submit templates for output scripts that would trigger auto-adding the > matched outpoint - autoexpansion is only needed in the case where the > input script doesn't contain any predictable data. For pay-to-address > and P2SH it does, so expansion doesn't help. Matt said he'd hopefully > try to look at this soon. The flags mentioned have been implemented, both to disable autoexpansion, enable it for all outputs, enable for only pay to pubkey outputs (the most likely use-case), or use a set of templates. The matched templates part isn't properly tested and I would like comments on that part (see the last few commits at https://github.com/bitcoin/bitcoin/pull/1795). > > With auto-expansion disabled, the FP rate adjusted and a bugfix on the > bcj side I was able to sync a wallet using a bloom filtered chain. > > Although it's tight, I think this work should go into 0.8 - it'll be > much more compelling to advertise it this way, we can say "Upgrade to > 0.8 and help network performance for everyone". And in the case that > we discover a showstopper problem, we just don't deploy the code that > uses the new messages into clients. Ive been missing lately, when is 0.8 targeted for freeze? Matt