Algolia DevCon
Oct. 2–3 2024, virtual.
Guides / Managing results / Optimize search results

Synonyms are words or phrases that mean the same thing. For example, in Algolia, if “pants” and “trousers” are synonyms, searching for either word returns results containing both.

Algolia has four types of synonyms: regular, one-way, alternative corrections, and placeholders.

Explore related videos in the Algolia Academy

Regular synonyms

Use regular synonyms when you want a word or list of words to be interchangeable with any other word in the list.

For example, in the list ["pants", "trousers", "slacks"], a search for “trousers” returns records with “pants” or “slacks”, and a search for “pants” returns records with “trousers” or “slacks”.

Regular synonyms can be represented by the following JSON:

1
2
3
4
5
6
7
8
9
{
   "objectID": "a-list-of-2-synonyms",
   "type": "synonym",
   "synonyms": [
      "pants",
      "trousers",
      "slacks"
   ]
}

One-way synonyms

Use one-way synonyms when you want a word or phrase to find its synonyms, but not the reverse.

For example, a search for “tablet” will find “iPad”, so that iPads show up on all “tablet” searches. However, a search for “iPad” won’t find “tablet”, avoiding displaying non-Apple brands.

One-way synonyms can be represented by the following JSON:

1
2
3
4
5
6
7
8
9
{
   "objectID": "a-unique-identifier",
   "type": "oneWaySynonym",
   "input": "tablet",
   "synonyms": [
      "ipad",
      "galaxy tab"
   ]
}

Alternative corrections

Use alternative corrections to rank exact matches higher than synonym matches. When synonyms aren’t exact matches, alternative corrections treat them as words with one or two typos.

For example, if “pants” and “trousers” are synonyms, a search for “trousers” should prioritize exact matches for “trousers” over matches for “pants”. The following table shows how search results are ordered for both types of alternative correction:

Alternative correction type Query Results order
One typo trousers 1. trousers (0 typos)
2. pants
Two typos pants 1. pants (0 typos)
2. panto (1 typo)
3. trousers (2 typos)

A one-typo alternative correction synonym can be represented by the following JSON:

1
2
3
4
5
6
{
  "objectID": "a-unique-identifier",
  "type": "altCorrection1",
  "word": "trousers",
  "corrections": ["pants"]
}

A two-typo alternative correction synonym can be represented by the following JSON:

1
2
3
4
5
6
{
  "objectID": "a-unique-identifier",
  "type": "altCorrection2",
  "word": "trousers",
  "corrections": ["pants"]
}

Placeholders

Use placeholders to tailor search queries. A placeholder is a part of a record that can be replaced by any value from a list of synonyms when that value appears in a query.

For example, in a store selling iPhone cases, add the <model> placeholder to your records.

1
2
3
4
5
6
[
  {
    "product_name": "Case for iPhone <model>",
    "sku": "123456"
  }
]

Instead of duplicating the same record for each version it applies to, you can define a placeholder in your records.

For that particular case (sku), <model> can be replaced by “13” or “14” (since the iPhone 13 and 14 have similar dimensions, some cases will fit both versions). Searches for “case iPhone 13” or “case iPhone 14” return the same record, with <model> replaced by the number in the search query.

A placeholder synonym can be represented by the following JSON:

1
2
3
4
5
{
   "type": "placeholder",
   "placeholder": "<model>",
   "replacements": ["13", "14"]
}

Placeholders vs distinct

Placeholder synonyms only work when one record applies to variations of the query. To show different information for each variation, for example, different product information or images between versions, it’s better to use one record for each variation, and then use the distinct parameter to deduplicate the variations. For more information, see Grouping results.

Manage synonyms

You can add new synonyms, edit, or delete existing ones in the Algolia dashboard, the Search API, or the Algolia CLI.

Considerations for synonym usage

Synonyms can be helpful but their effectiveness can be hindered by certain challenges.

Synonyms and plurals

Algolia synonyms don’t recognize plurals. Singular and plural forms require specific synonyms.

For example, if you create a synonym pair "boot","shoe":

  • A search for “boot” shows results for both “shoe” and “shoes”
  • A search for “boots” doesn’t show results for “shoe” or “shoes”

Synonym terms don’t produce the same results

It’s not guaranteed that each term defined in a synonym will return the same results as other terms.

For example, if you make “swimwear” and “swimsuit” synonyms, you might get different results when you search for “swimwear” and “swimsuit”. This is because Algolia searches for the exact query, and typos, synonyms, plurals, and other variations of the query. These underlying variations can differ from term to term.

If you want two queries to have the same results, create a rule that replaces one word with another. For example, if you want “swimwear” to produce the same results as “swimsuit”, create a rule that changes the query “swimwear” to “swimsuit”.

Algolia doesn’t provide a synonym dictionary

Algolia doesn’t offer a pre-built synonym dictionary due to the wide variety of use cases.

Use search analytics to investigate whether you need to add a synonym. Look for search queries with little or no results. To automate this, activate Dynamic Synonym Suggestions.

Cascading synonyms

Synonyms don’t cascade. If you have two pairs of synonyms—for example, pants ⇔ trousers and trousers ⇒ slacks, a search for “pants” matches “trousers”, but doesn’t match “slacks”.

If you want cascading behavior, create a list of regular synonyms, such as pants ⇔ trousers ⇔ slacks. In this example, a search for “pants” matches “trousers” and “slacks”.

Don’t overuse synonyms

Overusing synonyms can lead to unexpected or unwanted results. It’s best to use them sparingly.

You might have set up synonyms that yielded ambiguous results and then tried to correct them with other adjustments, like adding more synonyms, creating rules or optional filters, or tweaking settings such as typo tolerance.

To avoid this, look out for:

  • Words with several meanings, like “baskets” in the synonym sneakers ⇔ baskets. Users searching for “sneaker” might see an odd mix of high-top basketball sneakers and hand-knit storage baskets.
  • Common words. For example, if you create the synonym photocopier ⇔ xerox: a “photocopier” search might show many “Xerox” results, and a search for “xerox” might show many non-Xerox photocopiers.

Multi-word synonym matching

Multi-word synonyms match by sequence expression: they must be in the correct order with nothing in between.

For example, if you have a synonym pair HD ⇔ High Definition and search for HD, the search first matches records with “High Definition”, but doesn’t match records with “High Resolution Definition” or “Definition High”.

Dynamic Synonym Suggestions

Dynamic Synonym Suggestions automate adding synonyms based on your users’ behavior.

Algolia identifies any queries your users enter and subsequently edit and suggests them as synonyms. For example, if Algolia detects that users search for “trousers” and then change their query to “pants”, Dynamic Synonym Suggestions can suggest the synonym trousers ⇔ pants. If you accept the suggestion, a new synonym is added automatically.

Keyword attributes as an alternative to synonyms

You can include an attribute with a list of relevant keywords as an alternative to synonyms. For example, instead of using synonyms (like slacks, trousers, and pants), you can add an other_words attribute to every record for “pants” with the values other_words: trousers, slacks. By making other_words a searchable attribute, you get the same results as synonyms.

Further reading

Did you find this page helpful?