diff options
author | sra@chromium.org <sra@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-08 23:00:29 +0000 |
---|---|---|
committer | sra@chromium.org <sra@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-08 23:00:29 +0000 |
commit | 04ca1bc65afb76ea30698c25f24599d20119e3d2 (patch) | |
tree | 2bb65e974d478f4d607b83f6a84a56c01f501ac0 /courgette/difference_estimator.h | |
parent | 9adf1dcf3281408560267787eddcc767566b425f (diff) | |
download | chromium_src-04ca1bc65afb76ea30698c25f24599d20119e3d2.zip chromium_src-04ca1bc65afb76ea30698c25f24599d20119e3d2.tar.gz chromium_src-04ca1bc65afb76ea30698c25f24599d20119e3d2.tar.bz2 |
Move Courgette
from src\third_party\courgette
to src\courgette and src\courgette\third_party
Fixed #includes
Added properties to ignore generated files:
C:\c5\src>svn pg svn:ignore courgette
courgette.xcodeproj
courgette.sln
courgette_fuzz.vcproj
courgette_lib.vcproj
courgette_minimal_tool.vcproj
courgette_tool.vcproj
courgette.vcproj
courgette_unittests.vcproj
SConstruct
courgette_fuzz.scons
courgette_lib.scons
courgette_main.scons
courgette_minimal_tool.scons
courgette.scons
courgette_tool.scons
courgette_unittests.scons
Review URL: http://codereview.chromium.org/115062
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@15692 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'courgette/difference_estimator.h')
-rw-r--r-- | courgette/difference_estimator.h | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/courgette/difference_estimator.h b/courgette/difference_estimator.h new file mode 100644 index 0000000..295ff93 --- /dev/null +++ b/courgette/difference_estimator.h @@ -0,0 +1,58 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +// A DifferenceEstimator class provides a means for quickly estimating the +// difference between two regions of memory. + +#ifndef COURGETTE_DIFFERENCE_ESTIMATOR_H_ +#define COURGETTE_DIFFERENCE_ESTIMATOR_H_ + +#include <vector> + +#include "courgette/region.h" + +namespace courgette { + +// A DifferenceEstimator simplifies the task of determining which 'Subject' byte +// strings (stored in regions of memory) are good matches to existing 'Base' +// regions. The ultimate measure would be to try full differential compression +// and measure the output size, but an estimate that correlates well with the +// full compression is more efficient. +// +// The measure is asymmetric, if the Subject is a small substring of the Base +// then it should match very well. +// +// The comparison is staged: first make Base and Subject objects for the regions +// and then call 'Measure' to get the estimate. The staging allows multiple +// comparisons to be more efficient by precomputing information used in the +// comparison. +// +class DifferenceEstimator { + public: + DifferenceEstimator(); + ~DifferenceEstimator(); + + class Base; + class Subject; + + // This DifferenceEstimator owns the objects returned by MakeBase and + // MakeSubject. Caller continues to own memory at |region| and must not free + // it until ~DifferenceEstimator has been called. + Base* MakeBase(const Region& region); + Subject* MakeSubject(const Region& region); + + // Returns a value correlated with the size of the bsdiff or xdelta difference + // from |base| to |subject|. Returns zero iff the base and subject regions + // are bytewise identical. + size_t Measure(Base* base, Subject* subject); + + private: + std::vector<Base*> owned_bases_; + std::vector<Subject*> owned_subjects_; + DISALLOW_COPY_AND_ASSIGN(DifferenceEstimator); +}; + +} // namespace + +#endif // COURGETTE_DIFFERENCE_ESTIMATOR_H_ |