Multiplexer token filter

Multiplexer token filter

A token filter of type multiplexer will emit multiple tokens at the same position, each version of the token having been run through a different filter. Identical output tokens at the same position will be removed.

If the incoming token stream has duplicate tokens, then these will also be removed by the multiplexer

Options

filters

a list of token filters to apply to incoming tokens. These can be any token filters defined elsewhere in the index mappings. Filters can be chained using a comma-delimited string, so for example “lowercase, porter_stem” would apply the lowercase filter and then the porter_stem filter to a single token.

Shingle or multi-word synonym token filters will not function normally when they are declared in the filters array because they read ahead internally which is unsupported by the multiplexer

preserve_original

if true (the default) then emit the original token in addition to the filtered tokens

Settings example

You can set it up like:

  1. resp = client.indices.create(
  2. index="multiplexer_example",
  3. settings={
  4. "analysis": {
  5. "analyzer": {
  6. "my_analyzer": {
  7. "tokenizer": "standard",
  8. "filter": [
  9. "my_multiplexer"
  10. ]
  11. }
  12. },
  13. "filter": {
  14. "my_multiplexer": {
  15. "type": "multiplexer",
  16. "filters": [
  17. "lowercase",
  18. "lowercase, porter_stem"
  19. ]
  20. }
  21. }
  22. }
  23. },
  24. )
  25. print(resp)
  1. response = client.indices.create(
  2. index: 'multiplexer_example',
  3. body: {
  4. settings: {
  5. analysis: {
  6. analyzer: {
  7. my_analyzer: {
  8. tokenizer: 'standard',
  9. filter: [
  10. 'my_multiplexer'
  11. ]
  12. }
  13. },
  14. filter: {
  15. my_multiplexer: {
  16. type: 'multiplexer',
  17. filters: [
  18. 'lowercase',
  19. 'lowercase, porter_stem'
  20. ]
  21. }
  22. }
  23. }
  24. }
  25. }
  26. )
  27. puts response
  1. const response = await client.indices.create({
  2. index: "multiplexer_example",
  3. settings: {
  4. analysis: {
  5. analyzer: {
  6. my_analyzer: {
  7. tokenizer: "standard",
  8. filter: ["my_multiplexer"],
  9. },
  10. },
  11. filter: {
  12. my_multiplexer: {
  13. type: "multiplexer",
  14. filters: ["lowercase", "lowercase, porter_stem"],
  15. },
  16. },
  17. },
  18. },
  19. });
  20. console.log(response);
  1. PUT /multiplexer_example
  2. {
  3. "settings": {
  4. "analysis": {
  5. "analyzer": {
  6. "my_analyzer": {
  7. "tokenizer": "standard",
  8. "filter": [ "my_multiplexer" ]
  9. }
  10. },
  11. "filter": {
  12. "my_multiplexer": {
  13. "type": "multiplexer",
  14. "filters": [ "lowercase", "lowercase, porter_stem" ]
  15. }
  16. }
  17. }
  18. }
  19. }

And test it like:

  1. resp = client.indices.analyze(
  2. index="multiplexer_example",
  3. analyzer="my_analyzer",
  4. text="Going HOME",
  5. )
  6. print(resp)
  1. response = client.indices.analyze(
  2. index: 'multiplexer_example',
  3. body: {
  4. analyzer: 'my_analyzer',
  5. text: 'Going HOME'
  6. }
  7. )
  8. puts response
  1. const response = await client.indices.analyze({
  2. index: "multiplexer_example",
  3. analyzer: "my_analyzer",
  4. text: "Going HOME",
  5. });
  6. console.log(response);
  1. POST /multiplexer_example/_analyze
  2. {
  3. "analyzer" : "my_analyzer",
  4. "text" : "Going HOME"
  5. }

And it’d respond:

  1. {
  2. "tokens": [
  3. {
  4. "token": "Going",
  5. "start_offset": 0,
  6. "end_offset": 5,
  7. "type": "<ALPHANUM>",
  8. "position": 0
  9. },
  10. {
  11. "token": "going",
  12. "start_offset": 0,
  13. "end_offset": 5,
  14. "type": "<ALPHANUM>",
  15. "position": 0
  16. },
  17. {
  18. "token": "go",
  19. "start_offset": 0,
  20. "end_offset": 5,
  21. "type": "<ALPHANUM>",
  22. "position": 0
  23. },
  24. {
  25. "token": "HOME",
  26. "start_offset": 6,
  27. "end_offset": 10,
  28. "type": "<ALPHANUM>",
  29. "position": 1
  30. },
  31. {
  32. "token": "home",
  33. "start_offset": 6,
  34. "end_offset": 10,
  35. "type": "<ALPHANUM>",
  36. "position": 1
  37. }
  38. ]
  39. }

The stemmer has also emitted a token home at position 1, but because it is a duplicate of this token it has been removed from the token stream

The synonym and synonym_graph filters use their preceding analysis chain to parse and analyse their synonym lists, and will throw an exception if that chain contains token filters that produce multiple tokens at the same position. If you want to apply synonyms to a token stream containing a multiplexer, then you should append the synonym filter to each relevant multiplexer filter list, rather than placing it after the multiplexer in the main token chain definition.