Search/Lucene/Search/Query/Fuzzy.php
Zend Framework
LICENSE
This source file is subject to the new BSD license that is bundled with this package in the file LICENSE.txt. It is also available through the world-wide-web at this URL: http://framework.zend.com/license/new-bsd If you did not receive a copy of the license and are unable to obtain it through the world-wide-web, please send an email to [email protected] so we can send you a copy immediately.
- Category
- Zend
- Copyright
- Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
- License
- New BSD License
- Package
- Zend_Search_Lucene
- Subpackage
- Search
- Version
- $Id: Fuzzy.php 24593 2012-01-05 20:35:02Z matthew $
\Zend_Search_Lucene_Search_Query_Fuzzy
- Parent(s)
- \Zend_Search_Lucene_Search_Query
- Category
- Zend
- Copyright
- Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
- License
- New BSD License
Constants
Properties

float $_boost = 1
1Details- Type
- float
- Inherited_from
- \Zend_Search_Lucene_Search_Query::$$_boost

integer $_currentColorIndex = 0Current highlight color
Inherited from: \Zend_Search_Lucene_Search_Query::$$_currentColorIndex0Details- Type
- integer
- Inherited_from
- \Zend_Search_Lucene_Search_Query::$$_currentColorIndex

integer $_defaultPrefixLength = 3Default non-fuzzy prefix length
3Details- Type
- integer

array $_matches = nullMatched terms.
Matched terms list. It's filled during the search (rewrite operation) and may be used for search result post-processing
Array of Zend_Search_Lucene_Index_Term objects
nullDetails- Type
- array

$_maxDistances = array()Array of precalculated max distances
keys are integers representing a word size
array()Details- Type
- n/a

float $_minimumSimilarity = A value between 0 and 1 to set the required similarity between the query term and the matching terms.
For example, for a _minimumSimilarity of 0.5 a term of the same length as the query term is considered similar to the query term if the edit distance between both terms is less than length(term)*0.5
- Type
- float

array $_termKeys = nullArray of the term keys.
Used to sort terms in alphabetical order if terms have the same socres
nullDetails- Type
- array

\Zend_Search_Lucene_Search_Weight $_weight = null
nullDetails- Type
- \Zend_Search_Lucene_Search_Weight
- Inherited_from
- \Zend_Search_Lucene_Search_Query::$$_weight
Methods

__construct(\Zend_Search_Lucene_Index_Term $term, float $minimumSimilarity = self::DEFAULT_MIN_SIMILARITY, integer $prefixLength = null) : voidZend_Search_Lucene_Search_Query_Wildcard constructor.
| Name | Type | Description |
|---|---|---|
| $term | \Zend_Search_Lucene_Index_Term | |
| $minimumSimilarity | float | |
| $prefixLength | integer |
| Exception | Description |
|---|---|
| \Zend_Search_Lucene_Exception |

_calculateMaxDistance(integer $prefixLength, integer $termLength, integer $length) : integerCalculate maximum distance for specified word length
| Name | Type | Description |
|---|---|---|
| $prefixLength | integer | |
| $termLength | integer | |
| $length | integer |
| Type | Description |
|---|---|
| integer |

_highlightMatches(\Zend_Search_Lucene_Search_Highlighter_Interface $highlighter) : voidQuery specific matches highlighting
| Name | Type | Description |
|---|---|---|
| $highlighter | \Zend_Search_Lucene_Search_Highlighter_Interface | Highlighter object (also contains doc for highlighting) |

_initWeight(\Zend_Search_Lucene_Interface $reader) : voidConstructs an initializes a Weight for a _top-level_query_.
Inherited from: \Zend_Search_Lucene_Search_Query::_initWeight()| Name | Type | Description |
|---|---|---|
| $reader | \Zend_Search_Lucene_Interface |

createWeight(\Zend_Search_Lucene_Interface $reader) : \Zend_Search_Lucene_Search_WeightConstructs an appropriate Weight implementation for this query.
| Name | Type | Description |
|---|---|---|
| $reader | \Zend_Search_Lucene_Interface |
| Type | Description |
|---|---|
| \Zend_Search_Lucene_Search_Weight |
| Exception | Description |
|---|---|
| \Zend_Search_Lucene_Exception |

execute(\Zend_Search_Lucene_Interface $reader, \Zend_Search_Lucene_Index_DocsFilter | null $docsFilter = null) : voidExecute query in context of index reader It also initializes necessary internal structures
Query specific implementation
| Name | Type | Description |
|---|---|---|
| $reader | \Zend_Search_Lucene_Interface | |
| $docsFilter | \Zend_Search_Lucene_Index_DocsFilter | null |
| Exception | Description |
|---|---|
| \Zend_Search_Lucene_Exception |

getBoost() : floatGets the boost for this clause.
Inherited from: \Zend_Search_Lucene_Search_Query::getBoost()Documents matching this clause will (in addition to the normal weightings) have their score multiplied by boost. The boost is 1.0 by default.
| Type | Description |
|---|---|
| float |

getDefaultPrefixLength() : integerGet default non-fuzzy prefix length
| Type | Description |
|---|---|
| integer |

getQueryTerms() : arrayReturn query terms
| Type | Description |
|---|---|
| array |
| Exception | Description |
|---|---|
| \Zend_Search_Lucene_Exception |

highlightMatches(string $inputHTML, string $defaultEncoding = '', \Zend_Search_Lucene_Search_Highlighter_Interface | null $highlighter = null) : stringHighlight matches in $inputHTML
Inherited from: \Zend_Search_Lucene_Search_Query::highlightMatches()| Name | Type | Description |
|---|---|---|
| $inputHTML | string | |
| $defaultEncoding | string | HTML encoding, is used if it's not specified using Content-type HTTP-EQUIV meta tag. |
| $highlighter | \Zend_Search_Lucene_Search_Highlighter_Interface | null |
| Type | Description |
|---|---|
| string |

htmlFragmentHighlightMatches(string $inputHtmlFragment, string $encoding = 'UTF-8', \Zend_Search_Lucene_Search_Highlighter_Interface | null $highlighter = null) : stringHighlight matches in $inputHtmlFragment and return it (without HTML header and body tag)
Inherited from: \Zend_Search_Lucene_Search_Query::htmlFragmentHighlightMatches()| Name | Type | Description |
|---|---|---|
| $inputHtmlFragment | string | |
| $encoding | string | Input HTML string encoding |
| $highlighter | \Zend_Search_Lucene_Search_Highlighter_Interface | null |
| Type | Description |
|---|---|
| string |

matchedDocs() : arrayGet document ids likely matching the query
It's an array with document ids as keys (performance considerations)
| Type | Description |
|---|---|
| array |
| Exception | Description |
|---|---|
| \Zend_Search_Lucene_Exception |

optimize(\Zend_Search_Lucene_Interface $index) : \Zend_Search_Lucene_Search_QueryOptimize query in the context of specified index
| Name | Type | Description |
|---|---|---|
| $index | \Zend_Search_Lucene_Interface |
| Type | Description |
|---|---|
| \Zend_Search_Lucene_Search_Query |

reset() : voidReset query, so it can be reused within other queries or with other indeces
Inherited from: \Zend_Search_Lucene_Search_Query::reset()
rewrite(\Zend_Search_Lucene_Interface $index) : \Zend_Search_Lucene_Search_QueryRe-write query into primitive queries in the context of specified index
| Name | Type | Description |
|---|---|---|
| $index | \Zend_Search_Lucene_Interface |
| Type | Description |
|---|---|
| \Zend_Search_Lucene_Search_Query |
| Exception | Description |
|---|---|
| \Zend_Search_Lucene_Exception |

score(integer $docId, \Zend_Search_Lucene_Interface $reader) : floatScore specified document
| Name | Type | Description |
|---|---|---|
| $docId | integer | |
| $reader | \Zend_Search_Lucene_Interface |
| Type | Description |
|---|---|
| float |
| Exception | Description |
|---|---|
| \Zend_Search_Lucene_Exception |

setBoost(float $boost) : voidSets the boost for this query clause to $boost.
Inherited from: \Zend_Search_Lucene_Search_Query::setBoost()| Name | Type | Description |
|---|---|---|
| $boost | float |