enc_U2FsdGVkX19zXqyvW2lz07KxhU5tPOErGW3J0bN3S1qoYF5UFJf7uVk3SXVvGMMSfE0O3LDwvrQgixxM+j9qN/g9ku+M9LJwAUxFxM1uI5o+IcNqSOr3FXo8vGM09vvbPbh+DJQ4nv3fC2qMuLzH7mzeyyuKJr4P8ei6g2pEEU/0umGz9trroqtgtPRy4g6log+aAT/XHa3EQhj9rJ+YYg==_enc

enc_U2FsdGVkX19u2apIFYGq146aHHO+SFXBGZR+LBKyZPJsVCTBVnVOTx8Guq3mRO5Y_enc

  1. Any screening in Go!Scan uses a customised filter to restrict the number of results. This filter will return a boolean result to define if the candidate matches or not the filter. A candidate who don’t match the filter will not be returned and will not be scored.
  2. Customers matching the filter will be returned in a first order, starting from the most close match to the less close match. This first order-score is detailed in the order score section. enc_U2FsdGVkX1/1VLHPVx8Cb2W8dKLYHoM0bQOPsig1d74vmGvRY/yc8i2Y9raTbcjzCST+J+hkWlCZJ4YKojND/TutYm9xuICCjYGNI6XgYLJNUxFLbR+sH/RcS5Xv+aUvTzLnRkW4pvBvkKILht1SfbyCM2gy37jhI/hPP0ahdXuoKRuotncOMEWsr3EPLX5Xscvo51V/b0vdh0YQgDAgsGh8uAsGGKEdb77/HCZX+ipgTrrsTje2UC+/qvhe1pqlPbHOI2+IVvDbijR0eVrzzw==_enc
  3. Each of the results will be assigned a definitive score detailed in the definitive score section. This score will be used to determine if an alert must be created or not.

enc_U2FsdGVkX19aOzXUSsyMH5QaroSe2hQMsfxSTvkuYybde6ComX91sVx6NCSQXAAeSRrmoHs1sj+yuTDVj9oiOA==_enc

enc_U2FsdGVkX1+94O2jBxl71yS37NAGBxy2YrwYSyrcSlAXk159uTQe/dousdM370Fr_enc

In the case were no filter is set, the default values apply:

Threshold: 50% (100% in case of Exact match required)

Weighting: First name 33%, Last name 66%

Date of birth: Only year of birth is compared

All records types are returned (SIP, SIE, PEP, and associates RCAs) active or not, deceased or not, etc.

enc_U2FsdGVkX1+VDtkFQA5sn2Vy6SIkYwqwlpUlymiOadgBfHcrovb4n9ZsTQwVlnTC_enc

Before any score computation, a boolean filter is applied to the search. You will find more details about all the options of this filter here: Go!Scan post-filtering.

enc_U2FsdGVkX1+xMOmke19riK5ClXhS7qQN4sb9aiGPOiFIWoFP3RuDrHhtZb8oOeAd_enc

When executing a search on ElasticSearch we will execute a fuzzy search. This work by generating alternative versions of the search input, for instance a search against the name “James” will in fact search for any record of one of the following form: “Jmes”, “ames”, “Jmaes”, “Jams”, etc. We generate for each words up to 50 variations. The variations depends on the size of the string using the following logic: between 0 and 2 characters no variation created, between 3 and 5 only one edit is allowed, for more than 6 characters only two edits are allowed. One edit match one integer using the Levenshtein distance.

This variations are used to search against all the names fields present in the records in any order. We use multiple nested search queries to boost candidates having a match in the correct category (for instance if the first name James matches a last name Jakes it will have a lower sort score than if it matches a first name Jakes).

The most records matches the input, the better the order score will be. More details about the sort score can be found here: https://www.compose.com/articles/how-scoring-works-in-elasticsearch/.

enc_U2FsdGVkX184uKdwSI0n26BdRYyDiKAaumZCAbr+rbT49QAOK0d448FlcixjKWQx_enc

enc_U2FsdGVkX18lqCg/mTMxx68iuLHeyMErQTcAujhg7lY=_enc

enc_U2FsdGVkX1/bxmuWCPlxpg4GCLobcMPx3DFBQ2drup3Aa4An/dFWakoO8U0zwObUwi5of7YVuL98cllgUVlVio0HiWJxd5BCvHo0XihIj4Eh8GI+SDzRWkCQBWhS78qJGhuGo14jhLDFWugfFdUFGf+0ecA6O2ixd+JAZVjK578=_enc

enc_U2FsdGVkX19E+Q9bfHLf4lrr2rNHAEucfuIgXfty2h5hr6ldKyXJR3owvl82dF6sfMEFgi4LlJHORbkcOKSUng==_enc enc_U2FsdGVkX19xLGXI28ws8OVRG6E0UKnwo3qsh30/Ryml2xdFQvSP/42FgmSh33yg2EnzXB4UGcwH4BICWPhRHQ==_enc

The Record contains multiple names, for instance the Record first name could be the single string "Brigitte" and the Record last name could be the list of strings ["Macron", "Trogneux"].

For the Query with first name “Brigite” and last name “Macon”, we do the following.

  1. a. Compare “Brigite” **to “Brigitte” with the formula: S1=fls+(1f)jS_1 = f * l_s + (1-f)*j with f=(Ml)/(m+l)f = (M-l)/(m+l). l is the Levenstein distance between the two inputs, j the Jaro-Winkler distance, M the biggest input length and m the shortest input length. S is the final comparison score. In our example, M=8,m=7,ld=1,ls=88,j=98M = 8, m = 7, l_d = 1, l_s = 88, j = 98 so f = 0.875 and S1 = 89.25. enc_U2FsdGVkX1+TjzhjC7xwS+vKbQI2ARsg9fJeKdgcJYhOvLxM6AQStADBRNOvzv1d+61R1pT7X2xkLGRK1+uh8gnaTOoq2TWisVG+O63sg9k=_enc b. Compare “Macon” to “Macron” (score of 85.2%) and “Macon” to “Trogneux” (score of 33.5). **c.** For each field we keep the best score so here we have a score of 89.25% on first name and 85.2% on last name.
  2. Apply defined weight to each name type, for instance 1 on first name and 2 on last name. Here it means S2=(189.25+285.2)/3=86.6S_2 = (1*89.25+2*85.2)/3 = 86.6% (this does not apply on Company Search where only one name type exists)
  3. Keep or not the record depending on defined threshold. For instance the default Fuzzy Threshold is set to 50% while the Exact match is set to 100%.
  4. Birth date comparison works as an additional filter (this does not apply on Company Search).

If exact date of birth is required, only will be returned the record:

  • without defined date of birth,
  • that match the defined input date,
  • with only a partial defined date (year only for instance) that matches the defined input,
  • month / day inversion is allowed with a penalty of 3%.

enc_U2FsdGVkX1+LFUvv0/lehC1jHa94EY5Lsyd6hg1N5Fe/0x+f5E8bmAMuVjLcxFiqhcoKKaM3NkJ9xDsPYIOGoOJvfRW7gWKglRf1OCZS4m+Ruu+5uSWWkp7ouw88FXZ7Ql8RblV+SWb/c/3v7xeWV8anDXIH8PkiFv2nv3k1jiU=_enc

enc_U2FsdGVkX18d+qrXlxBhFnahUACY8ZytVONYZvOtt+BXsnmlRe44Xpf14X1PcndcGQ74UB36RVqZtyo3m0bTpA==_enc

enc_U2FsdGVkX1+RfGwHo1E/qSOH3szj4Wtnn2lKFfxeFKMAAEUYbZOlGEH75F2K7ssLr5y8zHB1l+xmIw1jBtlnlGfAicX9iylZIhDXVfnKNgeetxNtKpBMyGwbmOmKgMDD5tU1Yq00A9H/fmpzIuqrCg==_enc

DescriptionPenalty
Full alignment of all names in a single record variation0%
Full alignment of all names but across multiple record variations0%
Reverted first name and middle name1%
Shuffled names (all found but all in different categories)2%
All names are present but for instance first name and last name are both in the first name category3%
Some names are not found but the record also don’t have this name type. For instance first name was not matched, but the record doesn’t have a first name registered.4%

enc_U2FsdGVkX1/owlBdYp+8v738rh9cagho9wtuIng8Q9h+X78NzC27cpy8s8xUIpQDEgTgr0VYv+F35TvLk0DLSg==_enc

DescriptionPenalty
Requested a match in a category but DJ has nothing for this category1%
Input contain multiple words present across multiple DJ categories1%

enc_U2FsdGVkX188xeX7pA92/ecXosO08MM/aUYEOiqt6eH+U+D6kHGnSbQDWvdMK65V_enc

enc_U2FsdGVkX1/r8FCIfuC3XtUROhgqLJ6pcKLbbpwiksQp4ATgoAw5zpQvyFs2rD09_enc

If one the following information changed, the alert for instance set as “false positive” will be changed back as “new” and will need to be reviewed.

  • First name, middle name, last name, date of birth, domicile or nationality or the screened customer
  • Any information of the list record for instance an additional note regarding the record.

enc_U2FsdGVkX187ex2dInNNBSRda4zO71oSi9V5k6t02uxadKMYhvVYQ1F4hh5uPzbh_enc

enc_U2FsdGVkX18rjjBIrn4YWE6Py9hkXuxZmgC2MaLceZyzVdanqGDkv6viwXg/q8cwVXrKCzfgjeiiQCwkr2PbiptG/WPV4Sd17S4n5Gu9BB19SGEGxfylNJU2oqr437zVshQtJrZb/agPSLYYo/7Kw4H2ao92lfbFUsNWdAqi9u80MRwhAejx0VCOqUxOynefd4ErdD2JhqQtjY6jtIk5bDh9bafBc1Wu/mzrxwEjT+2DVBDurvqDrN6ZR3W2AEK6d7PqTW8CzO54d1Rrph1m8PA1e4a/Oo5phTGDc1C9TBg=_enc

enc_U2FsdGVkX18oim52MtsDmcahgothsuzUXGvwJ7OXF8pX5hpmJTB72pJCh7Wajopn_enc

You can set custom parameters if you use the post_filtering_alias parameter when doing your transactional name screening. These parameters allow to filter out more results using more precise parameters and are applied on top of the name-search internal filtering.