Skip to main content

Basic design decisions for a commerce search setup ( with an ATG Search view)

In this blog I would like to explain the basic set of configuration/design decisions needed to setup an ATG search project. Most of these design decisions are common for all Enterprise search applications.


1. Decide the searchable properties :   This means the properties that the business want the user to search in the ecommerce platform. In ATG search these are configured as the text properties in the product-catalog-output-config.xml ( the definitionFile of the \atg\commerce\search\ProductCatalogOutputConfig). Usually the displayName of product/sku, displayName of department/category/sub-category, skuId, brandName are the properties configured as searchable.

2. Decide the search refinement properties or the faceted properties :  After a user search for a keyword, search refinement is the next step done to filter his results. ATG supports the search refinement using the Faceted Search concept. Read more about facted search @ http://en.wikipedia.org/wiki/Faceted_search. Here we need to decide which are global and which are local facets. Global facets are the search refinements common to all the category/department.For example Price/Brand are the facets common for all skus. Local facets are the search refinements specific to some category/departments. For example New Release/Coming Soon are the facets specific to Physical Media products like Vidoe/DVD/Blue-ray. In ATG search these are configured as the meta properties in the product-catalog-output-config.xml. Facet definition against the category can be done from the ATG - BCC. Read more about how to create facets @ http://tips4ufromsony.blogspot.in/2012/02/search-facets-how-to-create-new-search.html . For text queries we normally use refineConfig=”map” and engine itself determines the right refine config.

3. Decide the search sort properties :  All the ecommerce site should allow the user to sort the search results based on some properties. You need to decide which are the properties and you need to add these properties as the meta properties in the product-catalog-output-config.xml. For sorting you need to specify the below parameters in the search engine request xml.
        a. docSort="predicate"  --> This attribute specifies the criterion for sorting the result groups returned by ATG Search. If the docSort parameter is not specified in the page, its value is taken from the component’s defaultSortMode property. The default value is relevance, which means the result groups are sorted by their relevance scores.
       b. docSortOrder=""  --> Ascending or descending order. If the sortOrder parameter is not specified in the page, its value is taken from the component’s defaultSortOrder property. The default value is descending
c. sortProp=""   --> This attribute specifies the property to sort on if the value of the docSort attribute is numprop or strprop.
d. docSortPred=".."  --> This attribute specifies the set of properties used for the default predicate sorting. An example can be docSortPred="relevance:descending|numprop:descending:childSKUs.skuFeature:1

4. Decide the refinment related search engine request parameters :  refineConfig="name" refineMax="max" refineTop="top" refineMin="min"  are the search engine request parameters related to facet.
• Max --> Maximum number of facet properties to return, even if the facet set could generate more. The default value is 0, which means no calculation is made.
• Top --> Maximum number of facet property values (per property). The values are selected in sort order, which usually is in terms of the number of index items that has each value. The default value is 5.
• Min --> Minimum size of a facet property value, in terms of the number of index items with that value. The default value is 0.

5. Decide whether you need the related search keywords :  If your ecommerce site wnat to display related search keywords , you need to specify " feedback=true" in the search engine request xml. For example if you search for "apple",  related searches will display "apple ipad , apple ipod,..."

6. Decide how many search result you want to display in each page <pagination> :  Pagination of the search result setup has the following parameters in the request xml
      a. pageSize  --> Specify the total number of results in a page
b. pageNum   -->  Specify the current page number


7. Decide whether you need automatic spell correction in the search result :  This can be set in request xml as autospell="true" to enable the spell check for ATG search . Make sure that terms like product names are added to the dictionary to avoid search treating them as miss spelt words.

8. Decide the maximum search results :  For performance related reasons, you may need to restrict the search results to a maximum count. This can be done in ATG search by using the below request parameter.
a. pool=500 --> sets the maximum number of results in search to 500.
b. retMax=6000 --> Limits the number of top candidates that are matched in detail for their final relevancy.

9. Decide whether you go for an AND/OR of the search keywords :  If the search query is " oracle atg" then whether the search need to run for  " oracle AND atg"  or   " oracle OR atg"  is decided based on the   mode=AND  property of the request parameter.

10. Decide whether you need to create synonym for some search keywords :  If the ecommerce site has some products with name baby and the business want to display these products for a search with keyword  child/ boy / girl / kid ,  then you need to create search synonyms using the BCC - Search Admin - Term Dictionary to give these terms as the synonym of baby.

11. Decide whether you need to specify a search redirection rule :  Search Redirection rule is used to redirect a keyword search to a a different  URL. Read more about atg search redirect rules @ http://tips4ufromsony.blogspot.in/2012/02/atg-search-how-to-define-search.html

12. Decide whether you need to specify a search result exclusion : Search result exclusion rule is used to specify the rules like " if the search query contains some phrase/word/pattern, do not return products in category/Id/name is...". Read more about atg search result exclusion @ http://tips4ufromsony.blogspot.in/2012/02/atg-search-how-to-define-search.html

13. Decide whether you need to specify a search result positioning rule: Search result positioning  is used to define rules that move certain search results higher on the results list. Read more about atg search result positioning  @ http://tips4ufromsony.blogspot.in/2012/02/atg-search-how-to-define-search.html

14. Decide whether you need to specify a search property prioritization: Search property prioritization is used to define the priority and weightage of different properties for determining the order of search results. Read more about atg search property prioritization @ http://tips4ufromsony.blogspot.in/2012/02/atg-search-how-to-define-search.html

15. Decide how many search engines you need : Based on the performance requirement of the ecommerce site, create the Search Project @ BCC - Search Admin and add the search engine hosts. Read more about search project creation and search engine host set up @  http://tips4ufromsony.blogspot.com/2012/01/atg-search-how-to-create-search-project.html.

16. Decide whether you need to have the search suggestions module : Based on the search results, if no search results are returned the search suggestions module can suggest for some other query/results.

17. Decide whether you need Type ahead functionality : ATG 9 is supporting the Type ahead functionality,  which provides suggestions for search queries as you start typing some search key words.

18. Decide whether you need Insta search :  Instant search  or Insta search will give you search results as you type some search keywords.

Comments

  1. Hi Sony
    I am currently facing a problem with ATGSearch which I have mentioned here.
    https://forums.oracle.com/forums/thread.jspa?threadID=2361169
    If possible please take a look at it. Appreciate your help

    ReplyDelete
  2. will look into it and update your oracle forum entry :-)

    ReplyDelete
  3. Hi Sony,
    In request i enabled feedback="true"

    As per ATG docs, I am using the OOTB property QueryRequest.Response.getFeedbackReport() to display related search items. Using this object we can retrieve the values using the property getRelatedPhraseTerms().getTerms(). But it always giving me an empty FeedbackReport. Do i need to any setup before indexing? I really Appreciate your help

    Thanks
    Venkat

    ReplyDelete
  4. Try this :

    facetSearchResponse.searchResults.feedbackReport.relatedSentenceTerms.terms

    ReplyDelete
  5. Excellent Article

    Aravind

    ReplyDelete
  6. Hi Sony
    I am currently facing a problem with ATGSearch which I have mentioned here.
    https://forums.oracle.com/forums/thread.jspa?threadID=2453031.
    If possible please take a look at it. Appreciate your help

    ReplyDelete

Post a Comment

Popular posts from this blog

Search Facets - how to create a new search facets in ATG Search

A Facet is a search refinement element that corresponds to a property of a commerce item type. ATG supports the search result refinement using the Faceted Search concept. Read more about facted search @  http://en.wikipedia.org/wiki/Faceted_search . Facet can either be ranges or specific values. Each facet is stored in the RefinementRepository as a separate refineElement repository item. Facets are divided into Global and Local facets. Global facets apply to all the categories and local facets only to the category in which they are created. For example Price/Brand can be considered as the facets that are common for all skus and New Release/Coming Soon can be considered as the facets that are specific to Physical Media products like Vidoe/DVD/Blue-ray/Books. We can use the ATG BCC - Merchandising UI to create facets. The Faceting Property depends on the meta-properties defined in the \atg\commerce\search\product-catalog-output-config.xml ( the definitionFile of the \atg\commerce\s

ATG - quick reference to commonly used DSP Tags

In this blog, I would like to give a quick reference to the most commonly used DSP Tags.Note that in this DSP tag details : bean refers to a Nucleus path, component name, and property name param refers to a Page parameter value refers to a Static-value var refers to a EL variable id refers to a scripting variable ============================================================== 1.dsp:importbean     example: <dsp:importbean bean="/atg/dynamo/droplet/Switch"/> ============================================================== 2.dsp:page     usage: It encloses a JSP. The dsp:page invokes the JSP handler, which calls the servlet pipeline and generates HTTPServletRequest.    example:    <dsp:page> ..... </dsp:page> ============================================================== 3.dsp:include     usage: Embeds a page fragment in a JSP.     example:   <dsp:include src="/myPage/ResultPage.jsp" flush="true">            

GC Log Analyzer from IBM

This blog is about the GC( garbage collection) log analyzer from IBM. If you have a GC log and you want to analyze the file,  this IBM tool will help you with some graphical analyzer and some recommendations. You can download it from the following URL : https://www.ibm.com/support/pages/ibm-pattern-modeling-and-analysis-tool-java-garbage-collector-pmat Please find below some screenshots and details that might help you. 1. Screenshot 1: 2. Screenshot 2 : 3. Screenshot 3 : 4. Screenshot 4:

ATG Search and Search engine activity log

We could use the SearchEngineActivity log files to get the request/response to the search engine from a commerce instance. This folder is located in each commerce instance or the instances from which the call to the search engine is done. The SearchEngineActivity log file folder can be configured @ SearchEngineService component ( /dyn/admin/nucleus/atg/search/routing/SearchEngineService). To get the log files for the search engine calls, you need to specify the SearchEngineService.dumpingRequests as true. Then you need to specify the engineActivityPath as the folder in which you need the SearchEngineActivity logs. Below you could find my SearchEngineActivity log folder. Each successful call to the search engine from the commerce instance will create 5 files in the SearchEngineActivity folder : namely  request, response, search engineinfo, stack trace and response row . Each file name start with a specific sequence. You could see that the file name like "2630436491482_

ATG Search - how to create a search project

Here I am going to explain how we can create a new ATG search project. It involves 3 steps --> Specify the general search project settings, Specify the content of search indexing and Build the index. Below I am elaborating the different steps involved with screen shots : 1. Go to Search Project Administration ui @  BCC and Click the button "New Search Project" to create a new search project. 2. Specify the search project name, give description and click the button "Create Search Project". 3. Click the button "Add Content" to add the search project content. 4. Specify the content name, select the content type and specify the IndexingOutputConfig path if the content type is ATG repository. Specify the remote host and port if you are using another server for fetching the content. 5. Click the content in the left side and expand the advanced option to specify the language and other customizations. 6. Click the