Advanced Search development - 'homemade' fuzzy logic...

Author Message

steve walker

Friday 03 September 2004 9:19:24 am

Paul and Hans,

Got it working exactly as I hoped for. The basic code with text form boxes is:

{let carat=ezhttp( 'search_carat', 'get' )}
{let clarity=ezhttp( 'search_clarity', 'get' )}

{let carat_in='('|concat($carat,')') 
let clarity_in='('|concat($clarity,')')

let page_limit=3

let exactresults=fetch(content,tree,hash(parent_node_id, 59, limit, $page_limit,
attribute_filter,  
array(and,array('stone_product/carat','in',$carat_in), 
array('stone_product/clarity','in',$clarity_in))))

let fcarat_in='%'|concat($carat,'%')  
let fclarity_in='%'|concat($clarity,'%')

let exactmatches=count($exactresults)
let fuzzyresults=fetch(content,tree,hash(parent_node_id, 59, limit, sub($page_limit,$exactmatches),
attribute_filter,  
array(and,array('stone_product/fcarat','like',$fcarat_in), 
array('stone_product/fclarity','like',$fclarity_in))))
}

<form action="{"/gia_certificated_diamonds"|ezurl}" method="get">
<div class="maincontentheader">
<h1>Stone Search</h1>
</div>

<div class="block">
<label>{"Carat"|i18n("design/standard/content/search")}</label><div class="labelbreak"></div>
<input class="box" type="text" size="40" name="search_carat" value="{$carat|wash}" />
</div>

<div class="block">
<label>{"Clarity"|i18n("design/standard/content/search")}</label><div class="labelbreak"></div>
<input class="box" type="text" size="40" name="search_clarity" value="{$clarity|wash}" />
</div>

<div class="break"></div>
</div>

<div class="buttonblock'">
<input class="button" type="submit" name="SearchButton" value="{'Search'|i18n('design/standard/content/search')}" />
</div>

<h2>Display the Results</h2>
<br>

exact results:
{section var=exactresults loop=$exactresults sequence=array(bglight,bgdark)}

   {node_view_gui view=line content_node=$exactresults.item}<br>
  
{/section}
<br>
fuzzy results:
{section var=fuzzyresults loop=$fuzzyresults sequence=array(bglight,bgdark)}

   {node_view_gui view=line content_node=$fuzzyresults.item}<br>
  
{/section}

</form>


{/let}
{/let}
{/let}

I've now got to add more fields and change them to dropdown lists, but the guts is well and truly there.

Many thanks for your help.

Regards Steve.

http://www.oneworldmarket.co.uk

Paul Borgermans

Friday 03 September 2004 9:54:17 am

you're welcome :-)

good luck on your further journey with ez publish!

-paul

eZ Publish, eZ Find, Solr expert consulting and training
http://twitter.com/paulborgermans

steve walker

Tuesday 07 September 2004 1:26:50 am

Hi there,

Have realised there is one issue stopping this working as it should - I think (hope) its only a minor tweak.

The problem is that the fuzzy values should always have the non-fuzzy values in their array as well. To try to explain, if I have:

colour = G
fuzzy colours = F H

size = 4
fuzzy size = 3 5

The fuzzy fetch needs to be able to look for the colour 'G' as well as size '3' or '5'. In the current code the fuzzy fetch only looks at stones that have values totally different (but one step away) - to cure this the fuzzy values would need to have the exact ones in there, so the example would change to:

colour = G
fuzzy colours = F G H

size = 4
fuzzy size = 3 4 5

The problem now is duplicates found in the two fetches.

Is it possible to take two fetches and make a comparison such that the second fetch removes any duplicates which it finds through checking the first fetch?

Many thanks, Steve.

http://www.oneworldmarket.co.uk

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 19 2025 07:05:56
Script start
Timing: Jan 19 2025 07:05:56
Module start 'layout'
Timing: Jan 19 2025 07:05:56
Module start 'content'
Timing: Jan 19 2025 07:05:57
Module end 'content'
Timing: Jan 19 2025 07:05:57
Script end

Main resources:

Total runtime1.0021 sec
Peak memory usage4,096.0000 KB
Database Queries56

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0084 589.8281152.6406
Module start 'layout' 0.00840.0036 742.468839.9375
Module start 'content' 0.01210.9886 782.4063535.1328
Module end 'content' 1.00070.0014 1,317.539114.2578
Script end 1.0021  1,331.7969 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00320.3169160.0002
Check MTime0.00130.1312160.0001
Mysql Total
Database connection0.00120.123110.0012
Mysqli_queries0.947894.5792560.0169
Looping result0.00050.0513540.0000
Template Total0.968296.620.4841
Template load0.00190.186520.0009
Template processing0.966396.425620.4831
Template load and register function0.00030.025310.0003
states
state_id_array0.00090.086310.0009
state_identifier_array0.00190.189120.0009
Override
Cache load0.00150.1515300.0001
Sytem overhead
Fetch class attribute can translate value0.00110.109720.0005
Fetch class attribute name0.00060.058140.0001
XML
Image XML parsing0.00080.075720.0004
class_abstraction
Instantiating content class attribute0.00000.000840.0000
General
dbfile0.00180.1839170.0001
String conversion0.00000.001140.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
3content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
8content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
1content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
4content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 19
 Number of unique templates used: 7

Time used to render debug report: 0.0001 secs