Rev 9 | Blame | Compare with Previous | Last modification | View Log | RSS feed
// cache les association "mot dans le texte" => "mot du dictionnaire"// obtenues à l'aide de levenshtein() et texte_to_mot()var assoc_mot_clef = new Array();function texte_to_mot(mot) {if(assoc_mot_clef[mot]) return assoc_mot_clef[mot];var proche = '';var lev = 99;$.each(motsAyantDefinition, function(i, item) {x = levenshtein(mot, item);if(x < lev) { lev = x; proche = item; }});assoc_mot_clef[mot] = proche;return proche;}function levenshtein (s1, s2) {// http://kevin.vanzonneveld.net// + original by: Carlos R. L. Rodrigues (http://www.jsfromhell.com)// + bugfixed by: Onno Marsman// + revised by: Andrea Giammarchi (http://webreflection.blogspot.com)// + reimplemented by: Brett Zamir (http://brett-zamir.me)// + reimplemented by: Alexander M Beedie// * example 1: levenshtein('Kevin van Zonneveld', 'Kevin van Sommeveld');// * returns 1: 3if (s1 == s2) {return 0;}var s1_len = s1.length;var s2_len = s2.length;if (s1_len === 0) {return s2_len;}if (s2_len === 0) {return s1_len;}// BEGIN STATICvar split = false;try {split = !('0')[0];} catch (e) {split = true; // Earlier IE may not support access by string index}// END STATICif (split) {s1 = s1.split('');s2 = s2.split('');}var v0 = new Array(s1_len + 1);var v1 = new Array(s1_len + 1);var s1_idx = 0,s2_idx = 0,cost = 0;for (s1_idx = 0; s1_idx < s1_len + 1; s1_idx++) {v0[s1_idx] = s1_idx;}var char_s1 = '',char_s2 = '';for (s2_idx = 1; s2_idx <= s2_len; s2_idx++) {v1[0] = s2_idx;char_s2 = s2[s2_idx - 1];for (s1_idx = 0; s1_idx < s1_len; s1_idx++) {char_s1 = s1[s1_idx];cost = (char_s1 == char_s2) ? 0 : 1;var m_min = v0[s1_idx + 1] + 1;var b = v1[s1_idx] + 1;var c = v0[s1_idx] + cost;if (b < m_min) {m_min = b;}if (c < m_min) {m_min = c;}v1[s1_idx + 1] = m_min;}var v_tmp = v0;v0 = v1;v1 = v_tmp;}return v0[s1_len];}