fork download
  1. function aln_xdrop(a, b, pen, xdrop) {
  2. let max_sc = xdrop, max_i = -1, max_j = -1;
  3. let st = 0, H = [];
  4. for (let j = 0; j < b.length; ++j) { // initialize row -1
  5. const sc = xdrop - pen * (j + 1);
  6. if (sc <= 0) break;
  7. H[j] = sc;
  8. }
  9.  
  10. for (let i = 0; i < a.length; ++i) {
  11. // console.log(H)
  12. let H11 = st === 0? xdrop - pen * i : H[st - 1]; // H[i-1,j-1]
  13. let H01 = H11 - pen; // H[i,j-1] = H[i-1,j-1] - pen
  14. if (H01 <= 0) ++st; // ignored dropped cells
  15. let max_row_sc = 0; // max score on row i
  16. for (let j = st; j < b.length; ++j) {
  17. let H00 = H11 + (a[i] == b[j]? 1 : -pen); // H[i,j] = H[i-1,j-1] + s(a[i], b[j])
  18. if (j < H.length)
  19. H00 = H00 > H[j] - pen? H00 : H[j] - pen; // H[i,j] = max(H[i,j], H[i-1,j] - pen)
  20. H00 = H00 > H01 - pen? H00 : H01 - pen; // H[i,j] = max(H[i,j], H[i,j-1] - pen)
  21. if (j >= H.length && H00 <= max_sc - xdrop) break;
  22. max_row_sc = max_row_sc > H00? max_row_sc : H00; // keep the max row score
  23. if (H00 > max_sc) // keep the overall max score and the cell position
  24. max_sc = H00, max_i = i, max_j = j;
  25. H01 = H00;
  26. H11 = j < H.length? H[j] : 0;
  27. H[j] = H00;
  28. }
  29. if (max_row_sc <= max_sc - xdrop) break;
  30. }
  31. return [max_sc - xdrop, max_i, max_j];
  32. }
  33.  
  34. // let a = "GTTGATGGTCTACAACGTTATCGTCACAGCCCATGCATTTGTAATAATCTTCTTCATAGTAATA";
  35. // let b = "GATAGATGGTCTGAGCTATGATATCAATTGGCTTCCTAGGGTTTATCGTGTGAGCACACCATATT";
  36.  
  37. let a = "CGATATAAGCAATATTATTATATTACGCCCAATAAACGATAGCTAATATGCCGCGGAGCGATCGAACCGCCCCGATAAGACCCC";
  38. let b = "CGATATAAGCAATATTAaTATATTAGCCCAATAAACGATAGCTAATATGggGCGGAGCGATCGAACCGCCCCGAaaTAAGACCCC";
  39.  
  40. let [max_sc, max_i, max_j] = aln_xdrop(a, b, 2, 5);
  41. console.log(max_sc, max_i, max_j, a.substr(0, max_i+1), b.substr(0, max_j+1));
Success #stdin #stdout 0.1s 31512KB
stdin
Standard input is empty
stdout
68 83 84 'CGATATAAGCAATATTATTATATTACGCCCAATAAACGATAGCTAATATGCCGCGGAGCGATCGAACCGCCCCGATAAGACCCC' 'CGATATAAGCAATATTAaTATATTAGCCCAATAAACGATAGCTAATATGggGCGGAGCGATCGAACCGCCCCGAaaTAAGACCCC'