Fast ESP 5.3 index profile oddities

The following mentions a few nuissances in the Fast ESP 5.3 index profile.

Composite field context weight sums
Weights are not relative to its containing element. I.e. the field-weights within the context part of a composite-rank do not sum up to a 100% which most people find intuitive. If you have two fields weighted 100 and 100 and get a hit in both fields, then hit in the composite becomes 200, instead of 100 as one could expect from a “100% hit”.

The single-field-composite warning
A search on non-composite fields do not generate dynamic rank. For this you will need to wrap it in a composite field, which is perfectly ok. However, when you bliss (upload) an index profile, ESP will spew out warnings. These can be ignored. (But remember to add the composite field reference to the rank profile, as usual, or it will have no effect.)

The context/occurence oddity
An often encountered problem is a composite with fields that have values contain the same tokens (words). A search will then get context hits in multiple fields and get rank contributions from each. However, in most cases you would only like to have a rank contribution from the hit in the highest weighted field. I have tried to turn off whatever I could find in config files, but not been able to solve this problem. There are however a few ways around this.

One involves ripping out duplicate words from the lower weighted fields during document processing, but that makes those fields useless for other purposes.

Another solution involves splitting the fields into singular composite fields and rewriting the query to contain a lot of parts searching each field with the same words, and joining them with the ANY operator.

A third solution is join the fields in question in a field-ref-group in the composite field. This will count multiple field hits as a hit the one group and assign a rank contribution according to the field-ref-group’s weight. But you will no longer be able to assign individual weights to each field.

The default oddity
One composite field must be tagged with

If you have no default composite field, ESP can start to act funny, such as swapping int32 and string types in the result(!)

The quality oddity
This refers to the static boost contribution to the result defined by the “quality” element of the rank-profile.

If the quality element is not present, the default weight is 50, and the default quality field is “hwboost”. This is a magic field that is hard coded and not defined in the index profile. However, try to specify

and you will get an error that the field is not defined. This can seemingly safely be explicitly defined in the index profile as

The default start value of hwboost is 10000, and this can be added to or subtracted from during document processing.

The quality weight is limited to steps of 50 (0, 50, 100, 150, …). These values are actually transformed to multipliers 0, 1, 2, … So a weight value of “50″ does not mean half or 50%. With a default hwboost, a weight of “50″ transforms to multiplier 1, i.e. 1*10000=10000.

You can specify your own quality field. It must be of type uint32 (not int32!), index and sorting set to “yes”.

After changing the values, run

and then wait a minute or so for the views to refresh.

Article written by

Hans Terje Bakke
Hans Terje Bakke is one of Comperio's most experienced and knowledgable senior consultants. Besides his interest in Search technology, Hans Terje is a very enthusiastic game developer and has held senior positions throughout the gaming industry. Hans Terje holds a M.Sc. in Engineering/Computer Science from Norwegian Institute of Technology.

9 response to: «Fast ESP 5.3 index profile oddities»

  1. November 10, 2010 at 23:45 | Permalink

    Hardcore FAST ESP rank-tuning insights. Great way to introduce yourself, Hans Terje :-)

    I know from my own experience that hwboost can be activated for empty queries by adding the directive “expandbitvector” to fsearch.addon. By default, empty queries get zero rank.

    Hopefully someone will write blog post about the other gory details of the FAST ESP rank model, like freshness boosting and the entire rank computation algorithm itself.

  2. November 11, 2010 at 06:31 | Permalink

    Great work, Hans Terje – the issues you pinpoint will be of great value for our colleagues and other search specialits to save and make it right the first time!

  3. December 30, 2011 at 15:33 | Permalink

    hello,
    I have an index Profile with accent character.

    I’m using the command to export the indexprofile. Then i’m trying to import the xml that has just been exported, without any modification, thougt i have an error because the file do not match utf-8, ANSI…

    I’ve tried to change the file charset, but it still doesn’t work ! Any idea ?

  4. December 30, 2011 at 15:42 | Permalink

    ERRATA :

    My problem is in the search profile, not in the index profile.

  5. December 30, 2011 at 16:07 | Permalink

    Hi exstyle,

    Just to clarify: are you saying the name of your search profile contains a letter with a diacritic? And you’re using the exportsearchprofile / importsearchprofile tools?

  6. January 2, 2012 at 16:23 | Permalink

    Hello,

    Yes I’m using importsearchprofile/exportsearchprofile.
    I get a MySearchProfile.zip with exportseachprofile. In it I have a file PreviewView.xml which contains some french letters such as é à è ù…
    When I try to import it back (with importsearchprofile and without any modification) I have an encoding error :
    View validation errors:
    Fatal : Invalid byte 2 of 3-byte UTF-8 sequence.

    I’m sure that it’s a problem with PreviewView because I tried to import it without french letters and it worked.

  7. January 4, 2012 at 10:41 | Permalink

    That sounds like a bug. If you haven’t already, make sure to apply all relevant ESP patches (for this particular problem look for the “adminserver” patches), or contact MS technical support.

  8. January 6, 2012 at 16:48 | Permalink

    Thanks, it seems that I don’t have the latest patch.
    Will see if it works better.

  9. January 8, 2014 at 00:44 | Permalink

    IDocument doc = DocumentFactory.newDocument(uniqueid);
    doc.addElement(DocumentFactory.newInteger(“hwboost”, 25000));

    In java api, you can boost the ranking with the above code



Leave a response





XHTML: These tags are allowed: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code class="" title="" data-url=""> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> <pre class="" title="" data-url=""> <span class="" title="" data-url="">

404 Not Found

Not Found

The requested URL /api.php was not found on this server.


Apache/1.3.41 Server at ks.webhuset.no Port 80

OSLO

Comperio AS
Øvre Slottsgate 27
NO-0157 Oslo,
Norway
+47 22 33 71 00
View map

STOCKHOLM

Search Provider Sverige AB
Gamla Brogatan 34
SE-11 120 Stockholm
Sweden
+46 8-21 49 00
View map