@datagrok/bio 1.6.0 → 1.7.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/package.js CHANGED
@@ -2127,13 +2127,8 @@ function getActivityCliffs(df, seqCol, axesNames, scatterTitle, activities, simi
2127
2127
  if (zoom) {
2128
2128
  const currentLine = lines[linesRes.linesDf.currentRowIdx];
2129
2129
  setTimeout(() => {
2130
- const x1 = sp.dataFrame.get(axesNames[0], currentLine.mols[0]);
2131
- const y1 = sp.dataFrame.get(axesNames[1], currentLine.mols[0]);
2132
- const x2 = sp.dataFrame.get(axesNames[0], currentLine.mols[1]);
2133
- const y2 = sp.dataFrame.get(axesNames[1], currentLine.mols[1]);
2134
- const xDiff = Math.abs(x1 - x2) * 5;
2135
- const yDiff = Math.abs(y1 - y2) * 5;
2136
- sp.zoom(x1 < x2 ? x1 - xDiff : x2 - xDiff, y1 > y2 ? y1 + yDiff : y2 + yDiff, x1 > x2 ? x1 + xDiff : x2 + xDiff, y1 < y2 ? y1 - yDiff : y2 - yDiff);
2130
+ const { zoomLeft, zoomRight, zoomTop, zoomBottom } = getZoomCoordinates(sp.viewport.width, sp.viewport.height, sp.dataFrame.get(axesNames[0], currentLine.mols[0]), sp.dataFrame.get(axesNames[1], currentLine.mols[0]), sp.dataFrame.get(axesNames[0], currentLine.mols[1]), sp.dataFrame.get(axesNames[1], currentLine.mols[1]));
2131
+ sp.zoom(zoomLeft, zoomTop, zoomRight, zoomBottom);
2137
2132
  }, 300);
2138
2133
  zoom = false;
2139
2134
  }
@@ -2142,6 +2137,22 @@ function getActivityCliffs(df, seqCol, axesNames, scatterTitle, activities, simi
2142
2137
  return sp;
2143
2138
  });
2144
2139
  }
2140
+ function getZoomCoordinates(W0, H0, x1, y1, x2, y2) {
2141
+ const W1 = Math.abs(x1 - x2);
2142
+ const H1 = Math.abs(y1 - y2);
2143
+ const scaleW = W0 / W1;
2144
+ const scaleH = H0 / H1;
2145
+ const scale = Math.min(scaleW, scaleH);
2146
+ const W2 = (W0 / scale) * 5;
2147
+ const H2 = (H0 / scale) * 5;
2148
+ const left = x1 < x2 ? x1 : x2;
2149
+ const top = y1 > y2 ? y1 : y2;
2150
+ const zoomLeft = (left + W1 / 2) - W2 / 2;
2151
+ const zoomRight = zoomLeft + W2;
2152
+ const zoomTop = (top - H1 / 2) + H2 / 2;
2153
+ const zoomBottom = zoomTop - H2;
2154
+ return { zoomLeft: zoomLeft, zoomRight: zoomRight, zoomTop: zoomTop, zoomBottom: zoomBottom };
2155
+ }
2145
2156
  function checkCursorOnLine(event, canvas, lines) {
2146
2157
  const rect = canvas.getBoundingClientRect();
2147
2158
  const x = event.clientX - rect.left;
@@ -2215,7 +2226,7 @@ function getSimilaritiesMarixFromDistances(dim, distances, simArr) {
2215
2226
  }
2216
2227
  return simArr;
2217
2228
  }
2218
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-cliffs.js","sourceRoot":"","sources":["activity-cliffs.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { Matrix } from '@datagrok-libraries/utils/src/type-declarations';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\n\nexport interface ILine {\n  id: number;\n  mols: number[];\n  selected: boolean;\n  a: number[]; // [x, y]\n  b: number[]; // [x, y]\n}\n\ninterface IRenderedLines {\n  lines: ILine[];\n  linesDf: DG.DataFrame;\n}\n\nexport interface ISequenceSpaceParams {\n    seqCol: DG.Column,\n    methodName: string,\n    similarityMetric: string,\n    embedAxesNames: string[],\n    options?: any\n}\n\nexport interface ISequenceSpaceResult {\n    distance: Matrix;\n    coordinates: DG.ColumnList;\n  }\n\nexport interface IDrawTooltipParams {\n  tooltips: any,\n  line: ILine,\n  df: DG.DataFrame,\n  seqCol: DG.Column,\n  activity: DG.Column,\n  x: number,\n  y: number\n}\n\nlet zoom = false;\n\n// Searches for activity cliffs in a chemical dataset by selected cutoff\nexport async function getActivityCliffs(\n    df: DG.DataFrame, \n    seqCol: DG.Column, \n    axesNames: string[],\n    scatterTitle: string,\n    activities: DG.Column, \n    similarity: number,\n    similarityMetric: string, \n    methodName: string, \n    semType: string,\n    units: string,\n    seqSpaceFunc: (params: ISequenceSpaceParams) => Promise<ISequenceSpaceResult>,\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>,\n    tooltipDrawFunc: (params: IDrawTooltipParams) => void,\n    options?: any) : Promise<DG.Viewer> {\n  const automaticSimilarityLimit = false;\n  const MIN_SIMILARITY = 80;\n\n  const initialSimilarityLimit = automaticSimilarityLimit ? MIN_SIMILARITY : similarity / 100;\n\n  const {distance, coordinates} = await seqSpaceFunc({\n    seqCol: seqCol,\n    methodName: methodName,\n    similarityMetric: similarityMetric,\n    embedAxesNames: axesNames,\n    options: options\n  });\n\n  for (const col of coordinates)\n    df.columns.add(col);\n\n  const dfSeq = DG.DataFrame.fromColumns([DG.Column.fromList('string', 'seq', seqCol.toList())]);\n  const dim = seqCol.length;\n  const simArr: DG.Column[] = Array(dim - 1);\n\n  if (!distance)\n    await getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc);\n  else\n    getSimilaritiesMarixFromDistances(dim, distance, simArr);\n\n  const optSimilarityLimit = initialSimilarityLimit;\n\n  const simVals: number[] = [];\n  const saliVals: number[] = [];\n  const n1: number[] = [];\n  const n2: number[] = [];\n\n  for (let i = 0; i != dim - 1; ++i) {\n    for (let j = 0; j != dim - 1 - i; ++j) {\n      const sim: number = simArr[i].get(j);\n\n      if (sim >= optSimilarityLimit) {\n        n1.push(i);\n        n2.push(i + j + 1);\n        simVals.push(sim);\n        const diff = Math.abs(activities.get(i) - activities.get(i + j + 1));\n        if (sim != 1)\n          saliVals.push(diff / (1 - sim));\n        else\n          saliVals.push(Infinity);\n      }\n    }\n  }\n\n  const saliValsWithoutInfinity = saliVals.filter(it => it !== Infinity);\n  const saliMin = Math.min(...saliValsWithoutInfinity);\n  const saliMax = Math.max(...saliValsWithoutInfinity);\n  const saliOpacityCoef = 0.8/(saliMax - saliMin);\n\n\n  const neighboursCount = new Array(dim).fill(0);\n  const similarityCount = new Array(dim).fill(0);\n  const saliCount = new Array(dim).fill(0);\n\n  for (let i = 0; i != n1.length; ++i) {\n    neighboursCount[n1[i]] += 1;\n    neighboursCount[n2[i]] += 1;\n    similarityCount[n1[i]] += simVals[i];\n    similarityCount[n2[i]] += simVals[i];\n    if (saliVals[i] != Infinity) {\n      if (activities.get(n1[i]) > activities.get(n2[i]))\n        saliCount[n1[i]] += saliVals[i];\n      else\n        saliCount[n2[i]] += saliVals[i];\n    }\n  }\n\n  const sali: DG.Column = DG.Column.fromList('double', `sali_${axesNames[0].substring(axesNames[0].lastIndexOf('_'))}`, saliCount);\n\n  df.columns.add(sali);\n\n  const view = grok.shell.getTableView(df.name);\n  const sp = view.addViewer(DG.Viewer.scatterPlot(df, {\n    xColumnName: axesNames[0],\n    yColumnName: axesNames[1],\n    size: sali.name,\n    color: activities.name,\n    showXSelector: false,\n    showYSelector: false,\n    showSizeSelector: false,\n    showColorSelector: false,\n    markerMinSize: 5,\n    markerMaxSize: 25,\n    title: scatterTitle\n  })) as DG.ScatterPlotViewer;\n\n  const canvas = (sp.getInfo() as any)['canvas'];\n  const linesRes = createLines(n1, n2, seqCol, activities, saliVals, semType, units);\n  const tooltips: any = {};\n\n  linesRes.linesDf.onCurrentCellChanged.subscribe(() => {\n    const currentMolIdx = linesRes.linesDf.currentCol && linesRes.linesDf.currentCol.name === '2_seq' ? 1 : 0;\n    sp.dataFrame.currentRowIdx =\n      linesRes.linesDf.currentRowIdx !== -1 ? linesRes.lines[linesRes.linesDf.currentRowIdx].mols[currentMolIdx] : -1;\n    sp.dataFrame.selection.set(0, !linesRes.lines[0].selected);\n    sp.dataFrame.selection.set(0, linesRes.lines[0].selected);\n    linesDfGrid.invalidate();\n  });\n\n  linesRes.linesDf.onSelectionChanged.subscribe((_) => {\n    if (linesRes.linesDf.mouseOverRowIdx !== -1) {\n      const line = linesRes.lines[linesRes.linesDf.mouseOverRowIdx];\n      line.selected = !line.selected;\n      if (!line.selected)\n        df.selection.setAll(false);\n    }\n    linesRes.lines.forEach((l) => {\n      if (l.selected)\n        l.mols.forEach((m) => df.selection.set(m, true));\n    });\n    linesDfGrid.invalidate();\n  });\n\n  const linesDfGrid = linesRes.linesDf.plot.grid().sort(['act_diff'], [false]);\n\n  linesDfGrid.onCellClick.subscribe(() => {\n    zoom = true;\n  });\n\n  const listCliffsLink = ui.button(`${linesRes.linesDf.rowCount} cliffs`, () => {\n    const cliffsDialog = ui.dialog({title: 'Activity cliffs'})\n      .add(linesDfGrid.root)\n      .show();\n    cliffsDialog.root.id = 'cliffs_dialog';\n  });\n  listCliffsLink.style.position = 'absolute';\n  listCliffsLink.style.top = '10px';\n  listCliffsLink.style.right = '10px';\n  sp.root.append(listCliffsLink);\n\n  let timer: NodeJS.Timeout;\n  canvas.addEventListener('mousemove', function (event: MouseEvent) {\n    clearTimeout(timer);\n    timer = global.setTimeout(function () {\n      const line = checkCursorOnLine(event, canvas, linesRes.lines);\n      if (line && df.mouseOverRowIdx === -1) {\n        if (!tooltips[line.id]) {\n          const drawTooltipParams = {\n            tooltips: tooltips,\n            line: line,\n            df: df,\n            seqCol: seqCol,\n            activity: activities,\n            x: event.clientX,\n            y: event.clientY\n          }\n          tooltipDrawFunc(drawTooltipParams);\n        }\n        ui.tooltip.show(tooltips[line.id], event.clientX, event.clientY);\n      }\n    }, 1000);\n  });\n\n  canvas.addEventListener('mousedown', function(event: MouseEvent) {\n    const line = checkCursorOnLine(event, canvas, linesRes.lines);\n    if (line && df.mouseOverRowIdx === -1) {\n      if (event.ctrlKey) {\n        line.selected = !line.selected;\n        linesRes.linesDf.selection.set(line.id, line.selected);\n\n        if (!line.selected)\n          df.selection.setAll(false);\n\n        linesRes.lines.forEach((l) => {\n          if (l.selected)\n            l.mols.forEach((m) => df.selection.set(m, true));\n        });\n      } else {\n        if (linesRes.linesDf.currentRowIdx !== line.id) {\n          linesRes.linesDf.currentRowIdx = line.id;\n          df.currentRowIdx = line.mols[0];\n          df.selection.set(0, !linesRes.lines[0].selected);\n          df.selection.set(0, linesRes.lines[0].selected);\n        }\n      }\n    }\n  });\n\n  sp.onEvent('d4-before-draw-scene')\n    .subscribe((_) => {\n      const lines = renderLines(sp,\n        axesNames[0], axesNames[1], linesRes, saliVals, saliOpacityCoef, saliMin);\n      if (zoom) {\n        const currentLine = lines[linesRes.linesDf.currentRowIdx];\n        setTimeout(()=> {\n          const x1 = sp.dataFrame.get(axesNames[0], currentLine.mols[0]);\n          const y1 = sp.dataFrame.get(axesNames[1], currentLine.mols[0]);\n          const x2 = sp.dataFrame.get(axesNames[0], currentLine.mols[1]);\n          const y2 = sp.dataFrame.get(axesNames[1], currentLine.mols[1]);\n          const xDiff = Math.abs(x1 - x2)*5;\n          const yDiff = Math.abs(y1 - y2)*5;\n          sp.zoom(x1 < x2 ? x1 - xDiff : x2 - xDiff,\n            y1 > y2 ? y1 + yDiff : y2  + yDiff,\n            x1 > x2 ? x1 + xDiff : x2 + xDiff,\n            y1 < y2 ? y1 - yDiff : y2 - yDiff);\n        }, 300);\n        zoom = false;\n      }\n    });\n\n  sp.addProperty('similarityLimit', 'double', optSimilarityLimit);\n  return sp;\n}\n\nfunction checkCursorOnLine(event: any, canvas: any, lines: ILine[]): ILine | null {\n  const rect = canvas.getBoundingClientRect();\n  const x = event.clientX - rect.left;\n  const y = event.clientY - rect.top;\n  for (const line of lines) {\n    const dist =\n      Math.abs(Math.hypot(line.a[0] - x, line.a[1] - y) +\n      Math.hypot(line.b[0] - x, line.b[1] - y) - Math.hypot(line.a[0] - line.b[0], line.a[1] - line.b[1]));\n    if (dist < 2)\n      return line;\n  }\n  return null;\n}\n\nfunction renderLines(sp: DG.ScatterPlotViewer,\n  xAxis: string, yAxis: string, linesRes: IRenderedLines, saliVals: number[], saliOpacityCoef: number, saliMin: number): ILine [] {\n  const lines = linesRes.lines;\n  const canvas = (sp.getInfo() as {[index: string] : any})['canvas'];\n  const ctx = canvas.getContext('2d') as CanvasRenderingContext2D;\n  const x = sp.dataFrame!.columns.byName(xAxis);\n  const y = sp.dataFrame!.columns.byName(yAxis);\n  for (let i = 0; i < lines.length; i++) {\n    const pointFrom = sp.worldToScreen(x.get(lines[i].mols[0]), y.get(lines[i].mols[0]));\n    const pointTo = sp.worldToScreen(x.get(lines[i].mols[1]), y.get(lines[i].mols[1]));\n    lines[i].a = [pointFrom.x, pointFrom.y];\n    lines[i].b = [pointTo.x, pointTo.y];\n    const line = new Path2D();\n    line.moveTo(lines[i].a[0], lines[i].a[1]);\n    const color = lines[i].selected ? '255,255,0' : '0,128,0';\n    const opacity = saliVals[i] === Infinity ? 1 : 0.2 + (saliVals[i] - saliMin)*saliOpacityCoef;\n    ctx.strokeStyle = `rgba(${color},${opacity})`;\n    ctx.lineWidth = lines[i].id === linesRes.linesDf.currentRowIdx ? 3 : 1;\n    line.lineTo(lines[i].b[0], lines[i].b[1]);\n    ctx.stroke(line);\n  }\n  return lines;\n}\n\nfunction createLines(\n  n1: number[], \n  n2: number[], \n  seq: DG.Column, \n  activities: DG.Column, \n  saliVals: number[],\n  semType: string,\n  units: string) : IRenderedLines {\n  const lines: ILine[] = [];\n  for (let i = 0; i < n1.length; i++) {\n    const num1 = n1[i];\n    const num2 = n2[i];\n    lines.push({id: i, mols: [num1, num2], selected: false, a: [], b: []});\n  }\n  const linesDf = DG.DataFrame.create(lines.length);\n  linesDf.columns.addNewString('1_seq').init((i: number) => seq.get(lines[i].mols[0]));\n  linesDf.columns.addNewString('2_seq').init((i: number) => seq.get(lines[i].mols[1]));\n  linesDf.columns.addNewFloat('act_diff')\n    .init((i: number) => Math.abs(activities.get(lines[i].mols[0]) - activities.get(lines[i].mols[1])));\n  linesDf.columns.addNewInt('line_index').init((i: number) => i);\n  linesDf.columns.addNewFloat('sali').init((i: number) => saliVals[i]);\n  linesDf.col('1_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('2_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('1_seq')!.semType = semType;\n  linesDf.col('2_seq')!.semType = semType;\n  return {lines, linesDf};\n}\n\nexport async function getSimilaritiesMarix(\n    dim: number, \n    seqCol: DG.Column, \n    dfSeq: DG.DataFrame, \n    simArr: DG.Column[],\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>\n    )\n  : Promise<DG.Column[]> {\n  for (let i = 0; i != dim - 1; ++i) {\n    const mol = seqCol.get(i);\n    dfSeq.rows.removeAt(0, 1, false);\n    simArr[i] = (await simFunc(dfSeq.col('seq')!, mol))!;\n  }\n  return simArr;\n}\n\nexport function getSimilaritiesMarixFromDistances(dim: number, distances: Matrix, simArr: DG.Column[])\n  : DG.Column[] {\n  for (let i = 0; i < dim - 1; ++i) {\n    const similarityArr = [];\n    for (let j = i + 1; j < dim; ++j)\n      similarityArr.push(getSimilarityFromDistance(distances[i][j]));\n    simArr[i] = DG.Column.fromFloat32Array('similarity', Float32Array.from(similarityArr));\n  }\n  return simArr;\n}"]}
2229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-cliffs.js","sourceRoot":"","sources":["activity-cliffs.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { Matrix } from '@datagrok-libraries/utils/src/type-declarations';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\n\nexport interface ILine {\n  id: number;\n  mols: number[];\n  selected: boolean;\n  a: number[]; // [x, y]\n  b: number[]; // [x, y]\n}\n\ninterface IRenderedLines {\n  lines: ILine[];\n  linesDf: DG.DataFrame;\n}\n\nexport interface ISequenceSpaceParams {\n    seqCol: DG.Column,\n    methodName: string,\n    similarityMetric: string,\n    embedAxesNames: string[],\n    options?: any\n}\n\nexport interface ISequenceSpaceResult {\n    distance: Matrix;\n    coordinates: DG.ColumnList;\n  }\n\nexport interface IDrawTooltipParams {\n  tooltips: any,\n  line: ILine,\n  df: DG.DataFrame,\n  seqCol: DG.Column,\n  activity: DG.Column,\n  x: number,\n  y: number\n}\n\nlet zoom = false;\n\n// Searches for activity cliffs in a chemical dataset by selected cutoff\nexport async function getActivityCliffs(\n    df: DG.DataFrame, \n    seqCol: DG.Column, \n    axesNames: string[],\n    scatterTitle: string,\n    activities: DG.Column, \n    similarity: number,\n    similarityMetric: string, \n    methodName: string, \n    semType: string,\n    units: string,\n    seqSpaceFunc: (params: ISequenceSpaceParams) => Promise<ISequenceSpaceResult>,\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>,\n    tooltipDrawFunc: (params: IDrawTooltipParams) => void,\n    options?: any) : Promise<DG.Viewer> {\n  const automaticSimilarityLimit = false;\n  const MIN_SIMILARITY = 80;\n\n  const initialSimilarityLimit = automaticSimilarityLimit ? MIN_SIMILARITY : similarity / 100;\n\n  const {distance, coordinates} = await seqSpaceFunc({\n    seqCol: seqCol,\n    methodName: methodName,\n    similarityMetric: similarityMetric,\n    embedAxesNames: axesNames,\n    options: options\n  });\n\n  for (const col of coordinates)\n    df.columns.add(col);\n\n  const dfSeq = DG.DataFrame.fromColumns([DG.Column.fromList('string', 'seq', seqCol.toList())]);\n  const dim = seqCol.length;\n  const simArr: DG.Column[] = Array(dim - 1);\n\n  if (!distance)\n    await getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc);\n  else\n    getSimilaritiesMarixFromDistances(dim, distance, simArr);\n\n  const optSimilarityLimit = initialSimilarityLimit;\n\n  const simVals: number[] = [];\n  const saliVals: number[] = [];\n  const n1: number[] = [];\n  const n2: number[] = [];\n\n  for (let i = 0; i != dim - 1; ++i) {\n    for (let j = 0; j != dim - 1 - i; ++j) {\n      const sim: number = simArr[i].get(j);\n\n      if (sim >= optSimilarityLimit) {\n        n1.push(i);\n        n2.push(i + j + 1);\n        simVals.push(sim);\n        const diff = Math.abs(activities.get(i) - activities.get(i + j + 1));\n        if (sim != 1)\n          saliVals.push(diff / (1 - sim));\n        else\n          saliVals.push(Infinity);\n      }\n    }\n  }\n\n  const saliValsWithoutInfinity = saliVals.filter(it => it !== Infinity);\n  const saliMin = Math.min(...saliValsWithoutInfinity);\n  const saliMax = Math.max(...saliValsWithoutInfinity);\n  const saliOpacityCoef = 0.8/(saliMax - saliMin);\n\n\n  const neighboursCount = new Array(dim).fill(0);\n  const similarityCount = new Array(dim).fill(0);\n  const saliCount = new Array(dim).fill(0);\n\n  for (let i = 0; i != n1.length; ++i) {\n    neighboursCount[n1[i]] += 1;\n    neighboursCount[n2[i]] += 1;\n    similarityCount[n1[i]] += simVals[i];\n    similarityCount[n2[i]] += simVals[i];\n    if (saliVals[i] != Infinity) {\n      if (activities.get(n1[i]) > activities.get(n2[i]))\n        saliCount[n1[i]] += saliVals[i];\n      else\n        saliCount[n2[i]] += saliVals[i];\n    }\n  }\n\n  const sali: DG.Column = DG.Column.fromList('double', `sali_${axesNames[0].substring(axesNames[0].lastIndexOf('_'))}`, saliCount);\n\n  df.columns.add(sali);\n\n  const view = grok.shell.getTableView(df.name);\n  const sp = view.addViewer(DG.Viewer.scatterPlot(df, {\n    xColumnName: axesNames[0],\n    yColumnName: axesNames[1],\n    size: sali.name,\n    color: activities.name,\n    showXSelector: false,\n    showYSelector: false,\n    showSizeSelector: false,\n    showColorSelector: false,\n    markerMinSize: 5,\n    markerMaxSize: 25,\n    title: scatterTitle\n  })) as DG.ScatterPlotViewer;\n\n  const canvas = (sp.getInfo() as any)['canvas'];\n  const linesRes = createLines(n1, n2, seqCol, activities, saliVals, semType, units);\n  const tooltips: any = {};\n\n  linesRes.linesDf.onCurrentCellChanged.subscribe(() => {\n    const currentMolIdx = linesRes.linesDf.currentCol && linesRes.linesDf.currentCol.name === '2_seq' ? 1 : 0;\n    sp.dataFrame.currentRowIdx =\n      linesRes.linesDf.currentRowIdx !== -1 ? linesRes.lines[linesRes.linesDf.currentRowIdx].mols[currentMolIdx] : -1;\n    sp.dataFrame.selection.set(0, !linesRes.lines[0].selected);\n    sp.dataFrame.selection.set(0, linesRes.lines[0].selected);\n    linesDfGrid.invalidate();\n  });\n\n  linesRes.linesDf.onSelectionChanged.subscribe((_) => {\n    if (linesRes.linesDf.mouseOverRowIdx !== -1) {\n      const line = linesRes.lines[linesRes.linesDf.mouseOverRowIdx];\n      line.selected = !line.selected;\n      if (!line.selected)\n        df.selection.setAll(false);\n    }\n    linesRes.lines.forEach((l) => {\n      if (l.selected)\n        l.mols.forEach((m) => df.selection.set(m, true));\n    });\n    linesDfGrid.invalidate();\n  });\n\n  const linesDfGrid = linesRes.linesDf.plot.grid().sort(['act_diff'], [false]);\n\n  linesDfGrid.onCellClick.subscribe(() => {\n    zoom = true;\n  });\n\n  const listCliffsLink = ui.button(`${linesRes.linesDf.rowCount} cliffs`, () => {\n    const cliffsDialog = ui.dialog({title: 'Activity cliffs'})\n      .add(linesDfGrid.root)\n      .show();\n    cliffsDialog.root.id = 'cliffs_dialog';\n  });\n  listCliffsLink.style.position = 'absolute';\n  listCliffsLink.style.top = '10px';\n  listCliffsLink.style.right = '10px';\n  sp.root.append(listCliffsLink);\n\n  let timer: NodeJS.Timeout;\n  canvas.addEventListener('mousemove', function (event: MouseEvent) {\n    clearTimeout(timer);\n    timer = global.setTimeout(function () {\n      const line = checkCursorOnLine(event, canvas, linesRes.lines);\n      if (line && df.mouseOverRowIdx === -1) {\n        if (!tooltips[line.id]) {\n          const drawTooltipParams = {\n            tooltips: tooltips,\n            line: line,\n            df: df,\n            seqCol: seqCol,\n            activity: activities,\n            x: event.clientX,\n            y: event.clientY\n          }\n          tooltipDrawFunc(drawTooltipParams);\n        }\n        ui.tooltip.show(tooltips[line.id], event.clientX, event.clientY);\n      }\n    }, 1000);\n  });\n\n  canvas.addEventListener('mousedown', function(event: MouseEvent) {\n    const line = checkCursorOnLine(event, canvas, linesRes.lines);\n    if (line && df.mouseOverRowIdx === -1) {\n      if (event.ctrlKey) {\n        line.selected = !line.selected;\n        linesRes.linesDf.selection.set(line.id, line.selected);\n\n        if (!line.selected)\n          df.selection.setAll(false);\n\n        linesRes.lines.forEach((l) => {\n          if (l.selected)\n            l.mols.forEach((m) => df.selection.set(m, true));\n        });\n      } else {\n        if (linesRes.linesDf.currentRowIdx !== line.id) {\n          linesRes.linesDf.currentRowIdx = line.id;\n          df.currentRowIdx = line.mols[0];\n          df.selection.set(0, !linesRes.lines[0].selected);\n          df.selection.set(0, linesRes.lines[0].selected);\n        }\n      }\n    }\n  });\n\n  sp.onEvent('d4-before-draw-scene')\n    .subscribe((_) => {\n      const lines = renderLines(sp,\n        axesNames[0], axesNames[1], linesRes, saliVals, saliOpacityCoef, saliMin);\n      if (zoom) {\n        const currentLine = lines[linesRes.linesDf.currentRowIdx];\n        setTimeout(()=> {\n          const {zoomLeft, zoomRight, zoomTop, zoomBottom} = getZoomCoordinates(\n            sp.viewport.width,\n            sp.viewport.height,\n            sp.dataFrame.get(axesNames[0], currentLine.mols[0]),\n            sp.dataFrame.get(axesNames[1], currentLine.mols[0]),\n            sp.dataFrame.get(axesNames[0], currentLine.mols[1]),\n            sp.dataFrame.get(axesNames[1], currentLine.mols[1])\n          )        \n          sp.zoom(zoomLeft,\n            zoomTop,\n            zoomRight,\n            zoomBottom);\n        }, 300);\n        zoom = false;\n      }\n    });\n\n  sp.addProperty('similarityLimit', 'double', optSimilarityLimit);\n  return sp;\n}\n\nfunction getZoomCoordinates(W0: number, H0: number, x1: number, y1: number, x2: number, y2: number) {\n  const W1 = Math.abs(x1 - x2);\n  const H1 = Math.abs(y1 - y2);\n  const scaleW = W0 / W1;\n  const scaleH = H0 / H1;\n  const scale = Math.min(scaleW, scaleH);\n  const W2 = (W0 / scale) * 5;\n  const H2 = (H0 / scale) * 5;\n  const left = x1 < x2 ? x1 : x2;\n  const top = y1 > y2 ? y1 : y2;\n  const zoomLeft = (left + W1 / 2) - W2 / 2;\n  const zoomRight = zoomLeft + W2;\n  const zoomTop = (top - H1 / 2) + H2 / 2;\n  const zoomBottom = zoomTop - H2;\n  return {zoomLeft: zoomLeft, zoomRight: zoomRight, zoomTop: zoomTop, zoomBottom: zoomBottom};\n}\n\nfunction checkCursorOnLine(event: any, canvas: any, lines: ILine[]): ILine | null {\n  const rect = canvas.getBoundingClientRect();\n  const x = event.clientX - rect.left;\n  const y = event.clientY - rect.top;\n  for (const line of lines) {\n    const dist =\n      Math.abs(Math.hypot(line.a[0] - x, line.a[1] - y) +\n      Math.hypot(line.b[0] - x, line.b[1] - y) - Math.hypot(line.a[0] - line.b[0], line.a[1] - line.b[1]));\n    if (dist < 2)\n      return line;\n  }\n  return null;\n}\n\nfunction renderLines(sp: DG.ScatterPlotViewer,\n  xAxis: string, yAxis: string, linesRes: IRenderedLines, saliVals: number[], saliOpacityCoef: number, saliMin: number): ILine [] {\n  const lines = linesRes.lines;\n  const canvas = (sp.getInfo() as {[index: string] : any})['canvas'];\n  const ctx = canvas.getContext('2d') as CanvasRenderingContext2D;\n  const x = sp.dataFrame!.columns.byName(xAxis);\n  const y = sp.dataFrame!.columns.byName(yAxis);\n  for (let i = 0; i < lines.length; i++) {\n    const pointFrom = sp.worldToScreen(x.get(lines[i].mols[0]), y.get(lines[i].mols[0]));\n    const pointTo = sp.worldToScreen(x.get(lines[i].mols[1]), y.get(lines[i].mols[1]));\n    lines[i].a = [pointFrom.x, pointFrom.y];\n    lines[i].b = [pointTo.x, pointTo.y];\n    const line = new Path2D();\n    line.moveTo(lines[i].a[0], lines[i].a[1]);\n    const color = lines[i].selected ? '255,255,0' : '0,128,0';\n    const opacity = saliVals[i] === Infinity ? 1 : 0.2 + (saliVals[i] - saliMin)*saliOpacityCoef;\n    ctx.strokeStyle = `rgba(${color},${opacity})`;\n    ctx.lineWidth = lines[i].id === linesRes.linesDf.currentRowIdx ? 3 : 1;\n    line.lineTo(lines[i].b[0], lines[i].b[1]);\n    ctx.stroke(line);\n  }\n  return lines;\n}\n\nfunction createLines(\n  n1: number[], \n  n2: number[], \n  seq: DG.Column, \n  activities: DG.Column, \n  saliVals: number[],\n  semType: string,\n  units: string) : IRenderedLines {\n  const lines: ILine[] = [];\n  for (let i = 0; i < n1.length; i++) {\n    const num1 = n1[i];\n    const num2 = n2[i];\n    lines.push({id: i, mols: [num1, num2], selected: false, a: [], b: []});\n  }\n  const linesDf = DG.DataFrame.create(lines.length);\n  linesDf.columns.addNewString('1_seq').init((i: number) => seq.get(lines[i].mols[0]));\n  linesDf.columns.addNewString('2_seq').init((i: number) => seq.get(lines[i].mols[1]));\n  linesDf.columns.addNewFloat('act_diff')\n    .init((i: number) => Math.abs(activities.get(lines[i].mols[0]) - activities.get(lines[i].mols[1])));\n  linesDf.columns.addNewInt('line_index').init((i: number) => i);\n  linesDf.columns.addNewFloat('sali').init((i: number) => saliVals[i]);\n  linesDf.col('1_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('2_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('1_seq')!.semType = semType;\n  linesDf.col('2_seq')!.semType = semType;\n  return {lines, linesDf};\n}\n\nexport async function getSimilaritiesMarix(\n    dim: number, \n    seqCol: DG.Column, \n    dfSeq: DG.DataFrame, \n    simArr: DG.Column[],\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>\n    )\n  : Promise<DG.Column[]> {\n  for (let i = 0; i != dim - 1; ++i) {\n    const mol = seqCol.get(i);\n    dfSeq.rows.removeAt(0, 1, false);\n    simArr[i] = (await simFunc(dfSeq.col('seq')!, mol))!;\n  }\n  return simArr;\n}\n\nexport function getSimilaritiesMarixFromDistances(dim: number, distances: Matrix, simArr: DG.Column[])\n  : DG.Column[] {\n  for (let i = 0; i < dim - 1; ++i) {\n    const similarityArr = [];\n    for (let j = i + 1; j < dim; ++j)\n      similarityArr.push(getSimilarityFromDistance(distances[i][j]));\n    simArr[i] = DG.Column.fromFloat32Array('similarity', Float32Array.from(similarityArr));\n  }\n  return simArr;\n}"]}
2219
2230
 
2220
2231
  /***/ }),
2221
2232
 
@@ -3972,6 +3983,10 @@ function getPalleteByType(paletteType) {
3972
3983
  return _datagrok_libraries_bio_src_aminoacids__WEBPACK_IMPORTED_MODULE_2__.AminoacidsPalettes.GrokGroups;
3973
3984
  case 'NT':
3974
3985
  return _datagrok_libraries_bio_src_nucleotides__WEBPACK_IMPORTED_MODULE_3__.NucleotidesPalettes.Chromatogram;
3986
+ case 'DNA':
3987
+ return _datagrok_libraries_bio_src_nucleotides__WEBPACK_IMPORTED_MODULE_3__.NucleotidesPalettes.Chromatogram;
3988
+ case 'RNA':
3989
+ return _datagrok_libraries_bio_src_nucleotides__WEBPACK_IMPORTED_MODULE_3__.NucleotidesPalettes.Chromatogram;
3975
3990
  // other
3976
3991
  default:
3977
3992
  return _datagrok_libraries_bio_src_unknown__WEBPACK_IMPORTED_MODULE_4__.UnknownSeqPalettes.Color;
@@ -4002,13 +4017,14 @@ function processSequence(subParts) {
4002
4017
  * @param {string} [color=undefinedColor] String color.
4003
4018
  * @param {number} [pivot=0] Pirvot.
4004
4019
  * @param {boolean} [left=false] Is left aligned.
4005
- * @param {boolean} [hideMod=false] Hide amino acid redidue modifications.
4006
4020
  * @param {number} [transparencyRate=0.0] Transparency rate where 1.0 is fully transparent
4021
+ * @param {string} [separator=''] Is separator for sequence.
4022
+ * @param {boolean} [last=false] Is checker if element last or not.
4007
4023
  * @return {number} x coordinate to start printing at.
4008
4024
  */
4009
- function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pivot = 0, left = false, hideMod = false, transparencyRate = 1.0, separator = '', last = false) {
4025
+ function printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pivot = 0, left = false, transparencyRate = 1.0, separator = '', last = false) {
4010
4026
  g.textAlign = 'start';
4011
- let colorPart = s.substring(0);
4027
+ const colorPart = s.substring(0);
4012
4028
  let grayPart = separator;
4013
4029
  if (last) {
4014
4030
  grayPart = '';
@@ -4053,31 +4069,31 @@ class MacromoleculeSequenceCellRenderer extends datagrok_api_dg__WEBPACK_IMPORTE
4053
4069
  */
4054
4070
  render(g, x, y, w, h, gridCell, cellStyle) {
4055
4071
  var _a, _b;
4056
- const grid = gridCell.grid;
4072
+ const grid = gridCell.gridRow !== -1 ? gridCell.grid : undefined;
4057
4073
  const cell = gridCell.cell;
4058
4074
  const tag = gridCell.cell.column.getTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.TAGS.UNITS);
4059
4075
  if (tag === 'HELM') {
4060
- let host = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_6__.div([], { style: { width: `${w}px`, height: `${h}px` } });
4076
+ const host = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_6__.div([], { style: { width: `${w}px`, height: `${h}px` } });
4061
4077
  host.setAttribute('dataformat', 'helm');
4062
4078
  host.setAttribute('data', gridCell.cell.value);
4063
4079
  gridCell.element = host;
4064
4080
  //@ts-ignore
4065
- var canvas = new JSDraw2.Editor(host, { width: w, height: h, skin: "w8", viewonly: true });
4066
- var formula = canvas.getFormula(true);
4081
+ const canvas = new JSDraw2.Editor(host, { width: w, height: h, skin: 'w8', viewonly: true });
4082
+ const formula = canvas.getFormula(true);
4067
4083
  if (!formula) {
4068
4084
  gridCell.element = datagrok_api_ui__WEBPACK_IMPORTED_MODULE_6__.divText(gridCell.cell.value, { style: { color: 'red' } });
4069
4085
  }
4070
4086
  else {
4071
4087
  gridCell.element = host;
4072
- var molWeight = Math.round(canvas.getMolWeight() * 100) / 100;
4073
- var coef = Math.round(canvas.getExtinctionCoefficient(true) * 100) / 100;
4074
- var molfile = canvas.getMolfile();
4075
- var result = formula + ', ' + molWeight + ', ' + coef + ', ' + molfile;
4088
+ const molWeight = Math.round(canvas.getMolWeight() * 100) / 100;
4089
+ const coef = Math.round(canvas.getExtinctionCoefficient(true) * 100) / 100;
4090
+ const molfile = canvas.getMolfile();
4091
+ const result = formula + ', ' + molWeight + ', ' + coef + ', ' + molfile;
4076
4092
  lru.set(gridCell.cell.value, result);
4077
4093
  }
4078
4094
  }
4079
4095
  else {
4080
- const [type, subtype, paletteType] = gridCell.cell.column.getTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.TAGS.UNITS).split(":");
4096
+ const [type, subtype, paletteType] = gridCell.cell.column.getTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.TAGS.UNITS).split(':');
4081
4097
  w = grid ? Math.min(grid.canvas.width - x, w) : g.canvas.width - x;
4082
4098
  g.save();
4083
4099
  g.beginPath();
@@ -4090,10 +4106,9 @@ class MacromoleculeSequenceCellRenderer extends datagrok_api_dg__WEBPACK_IMPORTE
4090
4106
  const units = gridCell.cell.column.getTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.TAGS.UNITS);
4091
4107
  const palette = getPalleteByType(paletteType);
4092
4108
  const separator = (_b = gridCell.cell.column.getTag('separator')) !== null && _b !== void 0 ? _b : '';
4093
- const splitterFunc = _datagrok_libraries_bio_src_viewers_web_logo__WEBPACK_IMPORTED_MODULE_5__.WebLogo.getSplitter(units, gridCell.cell.column.getTag('separator')); // splitter,
4109
+ const splitterFunc = _datagrok_libraries_bio_src_viewers_web_logo__WEBPACK_IMPORTED_MODULE_5__.WebLogo.getSplitter(units, gridCell.cell.column.getTag('separator'));
4094
4110
  const subParts = splitterFunc(cell.value);
4095
4111
  // console.log(subParts);
4096
- const textSize = g.measureText(subParts.join(''));
4097
4112
  let x1 = x;
4098
4113
  let color = undefinedColor;
4099
4114
  subParts.forEach((amino, index) => {
@@ -4103,7 +4118,7 @@ class MacromoleculeSequenceCellRenderer extends datagrok_api_dg__WEBPACK_IMPORTE
4103
4118
  if (index === subParts.length - 1) {
4104
4119
  last = true;
4105
4120
  }
4106
- x1 = printLeftOrCentered(x1, y, w, h, g, amino, color, 0, true, false, 1.0, separator, last);
4121
+ x1 = printLeftOrCentered(x1, y, w, h, g, amino, color, 0, true, 1.0, separator, last);
4107
4122
  });
4108
4123
  g.restore();
4109
4124
  }
@@ -4370,13 +4385,33 @@ __webpack_require__.r(__webpack_exports__);
4370
4385
  /** Class for handling conversion of notation systems in Macromolecule columns */
4371
4386
  class NotationConverter {
4372
4387
  constructor(col) {
4388
+ this._defaultGapSymbolsDict = {
4389
+ helm: '*',
4390
+ separator: '',
4391
+ fasta: '-',
4392
+ };
4373
4393
  this._sourceColumn = col;
4374
- this._sourceUnits = this._sourceColumn.tags[datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.TAGS.UNITS];
4375
- this._sourceNotation = this.determineSourceNotation();
4394
+ const units = this._sourceColumn.tags[datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.TAGS.UNITS];
4395
+ if (units !== null)
4396
+ this._sourceUnits = units;
4397
+ else
4398
+ throw new Error('Units are not specified in column');
4399
+ this._sourceNotation = this.getSourceNotation();
4400
+ this._defaultGapSymbol = (this.isFasta()) ? this._defaultGapSymbolsDict.fasta :
4401
+ (this.isHelm()) ? this._defaultGapSymbolsDict.helm :
4402
+ this._defaultGapSymbolsDict.separator;
4376
4403
  }
4377
4404
  get sourceUnits() { return this._sourceUnits; }
4378
4405
  get sourceColumn() { return this._sourceColumn; }
4379
4406
  get sourceNotation() { return this._sourceNotation; }
4407
+ get defaultGapSymbol() { return this._defaultGapSymbol; }
4408
+ get separator() {
4409
+ const separator = this.sourceColumn.getTag('separator');
4410
+ if (separator !== null)
4411
+ return separator;
4412
+ else
4413
+ throw new Error('Separator not set');
4414
+ }
4380
4415
  isFasta() { return this.sourceNotation === "FASTA" /* NOTATION.FASTA */; }
4381
4416
  isSeparator() { return this.sourceNotation === "SEPARATOR" /* NOTATION.SEPARATOR */; }
4382
4417
  isHelm() { return this.sourceNotation === "HELM" /* NOTATION.HELM */; }
@@ -4390,33 +4425,15 @@ class NotationConverter {
4390
4425
  /**
4391
4426
  * @return {NOTATION} Notation associated with the units type
4392
4427
  */
4393
- determineSourceNotation() {
4428
+ getSourceNotation() {
4394
4429
  if (this.sourceUnits.toLowerCase().startsWith('fasta'))
4395
4430
  return "FASTA" /* NOTATION.FASTA */;
4396
4431
  else if (this.sourceUnits.toLowerCase().startsWith('separator'))
4397
4432
  return "SEPARATOR" /* NOTATION.SEPARATOR */;
4398
- else
4399
- // TODO: handle possible exceptions
4433
+ else if (this.sourceUnits.toLowerCase().startsWith('helm'))
4400
4434
  return "HELM" /* NOTATION.HELM */;
4401
- }
4402
- /**
4403
- * Determine the separator used in SEPARATOR column
4404
- *
4405
- * @return {string} The detected separator
4406
- */
4407
- determineSeparator() {
4408
- // TODO: figure out how to determine the separator efficiently
4409
- const col = this.sourceColumn;
4410
- let i = 0;
4411
- const re = /[^a-z]/;
4412
- while (i < col.length) {
4413
- const molecule = col.get(i);
4414
- const foundSeparator = molecule.toLowerCase().match(re);
4415
- if (foundSeparator)
4416
- return foundSeparator[0];
4417
- i++;
4418
- }
4419
- throw new Error('No separators found');
4435
+ else
4436
+ throw new Error('The column has units that do not correspond to any notation');
4420
4437
  }
4421
4438
  /**
4422
4439
  * Create a new empty column of the specified notation type and the same
@@ -4432,11 +4449,13 @@ class NotationConverter {
4432
4449
  const newColName = col.dataFrame.columns.getUnusedName(name);
4433
4450
  // dummy code
4434
4451
  const newColumn = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.Column.fromList('string', newColName, new Array(len).fill(''));
4435
- newColumn.semType = 'Macromolecule';
4452
+ newColumn.semType = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.SEMTYPE.MACROMOLECULE;
4436
4453
  newColumn.setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.TAGS.UNITS, this.sourceUnits.replace(this.sourceNotation.toLowerCase().toString(), targetNotation.toLowerCase().toString()));
4437
4454
  // TODO: specify cell renderers for all cases
4438
4455
  if (this.toFasta(targetNotation)) {
4439
- newColumn.setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.TAGS.CELL_RENDERER, 'Macromolecule');
4456
+ newColumn.setTag(datagrok_api_dg__WEBPACK_IMPORTED_MODULE_0__.TAGS.CELL_RENDERER,
4457
+ // TODO: replace by the enumeration value
4458
+ 'Macromolecule');
4440
4459
  }
4441
4460
  return newColumn;
4442
4461
  }
@@ -4463,16 +4482,12 @@ class NotationConverter {
4463
4482
  });
4464
4483
  return newColumn;
4465
4484
  }
4466
- /**
4467
- * Convert a Macromolecule column from FASTA to HELM
4468
- *
4469
- * @param {string} fastaGapSymbol Optional fasta gap symbol
4470
- * @param {string} helmGapSymbol Optional helm gap symbol
4471
- * @return {DG.Column} A new column in HELM notation
4472
- */
4473
- convertFastaToHelm(fastaGapSymbol = '-', helmGapSymbol = '*') {
4474
- // a function splitting FASTA sequence into an array of monomers
4475
- const splitterAsFasta = _datagrok_libraries_bio_src_viewers_web_logo__WEBPACK_IMPORTED_MODULE_1__.WebLogo.splitterAsFasta;
4485
+ convertToHelm(sourceGapSymbol = null) {
4486
+ if (sourceGapSymbol === null)
4487
+ sourceGapSymbol = this.defaultGapSymbol;
4488
+ // A function splitting a sequence into an array of monomers according to
4489
+ // its notation
4490
+ const splitter = _datagrok_libraries_bio_src_viewers_web_logo__WEBPACK_IMPORTED_MODULE_1__.WebLogo.getSplitterForColumn(this.sourceColumn);
4476
4491
  const prefix = (this.isDna()) ? 'DNA1{' :
4477
4492
  (this.isRna()) ? 'RNA1{' :
4478
4493
  (this.isPeptide()) ? 'PEPTIDE1{' :
@@ -4486,20 +4501,17 @@ class NotationConverter {
4486
4501
  const newColumn = this.getNewColumn("HELM" /* NOTATION.HELM */);
4487
4502
  // assign the values to the empty column
4488
4503
  newColumn.init((idx) => {
4489
- const fastaPolymer = this.sourceColumn.get(idx);
4490
- const fastaMonomersArray = splitterAsFasta(fastaPolymer);
4504
+ const sourcePolymer = this.sourceColumn.get(idx);
4505
+ const sourceMonomersArray = splitter(sourcePolymer);
4491
4506
  const helmArray = [prefix];
4492
4507
  let firstIteration = true;
4493
- for (let i = 0; i < fastaMonomersArray.length; i++) {
4494
- if (fastaMonomersArray[i] === fastaGapSymbol) {
4495
- // TODO: verify the correctness of gap symbols handling
4496
- helmArray.push(helmGapSymbol);
4497
- }
4498
- else {
4499
- const dot = firstIteration ? '' : '.';
4500
- const item = [dot, leftWrapper, fastaMonomersArray[i], rightWrapper];
4501
- helmArray.push(item.join(''));
4502
- }
4508
+ for (let i = 0; i < sourceMonomersArray.length; i++) {
4509
+ const dot = firstIteration ? '' : '.';
4510
+ let token = sourceMonomersArray[i];
4511
+ if (token === sourceGapSymbol)
4512
+ token = this._defaultGapSymbolsDict.helm;
4513
+ const item = [dot, leftWrapper, token, rightWrapper];
4514
+ helmArray.push(item.join(''));
4503
4515
  firstIteration = false;
4504
4516
  }
4505
4517
  helmArray.push(postfix);
@@ -4527,11 +4539,11 @@ class NotationConverter {
4527
4539
  // * NO, they can be multi-characters
4528
4540
  // conversion
4529
4541
  // * consider automatic determining the separator
4530
- // if (separator === null)
4531
- // separator = this.determineSeparator();
4542
+ if (separator === null)
4543
+ separator = this.separator;
4532
4544
  // a function splitting FASTA sequence into an array of monomers
4533
4545
  //const splitterAsSeparator = WebLogo.getSplitterWithSeparator(separator);
4534
- const splitter = _datagrok_libraries_bio_src_viewers_web_logo__WEBPACK_IMPORTED_MODULE_1__.WebLogo.getSplitterForColumn(this._sourceColumn);
4546
+ const splitter = _datagrok_libraries_bio_src_viewers_web_logo__WEBPACK_IMPORTED_MODULE_1__.WebLogo.getSplitterForColumn(this.sourceColumn);
4535
4547
  const newColumn = this.getNewColumn("FASTA" /* NOTATION.FASTA */);
4536
4548
  // assign the values to the empty column
4537
4549
  newColumn.init((idx) => {
@@ -4557,43 +4569,6 @@ class NotationConverter {
4557
4569
  });
4558
4570
  return newColumn;
4559
4571
  }
4560
- convertSeparatorToHelm(fastaGapSymbol = '-', helmGapSymbol = '*') {
4561
- // a function splitting FASTA sequence into an array of monomers
4562
- const splitter = _datagrok_libraries_bio_src_viewers_web_logo__WEBPACK_IMPORTED_MODULE_1__.WebLogo.getSplitterForColumn(this._sourceColumn);
4563
- const prefix = (this.isDna()) ? 'DNA1{' :
4564
- (this.isRna()) ? 'RNA1{' :
4565
- (this.isPeptide()) ? 'PEPTIDE1{' :
4566
- 'Unknown'; // this case should be handled as exceptional
4567
- if (prefix === 'Unknown')
4568
- throw new Error('Neither peptide, nor nucleotide');
4569
- const postfix = '}$$$';
4570
- const leftWrapper = (this.isDna()) ? 'D(' :
4571
- (this.isRna()) ? 'R(' : ''; // no wrapper for peptides
4572
- const rightWrapper = (this.isDna() || this.isRna()) ? ')P' : ''; // no wrapper for peptides
4573
- const newColumn = this.getNewColumn("HELM" /* NOTATION.HELM */);
4574
- // assign the values to the empty column
4575
- newColumn.init((idx) => {
4576
- const fastaPolymer = this.sourceColumn.get(idx);
4577
- const fastaMonomersArray = splitter(fastaPolymer);
4578
- const helmArray = [prefix];
4579
- let firstIteration = true;
4580
- for (let i = 0; i < fastaMonomersArray.length; i++) {
4581
- if (fastaMonomersArray[i] === fastaGapSymbol) {
4582
- // TODO: verify the correctness of gap symbols handling
4583
- helmArray.push(helmGapSymbol);
4584
- }
4585
- else {
4586
- const dot = firstIteration ? '' : '.';
4587
- const item = [dot, leftWrapper, fastaMonomersArray[i], rightWrapper];
4588
- helmArray.push(item.join(''));
4589
- }
4590
- firstIteration = false;
4591
- }
4592
- helmArray.push(postfix);
4593
- return helmArray.join('');
4594
- });
4595
- return newColumn;
4596
- }
4597
4572
  convertHelmToFasta() {
4598
4573
  // TODO: implementation
4599
4574
  return this.getNewColumn("FASTA" /* NOTATION.FASTA */);
@@ -4616,12 +4591,10 @@ class NotationConverter {
4616
4591
  throw new Error('Target separator is not specified');
4617
4592
  if (this.isFasta() && this.toSeparator(targetNotation) && tgtSeparator !== null)
4618
4593
  return this.convertFastaToSeparator(tgtSeparator);
4619
- else if (this.isFasta() && this.toHelm(targetNotation))
4620
- return this.convertFastaToHelm();
4594
+ else if ((this.isFasta() || this.isSeparator()) && this.toHelm(targetNotation))
4595
+ return this.convertToHelm();
4621
4596
  else if (this.isSeparator() && this.toFasta(targetNotation))
4622
4597
  return this.convertSeparatorToFasta(tgtSeparator);
4623
- else if (this.isSeparator() && this.toHelm(targetNotation))
4624
- return this.convertSeparatorToHelm();
4625
4598
  else if (this.isHelm() && this.toFasta(targetNotation))
4626
4599
  return this.convertHelmToFasta();
4627
4600
  else
@@ -10747,6 +10720,20 @@ function toAtomicLevel(df, macroMolecule) {
10747
10720
  }
10748
10721
  if (!checkInputColumn(macroMolecule, 'To Atomic Level'))
10749
10722
  return;
10723
+ let currentView;
10724
+ for (let view of datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.tableViews) {
10725
+ if (df.name === view.name) {
10726
+ currentView = view;
10727
+ }
10728
+ }
10729
+ const file = yield _package.files.readAsText('tests/sar-small.csv');
10730
+ const df2 = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.DataFrame.fromCsv(file);
10731
+ const v = datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.addTableView(df2);
10732
+ setTimeout(() => {
10733
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.closeTable(df2);
10734
+ v.close();
10735
+ datagrok_api_grok__WEBPACK_IMPORTED_MODULE_0__.shell.v = currentView;
10736
+ }, 100);
10750
10737
  const monomersLibFile = yield _package.files.readAsText(_utils_utils__WEBPACK_IMPORTED_MODULE_10__.HELM_CORE_LIB_FILENAME);
10751
10738
  const monomersLibObject = JSON.parse(monomersLibFile);
10752
10739
  const atomicCodes = (0,_utils_utils__WEBPACK_IMPORTED_MODULE_10__.getMolfilesFromSeq)(macroMolecule, monomersLibObject);
@@ -10754,7 +10741,7 @@ function toAtomicLevel(df, macroMolecule) {
10754
10741
  const col = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.Column.fromStrings('regenerated', result);
10755
10742
  col.semType = datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.SEMTYPE.MOLECULE;
10756
10743
  col.tags[datagrok_api_dg__WEBPACK_IMPORTED_MODULE_1__.TAGS.UNITS] = 'molblock';
10757
- df.columns.add(col);
10744
+ df.columns.add(col, true);
10758
10745
  });
10759
10746
  }
10760
10747
  //top-menu: Bio | MSA...
@@ -10875,4 +10862,4 @@ function convertPanel(col) {
10875
10862
  bio = __webpack_exports__;
10876
10863
  /******/ })()
10877
10864
  ;
10878
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package.js","mappings":";;;;;;;;;;AAAA;AACA,EAAE,KAA4D;AAC9D,EAAE,CACmD;AACrD,CAAC,sBAAsB;;AAEvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,eAAe;AACjC;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,OAAO;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA,6BAA6B;AAC7B;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,iBAAiB,kBAAkB,UAAU;AAC/D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,eAAe;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA,uBAAuB;AACvB,WAAW;AACX;AACA;AACA,2DAA2D,gBAAgB,IAAI;AAC/E;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8DAA8D;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf,WAAW;AACX,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qBAAqB;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,yCAAyC,IAAI;AAC7C,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,aAAa,SAAS,YAAY;AAClD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+EAA+E;AAC/E;;AAEA,+FAA+F,6BAA6B;AAC5H;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iCAAiC;AACjC;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA,yDAAyD,WAAW;AACpE,6DAA6D,WAAW;AACxE;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,gCAAgC;;AAE9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,uEAAuE;AACvE;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC;AACD;;;;;;;;;;;;;;;;;;ACrdgD;AACzC,iCAAiC,yDAAc;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yDAAyD,OAAO;AAChE;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,gBAAgB,kBAAkB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,yBAAyB;AAC9E,qDAAqD,yBAAyB;AAC9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;ACjOK;AACzC,kCAAkC,yDAAc;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;AC1BpC;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;AC3C8B;AACzE;AACA;AACA;AACA;AACA;AACA,QAAQ,uFAAM,+CAA+C,KAAK;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC;AACzC,YAAY,uFAAM,0CAA0C,YAAY,4BAA4B,IAAI;AACxG;AACA;AACA;AACA,6CAA6C;AAC7C,YAAY,uFAAM,gDAAgD,YAAY,6BAA6B,IAAI;AAC/G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,UAAU;AAC5B;AACA;AACA;AACA;AACA;AACA,wBAAwB,YAAY;AACpC;AACA,YAAY,uFAAM,uCAAuC,KAAK,uBAAuB,SAAS;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA,wBAAwB,kBAAkB;AAC1C;AACA,YAAY,uFAAM,uCAAuC,KAAK,qBAAqB,MAAM;AACzF;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;AC1JpC;AACP;AACA;AACA;AACA;AACA,wBAAwB,cAAc;AACtC;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACgD;AACzC;AACP;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA,+CAA+C,uEAA4B;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,iCAAiC,yDAAc;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;AC7C3C;AACO;AACP;AACA;AACA;AACA;AACA,CAAC,oCAAoC;AACrC;AACA;AACA;AACO;AACP;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC7B3C,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACA;AAClB;AACS;AAC4C;AACwB;AAClC;AACG;AAClB;AAChD;AACA;AACA,eAAe,kDAAQ;AACvB;AACA,oEAA0B;AAC1B;AACA;AACO;AACP;AACA;AACA,0BAA0B,iDAAO;AACjC;AACA;AACO;AACP,iBAAiB;AACjB,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACO,sBAAsB,qDAAW;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,iDAAiD;AAC5D;AACA,WAAW,mDAAmD;AAC9D;AACA,WAAW,mDAAmD;AAC9D;AACA;AACA;AACA;AACA;AACA,8EAA8E,sCAAsC;AACpH,kFAAkF,sCAAsC;AACxH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,gDAAM;AACjC;AACA,0BAA0B,mDAAS;AACnC;AACA,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB,+BAA+B,2CAAc;AAC7C;AACA;AACA;AACA;AACA;AACA,oBAAoB,iEAAuB;AAC3C;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA,aAAa;AACb,+BAA+B,2CAAc;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,+BAA+B,0DAAgB;AAC/C;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,2BAA2B,sBAAsB,gBAAgB,uBAAuB;AACxF,6BAA6B,kBAAkB,kBAAkB,oBAAoB;AACrF;AACA,iBAAiB,cAAc,KAAK,UAAU,UAAU,0BAA0B,WAAW,aAAa;AAC1G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,uDAAa;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0DAA0D,SAAS;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,eAAe,MAAM;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B,SAAS;AACT;AACA;AACA,0CAA0C,cAAc,iCAAiC,cAAc;AACvG;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,0CAA0C,cAAc;AACxD,SAAS;AACT;AACA;AACA;AACA,sBAAsB;AACtB,SAAS;AACT;AACA,oCAAoC,iCAAiC;AACrE,0CAA0C,cAAc,iCAAiC,cAAc;AACvG;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,cAAc;AACxD,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,oBAAoB;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,cAAc,2BAA2B,UAAU;AACvF;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,oCAAoC,iDAAO;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8EAA8E,oBAAoB;AAClG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,EAAE,gCAAgC,2BAA2B;AAC1G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,MAAM;AAC3C;AACA,iDAAiD,OAAO;AACxD;AACA;AACA,mDAAmD,aAAa;AAChE;AACA;AACA;AACA,+DAA+D,MAAM;AACrE,wCAAwC,OAAO;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yDAAyD,cAAc;AACvE;AACA,yDAAyD,uBAAuB;AAChF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,uBAAuB;AAChE,yCAAyC,uBAAuB;AAChE,yCAAyC,uBAAuB;AAChE,yCAAyC,uBAAuB;AAChE;AACA,2CAA2C,mBAAmB;AAC9D,2CAA2C,yBAAyB;AACpE;AACA;AACA,eAAe,WAAW;AAC1B,eAAe,SAAS;AACxB,gBAAgB,YAAY;AAC5B;AACA;AACA;AACA;AACA,iBAAiB,4EAAmC;AACpD,sBAAsB,sEAA6B;AACnD;AACA,iBAAiB,8EAAoC;AACrD,sBAAsB,0EAAgC;AACtD;AACA;AACA;AACA;AACA,iCAAiC,2DAAiB,IAAI,0EAAgC;AACtF,iCAAiC,yDAAgB,IAAI,sEAA6B;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,8DAAwB;AAC1C;AACA;AACA,mEAAmE,kBAAkB;AACrF,eAAe,WAAW;AAC1B,eAAe,QAAQ;AACvB,eAAe,cAAc;AAC7B,iBAAiB,aAAa,wBAAwB;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,mFAAM;AAChC,8BAA8B,mFAAM;AACpC,oBAAoB,iGAAgB,sBAAsB,6FAAY,UAAU,6FAAY;AAC5F;AACA;AACA;AACA;AACA,kBAAkB,cAAc;AAChC,mBAAmB,WAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,kEAAwB;AAC/E;AACA,qCAAqC,uDAAa;AAClD;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK;AACpB,gBAAgB,UAAU;AAC1B;AACA;AACA,oBAAoB,yCAAE;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,EAAE;AACrD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,eAAe,QAAQ;AACvB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,OAAO;AACvD;AACA;AACA;AACA,4BAA4B,kEAAwB;AACpD,yDAAyD,kEAAwB,CAAC;AAClF,iCAAiC,uDAAa;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;AChpB3C,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC4E;AACyB;AAC9F;AACP;AACA,8CAA8C,kHAAiC,GAAG,yCAAyC;AAC3H,wFAAwF,0FAAS;AACjG;AACA,KAAK;AACL;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;AClBD;AACY;AAC6B;AACU;AACtF;AACP;AACA,6BAA6B,uGAA0B;AACvD,KAAK;AACL;AACA,uBAAuB,yDAAW;AAClC,wBAAwB,gEAAW;AACnC,KAAK;AACL;AACA,oBAAoB,sGAA2B;AAC/C,gBAAgB,kGAAuB;AACvC,sBAAsB,wGAA6B;AACnD,0BAA0B,+GAAiC;AAC3D,kBAAkB,oGAAyB;AAC3C,sBAAsB,wGAA6B;AACnD,yBAAyB,8GAAgC;AACzD,0BAA0B,+GAAiC;AAC3D,kBAAkB,oGAAyB;AAC3C,iBAAiB,mGAAwB;AACzC,KAAK;AACL;AACO;AACP;AACA;AACA;AACA;AACA;AACA,CAAC,IAAI;AACE;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,gBAAgB;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,oBAAoB;AACnC,gBAAgB,UAAU;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;AC7E3C,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC0C;AACJ;AACA;AACuD;AAC7F;AACA;AACO;AACP;AACA;AACA;AACA;AACA,gBAAgB,wBAAwB;AACxC;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,sBAAsB,kEAAwB,EAAE,4DAAkB;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,cAAc;AACtC,4BAA4B,kBAAkB;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,4DAAkB,mBAAmB,sDAAsD;AAChH;AACA,qBAAqB,iEAAuB;AAC5C,kCAAkC,+DAAqB;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT,+BAA+B,mDAAS,IAAI,2BAA2B;AACvE,iCAAiC,mDAAS,GAAG,0BAA0B;AACvE;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,qBAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,kBAAkB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,MAAM,GAAG,QAAQ;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,eAAe;AACnC;AACA;AACA,qBAAqB,0DAA0D;AAC/E;AACA,oBAAoB,6DAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,uDAAa;AAC3C,8BAA8B,uDAAa;AAC3C;AACA;AACA,aAAa;AACb;AACO;AACP;AACA,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP,oBAAoB,aAAa;AACjC;AACA,4BAA4B,SAAS;AACrC,+BAA+B,2GAAyB;AACxD,oBAAoB,oEAA0B;AAC9C;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;AC5QpC;AACP;AACA,0CAA0C,4KAA2C;AACrF;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,8BAA8B,QAAQ,uBAAuB;AAC7D,sBAAsB,0CAA0C;AAChE;AACA,KAAK;AACL;AACA,2CAA2C;;;;;;;;;;;;;;;;ACd3C;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACpBN;AAC9B;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,kDAAS;AAC7B;AACA,oBAAoB,YAAY;AAChC;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;ACpL3C;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACpCE;AACK;AAClD;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,QAAQ;AACnB,YAAY;AACZ;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,aAAa;AACzB;AACA;AACA;AACA,2DAA2D,sDAAM;AACjE;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACO;AACP;AACA,4BAA4B,sDAAM;AAClC;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA,sBAAsB,sDAAM;AAC5B,oBAAoB,cAAc;AAClC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACA;AACA,oBAAoB,cAAc;AAClC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACA;AACA,sBAAsB,sDAAM;AAC5B,oBAAoB,cAAc;AAClC;AACA;AACA;AACO;AACP;AACA,oBAAoB,cAAc;AAClC;AACA;AACA;AACO;AACP;AACA;AACA;AACA,oBAAoB,eAAe;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA,oBAAoB,gBAAgB;AACpC,wBAAwB,gBAAgB;AACxC,2BAA2B,oDAAW;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,gBAAgB;AAC3B,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA,oBAAoB,YAAY;AAChC,4BAA4B,YAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,gBAAgB;AAClD;AACP;AACA;AACA,oBAAoB,YAAY;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU,OAAO;AACjB,UAAU,SAAS;AACnB,WAAW,UAAU;AACrB;AACO;AACP;AACA,oCAAoC;AACpC,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,oCAAoC;AAC/C;AACA,aAAa,UAAU;AACvB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,kDAAS;AAC7B;AACA,oBAAoB,YAAY;AAChC;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACO;AACP;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,YAAY;AACZ;AACO;AACP;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;ACxO9B;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,OAAO;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,WAAW;AAC7B;AACA;AACA;AACA;AACA,SAAS,eAAe;AACxB;AACA;AACA;AACA;AACA,wBAAwB,SAAS;AACjC;AACA;AACA;AACA,oBAAoB,OAAO;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,SAAS;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,SAAS;AAC/B;AACA;AACA;AACA,kBAAkB,OAAO;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,SAAS;AAC/B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB,gBAAgB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;;;;;;;;;;;AClJa;AACb;AACA,8CAA6C,EAAE,aAAa,EAAC;AAC7D,mBAAmB,GAAG,YAAY;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,UAAU;AAC9B,8CAA8C,qCAAqC;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,UAAU;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;;;;;;;;;;;;;;;;;ACtFnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB;AACxB,yBAAyB;AACzB,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,eAAe;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,eAAe;AACvC;AACA,4BAA4B,eAAe;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA,4BAA4B,mBAAmB;AAC/C;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC,4BAA4B,gBAAgB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA,4BAA4B,mBAAmB;AAC/C;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC,4BAA4B,gBAAgB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;AChfA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC0C;AACnC;AACP;AACA;AACA,kCAAkC,6DAAmB;AACrD,wBAAwB,qBAAqB;AAC7C,4BAA4B,wBAAwB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA,2DAA2D;AAC3D;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,qBAAqB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D;AAC/D;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C,+FAA+F;AAC/F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D;AAC/D;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iFAAiF;AACjF;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA,yBAAyB,oBAAoB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;;;;;;;;;;;;;;;;;;;;;;;;;ACrUiC;AACK;AACsC;AACE;AACL;AACF;AACjC;AACtC,gBAAgB,qDAAW;AAC3B;AACA;AACA;AACA;AACA,mBAAmB,iGAA6B;AAChD;AACA,mBAAmB,qGAAgC;AACnD;AACA;AACA,mBAAmB,yFAAwB;AAC3C;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,iBAAiB,EAAE,IAAI;AAC/C;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,0BAA0B;AACrC,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,SAAS;AACpB,WAAW,SAAS;AACpB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,gDAAgD,6DAAmB;AAC1E,iBAAiB;AACjB,qBAAqB,OAAO,gEAA0B;AACtD,0BAA0B;AAC1B,yBAAyB;AACzB;AACA;AACA;AACA,eAAe,0BAA0B;AACzC,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,aAAa;AAC5B,eAAe,kBAAkB;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,uDAAa;AAC7D;AACA,uBAAuB,gDAAM,OAAO,SAAS,UAAU,EAAE,gBAAgB,EAAE,OAAO;AAClF;AACA;AACA;AACA;AACA,oDAAoD,iDAAiD;AACrG;AACA;AACA,mCAAmC,oDAAU,wBAAwB,SAAS,gBAAgB;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6EAA6E,uDAAa;AAC1F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,uDAAa;AACnE;AACA;AACA,iCAAiC,6FAAmB,mDAAmD;AACvG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;ACvJO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,sCAAsC;AAChC;AACP;AACA;AACA;AACA,CAAC,gCAAgC;AAC1B;AACP;AACA;AACA;AACA;AACA;AACA,CAAC,oBAAoB;AACd;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,8BAA8B;AACxB;AACA;AACA;AACA;AACP;AACA;AACA,CAAC,sBAAsB;AAChB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,YAAY,6GAA6G;AACzH,YAAY,wGAAwG;AACpH,WAAW,mGAAmG;AAC9G,YAAY,oEAAoE;AAChF;AACA;AACA;AACA,KAAK;AACL,WAAW,0DAA0D;AACrE;;;;;;;;;;;;;;;;;;;ACzDsC;AACmB;AACzD;AACA;AACA;AACA,WAAW,WAAW;AACtB;AACO;AACP,0BAA0B,kEAAiB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,wDAAc;AAC9C,2BAA2B,wDAAc;AACzC,IAAI,mDAAS;AACb,aAAa,gDAAM;AACnB,QAAQ,+CAAK;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;;;;;;;;;;;;;;;;;;;;;ACnCA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACtC;AACmC;AACmD;AACtF;AACA;AACA;AACA,WAAW,UAAU;AACrB,YAAY,QAAQ;AACpB;AACA;AACA,uDAAuD,MAAM,IAAI,EAAE;AACnE;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,UAAU;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,WAAW;AACtB,WAAW,SAAS;AACpB,YAAY,oBAAoB;AAChC;AACO;AACP;AACA;AACA;AACA,gDAAgD,sGAA4B;AAC5E;AACA,8BAA8B,uDAAK;AACnC;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,+DAAqB,QAAQ,YAAY;AAChE;AACA,uCAAuC,uDAAa;AACpD;AACA,sBAAsB,uDAAa;AACnC,yBAAyB,kEAAwB;AACjD;AACA,KAAK;AACL;AACO;AACP;AACA;AACA;AACA,4BAA4B,oBAAoB;AAChD;AACA,gCAAgC,+DAAqB;AACrD,sDAAsD,EAAE;AACxD;AACA;AACA,mDAAmD,GAAG,QAAQ,MAAM;AACpE;AACA;AACA,KAAK;AACL;;;;;;;;;;;;;;;;;;;AChFsC;AACiC;AACvE;AACO;AACP;AACA;AACA,oDAAoD,uDAAa;AACjE;AACA;AACA,wBAAwB;AACxB,yBAAyB;AACzB,2BAA2B;AAC3B,gBAAgB;AAChB,oBAAoB;AACpB,eAAe;AACf,8BAA8B;AAC9B,kCAAkC;AAClC,6BAA6B;AAC7B,cAAc;AACd,cAAc;AACd,kBAAkB;AAClB;AACA;AACA,gBAAgB,cAAc;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,QAAQ;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,UAAU;AACzB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,4DAAkB;AAC5C;AACA,yBAAyB,uDAAa;AACtC;AACA;AACA,6BAA6B,+DAAqB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,gBAAgB,kBAAkB;AAClC;AACA;AACA;AACA,gCAAgC,iGAAuB;AACvD;AACA;AACA;AACA;AACA;AACA,4BAA4B,+BAA+B;AAC3D;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,gBAAgB,wBAAwB;AACxC;AACA;AACA;AACA,gCAAgC,iGAAuB;AACvD,8CAA8C;AAC9C,mCAAmC;AACnC,+CAA+C;AAC/C,+BAA+B;AAC/B;AACA;AACA,0BAA0B;AAC1B;AACA,wCAAwC;AACxC,yEAAyE;AACzE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,+BAA+B;AAC3D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,sGAA4B;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,gCAAgC;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,yBAAyB,sGAA4B;AACrD,8CAA8C;AAC9C,mCAAmC;AACnC,+CAA+C;AAC/C,+BAA+B;AAC/B;AACA;AACA,0BAA0B;AAC1B;AACA,wCAAwC;AACxC,yEAAyE;AACzE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,+BAA+B;AAC3D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,UAAU;AACzB,eAAe,eAAe;AAC9B,gBAAgB,0BAA0B;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;ACtQA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACA;AACuD;AACjB;AACrE;AACP;AACA;AACA;AACA,wBAAwB,wBAAwB;AAChD,2BAA2B,2GAAyB,CAAC,yGAAyC;AAC9F,eAAe,4DAAkB,CAAC,8DAAoB;AACtD,KAAK;AACL;AACO;AACP,sCAAsC,iDAAO;AAC7C,wBAAwB,iDAAO;AAC/B,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oDAAU;AAC9B,yBAAyB,oDAAU;AACnC;AACA;AACA;AACA,+CAA+C,iDAAO;AACtD;AACA;AACA,aAAa,SAAS,sBAAsB;AAC5C,KAAK;AACL;;;;;;;;;;;;;;;;;;;;;AC3CA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACsC;AACqB;AAC1F;AACP;AACA;AACA,sCAAsC,uDAAa;AACnD;AACA;AACA;AACA,4BAA4B,6FAA0B;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,+GAAoC;AAC9E,qEAAqE,oEAA0B;AAC/F,iBAAiB,yDAAyD,uDAAa;AACvF,KAAK;AACL;AACO;AACP;AACA;AACA,+BAA+B,GAAG,GAAG,WAAW;AAChD;;;;;;;;;;;;;;;;;;;;;;;;;;ACpCsC;AACiC;AAC7B;AACnC;AACA;AACA;AACA;AACA;AACP,2BAA2B,uDAAa;AACxC;AACA,yBAAyB,6FAAmB;AAC5C;AACA;AACA,oBAAoB,gBAAgB;AACpC;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA,oBAAoB,4DAAkB,YAAY,aAAa;AAC/D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,KAAK;AACL;AACA;;;;;;;;;;;;;;;;;;;;;ACzCA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACA;AACgC;AACtE,YAAY,gFAAY;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,8BAA8B,qDAAW;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uEAAuE,6DAA6D;AACpI,sEAAsE,6BAA6B;AACnG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,6FAA6F;AACjH,oBAAoB,6FAA6F;AACjH;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA,2BAA2B,0DAAgB;AAC3C;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,iCAAiC;AACjC,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,qEAAqE,0DAAgB;AACrF;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uEAAuE,qCAAqC;AAC5G;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,6CAA6C,mCAAmC,YAAY,OAAO,EAAE,+BAA+B,GAAG;AACvI;AACA;AACA;AACA,iCAAiC,2BAA2B;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,kDAAQ;AACtC;AACA;AACA,gDAAgD,gDAAM;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA,uCAAuC,gDAAM,gBAAgB,OAAO,EAAE,oBAAoB;AAC1F;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA,qBAAqB;AACrB;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,kCAAkC,4CAA4C;AAC9E,wBAAwB,gDAAM,oBAAoB,UAAU,uBAAuB,GAAG;AACtF;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,6BAA6B,4BAA4B;AACzD,iCAAiC,6BAA6B;AAC9D;AACA,iEAAiE,UAAU;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,IAAI,OAAO,KAAK;AAC/D;AACA;;;;;;;;;;;AC9OA;AACA,IAAI,IAAyD;AAC7D;AACA,MAAM,EAKmB;AACzB,CAAC;AACD,qCAAqC;AACrC;AACA;;AAEA;AACA,mBAAmB,8BAAmB;;AAEtC;AACA;AACA;;AAEA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;;AAEA;AACA,0EAA0E,8BAAmB;;AAE7F;AACA;;AAEA;AACA;AACA;;;AAGA;AACA,UAAU,8BAAmB;;AAE7B;AACA,UAAU,8BAAmB;;AAE7B;AACA,UAAU,8BAAmB;;AAE7B;AACA,iBAAiB,8BAAmB;AACpC,UAAU;AACV;AACA;AACA;AACA,gCAAgC,+BAAmB;;AAEnD;;AAEA,0BAA0B,+BAAmB;;AAE7C,sBAAsB,+BAAmB;;AAEzC,wBAAwB,+BAAmB;;AAE3C,oBAAoB,+BAAmB;;AAEvC,2BAA2B,+BAAmB;;AAE9C,oBAAoB,+BAAmB;;AAEvC,YAAY,+BAAmB;;AAE/B,gBAAgB,+BAAmB;;AAEnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,uEAAuE,aAAa;AACpF;AACA;;AAEA;AACA;AACA,MAAM;AACN,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,wEAAwE,eAAe;AACvF;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,0EAA0E,eAAe;AACzF;AACA;;AAEA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,KAAK,EAAE,EAGV;;AAEV;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,KAAK,EAAE,EAGV;;AAEV;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,2FAA2F,eAAe;AAC1G;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA,2EAA2E,eAAe;AAC1F;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA,2EAA2E,eAAe;AAC1F;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA,+FAA+F,eAAe;AAC9G;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,6DAA6D,sEAAsE;AACnI;;AAEA;AACA;AACA,aAAa;AACb;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;;AAEA;AACA,MAAM;AACN,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,2DAA2D,sEAAsE;AACjI;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;AACA,EAAE;;AAEF;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,KAAK,EAAE,EAGV;;AAEV;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;AACF;;AAEA;AACA;;AAEA;AACA,iBAAiB;;AAEjB;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;;AAEA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA,aAAa;;AAEb;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;;AAEA,mBAAmB,gCAAmB;;AAEtC;AACA;AACA,+CAA+C,gBAAgB;;AAE/D;AACA,KAAK;AACL;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,oBAAoB,WAAW,gCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,CAAC,gCAAmB;AACpB,CAAC,gCAAmB;AACpB,kBAAkB,gCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;AACA,YAAY,gCAAmB;;AAE/B;AACA,CAAC,gCAAmB;AACpB,+BAA+B;AAC/B,+BAA+B;AAC/B;AACA,EAAE;AACF;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA,WAAW;AACX,EAAE;;AAEF,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;AACA;AACA,iBAAiB,gCAAmB;AACpC,iBAAiB,gCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;AACA,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA,GAAG,gCAAmB;AACtB;AACA;AACA,0CAA0C;AAC1C,8CAA8C;AAC9C,OAAO,2BAA2B;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,gCAAmB;AAChD;AACA,KAAK,gCAAmB;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,iBAAiB,gCAAmB;AACpC,iBAAiB,gCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C,kEAAkE;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,+DAA+D;AAC/D;AACA;AACA;AACA,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA,yCAAyC;;AAEzC,OAAO;AACP;AACA;;AAEA,8BAA8B;AAC9B,uCAAuC;;AAEvC,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,kBAAkB,gCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,kBAAkB,gCAAmB;AACrC,kBAAkB,gCAAmB;AACrC,kBAAkB,gCAAmB;AACrC;AACA,GAAG;AACH;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;AACA,mBAAmB,gCAAmB;AACtC,kCAAkC,QAAQ,iBAAiB,YAAY;AACvE,EAAE;;AAEF,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA,wBAAwB;AACxB;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,cAAc,gCAAmB;AACjC,cAAc,gCAAmB;AACjC;AACA;AACA,0CAA0C,gCAAmB;AAC7D;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,cAAc,gCAAmB;AACjC;AACA,oDAAoD;AACpD;AACA,wCAAwC;AACxC;;A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mB;;AAErC,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,+CAA+C;AAC/C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,kBAAkB,gCAAmB;;AAErC;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA,oBAAoB;;AAEpB,6BAA6B,6BAA6B,cAAc;;AAExE,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,wDAAwD;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,eAAe,gCAAmB;;AAElC,wBAAwB,gCAAmB;;AAE3C,sBAAsB,gCAAmB;;AAEzC,gBAAgB,gCAAmB;;AAEnC;AACA;;AAEA;AACA,kBAAkB;AAClB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB,OAAO;AACP,gBAAgB;AAChB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,WAAW;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA,QAAQ;;AAER;AACA;AACA,qEAAqE;;AAErE;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,6BAA6B;AAC7B;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,mBAAmB;AACrD;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,mBAAmB;;AAEnB;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,0BAA0B,gBAAgB;AAC1C;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,cAAc;AACd;AACA;;AAEA;AACA,cAAc;AACd;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,MAAM;;AAEN;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,QAAQ;AACxD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA,gDAAgD,QAAQ;AACxD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA,MAAM;;AAEN;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,MAAM;;AAEN;AACA,gDAAgD,QAAQ;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA,gDAAgD,QAAQ;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;;AAEN;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA,6BAA6B,6BAA6B,cAAc,KAAK,gCAAmB;;AAEhG,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yBAAyB,sBAAsB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA,8BAA8B;;;AAG9B,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA;AACA,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,4BAA4B;AAC5B,sBAAsB,2BAA2B,SAAS;AAC1D,IAAI;AACJ,EAAE;AACF;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA,+DAA+D;AAC/D;AACA,OAAO;AACP;AACA,uBAAuB,iCAAiC;AACxD,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,uBAAuB,iCAAmB;AAC1C;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ,0BAA0B,gBAAgB;AAC1C,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,wBAAwB,gBAAgB;;AAExC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,iBAAiB,iCAAmB;AACpC,iBAAiB,iCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,mBAAmB;AACnB,iBAAiB,iCAAmB;AACpC,iBAAiB,iCAAmB;;AAEpC;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,SAAS,iCAAmB;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,SAAS,iCAAmB;AAC5B;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C,cAAc,WAAW;AACpE;AACA,yCAAyC;AACzC;AACA;AACA;AACA,iBAAiB,iCAAmB;AACpC;AACA,6BAA6B;AAC7B,0BAA0B;AAC1B,QAAQ;AACR;AACA;AACA,KAAK,UAAU;AACf;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,aAAa;AACb,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,oBAAoB,gCAAgC;AACpD,WAAW;AACX;AACA;AACA,SAAS;AACT,MAAM;AACN,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA;AACA,wBAAwB,sBAAsB;AAC9C;AACA;AACA,WAAW;AACX;AACA;AACA,QAAQ;AACR,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL,mBAAmB,oBAAoB,MAAM;AAC7C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG,iCAAmB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA,8CAA8C,WAAW;AACzD,CAAC,iCAAmB;AACpB;AACA,mBAAmB,iCAAmB;;AAEtC;AACA;AACA;AACA;AACA,yCAAyC,SAAS;AAClD;AACA,EAAE;AACF;AACA;AACA;AACA;AACA,qCAAqC,SAAS;AAC9C;AACA,EAAE;AACF,uCAAuC,iCAAmB;AAC1D,oCAAoC;AACpC,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV,QAAQ;AACR;AACA,MAAM;AACN,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,MAAM;AACN;AACA,EAAE;;AAEF,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kEAAkE,gBAAgB;AAClF;AACA,KAAK,2CAA2C,gCAAgC;AAChF;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA;AACA,gBAAgB,iCAAmB;AACnC,gBAAgB,iCAAmB;AACnC,gBAAgB,iCAAmB;AACnC;AACA;AACA;AACA;AACA;AACA,oDAAoD;AACpD;AACA;AACA,eAAe,iCAAmB;AAClC;AACA;AACA,SAAS,UAAU;AACnB;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,GAAG;AACT;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,eAAe,iCAAmB;AAClC,eAAe,iCAAmB;AAClC;AACA,MAAM,iCAAmB;AACzB;AACA,sBAAsB;AACtB,IAAI;AACJ;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,iBAAiB,iCAAmB;AACpC,iBAAiB,iCAAmB;AACpC;AACA;AACA,iBAAiB,iCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,sCAAsC,oBAAoB,GAAG;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,iCAAmB;AACzB;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,gBAAgB,iCAAmB;AACnC,gBAAgB,iCAAmB;AACnC;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,cAAc,iCAAmB;AACjC;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,gBAAgB,iCAAmB;;AAEnC,CAAC,iCAAmB;AACpB;AACA;AACA;AACA,EAAE;;AAEF,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA;AACA,cAAc,iCAAmB;AACjC,eAAe,iCAAmB,iBAAiB;AACnD;AACA;AACA,0BAA0B,iCAAmB,iBAAiB,QAAQ;AACtE;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,cAAc,iCAAmB;;AAEjC;AACA,CAAC,iCAAmB;AACpB,0BAA0B;AAC1B,EAAE;AACF;AACA;AACA;AACA;AACA,EAAE;;AAEF,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC;AACA,oBAAoB,iCAAmB;AACvC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,wBAAwB,OAAO;AAC/B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;AACjC;AACA,MAAM;AACN,KAAK,iCAAmB;AACxB;AACA;AACA;AACA,+DAA+D,OAAO;AACtE;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,IAAI;AACJ;AACA;AACA;AACA;AACA,KAAK,iCAAmB;AACxB,4BAA4B;AAC5B,4BAA4B;AAC5B,4BAA4B;AAC5B,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA;AACA,aAAa,iCAAmB,aAAa;AAC7C;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;;AAErC;AACA,eAAe,iCAAmB;AAClC;AACA;AACA;AACA;AACA,OAAO,iCAAmB;AAC1B,uCAAuC,iCAAmB,iBAAiB,2BAA2B;AACtG;AACA;AACA;AACA,KAAK,iCAAmB;AACxB,KAAK;AACL;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;;AAEA,GAAG,iCAAmB;;AAEtB;AACA;;AAEA;;AAEA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,aAAa,iCAAmB;;AAEhC,sBAAsB,QAAQ,iCAAmB,YAAY;;AAE7D,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,eAAe,iCAAmB;AAClC,eAAe,iCAAmB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;AACD;;;;;;;;;;;ACnrKA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;UAEA;UACA;;;;;WCzBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;WACA;WACA;WACA;WACA;;;;;WCJA;WACA;WACA;WACA;WACA,GAAG;WACH;WACA;WACA,CAAC;;;;;WCPD;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;WCNA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;;;;;WCfA;;WAEA;WACA;WACA;WACA;WACA;WACA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACrBA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACA;AAC0C;AACJ;AAC/B,qBAAqB,oDAAU;AACiC;AACT;AACE;AAChB;AACN;AACoC;AACS;AACC;AACb;AACxB;AACuB;AAC1E;AACO;AACP;AACA;AACA;AACA;AACA,qCAAqC,gBAAgB;AACrD,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACO;AACP,eAAe,oFAAiC;AAChD;AACA;AACA,6BAA6B,uDAAa;AAC1C,wBAAwB,kEAAwB;AAChD,QAAQ,4DAAkB;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,wCAAwC,EAAE,gCAAgC,EAAE,gBAAgB;AACpH;AACA,wBAAwB,wCAAwC,EAAE,gCAAgC,EAAE,eAAe;AACnH,QAAQ,4DAAkB;AAC1B;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA,4BAA4B;AAC5B;AACA;AACA;AACA;AACO;AACP,wBAAwB,yDAAiB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,eAAe,iFAAO;AACtB;AACA;AACA;AACA;AACA;AACO;AACP,eAAe,uEAAe;AAC9B;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA,6BAA6B;AACtB;AACP;AACA;AACA;AACA,0BAA0B,4EAAqB;AAC/C;AACA,qBAAqB,4CAA4C;AACjE;AACA,yCAAyC,uDAAa;AACtD,cAAc,qGAAiB,qGAAqG,kEAAwB,SAAS,gEAAa,EAAE,oFAAuB,EAAE,wEAAW;AACxN,KAAK;AACL;AACA;AACA;AACA;AACA,gCAAgC;AAChC,6BAA6B;AAC7B,mCAAmC;AACnC;AACO;AACP;AACA;AACA;AACA,+BAA+B,4EAAqB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,oEAAa;AACpD;AACA;AACA;AACA;AACA,4BAA4B,0DAAgB;AAC5C;AACA,oCAAoC,qEAAqE;AACzG;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AACxB;AACP;AACA,YAAY,sDAAY,GAAG,yCAAyC;AACpE,YAAY,4DAAkB;AAC9B;AACA;AACA;AACA;AACA,gEAAgE,iEAAsB;AACtF;AACA,4BAA4B,iEAAkB;AAC9C,6BAA6B,iEAAW;AACxC,oBAAoB,+DAAqB;AACzC,sBAAsB,6DAAmB;AACzC,iBAAiB,uDAAa;AAC9B;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACO;AACP;AACA;AACA;AACA,6BAA6B,6EAAS;AACtC;AACA;AACA,cAAc,uEAA6B;AAC3C;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACO;AACP;AACA;AACA,mBAAmB,uDAAa;AAChC;AACA,oBAAoB,+FAAqB;AACzC;AACA,YAAY,0DAAgB;AAC5B;AACA;AACA;AACA;AACA;AACA,iCAAiC,uDAAa;AAC9C;AACA,YAAY,4DAAkB;AAC9B,2BAA2B,wCAAwC,EAAE,gCAAgC,EAAE,eAAe;AACtH;AACA;AACA,kCAAkC,8BAA8B;AAChE,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,+BAA+B;AAC/B;AACA;AACA;AACA,eAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,+DAAqB;AACtD,wBAAwB,+DAAqB;AAC7C;AACA,kBAAkB,0FAAgB,iBAAiB,iGAAuB;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gEAAgE,uGAA6B;AAC7F;AACA;AACA,0BAA0B,kEAAwB;AAClD,2BAA2B,QAAQ,GAAG,SAAS;AAC/C,uBAAuB,uDAAa;AACpC,YAAY,kEAAwB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACd;AACP,IAAI,uDAAO;AACX","sources":["webpack://bio/./node_modules/@biowasm/aioli/dist/aioli.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/aminoacids.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/nucleotides.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/seq-palettes.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/sequence-encoder.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/unknown.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/vd-regions.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/viewers/web-logo.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/sequence-space.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/typed-metrics.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/viewers/activity-cliffs.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/workers/dimensionality-reducing-worker-creator.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/random.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/similarity-metrics.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/type-declarations.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/vector-operations.js","webpack://bio/./node_modules/fastest-levenshtein/index.js","webpack://bio/./node_modules/jaro-winkler-typescript/lib/index.js","webpack://bio/./src/seq_align.ts","webpack://bio/./src/utils/atomic-works.ts","webpack://bio/./src/utils/cell-renderer.ts","webpack://bio/./src/utils/constants.ts","webpack://bio/./src/utils/convert.ts","webpack://bio/./src/utils/multiple-sequence-alignment.ts","webpack://bio/./src/utils/notation-converter.ts","webpack://bio/./src/utils/sequence-activity-cliffs.ts","webpack://bio/./src/utils/sequence-space.ts","webpack://bio/./src/utils/utils.ts","webpack://bio/./src/viewers/vd-regions-viewer.ts","webpack://bio/./node_modules/wu/dist/wu.js","webpack://bio/external var \"DG\"","webpack://bio/external var \"grok\"","webpack://bio/external var \"rxjs\"","webpack://bio/external var \"ui\"","webpack://bio/webpack/bootstrap","webpack://bio/webpack/runtime/compat get default export","webpack://bio/webpack/runtime/define property getters","webpack://bio/webpack/runtime/get javascript chunk filename","webpack://bio/webpack/runtime/global","webpack://bio/webpack/runtime/hasOwnProperty shorthand","webpack://bio/webpack/runtime/make namespace object","webpack://bio/webpack/runtime/publicPath","webpack://bio/webpack/runtime/jsonp chunk loading","webpack://bio/./src/package.ts"],"sourcesContent":["(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n  typeof define === 'function' && define.amd ? define(factory) :\n  (global = global || self, global.Aioli = factory());\n}(this, (function () { 'use strict';\n\n  var name = \"@biowasm/aioli\";\n  var version = \"2.4.0-rc2\";\n  var description = \"A framework for building WebAssembly-based genomics tools\";\n  var browser = \"dist/aioli.js\";\n  var worker = \"dist/aioli.worker.js\";\n  var main = \"aioli.js\";\n  var repository = {\n  \ttype: \"git\",\n  \turl: \"git+https://github.com/biowasm/aioli.git\"\n  };\n  var author = \"Robert Aboukhalil\";\n  var license = \"MIT\";\n  var dependencies = {\n  \tcomlink: \"^4.3.1\",\n  \t\"wasm-feature-detect\": \"^1.2.11\"\n  };\n  var devDependencies = {\n  \t\"@rollup/plugin-commonjs\": \"^11.0.1\",\n  \t\"@rollup/plugin-json\": \"^4.1.0\",\n  \t\"@rollup/plugin-node-resolve\": \"^7.0.0\",\n  \tcypress: \"^8.0.0\",\n  \trollup: \"^1.29.0\",\n  \t\"rollup-plugin-terser\": \"^7.0.2\"\n  };\n  var scripts = {\n  \tbuild: \"rollup -c\",\n  \tdev: \"rollup -c -w\",\n  \ttest: \"cypress run\",\n  \t\"test-open\": \"cypress open\"\n  };\n  var files = [\n  \t\"dist\"\n  ];\n  var pkg = {\n  \tname: name,\n  \tversion: version,\n  \tdescription: description,\n  \tbrowser: browser,\n  \tworker: worker,\n  \tmain: main,\n  \trepository: repository,\n  \tauthor: author,\n  \tlicense: license,\n  \tdependencies: dependencies,\n  \tdevDependencies: devDependencies,\n  \tscripts: scripts,\n  \tfiles: files\n  };\n\n  /**\r\n   * Copyright 2019 Google Inc. All Rights Reserved.\r\n   * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n   * you may not use this file except in compliance with the License.\r\n   * You may obtain a copy of the License at\r\n   *     http://www.apache.org/licenses/LICENSE-2.0\r\n   * Unless required by applicable law or agreed to in writing, software\r\n   * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n   * See the License for the specific language governing permissions and\r\n   * limitations under the License.\r\n   */\r\n  const proxyMarker = Symbol(\"Comlink.proxy\");\r\n  const createEndpoint = Symbol(\"Comlink.endpoint\");\r\n  const releaseProxy = Symbol(\"Comlink.releaseProxy\");\r\n  const throwMarker = Symbol(\"Comlink.thrown\");\r\n  const isObject = (val) => (typeof val === \"object\" && val !== null) || typeof val === \"function\";\r\n  /**\r\n   * Internal transfer handle to handle objects marked to proxy.\r\n   */\r\n  const proxyTransferHandler = {\r\n      canHandle: (val) => isObject(val) && val[proxyMarker],\r\n      serialize(obj) {\r\n          const { port1, port2 } = new MessageChannel();\r\n          expose(obj, port1);\r\n          return [port2, [port2]];\r\n      },\r\n      deserialize(port) {\r\n          port.start();\r\n          return wrap(port);\r\n      },\r\n  };\r\n  /**\r\n   * Internal transfer handler to handle thrown exceptions.\r\n   */\r\n  const throwTransferHandler = {\r\n      canHandle: (value) => isObject(value) && throwMarker in value,\r\n      serialize({ value }) {\r\n          let serialized;\r\n          if (value instanceof Error) {\r\n              serialized = {\r\n                  isError: true,\r\n                  value: {\r\n                      message: value.message,\r\n                      name: value.name,\r\n                      stack: value.stack,\r\n                  },\r\n              };\r\n          }\r\n          else {\r\n              serialized = { isError: false, value };\r\n          }\r\n          return [serialized, []];\r\n      },\r\n      deserialize(serialized) {\r\n          if (serialized.isError) {\r\n              throw Object.assign(new Error(serialized.value.message), serialized.value);\r\n          }\r\n          throw serialized.value;\r\n      },\r\n  };\r\n  /**\r\n   * Allows customizing the serialization of certain values.\r\n   */\r\n  const transferHandlers = new Map([\r\n      [\"proxy\", proxyTransferHandler],\r\n      [\"throw\", throwTransferHandler],\r\n  ]);\r\n  function expose(obj, ep = self) {\r\n      ep.addEventListener(\"message\", function callback(ev) {\r\n          if (!ev || !ev.data) {\r\n              return;\r\n          }\r\n          const { id, type, path } = Object.assign({ path: [] }, ev.data);\r\n          const argumentList = (ev.data.argumentList || []).map(fromWireValue);\r\n          let returnValue;\r\n          try {\r\n              const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);\r\n              const rawValue = path.reduce((obj, prop) => obj[prop], obj);\r\n              switch (type) {\r\n                  case \"GET\" /* GET */:\r\n                      {\r\n                          returnValue = rawValue;\r\n                      }\r\n                      break;\r\n                  case \"SET\" /* SET */:\r\n                      {\r\n                          parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);\r\n                          returnValue = true;\r\n                      }\r\n                      break;\r\n                  case \"APPLY\" /* APPLY */:\r\n                      {\r\n                          returnValue = rawValue.apply(parent, argumentList);\r\n                      }\r\n                      break;\r\n                  case \"CONSTRUCT\" /* CONSTRUCT */:\r\n                      {\r\n                          const value = new rawValue(...argumentList);\r\n                          returnValue = proxy(value);\r\n                      }\r\n                      break;\r\n                  case \"ENDPOINT\" /* ENDPOINT */:\r\n                      {\r\n                          const { port1, port2 } = new MessageChannel();\r\n                          expose(obj, port2);\r\n                          returnValue = transfer(port1, [port1]);\r\n                      }\r\n                      break;\r\n                  case \"RELEASE\" /* RELEASE */:\r\n                      {\r\n                          returnValue = undefined;\r\n                      }\r\n                      break;\r\n                  default:\r\n                      return;\r\n              }\r\n          }\r\n          catch (value) {\r\n              returnValue = { value, [throwMarker]: 0 };\r\n          }\r\n          Promise.resolve(returnValue)\r\n              .catch((value) => {\r\n              return { value, [throwMarker]: 0 };\r\n          })\r\n              .then((returnValue) => {\r\n              const [wireValue, transferables] = toWireValue(returnValue);\r\n              ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);\r\n              if (type === \"RELEASE\" /* RELEASE */) {\r\n                  // detach and deactive after sending release response above.\r\n                  ep.removeEventListener(\"message\", callback);\r\n                  closeEndPoint(ep);\r\n              }\r\n          });\r\n      });\r\n      if (ep.start) {\r\n          ep.start();\r\n      }\r\n  }\r\n  function isMessagePort(endpoint) {\r\n      return endpoint.constructor.name === \"MessagePort\";\r\n  }\r\n  function closeEndPoint(endpoint) {\r\n      if (isMessagePort(endpoint))\r\n          endpoint.close();\r\n  }\r\n  function wrap(ep, target) {\r\n      return createProxy(ep, [], target);\r\n  }\r\n  function throwIfProxyReleased(isReleased) {\r\n      if (isReleased) {\r\n          throw new Error(\"Proxy has been released and is not useable\");\r\n      }\r\n  }\r\n  function createProxy(ep, path = [], target = function () { }) {\r\n      let isProxyReleased = false;\r\n      const proxy = new Proxy(target, {\r\n          get(_target, prop) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              if (prop === releaseProxy) {\r\n                  return () => {\r\n                      return requestResponseMessage(ep, {\r\n                          type: \"RELEASE\" /* RELEASE */,\r\n                          path: path.map((p) => p.toString()),\r\n                      }).then(() => {\r\n                          closeEndPoint(ep);\r\n                          isProxyReleased = true;\r\n                      });\r\n                  };\r\n              }\r\n              if (prop === \"then\") {\r\n                  if (path.length === 0) {\r\n                      return { then: () => proxy };\r\n                  }\r\n                  const r = requestResponseMessage(ep, {\r\n                      type: \"GET\" /* GET */,\r\n                      path: path.map((p) => p.toString()),\r\n                  }).then(fromWireValue);\r\n                  return r.then.bind(r);\r\n              }\r\n              return createProxy(ep, [...path, prop]);\r\n          },\r\n          set(_target, prop, rawValue) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              // FIXME: ES6 Proxy Handler `set` methods are supposed to return a\r\n              // boolean. To show good will, we return true asynchronously ¯\\_(ツ)_/¯\r\n              const [value, transferables] = toWireValue(rawValue);\r\n              return requestResponseMessage(ep, {\r\n                  type: \"SET\" /* SET */,\r\n                  path: [...path, prop].map((p) => p.toString()),\r\n                  value,\r\n              }, transferables).then(fromWireValue);\r\n          },\r\n          apply(_target, _thisArg, rawArgumentList) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              const last = path[path.length - 1];\r\n              if (last === createEndpoint) {\r\n                  return requestResponseMessage(ep, {\r\n                      type: \"ENDPOINT\" /* ENDPOINT */,\r\n                  }).then(fromWireValue);\r\n              }\r\n              // We just pretend that `bind()` didn’t happen.\r\n              if (last === \"bind\") {\r\n                  return createProxy(ep, path.slice(0, -1));\r\n              }\r\n              const [argumentList, transferables] = processArguments(rawArgumentList);\r\n              return requestResponseMessage(ep, {\r\n                  type: \"APPLY\" /* APPLY */,\r\n                  path: path.map((p) => p.toString()),\r\n                  argumentList,\r\n              }, transferables).then(fromWireValue);\r\n          },\r\n          construct(_target, rawArgumentList) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              const [argumentList, transferables] = processArguments(rawArgumentList);\r\n              return requestResponseMessage(ep, {\r\n                  type: \"CONSTRUCT\" /* CONSTRUCT */,\r\n                  path: path.map((p) => p.toString()),\r\n                  argumentList,\r\n              }, transferables).then(fromWireValue);\r\n          },\r\n      });\r\n      return proxy;\r\n  }\r\n  function myFlat(arr) {\r\n      return Array.prototype.concat.apply([], arr);\r\n  }\r\n  function processArguments(argumentList) {\r\n      const processed = argumentList.map(toWireValue);\r\n      return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];\r\n  }\r\n  const transferCache = new WeakMap();\r\n  function transfer(obj, transfers) {\r\n      transferCache.set(obj, transfers);\r\n      return obj;\r\n  }\r\n  function proxy(obj) {\r\n      return Object.assign(obj, { [proxyMarker]: true });\r\n  }\r\n  function toWireValue(value) {\r\n      for (const [name, handler] of transferHandlers) {\r\n          if (handler.canHandle(value)) {\r\n              const [serializedValue, transferables] = handler.serialize(value);\r\n              return [\r\n                  {\r\n                      type: \"HANDLER\" /* HANDLER */,\r\n                      name,\r\n                      value: serializedValue,\r\n                  },\r\n                  transferables,\r\n              ];\r\n          }\r\n      }\r\n      return [\r\n          {\r\n              type: \"RAW\" /* RAW */,\r\n              value,\r\n          },\r\n          transferCache.get(value) || [],\r\n      ];\r\n  }\r\n  function fromWireValue(value) {\r\n      switch (value.type) {\r\n          case \"HANDLER\" /* HANDLER */:\r\n              return transferHandlers.get(value.name).deserialize(value.value);\r\n          case \"RAW\" /* RAW */:\r\n              return value.value;\r\n      }\r\n  }\r\n  function requestResponseMessage(ep, msg, transfers) {\r\n      return new Promise((resolve) => {\r\n          const id = generateUUID();\r\n          ep.addEventListener(\"message\", function l(ev) {\r\n              if (!ev.data || !ev.data.id || ev.data.id !== id) {\r\n                  return;\r\n              }\r\n              ep.removeEventListener(\"message\", l);\r\n              resolve(ev.data);\r\n          });\r\n          if (ep.start) {\r\n              ep.start();\r\n          }\r\n          ep.postMessage(Object.assign({ id }, msg), transfers);\r\n      });\r\n  }\r\n  function generateUUID() {\r\n      return new Array(4)\r\n          .fill(0)\r\n          .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))\r\n          .join(\"-\");\r\n  }\n  //# sourceMappingURL=comlink.mjs.map\n\n  // Constants\n  const URL_CDN_ROOT = \"https://cdn.biowasm.com/v2\";\n  const CONFIG_DEFAULTS = {\n  \t// Biowasm CDN URLs\n  \turlCDN: URL_CDN_ROOT,\n  \t// Get the Worker code corresponding to the current Aioli version\n  \turlAioli: `${URL_CDN_ROOT}/aioli/${pkg.version}/aioli.worker.js`,\n  \t// Where we can find the base biowasm module (only modify this for local development)\n  \turlBaseModule: null,\n\n  \t// Folder to use for mounting the shared filesystem\n  \tdirShared: \"/shared\",\n  \t// Folder to use for mounting File/Blob objects to the virtual file system\n  \tdirMounted: \"/mnt\",\n  \t// Folder to use for symlinks (basically, we make a symlink to each file mounted on WORKERFS\n  \t// so that operations like \"samtools index\" don't crash due to the read-only nature of WORKERS).\n  \t// Also mount URLs lazily in that folder.\n  \tdirData: \"/data\",\n  \t// Interleave stdout/stderr. If set to false, `.exec()` returns an object { \"stdout\": <text>, \"stderr\": <text> }\n  \tprintInterleaved: true,\n\n  \t// Callback function to run whenever we receive a message from the WebWorker with payload { type: \"biowasm\", value: ... }.\n  \t// See <https://github.com/biowasm/biowasm/tree/main/tools/bhtsne> for an example of how this can be used to send regular updates\n  \t// back to the main thread before callMain() is done running.\n  \tcallback: null,\n\n  \t// Debugging\n  \tdebug: false,\n  \tenv: \"prd\"\n  };\n\n  // Class: 1 object = 1 worker; user can decide if they want tools running in separate threads or all of them in one\n  class Aioli\n  {\n  \tconstructor(tools, config={})\n  \t{\n  \t\tif(tools == null)\n  \t\t\tthrow \"Expecting array of tools as input to Aioli constructor.\";\n\n  \t\t// Parse user input\n  \t\tif(!Array.isArray(tools))\n  \t\t\ttools = [ tools ];\n  \t\t// Overwrite default config if specified\n  \t\tconfig = Object.assign({}, CONFIG_DEFAULTS, config);\n  \t\t// For convenience, support \"<tool>/<version>\" or \"<tool>/<program>/<version>\" instead of object config\n  \t\ttools = tools.map(this._parseTool);\n  \t\t// If testing with different environment e.g. cdn-stg.biowasm.com\n  \t\tif(config.env != \"prd\") {\n  \t\t\tconfig.urlCDN = config.urlCDN.replace(\"cdn\", `cdn-${config.env}`);\n  \t\t\tconfig.urlAioli = config.urlAioli.replace(\"cdn\", `cdn-${config.env}`);\n  \t\t}\n\n  \t\t// Add biowasm base module to list of tools to initialize (need this for the shared virtual filesystem)\n  \t\ttools = [{\n  \t\t\ttool: \"base\",\n  \t\t\tversion: pkg.version,\n  \t\t\turlPrefix: config.urlBaseModule\n  \t\t}, ...tools];\n\n  \t\t// Set state\n  \t\tthis.tools = tools;\n  \t\tthis.config = config;\n\n  \t\t// Handle callback (delete it because we can't send a function to the WebWorker)\n  \t\tif(this.config.callback != null)\n  \t\t\tthis.callback = this.config.callback;\n  \t\tdelete this.config.callback;\n\n  \t\treturn this.init();\n  \t}\n\n  \t// Initialize the WebWorker and the WebAssembly modules within it\n  \tasync init() {\n  \t\t// Note: We can only create a WebWorker using a URL that has the same origin as the app running it, i.e. we\n  \t\t// can't do `new Worker(\"https://cdn.biowasm.com/v2/...\")`, so instead we need to fetch the contents of that\n  \t\t// URL first, and then create the WebWorker. See <https://stackoverflow.com/a/60015898>.\n  \t\tconst moduleJS = await (await fetch(this.config.urlAioli)).text();\n  \t\tconst moduleBlob = new Blob([moduleJS], { type: \"application/javascript\" });\n\n  \t\t// Create the WebWorker\n  \t\tconst worker = new Worker(URL.createObjectURL(moduleBlob));\n  \t\t// Listen for \"biowasm\" messages from the WebWorker\n  \t\tif(this.callback)\n  \t\t\tworker.onmessage = e => {\n  \t\t\t\tif(e.data.type == \"biowasm\")\n  \t\t\t\t\tthis.callback(e.data.value);\n  \t\t\t};\n\n  \t\tconst aioli = wrap(worker);\n  \t\taioli.tools = this.tools;\n  \t\taioli.config = this.config;\n\n  \t\t// Initialize the tools inside the WebWorker\n  \t\tawait aioli.init();\n\n  \t\treturn aioli;\n  \t}\n\n  \t// Parse \"<tool>/<version>\" and \"<tool>/<program>/<version>\" into { \"tool\": <tool>, \"program\": <program>, \"version\": <version> }\n  \t_parseTool(tool)\n  \t{\n  \t\t// If not a string, leave it as is\n  \t\tif(typeof tool !== \"string\")\n  \t\t\treturn tool;\n\n  \t\t// Support \"<tool>/<version>\" and \"<tool>/<program>/<version>\"\n  \t\tconst toolSplit = tool.split(\"/\");\n  \t\tif(toolSplit.length != 2 && toolSplit.length != 3)\n  \t\t\tthrow \"Expecting '<tool>/<version>' or '<tool>/<program>/<version>'\";\n\n  \t\treturn {\n  \t\t\ttool: toolSplit[0],\n  \t\t\tprogram: toolSplit.length == 3 ? toolSplit[1] : toolSplit[0],\n  \t\t\tversion: toolSplit[toolSplit.length - 1]\n  \t\t};\n  \t}\n  }\n\n  return Aioli;\n\n})));\n//# sourceMappingURL=aioli.js.map\n","import { SeqPaletteBase } from './seq-palettes';\nexport class AminoacidsPalettes extends SeqPaletteBase {\n    static get Lesk() {\n        if (this.lesk === void 0) {\n            this.lesk = this.makePalette([\n                [['G', 'A', 'S', 'T'], 'orange'],\n                [['C', 'V', 'I', 'L', 'P', 'F', 'Y', 'M', 'W'], 'all_green'],\n                [['N', 'Q', 'H'], 'magenta'],\n                [['D', 'E'], 'red'],\n                [['K', 'R'], 'all_blue'],\n            ], false, AminoacidsPalettes);\n        }\n        return this.lesk;\n    }\n    static get GrokGroups() {\n        if (this.grokGroups === void 0) {\n            this.grokGroups = this.makePalette([\n                [['C', 'U'], 'yellow'],\n                [['G', 'P'], 'red'],\n                [['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'], 'all_green'],\n                [['R', 'H', 'K'], 'light_blue'],\n                [['D', 'E'], 'dark_blue'],\n                [['S', 'T', 'N', 'Q'], 'orange'],\n            ], false, AminoacidsPalettes);\n        }\n        return this.grokGroups;\n    }\n    static get RasMol() {\n        if (this.rasMol === void 0) {\n            this.rasMol = new AminoacidsPalettes({\n                // http://acces.ens-lyon.fr/biotic/rastop/help/colour.htm\n                'D': '#E60A0A',\n                'E': '#E60A0A',\n                'C': '#E6E600',\n                'M': '#E6E600',\n                'K': '#145AFF',\n                'R': '#145AFF',\n                'S': '#FA9600',\n                'T': '#FA9600',\n                'F': '#3232AA',\n                'Y': '#3232AA',\n                'N': '#00DCDC',\n                'Q': '#00DCDC',\n                'G': '#EBEBEB',\n                'L': '#0F820F',\n                'V': '#0F820F',\n                'I': '#0F820F',\n                'A': '#C8C8C8',\n                'W': '#B45AB4',\n                'H': '#8282D2',\n                'P': '#DC9682',\n                'others': '#BEA06E',\n            });\n        }\n        return this.rasMol;\n    }\n}\nexport class Aminoacids {\n    static getPalette(scheme = 'grok') {\n        switch (scheme) {\n            case 'grok':\n                return AminoacidsPalettes.GrokGroups;\n            case 'lesk':\n                return AminoacidsPalettes.Lesk;\n            default:\n                throw new Error(`ChemPalette: scheme \\`${scheme}\\` does not exist`);\n        }\n    }\n    /**\n     * Returns divided amino acid with its content in the bracket, if the content is number, then its omitted\n     *\n     * @param {string} c raw amino\n     * @return {[string, string]} outer and inner content\n     */\n    static getInnerOuter(c) {\n        let isInner = 0;\n        let inner = '';\n        let outer = '';\n        for (const char of c) {\n            if (char == '(')\n                isInner++;\n            else if (char == ')')\n                isInner--;\n            else if (isInner)\n                inner += char;\n            else\n                outer += char;\n        }\n        return !isNaN(parseInt(inner)) ? [outer, ''] : [outer, inner];\n    }\n    static getColorAAPivot(monomer = '', scheme = 'grok') {\n        var _a, _b, _c;\n        //const chemPaletteInstance = AAPalettes.GrokGroups();\n        const chemPaletteInstance = this.getPalette(scheme);\n        let [outerMonomer, innerMonomer] = this.getInnerOuter(monomer);\n        outerMonomer = (outerMonomer.length > 6 ? `${outerMonomer.slice(0, 3)}...` : outerMonomer);\n        innerMonomer = (innerMonomer.length > 6 ? `${innerMonomer.slice(0, 3)}...` : innerMonomer);\n        if (monomer.length == 1 || monomer[1] == '(') {\n            const amino = (_a = monomer[0]) === null || _a === void 0 ? void 0 : _a.toUpperCase();\n            return amino in chemPaletteInstance ?\n                [chemPaletteInstance.get(amino), amino, innerMonomer, 1] :\n                [this.undefinedColor, outerMonomer, innerMonomer, 1];\n        }\n        if (monomer[0] == 'd' && monomer[1] in chemPaletteInstance) {\n            if (monomer.length == 2 || monomer[2] == '(') {\n                const amino = (_b = monomer[1]) === null || _b === void 0 ? void 0 : _b.toUpperCase();\n                return amino in chemPaletteInstance ?\n                    [chemPaletteInstance.get(amino), amino, innerMonomer, 2] :\n                    [this.undefinedColor, outerMonomer, innerMonomer, 2];\n            }\n        }\n        if (monomer.substring(0, 3) in this.AAFullNames) {\n            if (monomer.length == 3 || monomer[3] == '(') {\n                const amino = this.AAFullNames[monomer.substring(0, 3)];\n                return amino in chemPaletteInstance ?\n                    [chemPaletteInstance.get(amino), amino, innerMonomer, 3] :\n                    [this.undefinedColor, outerMonomer, innerMonomer, 3];\n            }\n        }\n        if (((_c = monomer[0]) === null || _c === void 0 ? void 0 : _c.toLowerCase()) == monomer[0]) {\n            if (monomer.substring(1, 3) in this.AAFullNames) {\n                if (monomer.length == 4 || monomer[4] == '(') {\n                    const amino = this.AAFullNames[monomer.substring(1, 3)];\n                    return amino in chemPaletteInstance ?\n                        [chemPaletteInstance.get(amino), amino, innerMonomer, 4] :\n                        [this.undefinedColor, outerMonomer, innerMonomer, 4];\n                }\n            }\n        }\n        return [this.undefinedColor, outerMonomer, innerMonomer, 0];\n    }\n}\nAminoacids.SemType = 'Aminoacids';\nAminoacids.SemTypeMultipleAlignment = 'AminoacidsMultipleAlignment';\nAminoacids.undefinedColor = 'rgb(100,100,100)';\nAminoacids.Names = {\n    'G': 'Glycine',\n    'L': 'Leucine',\n    'Y': 'Tyrosine',\n    'S': 'Serine',\n    'E': 'Glutamic acid',\n    'Q': 'Glutamine',\n    'D': 'Aspartic acid',\n    'N': 'Asparagine',\n    'F': 'Phenylalanine',\n    'A': 'Alanine',\n    'K': 'Lysine',\n    'R': 'Arginine',\n    'H': 'Histidine',\n    'C': 'Cysteine',\n    'V': 'Valine',\n    'P': 'Proline',\n    'W': 'Tryptophan',\n    'I': 'Isoleucine',\n    'M': 'Methionine',\n    'T': 'Threonine',\n};\nAminoacids.AASmiles = {\n    'G': 'NCC(=O)O',\n    'L': 'N[C@H](CC(C)C)C(=O)O',\n    'Y': 'NC(CC1=CC=C(O)C=C1)C(=O)O',\n    'S': 'NC(CO)C(=O)O',\n    'E': 'N[C@@H](CCC(O)=O)C(=O)O',\n    'Q': 'N[C@@H](CCC(N)=O)C(=O)O',\n    'D': 'N[C@@H](CC(O)=O)C(=O)O',\n    'N': 'N[C@@H](CC(N)=O)C(=O)O',\n    'F': 'NC(CC1=CC=CC=C1)C(=O)O',\n    'A': 'N[C@H](C)C(=O)O',\n    'K': 'NC(CCCCN)C(=O)O',\n    'R': 'N[C@H](CCCNC(=N)C)C(=O)O',\n    'H': 'NC(CC1=CN=C[N]1)C(=O)O',\n    'C': 'N[C@@H](CS)C(=O)O',\n    'V': 'NC(C(C)C)C(=O)O',\n    'P': 'N(CCC1)C1C(=O)O',\n    'W': 'N[C@@H](Cc1c2ccccc2n([H])c1)C(=O)O',\n    'I': 'N[C@H]([C@H](C)CC)C(=O)O',\n    'M': 'NC(CCSC)C(=O)O',\n    'T': 'NC(C(O)C)C(=O)O',\n};\nAminoacids.AASmilesTruncated = {\n    'G': '*C*',\n    'L': 'CC(C)C[C@H](*)*',\n    'Y': 'C1=CC(=CC=C1CC(*)*)O',\n    'S': 'OCC(*)C*',\n    'E': '*[C@@H](CCC(O)=O)*',\n    'Q': '*N[C@@H](CCC(N)=O)*',\n    'D': '*[C@@H](CC(O)=O)*',\n    'N': '*[C@@H](CC(N)=O)*',\n    'F': 'C1=CC=C(C=C1)CC(*)*',\n    'A': 'C[C@H](*)*',\n    'K': 'C(CCN)CC(*)*',\n    'R': '*[C@H](CCCNC(=N)C)*',\n    'H': 'C1=C(NC=N1)CC(*)*',\n    'C': 'C([C@@H](*)*)S',\n    'V': 'CC(C)C(*)*',\n    'P': 'C1CCN(*)C1*',\n    'W': '*[C@@H](Cc1c2ccccc2n([H])c1)*',\n    'I': 'CC[C@H](C)[C@H](*)*',\n    'M': 'CSCCC(*)*',\n    'T': 'CC(O)C(*)*',\n};\n/** TODO: Full?\n */\nAminoacids.AAFullNames = {\n    'Ala': 'A',\n    'Arg': 'R',\n    'Asn': 'N',\n    'Asp': 'D',\n    'Cys': 'C',\n    'Gln': 'Q',\n    'Glu': 'E',\n    'Gly': 'G',\n    'His': 'H',\n    'Ile': 'I',\n    'Leu': 'L',\n    'Lys': 'K',\n    'Met': 'M',\n    'Phe': 'F',\n    'Pro': 'P',\n    'Ser': 'S',\n    'Thr': 'T',\n    'Trp': 'W',\n    'Tyr': 'Y',\n    'Val': 'V',\n};\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aminoacids.js","sourceRoot":"","sources":["aminoacids.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n\nimport {StringDictionary} from '@datagrok-libraries/utils/src/type-declarations';\nimport {SeqPalette, SeqPaletteBase} from './seq-palettes';\n\nexport class AminoacidsPalettes extends SeqPaletteBase {\n  private static lesk: SeqPalette;\n\n  public static get Lesk(): SeqPalette {\n    if (this.lesk === void 0) {\n      this.lesk = this.makePalette([\n        [['G', 'A', 'S', 'T'], 'orange'],\n        [['C', 'V', 'I', 'L', 'P', 'F', 'Y', 'M', 'W'], 'all_green'],\n        [['N', 'Q', 'H'], 'magenta'],\n        [['D', 'E'], 'red'],\n        [['K', 'R'], 'all_blue'],\n      ], false, AminoacidsPalettes);\n    }\n    return this.lesk;\n  }\n\n  private static grokGroups: SeqPalette;\n\n  public static get GrokGroups(): SeqPalette {\n    if (this.grokGroups === void 0) {\n      this.grokGroups = this.makePalette([\n        [['C', 'U'], 'yellow'],\n        [['G', 'P'], 'red'],\n        [['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'], 'all_green'],\n        [['R', 'H', 'K'], 'light_blue'],\n        [['D', 'E'], 'dark_blue'],\n        [['S', 'T', 'N', 'Q'], 'orange'],\n      ], false, AminoacidsPalettes);\n    }\n    return this.grokGroups;\n  }\n\n  private static rasMol: SeqPalette;\n\n  public static get RasMol(): SeqPalette {\n    if (this.rasMol === void 0) {\n      this.rasMol = new AminoacidsPalettes({\n        // http://acces.ens-lyon.fr/biotic/rastop/help/colour.htm\n        'D': '#E60A0A', // asp, aspartic acid, asp\n        'E': '#E60A0A', // glu, glutamic acid\n        'C': '#E6E600', // cys, cysteine\n        'M': '#E6E600', // met, methionine\n        'K': '#145AFF', // lys, lysine\n        'R': '#145AFF', // arg, arginine\n        'S': '#FA9600', // ser, serine\n        'T': '#FA9600', // thr, threonine\n        'F': '#3232AA', // phe, phenylalanine\n        'Y': '#3232AA', // tyr, tyrosine\n        'N': '#00DCDC', // asn, asparagine\n        'Q': '#00DCDC', // gln, glutamine\n        'G': '#EBEBEB', // gly, glycine\n        'L': '#0F820F', // leu, leucine\n        'V': '#0F820F', // val, valine\n        'I': '#0F820F', // ile, isoleucine\n        'A': '#C8C8C8', // ala, alanine\n        'W': '#B45AB4', // trp, tryptophan\n        'H': '#8282D2', // his, histidine\n        'P': '#DC9682', // pro, proline\n        'others': '#BEA06E',\n      });\n    }\n    return this.rasMol;\n  }\n}\n\nexport class Aminoacids {\n  static readonly SemType: string = 'Aminoacids';\n\n  static readonly SemTypeMultipleAlignment: string = 'AminoacidsMultipleAlignment';\n\n  static undefinedColor = 'rgb(100,100,100)';\n\n  public static Names: StringDictionary = {\n    'G': 'Glycine',\n    'L': 'Leucine',\n    'Y': 'Tyrosine',\n    'S': 'Serine',\n    'E': 'Glutamic acid',\n    'Q': 'Glutamine',\n    'D': 'Aspartic acid',\n    'N': 'Asparagine',\n    'F': 'Phenylalanine',\n    'A': 'Alanine',\n    'K': 'Lysine',\n    'R': 'Arginine',\n    'H': 'Histidine',\n    'C': 'Cysteine',\n    'V': 'Valine',\n    'P': 'Proline',\n    'W': 'Tryptophan',\n    'I': 'Isoleucine',\n    'M': 'Methionine',\n    'T': 'Threonine',\n  };\n\n  public static AASmiles: StringDictionary = {\n    'G': 'NCC(=O)O',\n    'L': 'N[C@H](CC(C)C)C(=O)O',\n    'Y': 'NC(CC1=CC=C(O)C=C1)C(=O)O',\n    'S': 'NC(CO)C(=O)O',\n    'E': 'N[C@@H](CCC(O)=O)C(=O)O',\n    'Q': 'N[C@@H](CCC(N)=O)C(=O)O',\n    'D': 'N[C@@H](CC(O)=O)C(=O)O',\n    'N': 'N[C@@H](CC(N)=O)C(=O)O',\n    'F': 'NC(CC1=CC=CC=C1)C(=O)O',\n    'A': 'N[C@H](C)C(=O)O',\n    'K': 'NC(CCCCN)C(=O)O',\n    'R': 'N[C@H](CCCNC(=N)C)C(=O)O',\n    'H': 'NC(CC1=CN=C[N]1)C(=O)O',\n    'C': 'N[C@@H](CS)C(=O)O',\n    'V': 'NC(C(C)C)C(=O)O',\n    'P': 'N(CCC1)C1C(=O)O',\n    'W': 'N[C@@H](Cc1c2ccccc2n([H])c1)C(=O)O',\n    'I': 'N[C@H]([C@H](C)CC)C(=O)O',\n    'M': 'NC(CCSC)C(=O)O',\n    'T': 'NC(C(O)C)C(=O)O',\n  };\n\n  public static AASmilesTruncated: StringDictionary = {\n    'G': '*C*',\n    'L': 'CC(C)C[C@H](*)*',\n    'Y': 'C1=CC(=CC=C1CC(*)*)O',\n    'S': 'OCC(*)C*',\n    'E': '*[C@@H](CCC(O)=O)*',\n    'Q': '*N[C@@H](CCC(N)=O)*',\n    'D': '*[C@@H](CC(O)=O)*',\n    'N': '*[C@@H](CC(N)=O)*',\n    'F': 'C1=CC=C(C=C1)CC(*)*',\n    'A': 'C[C@H](*)*',\n    'K': 'C(CCN)CC(*)*',\n    'R': '*[C@H](CCCNC(=N)C)*',\n    'H': 'C1=C(NC=N1)CC(*)*',\n    'C': 'C([C@@H](*)*)S',\n    'V': 'CC(C)C(*)*',\n    'P': 'C1CCN(*)C1*',\n    'W': '*[C@@H](Cc1c2ccccc2n([H])c1)*',\n    'I': 'CC[C@H](C)[C@H](*)*',\n    'M': 'CSCCC(*)*',\n    'T': 'CC(O)C(*)*',\n  };\n\n  /** TODO: Full?\n   */\n  public static AAFullNames: StringDictionary = {\n    'Ala': 'A',\n    'Arg': 'R',\n    'Asn': 'N',\n    'Asp': 'D',\n    'Cys': 'C',\n    'Gln': 'Q',\n    'Glu': 'E',\n    'Gly': 'G',\n    'His': 'H',\n    'Ile': 'I',\n    'Leu': 'L',\n    'Lys': 'K',\n    'Met': 'M',\n    'Phe': 'F',\n    'Pro': 'P',\n    'Ser': 'S',\n    'Thr': 'T',\n    'Trp': 'W',\n    'Tyr': 'Y',\n    'Val': 'V',\n  };\n\n  public static getPalette(scheme: string = 'grok'): SeqPalette {\n    switch (scheme) {\n    case 'grok':\n      return AminoacidsPalettes.GrokGroups;\n    case 'lesk':\n      return AminoacidsPalettes.Lesk;\n    default:\n      throw new Error(`ChemPalette: scheme \\`${scheme}\\` does not exist`);\n    }\n  }\n\n  /**\n   * Returns divided amino acid with its content in the bracket, if the content is number, then its omitted\n   *\n   * @param {string} c raw amino\n   * @return {[string, string]} outer and inner content\n   */\n  public static getInnerOuter(c: string): [string, string] {\n    let isInner = 0;\n    let inner = '';\n    let outer = '';\n\n    for (const char of c) {\n      if (char == '(')\n        isInner++;\n      else if (char == ')')\n        isInner--;\n      else if (isInner)\n        inner += char;\n      else\n        outer += char;\n    }\n\n    return !isNaN(parseInt(inner)) ? [outer, ''] : [outer, inner];\n  }\n\n  public static getColorAAPivot(monomer: string = '', scheme: 'grok' = 'grok'): [string, string, string, number] {\n    //const chemPaletteInstance = AAPalettes.GrokGroups();\n    const chemPaletteInstance = this.getPalette(scheme);\n    let [outerMonomer, innerMonomer] = this.getInnerOuter(monomer);\n    outerMonomer = (outerMonomer.length > 6 ? `${outerMonomer.slice(0, 3)}...` : outerMonomer);\n    innerMonomer = (innerMonomer.length > 6 ? `${innerMonomer.slice(0, 3)}...` : innerMonomer);\n\n    if (monomer.length == 1 || monomer[1] == '(') {\n      const amino = monomer[0]?.toUpperCase()!;\n      return amino in chemPaletteInstance ?\n        [chemPaletteInstance.get(amino), amino, innerMonomer, 1] :\n        [this.undefinedColor, outerMonomer, innerMonomer, 1];\n    }\n\n    if (monomer[0] == 'd' && monomer[1]! in chemPaletteInstance) {\n      if (monomer.length == 2 || monomer[2] == '(') {\n        const amino = monomer[1]?.toUpperCase()!;\n        return amino in chemPaletteInstance ?\n          [chemPaletteInstance.get(amino), amino, innerMonomer, 2] :\n          [this.undefinedColor, outerMonomer, innerMonomer, 2];\n      }\n    }\n\n    if (monomer.substring(0, 3) in this.AAFullNames) {\n      if (monomer.length == 3 || monomer[3] == '(') {\n        const amino = this.AAFullNames[monomer.substring(0, 3)];\n        return amino in chemPaletteInstance ?\n          [chemPaletteInstance.get(amino), amino, innerMonomer, 3] :\n          [this.undefinedColor, outerMonomer, innerMonomer, 3];\n      }\n    }\n\n    if (monomer[0]?.toLowerCase() == monomer[0]) {\n      if (monomer.substring(1, 3) in this.AAFullNames) {\n        if (monomer.length == 4 || monomer[4] == '(') {\n          const amino = this.AAFullNames[monomer.substring(1, 3)];\n          return amino in chemPaletteInstance ?\n            [chemPaletteInstance.get(amino), amino, innerMonomer, 4] :\n            [this.undefinedColor, outerMonomer, innerMonomer, 4];\n        }\n      }\n    }\n\n    return [this.undefinedColor, outerMonomer, innerMonomer, 0];\n  }\n}\n"]}","import { SeqPaletteBase } from './seq-palettes';\nexport class NucleotidesPalettes extends SeqPaletteBase {\n    static get Chromatogram() {\n        if (this.chromatogram === void 0) {\n            this.chromatogram = new NucleotidesPalettes({\n                'A': 'green',\n                'C': 'blue',\n                'G': 'black',\n                'T': 'red', 'U': 'red',\n                'others': 'gray',\n            });\n        }\n        return this.chromatogram;\n    }\n}\nexport class Nucleotides {\n}\nNucleotides.SemType = 'Nucleotides';\nNucleotides.SemTypeMultipleAlignment = 'NucleotidesMultipleAlignment';\nNucleotides.Names = {\n    'A': 'Adenine',\n    'C': 'Cytosine',\n    'G': 'Guanine',\n    'T': 'Thymine',\n    'U': 'Uracil',\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVjbGVvdGlkZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJudWNsZW90aWRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxPQUFPLEVBQWEsY0FBYyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFMUQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGNBQWM7SUFHOUMsTUFBTSxLQUFLLFlBQVk7UUFDNUIsSUFBSSxJQUFJLENBQUMsWUFBWSxLQUFLLEtBQUssQ0FBQyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxtQkFBbUIsQ0FBQztnQkFDMUMsR0FBRyxFQUFFLE9BQU87Z0JBQ1osR0FBRyxFQUFFLE1BQU07Z0JBQ1gsR0FBRyxFQUFFLE9BQU87Z0JBQ1osR0FBRyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsS0FBSztnQkFDdEIsUUFBUSxFQUFFLE1BQU07YUFDakIsQ0FBQyxDQUFDO1NBQ0o7UUFDRCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLFdBQVc7O0FBQ04sbUJBQU8sR0FBVyxhQUFhLENBQUM7QUFFaEMsb0NBQXdCLEdBQVcsOEJBQThCLENBQUM7QUFFcEUsaUJBQUssR0FBcUI7SUFDdEMsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsVUFBVTtJQUNmLEdBQUcsRUFBRSxTQUFTO0lBQ2QsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsUUFBUTtDQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBncm9rIGZyb20gJ2RhdGFncm9rLWFwaS9ncm9rJztcbmltcG9ydCAqIGFzIHVpIGZyb20gJ2RhdGFncm9rLWFwaS91aSc7XG5pbXBvcnQgKiBhcyBERyBmcm9tICdkYXRhZ3Jvay1hcGkvZGcnO1xuXG5pbXBvcnQge1N0cmluZ0RpY3Rpb25hcnl9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3R5cGUtZGVjbGFyYXRpb25zJztcbmltcG9ydCB7U2VxUGFsZXR0ZSwgU2VxUGFsZXR0ZUJhc2V9IGZyb20gJy4vc2VxLXBhbGV0dGVzJztcblxuZXhwb3J0IGNsYXNzIE51Y2xlb3RpZGVzUGFsZXR0ZXMgZXh0ZW5kcyBTZXFQYWxldHRlQmFzZSB7XG4gIHByaXZhdGUgc3RhdGljIGNocm9tYXRvZ3JhbTogU2VxUGFsZXR0ZTtcblxuICBwdWJsaWMgc3RhdGljIGdldCBDaHJvbWF0b2dyYW0oKTogU2VxUGFsZXR0ZSB7XG4gICAgaWYgKHRoaXMuY2hyb21hdG9ncmFtID09PSB2b2lkIDApIHtcbiAgICAgIHRoaXMuY2hyb21hdG9ncmFtID0gbmV3IE51Y2xlb3RpZGVzUGFsZXR0ZXMoe1xuICAgICAgICAnQSc6ICdncmVlbicsXG4gICAgICAgICdDJzogJ2JsdWUnLFxuICAgICAgICAnRyc6ICdibGFjaycsIC8vIG9yYW5nZSA/XG4gICAgICAgICdUJzogJ3JlZCcsICdVJzogJ3JlZCcsXG4gICAgICAgICdvdGhlcnMnOiAnZ3JheScsXG4gICAgICB9KTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuY2hyb21hdG9ncmFtO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBOdWNsZW90aWRlcyB7XG4gIHN0YXRpYyByZWFkb25seSBTZW1UeXBlOiBzdHJpbmcgPSAnTnVjbGVvdGlkZXMnO1xuXG4gIHN0YXRpYyByZWFkb25seSBTZW1UeXBlTXVsdGlwbGVBbGlnbm1lbnQ6IHN0cmluZyA9ICdOdWNsZW90aWRlc011bHRpcGxlQWxpZ25tZW50JztcblxuICBwdWJsaWMgc3RhdGljIE5hbWVzOiBTdHJpbmdEaWN0aW9uYXJ5ID0ge1xuICAgICdBJzogJ0FkZW5pbmUnLFxuICAgICdDJzogJ0N5dG9zaW5lJyxcbiAgICAnRyc6ICdHdWFuaW5lJyxcbiAgICAnVCc6ICdUaHltaW5lJyxcbiAgICAnVSc6ICdVcmFjaWwnLFxuICB9O1xufVxuIl19","export class SeqPaletteBase {\n    constructor(palette) {\n        this._palette = palette;\n    }\n    static makePalette(dt, simplified = false, PaletteType = SeqPaletteBase) {\n        const palette = {};\n        dt.forEach((cp) => {\n            const objList = cp[0];\n            const colour = cp[1];\n            objList.forEach((obj, ind) => {\n                palette[obj] = this.colourPalette[colour][simplified ? 0 : ind];\n            });\n        });\n        return new PaletteType(palette);\n    }\n    get(m) {\n        return this._palette[m];\n    }\n}\nSeqPaletteBase.undefinedColor = 'rgb(100,100,100)';\n/** Palette with shades of primary colors */\nSeqPaletteBase.colourPalette = {\n    'orange': ['rgb(255,187,120)', 'rgb(245,167,100)', 'rgb(235,137,70)', 'rgb(205, 111, 71)'],\n    'all_green': ['rgb(44,160,44)', 'rgb(74,160,74)', 'rgb(23,103,57)', 'rgb(30,110,96)', 'rgb(60,131,95)',\n        'rgb(24,110,79)', 'rgb(152,223,138)', 'rgb(182, 223, 138)', 'rgb(152, 193, 138)'],\n    'all_blue': ['rgb(31,119,180)', 'rgb(23,190,207)', 'rgb(122, 102, 189)', 'rgb(158,218,229)', 'rgb(141, 124, 217)',\n        'rgb(31, 120, 150)'],\n    'magenta': ['rgb(162,106,192)', 'rgb(197,165,224)', 'rgb(208,113,218)'],\n    'red': ['rgb(214,39,40)', 'rgb(255,152,150)'],\n    'st_blue': ['rgb(23,190,207)', 'rgb(158,218,229)', 'rgb(31,119,180)'],\n    'dark_blue': ['rgb(31,119,180)', 'rgb(31, 120, 150)'],\n    'light_blue': ['rgb(23,190,207)', 'rgb(158,218,229)', 'rgb(108, 218, 229)', 'rgb(23,190,227)'],\n    'lilac_blue': ['rgb(124,102,211)', 'rgb(149,134,217)', 'rgb(97, 81, 150)'],\n    'dark_green': ['rgb(23,103,57)', 'rgb(30,110,96)', 'rgb(60,131,95)', 'rgb(24,110,79)'],\n    'green': ['rgb(44,160,44)', 'rgb(74,160,74)'],\n    'light_green': ['rgb(152,223,138)', 'rgb(182, 223, 138)', 'rgb(152, 193, 138)'],\n    'st_green': ['rgb(44,160,44)', 'rgb(152,223,138)', 'rgb(39, 174, 96)', 'rgb(74,160,74)'],\n    'pink': ['rgb(247,182,210)'],\n    'brown': ['rgb(140,86,75)', 'rgb(102, 62, 54)'],\n    'gray': ['rgb(127,127,127)', 'rgb(199,199,199)', 'rgb(196,156,148)', 'rgb(222, 222, 180)'],\n    'yellow': ['rgb(188,189,34)'],\n    'white': ['rgb(230,230,230)'],\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VxLXBhbGV0dGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2VxLXBhbGV0dGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCQSxNQUFNLE9BQU8sY0FBYztJQTJDekIsWUFBWSxPQUFnQztRQUMxQyxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztJQUMxQixDQUFDO0lBbEJTLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBd0IsRUFDbkQsVUFBVSxHQUFHLEtBQUssRUFBRSxjQUFxQyxjQUFjO1FBRXZFLE1BQU0sT0FBTyxHQUE4QixFQUFFLENBQUM7UUFDOUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFO1lBQ2hCLE1BQU0sT0FBTyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0QixNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDckIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRTtnQkFDM0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2xFLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFRTSxHQUFHLENBQUMsQ0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUIsQ0FBQzs7QUFoRGEsNkJBQWMsR0FBRyxrQkFBa0IsQ0FBQztBQUVsRCw0Q0FBNEM7QUFDOUIsNEJBQWEsR0FBZ0M7SUFDekQsUUFBUSxFQUFFLENBQUMsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUUsbUJBQW1CLENBQUM7SUFDMUYsV0FBVyxFQUFFLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCO1FBQ3BHLGdCQUFnQixFQUFFLGtCQUFrQixFQUFFLG9CQUFvQixFQUFFLG9CQUFvQixDQUFDO0lBQ25GLFVBQVUsRUFBRSxDQUFDLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLG9CQUFvQixFQUFFLGtCQUFrQixFQUFFLG9CQUFvQjtRQUMvRyxtQkFBbUIsQ0FBQztJQUN0QixTQUFTLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsQ0FBQztJQUN2RSxLQUFLLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxrQkFBa0IsQ0FBQztJQUM3QyxTQUFTLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxpQkFBaUIsQ0FBQztJQUNyRSxXQUFXLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxtQkFBbUIsQ0FBQztJQUNyRCxZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxpQkFBaUIsQ0FBQztJQUM5RixZQUFZLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsQ0FBQztJQUMxRSxZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsQ0FBQztJQUN0RixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxnQkFBZ0IsQ0FBQztJQUM3QyxhQUFhLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxvQkFBb0IsQ0FBQztJQUMvRSxVQUFVLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsQ0FBQztJQUN4RixNQUFNLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztJQUM1QixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxrQkFBa0IsQ0FBQztJQUMvQyxNQUFNLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsQ0FBQztJQUMxRixRQUFRLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztJQUM3QixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztDQUM5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZ3JvayBmcm9tICdkYXRhZ3Jvay1hcGkvZ3Jvayc7XG5pbXBvcnQgKiBhcyB1aSBmcm9tICdkYXRhZ3Jvay1hcGkvdWknO1xuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcblxuZXhwb3J0IGludGVyZmFjZSBTZXFQYWxldHRlIHtcbiAgLy8gVGhlcmUgYXJlIHRvbyBtdWNoIHByb2JsZW0gd2l0aCBpbmRleGVyIHByb3BlcnR5IGluIHR5cGVzY3JpcHQuXG4gIC8vIC8qKlxuICAvLyAgKiBAcGFyYW0ge3N0cmluZ30gbSBNb25vbWVyIGNoYXJhY3RlclxuICAvLyAgKiBAcmV0dXJuIHtzdHJpbmd9IENvbG9yXG4gIC8vICAqL1xuICAvLyBbbTogc3RyaW5nXTogc3RyaW5nO1xuICAvKiogTW9ub21lciBjb2xvclxuICAgKiBAcGFyYW0ge3N0cmluZ30gbSBNb25vbWVyXG4gICAqL1xuICBnZXQobTogc3RyaW5nKTogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgU2VxUGFsZXR0ZUJhc2UgaW1wbGVtZW50cyBTZXFQYWxldHRlIHtcbiAgcHVibGljIHN0YXRpYyB1bmRlZmluZWRDb2xvciA9ICdyZ2IoMTAwLDEwMCwxMDApJztcblxuICAvKiogUGFsZXR0ZSB3aXRoIHNoYWRlcyBvZiBwcmltYXJ5IGNvbG9ycyAqL1xuICBwdWJsaWMgc3RhdGljIGNvbG91clBhbGV0dGU6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nW10gfSA9IHtcbiAgICAnb3JhbmdlJzogWydyZ2IoMjU1LDE4NywxMjApJywgJ3JnYigyNDUsMTY3LDEwMCknLCAncmdiKDIzNSwxMzcsNzApJywgJ3JnYigyMDUsIDExMSwgNzEpJ10sXG4gICAgJ2FsbF9ncmVlbic6IFsncmdiKDQ0LDE2MCw0NCknLCAncmdiKDc0LDE2MCw3NCknLCAncmdiKDIzLDEwMyw1NyknLCAncmdiKDMwLDExMCw5NiknLCAncmdiKDYwLDEzMSw5NSknLFxuICAgICAgJ3JnYigyNCwxMTAsNzkpJywgJ3JnYigxNTIsMjIzLDEzOCknLCAncmdiKDE4MiwgMjIzLCAxMzgpJywgJ3JnYigxNTIsIDE5MywgMTM4KSddLFxuICAgICdhbGxfYmx1ZSc6IFsncmdiKDMxLDExOSwxODApJywgJ3JnYigyMywxOTAsMjA3KScsICdyZ2IoMTIyLCAxMDIsIDE4OSknLCAncmdiKDE1OCwyMTgsMjI5KScsICdyZ2IoMTQxLCAxMjQsIDIxNyknLFxuICAgICAgJ3JnYigzMSwgMTIwLCAxNTApJ10sXG4gICAgJ21hZ2VudGEnOiBbJ3JnYigxNjIsMTA2LDE5MiknLCAncmdiKDE5NywxNjUsMjI0KScsICdyZ2IoMjA4LDExMywyMTgpJ10sXG4gICAgJ3JlZCc6IFsncmdiKDIxNCwzOSw0MCknLCAncmdiKDI1NSwxNTIsMTUwKSddLFxuICAgICdzdF9ibHVlJzogWydyZ2IoMjMsMTkwLDIwNyknLCAncmdiKDE1OCwyMTgsMjI5KScsICdyZ2IoMzEsMTE5LDE4MCknXSxcbiAgICAnZGFya19ibHVlJzogWydyZ2IoMzEsMTE5LDE4MCknLCAncmdiKDMxLCAxMjAsIDE1MCknXSxcbiAgICAnbGlnaHRfYmx1ZSc6IFsncmdiKDIzLDE5MCwyMDcpJywgJ3JnYigxNTgsMjE4LDIyOSknLCAncmdiKDEwOCwgMjE4LCAyMjkpJywgJ3JnYigyMywxOTAsMjI3KSddLFxuICAgICdsaWxhY19ibHVlJzogWydyZ2IoMTI0LDEwMiwyMTEpJywgJ3JnYigxNDksMTM0LDIxNyknLCAncmdiKDk3LCA4MSwgMTUwKSddLFxuICAgICdkYXJrX2dyZWVuJzogWydyZ2IoMjMsMTAzLDU3KScsICdyZ2IoMzAsMTEwLDk2KScsICdyZ2IoNjAsMTMxLDk1KScsICdyZ2IoMjQsMTEwLDc5KSddLFxuICAgICdncmVlbic6IFsncmdiKDQ0LDE2MCw0NCknLCAncmdiKDc0LDE2MCw3NCknXSxcbiAgICAnbGlnaHRfZ3JlZW4nOiBbJ3JnYigxNTIsMjIzLDEzOCknLCAncmdiKDE4MiwgMjIzLCAxMzgpJywgJ3JnYigxNTIsIDE5MywgMTM4KSddLFxuICAgICdzdF9ncmVlbic6IFsncmdiKDQ0LDE2MCw0NCknLCAncmdiKDE1MiwyMjMsMTM4KScsICdyZ2IoMzksIDE3NCwgOTYpJywgJ3JnYig3NCwxNjAsNzQpJ10sXG4gICAgJ3BpbmsnOiBbJ3JnYigyNDcsMTgyLDIxMCknXSxcbiAgICAnYnJvd24nOiBbJ3JnYigxNDAsODYsNzUpJywgJ3JnYigxMDIsIDYyLCA1NCknXSxcbiAgICAnZ3JheSc6IFsncmdiKDEyNywxMjcsMTI3KScsICdyZ2IoMTk5LDE5OSwxOTkpJywgJ3JnYigxOTYsMTU2LDE0OCknLCAncmdiKDIyMiwgMjIyLCAxODApJ10sXG4gICAgJ3llbGxvdyc6IFsncmdiKDE4OCwxODksMzQpJ10sXG4gICAgJ3doaXRlJzogWydyZ2IoMjMwLDIzMCwyMzApJ10sXG4gIH07XG5cbiAgcHJvdGVjdGVkIHN0YXRpYyBtYWtlUGFsZXR0ZShkdDogW3N0cmluZ1tdLCBzdHJpbmddW10sXG4gICAgc2ltcGxpZmllZCA9IGZhbHNlLCBQYWxldHRlVHlwZTogdHlwZW9mIFNlcVBhbGV0dGVCYXNlID0gU2VxUGFsZXR0ZUJhc2VcbiAgKSB7XG4gICAgY29uc3QgcGFsZXR0ZTogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSA9IHt9O1xuICAgIGR0LmZvckVhY2goKGNwKSA9PiB7XG4gICAgICBjb25zdCBvYmpMaXN0ID0gY3BbMF07XG4gICAgICBjb25zdCBjb2xvdXIgPSBjcFsxXTtcbiAgICAgIG9iakxpc3QuZm9yRWFjaCgob2JqLCBpbmQpID0+IHtcbiAgICAgICAgcGFsZXR0ZVtvYmpdID0gdGhpcy5jb2xvdXJQYWxldHRlW2NvbG91cl1bc2ltcGxpZmllZCA/IDAgOiBpbmRdO1xuICAgICAgfSk7XG4gICAgfSk7XG4gICAgcmV0dXJuIG5ldyBQYWxldHRlVHlwZShwYWxldHRlKTtcbiAgfVxuXG4gIHByaXZhdGUgcmVhZG9ubHkgX3BhbGV0dGU6IHsgW206IHN0cmluZ106IHN0cmluZyB9O1xuXG4gIGNvbnN0cnVjdG9yKHBhbGV0dGU6IHsgW206IHN0cmluZ106IHN0cmluZyB9KSB7XG4gICAgdGhpcy5fcGFsZXR0ZSA9IHBhbGV0dGU7XG4gIH1cblxuICBwdWJsaWMgZ2V0KG06IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3BhbGV0dGVbbV07XG4gIH1cbn1cbiJdfQ==","import { assert } from '@datagrok-libraries/utils/src/vector-operations';\nclass SideChainScales {\n    static getAvailableScales() {\n        return Object.entries(this.scales).map(([k, _]) => k);\n    }\n    static getScale(name) {\n        assert(!(this.scales[name] === undefined), `Scale '${name}' was not found.`);\n        return this.scales[name];\n    }\n}\nSideChainScales.scales = {\n    // Wimley-White interfacial hydrophobicity scale\n    'WimleyWhite': {\n        '-': 0,\n        'A': 0.17,\n        'C': -0.24,\n        'D': -0.07,\n        'E': -0.01,\n        'F': -1.13,\n        'G': 0.01,\n        'H': 0.17,\n        'I': -0.31,\n        'K': 0.99,\n        'L': -0.56,\n        'M': -0.23,\n        'N': 0.42,\n        'P': 0.45,\n        'Q': 0.58,\n        'R': 0.81,\n        'S': 0.13,\n        'T': 0.14,\n        'V': 0.07,\n        'W': -1.85,\n        'Y': -0.94,\n    },\n    'categorial': {\n        '-': 0,\n        'A': 1,\n        'C': 2,\n        'D': 3,\n        'E': 4,\n        'F': 5,\n        'G': 6,\n        'H': 7,\n        'I': 8,\n        'K': 9,\n        'L': 10,\n        'M': 11,\n        'N': 12,\n        'P': 13,\n        'Q': 14,\n        'R': 15,\n        'S': 16,\n        'T': 17,\n        'V': 18,\n        'W': 19,\n        'Y': 20,\n    },\n};\n/**\n * Class to categorial encode/decode aligned amino acid residues sequence.\n *\n * @export\n * @class AlignedSequenceEncoder\n */\nexport class AlignedSequenceEncoder {\n    constructor(scale = 'categorial') {\n        this.aa2num = SideChainScales.getScale(scale);\n        this.num2aa = {};\n        Object.entries(this.aa2num).forEach(([k, v]) => (this.num2aa[v] = k));\n    }\n    /**\n       * Truncate NH2 and -COOH terminals of the given sequence.\n       *\n       * @static\n       * @param {string} seq The sequence provided.\n       * @return {string} Truncated sequence.\n       * @memberof AlignedSequenceEncoder\n       */\n    static _truncateSequence(seq) {\n        let start = 0;\n        let end = seq.length;\n        const termina = ['NH2', 'COOH'];\n        if (seq.startsWith(termina[0])) {\n            const l = termina[0].length; // Cut only 'NH2' without following '-'.\n            assert(seq[l] == '-', `Wrong sequence format: ${termina[0]} without following '-' in '${seq}'.`);\n            start = l;\n        }\n        if (seq.endsWith(termina[1])) {\n            const l = termina[1].length + 1; // Cut both 'COOH' and precending '-'.\n            assert(seq[end - l] == '-', `Wrong sequence format: ${termina[1]} without '-' precending in '${seq}'.`);\n            end -= l;\n        }\n        return seq.substring(start, end);\n    }\n    /**\n       * Cuts auxiliary defises before a residue.\n       *\n       * @static\n       * @param {string} seq The sequence to process.\n       * @return {string} Processed sequence.\n       * @memberof AlignedSequenceEncoder\n       */\n    static _dropDefises(seq) {\n        return seq.replace(/(-)([^-]+)/g, '$2');\n    }\n    /**\n       * Performs truncation and cutting auxiliary defises.\n       *\n       * @static\n       * @param {string} sequence The sequence work under process.\n       * @return {string} Result of cleaning.\n       * @memberof AlignedSequenceEncoder\n       */\n    static clean(sequence) {\n        return AlignedSequenceEncoder._dropDefises(AlignedSequenceEncoder._truncateSequence(sequence));\n    }\n    /**\n       * Categorial encode of the sequence provided.\n       *\n       * @param {string} sequence The sequence.\n       * @return {number[]} Encoded vector.\n       * @memberof AlignedSequenceEncoder\n       */\n    encode(sequence) {\n        const nItems = sequence.length;\n        const values = new Array(nItems).fill(0);\n        for (let i = 0; i < nItems; ++i) {\n            const char = sequence[i];\n            assert(char in this.aa2num, `Unknown char '${char}' found in sequence '${sequence}'`);\n            values[i] = this.encodeLettter(char);\n        }\n        return values;\n    }\n    encodeLettter(letter) {\n        return this.aa2num[letter];\n    }\n    /**\n       * Decode the encoded vector into the sequence back.\n       *\n       * @param {number[]} value The vector encoded.\n       * @return {string} Decoded sequence.\n       * @memberof AlignedSequenceEncoder\n       */\n    decode(value) {\n        let s = '';\n        for (let i = 0; i < value.length; ++i) {\n            const code = value[i];\n            assert(code in this.num2aa, `Unknown code '${code}' found in vector '${value}'`);\n            s += this.num2aa[code];\n        }\n        return s;\n    }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sequence-encoder.js","sourceRoot":"","sources":["sequence-encoder.ts"],"names":[],"mappings":"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","sourcesContent":["import {assert} from '@datagrok-libraries/utils/src/vector-operations';\n\ntype SideChainScale = {[name: string]: number};\ntype SideChainScaleCollection = {[name: string]: SideChainScale};\n\nclass SideChainScales {\n  static scales: SideChainScaleCollection = {\n    // Wimley-White interfacial hydrophobicity scale\n    'WimleyWhite': {\n      '-': 0,\n      'A': 0.17,\n      'C': -0.24,\n      'D': -0.07, // Asp-: 1.23\n      'E': -0.01, // Glu-: 2.02\n      'F': -1.13, //\n      'G': 0.01,\n      'H': 0.17, // His+: 0.96\n      'I': -0.31,\n      'K': 0.99, // Lys+\n      'L': -0.56,\n      'M': -0.23,\n      'N': 0.42,\n      'P': 0.45,\n      'Q': 0.58,\n      'R': 0.81, // Arg+\n      'S': 0.13,\n      'T': 0.14,\n      'V': 0.07,\n      'W': -1.85,\n      'Y': -0.94,\n    },\n    'categorial': {\n      '-': 0,\n      'A': 1,\n      'C': 2,\n      'D': 3,\n      'E': 4,\n      'F': 5,\n      'G': 6,\n      'H': 7,\n      'I': 8,\n      'K': 9,\n      'L': 10,\n      'M': 11,\n      'N': 12,\n      'P': 13,\n      'Q': 14,\n      'R': 15,\n      'S': 16,\n      'T': 17,\n      'V': 18,\n      'W': 19,\n      'Y': 20,\n    },\n  };\n\n  static getAvailableScales(): string[] {\n    return Object.entries(this.scales).map(([k, _]) => k);\n  }\n\n  static getScale(name: string): SideChainScale {\n    assert(!(this.scales[name] === undefined), `Scale '${name}' was not found.`);\n    return this.scales[name];\n  }\n}\n\n/**\n * Class to categorial encode/decode aligned amino acid residues sequence.\n *\n * @export\n * @class AlignedSequenceEncoder\n */\nexport class AlignedSequenceEncoder {\n  protected aa2num: SideChainScale;\n  protected num2aa: {[code: number]: string};\n\n  constructor(scale: string = 'categorial') {\n    this.aa2num = SideChainScales.getScale(scale);\n    this.num2aa = {};\n    Object.entries(this.aa2num).forEach(([k, v]) => (this.num2aa[v] = k));\n  }\n\n  /**\n     * Truncate NH2 and -COOH terminals of the given sequence.\n     *\n     * @static\n     * @param {string} seq The sequence provided.\n     * @return {string} Truncated sequence.\n     * @memberof AlignedSequenceEncoder\n     */\n  static _truncateSequence(seq: string): string {\n    let start = 0;\n    let end = seq.length;\n    const termina = ['NH2', 'COOH'];\n\n    if (seq.startsWith(termina[0])) {\n      const l = termina[0].length; // Cut only 'NH2' without following '-'.\n      assert(seq[l] == '-', `Wrong sequence format: ${termina[0]} without following '-' in '${seq}'.`);\n      start = l;\n    }\n    if (seq.endsWith(termina[1])) {\n      const l = termina[1].length+1; // Cut both 'COOH' and precending '-'.\n      assert(seq[end-l] == '-', `Wrong sequence format: ${termina[1]} without '-' precending in '${seq}'.`);\n      end -= l;\n    }\n    return seq.substring(start, end);\n  }\n\n  /**\n     * Cuts auxiliary defises before a residue.\n     *\n     * @static\n     * @param {string} seq The sequence to process.\n     * @return {string} Processed sequence.\n     * @memberof AlignedSequenceEncoder\n     */\n  static _dropDefises(seq: string): string {\n    return seq.replace(/(-)([^-]+)/g, '$2');\n  }\n\n  /**\n     * Performs truncation and cutting auxiliary defises.\n     *\n     * @static\n     * @param {string} sequence The sequence work under process.\n     * @return {string} Result of cleaning.\n     * @memberof AlignedSequenceEncoder\n     */\n  static clean(sequence: string): string {\n    return AlignedSequenceEncoder._dropDefises(AlignedSequenceEncoder._truncateSequence(sequence));\n  }\n\n  /**\n     * Categorial encode of the sequence provided.\n     *\n     * @param {string} sequence The sequence.\n     * @return {number[]} Encoded vector.\n     * @memberof AlignedSequenceEncoder\n     */\n  public encode(sequence: string): number[] {\n    const nItems = sequence.length;\n    const values = new Array(nItems).fill(0);\n\n    for (let i = 0; i < nItems; ++i) {\n      const char = sequence[i];\n\n      assert(char in this.aa2num, `Unknown char '${char}' found in sequence '${sequence}'`);\n\n      values[i] = this.encodeLettter(char);\n    }\n    return values;\n  }\n\n  public encodeLettter(letter: string): number {\n    return this.aa2num[letter];\n  }\n\n  /**\n     * Decode the encoded vector into the sequence back.\n     *\n     * @param {number[]} value The vector encoded.\n     * @return {string} Decoded sequence.\n     * @memberof AlignedSequenceEncoder\n     */\n  public decode(value: number[]): string {\n    let s: string = '';\n\n    for (let i = 0; i < value.length; ++i) {\n      const code = value[i];\n\n      assert(code in this.num2aa, `Unknown code '${code}' found in vector '${value}'`);\n\n      s += this.num2aa[code];\n    }\n    return s;\n  }\n}\n"]}","export class StringUtils {\n    static hashCode(s) {\n        let hash = 0;\n        if (s.length === 0)\n            return hash;\n        for (let i = 0; i < s.length; i++) {\n            const chr = s.charCodeAt(i);\n            hash = ((hash << 5) - hash) + chr;\n            hash |= 0; // Convert to 32bit integer\n        }\n        return hash;\n    }\n}\nimport { SeqPaletteBase } from './seq-palettes';\nexport class UnknownSeqPalette {\n}\nexport class GrayAllPalette extends UnknownSeqPalette {\n    get(m) {\n        return '#666666';\n    }\n}\nexport class UnknownColorPalette extends UnknownSeqPalette {\n    static buildPalette() {\n        const res = [].concat(...Object.values(SeqPaletteBase.colourPalette));\n        return res;\n    }\n    get(m) {\n        const hash = StringUtils.hashCode(m);\n        const pI = hash % UnknownColorPalette.palette.length;\n        return UnknownColorPalette.palette[pI];\n    }\n}\nUnknownColorPalette.palette = UnknownColorPalette.buildPalette();\nexport class UnknownSeqPalettes extends SeqPaletteBase {\n    static get Gray() {\n        if (this.gray === void 0)\n            this.gray = new GrayAllPalette();\n        return this.gray;\n    }\n    static get Color() {\n        if (this.color === void 0)\n            this.color = new UnknownColorPalette();\n        return this.color;\n    }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5rbm93bi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVua25vd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsTUFBTSxPQUFPLFdBQVc7SUFDZixNQUFNLENBQUMsUUFBUSxDQUFDLENBQVM7UUFDOUIsSUFBSSxJQUFJLEdBQVcsQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDO1lBQ2hCLE9BQU8sSUFBSSxDQUFDO1FBQ2QsS0FBSyxJQUFJLENBQUMsR0FBVyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDekMsTUFBTSxHQUFHLEdBQVcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNwQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxHQUFHLENBQUM7WUFDbEMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLDJCQUEyQjtTQUN2QztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztDQUNGO0FBRUQsT0FBTyxFQUFhLGNBQWMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRTFELE1BQU0sT0FBZ0IsaUJBQWlCO0NBRXRDO0FBRUQsTUFBTSxPQUFPLGNBQWUsU0FBUSxpQkFBaUI7SUFDNUMsR0FBRyxDQUFDLENBQVM7UUFDbEIsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztDQUNGO0FBR0QsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGlCQUFpQjtJQUdoRCxNQUFNLENBQUMsWUFBWTtRQUN6QixNQUFNLEdBQUcsR0FBSSxFQUFlLENBQUMsTUFBTSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztRQUNwRixPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFFTSxHQUFHLENBQUMsQ0FBUztRQUNsQixNQUFNLElBQUksR0FBVyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzdDLE1BQU0sRUFBRSxHQUFHLElBQUksR0FBRyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDO1FBQ3JELE9BQU8sbUJBQW1CLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7O0FBWGEsMkJBQU8sR0FBYSxtQkFBbUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztBQWN2RSxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsY0FBYztJQUc3QyxNQUFNLEtBQUssSUFBSTtRQUNwQixJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssS0FBSyxDQUFDO1lBQ3RCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxjQUFjLEVBQUUsQ0FBQztRQUNuQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUlNLE1BQU0sS0FBSyxLQUFLO1FBQ3JCLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxLQUFLLENBQUM7WUFDdkIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLG1CQUFtQixFQUFFLENBQUM7UUFDekMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGdyb2sgZnJvbSAnZGF0YWdyb2stYXBpL2dyb2snO1xuaW1wb3J0ICogYXMgdWkgZnJvbSAnZGF0YWdyb2stYXBpL3VpJztcbmltcG9ydCAqIGFzIERHIGZyb20gJ2RhdGFncm9rLWFwaS9kZyc7XG5cbmV4cG9ydCBjbGFzcyBTdHJpbmdVdGlscyB7XG4gIHB1YmxpYyBzdGF0aWMgaGFzaENvZGUoczogc3RyaW5nKTogbnVtYmVyIHtcbiAgICBsZXQgaGFzaDogbnVtYmVyID0gMDtcbiAgICBpZiAocy5sZW5ndGggPT09IDApXG4gICAgICByZXR1cm4gaGFzaDtcbiAgICBmb3IgKGxldCBpOiBudW1iZXIgPSAwOyBpIDwgcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgY2hyOiBudW1iZXIgPSBzLmNoYXJDb2RlQXQoaSk7XG4gICAgICBoYXNoID0gKChoYXNoIDw8IDUpIC0gaGFzaCkgKyBjaHI7XG4gICAgICBoYXNoIHw9IDA7IC8vIENvbnZlcnQgdG8gMzJiaXQgaW50ZWdlclxuICAgIH1cbiAgICByZXR1cm4gaGFzaDtcbiAgfVxufVxuXG5pbXBvcnQge1NlcVBhbGV0dGUsIFNlcVBhbGV0dGVCYXNlfSBmcm9tICcuL3NlcS1wYWxldHRlcyc7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBVbmtub3duU2VxUGFsZXR0ZSBpbXBsZW1lbnRzIFNlcVBhbGV0dGUge1xuICBwdWJsaWMgYWJzdHJhY3QgZ2V0KG06IHN0cmluZyk6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIEdyYXlBbGxQYWxldHRlIGV4dGVuZHMgVW5rbm93blNlcVBhbGV0dGUge1xuICBwdWJsaWMgZ2V0KG06IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuICcjNjY2NjY2JztcbiAgfVxufVxuXG5cbmV4cG9ydCBjbGFzcyBVbmtub3duQ29sb3JQYWxldHRlIGV4dGVuZHMgVW5rbm93blNlcVBhbGV0dGUge1xuICBwdWJsaWMgc3RhdGljIHBhbGV0dGU6IHN0cmluZ1tdID0gVW5rbm93bkNvbG9yUGFsZXR0ZS5idWlsZFBhbGV0dGUoKTtcblxuICBwcml2YXRlIHN0YXRpYyBidWlsZFBhbGV0dGUoKTogc3RyaW5nW10ge1xuICAgIGNvbnN0IHJlcyA9IChbXSBhcyBzdHJpbmdbXSkuY29uY2F0KC4uLk9iamVjdC52YWx1ZXMoU2VxUGFsZXR0ZUJhc2UuY29sb3VyUGFsZXR0ZSkpO1xuICAgIHJldHVybiByZXM7XG4gIH1cblxuICBwdWJsaWMgZ2V0KG06IHN0cmluZyk6IHN0cmluZyB7XG4gICAgY29uc3QgaGFzaDogbnVtYmVyID0gU3RyaW5nVXRpbHMuaGFzaENvZGUobSk7XG4gICAgY29uc3QgcEkgPSBoYXNoICUgVW5rbm93bkNvbG9yUGFsZXR0ZS5wYWxldHRlLmxlbmd0aDtcbiAgICByZXR1cm4gVW5rbm93bkNvbG9yUGFsZXR0ZS5wYWxldHRlW3BJXTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgVW5rbm93blNlcVBhbGV0dGVzIGV4dGVuZHMgU2VxUGFsZXR0ZUJhc2Uge1xuICBwcml2YXRlIHN0YXRpYyBncmF5OiBTZXFQYWxldHRlO1xuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IEdyYXkoKTogU2VxUGFsZXR0ZSB7XG4gICAgaWYgKHRoaXMuZ3JheSA9PT0gdm9pZCAwKVxuICAgICAgdGhpcy5ncmF5ID0gbmV3IEdyYXlBbGxQYWxldHRlKCk7XG4gICAgcmV0dXJuIHRoaXMuZ3JheTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIGNvbG9yOiBTZXFQYWxldHRlO1xuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IENvbG9yKCk6IFNlcVBhbGV0dGUge1xuICAgIGlmICh0aGlzLmNvbG9yID09PSB2b2lkIDApXG4gICAgICB0aGlzLmNvbG9yID0gbmV3IFVua25vd25Db2xvclBhbGV0dGUoKTtcbiAgICByZXR1cm4gdGhpcy5jb2xvcjtcbiAgfVxufVxuIl19","// Data structures for V-Domain regions of antibodies\nexport var VdRegionType;\n(function (VdRegionType) {\n    VdRegionType[\"Unknown\"] = \"unknown\";\n    VdRegionType[\"FR\"] = \"framework\";\n    VdRegionType[\"CDR\"] = \"cdr\";\n})(VdRegionType || (VdRegionType = {}));\n/** Describes V-DOMAIN (IG and TR) region (of multiple alignment)\n * https://www.imgt.org/IMGTScientificChart/Numbering/IMGTIGVLsuperfamily.html\n */\nexport class VdRegion {\n    /**\n     * start and position are strings because they correspond to position names as column names in ANARCI output\n     * @param {VdRegionType} type  Type of the region\n     * @param {string} name  Name of the region\n     * @param {string} chain\n     * @param {string} order\n     * @param {string} positionStartName  Region start position (inclusive)\n     * @param {string} positionEndName  Region end position (inclusive)\n     */\n    constructor(type, name, chain, order, positionStartName, positionEndName) {\n        this.type = type;\n        this.name = name;\n        this.chain = chain;\n        this.order = order;\n        this.positionStartName = positionStartName;\n        this.positionEndName = positionEndName;\n    }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmQtcmVnaW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInZkLXJlZ2lvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEscURBQXFEO0FBRXJELE1BQU0sQ0FBTixJQUFZLFlBSVg7QUFKRCxXQUFZLFlBQVk7SUFDdEIsbUNBQW1CLENBQUE7SUFDbkIsZ0NBQWdCLENBQUE7SUFDaEIsMkJBQVcsQ0FBQTtBQUNiLENBQUMsRUFKVyxZQUFZLEtBQVosWUFBWSxRQUl2QjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLFFBQVE7SUFRbkI7Ozs7Ozs7O09BUUc7SUFDSCxZQUFZLElBQWtCLEVBQUUsSUFBWSxFQUFFLEtBQWEsRUFBRSxLQUFhLEVBQ3hFLGlCQUF5QixFQUFFLGVBQXVCO1FBQ2xELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxpQkFBaUIsQ0FBQztRQUMzQyxJQUFJLENBQUMsZUFBZSxHQUFHLGVBQWUsQ0FBQztJQUN6QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBEYXRhIHN0cnVjdHVyZXMgZm9yIFYtRG9tYWluIHJlZ2lvbnMgb2YgYW50aWJvZGllc1xuXG5leHBvcnQgZW51bSBWZFJlZ2lvblR5cGUge1xuICBVbmtub3duID0gJ3Vua25vd24nLFxuICBGUiA9ICdmcmFtZXdvcmsnLFxuICBDRFIgPSAnY2RyJyxcbn1cblxuLyoqIERlc2NyaWJlcyBWLURPTUFJTiAoSUcgYW5kIFRSKSByZWdpb24gKG9mIG11bHRpcGxlIGFsaWdubWVudClcbiAqIGh0dHBzOi8vd3d3LmltZ3Qub3JnL0lNR1RTY2llbnRpZmljQ2hhcnQvTnVtYmVyaW5nL0lNR1RJR1ZMc3VwZXJmYW1pbHkuaHRtbFxuICovXG5leHBvcnQgY2xhc3MgVmRSZWdpb24ge1xuICB0eXBlOiBWZFJlZ2lvblR5cGU7XG4gIG5hbWU6IHN0cmluZztcbiAgY2hhaW46IHN0cmluZztcbiAgb3JkZXI6IG51bWJlcjtcbiAgcG9zaXRpb25TdGFydE5hbWU6IHN0cmluZztcbiAgcG9zaXRpb25FbmROYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIHN0YXJ0IGFuZCBwb3NpdGlvbiBhcmUgc3RyaW5ncyBiZWNhdXNlIHRoZXkgY29ycmVzcG9uZCB0byBwb3NpdGlvbiBuYW1lcyBhcyBjb2x1bW4gbmFtZXMgaW4gQU5BUkNJIG91dHB1dFxuICAgKiBAcGFyYW0ge1ZkUmVnaW9uVHlwZX0gdHlwZSAgVHlwZSBvZiB0aGUgcmVnaW9uXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBuYW1lICBOYW1lIG9mIHRoZSByZWdpb25cbiAgICogQHBhcmFtIHtzdHJpbmd9IGNoYWluXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBvcmRlclxuICAgKiBAcGFyYW0ge3N0cmluZ30gcG9zaXRpb25TdGFydE5hbWUgIFJlZ2lvbiBzdGFydCBwb3NpdGlvbiAoaW5jbHVzaXZlKVxuICAgKiBAcGFyYW0ge3N0cmluZ30gcG9zaXRpb25FbmROYW1lICBSZWdpb24gZW5kIHBvc2l0aW9uIChpbmNsdXNpdmUpXG4gICAqL1xuICBjb25zdHJ1Y3Rvcih0eXBlOiBWZFJlZ2lvblR5cGUsIG5hbWU6IHN0cmluZywgY2hhaW46IHN0cmluZywgb3JkZXI6IG51bWJlcixcbiAgICBwb3NpdGlvblN0YXJ0TmFtZTogc3RyaW5nLCBwb3NpdGlvbkVuZE5hbWU6IHN0cmluZykge1xuICAgIHRoaXMudHlwZSA9IHR5cGU7XG4gICAgdGhpcy5uYW1lID0gbmFtZTtcbiAgICB0aGlzLmNoYWluID0gY2hhaW47XG4gICAgdGhpcy5vcmRlciA9IG9yZGVyO1xuICAgIHRoaXMucG9zaXRpb25TdGFydE5hbWUgPSBwb3NpdGlvblN0YXJ0TmFtZTtcbiAgICB0aGlzLnBvc2l0aW9uRW5kTmFtZSA9IHBvc2l0aW9uRW5kTmFtZTtcbiAgfVxufVxuIl19","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport wu from 'wu';\nimport * as rxjs from 'rxjs';\nimport { Vector } from '@datagrok-libraries/utils/src/type-declarations';\nimport { vectorLength, vectorDotProduct } from '@datagrok-libraries/utils/src/vector-operations';\nimport { Aminoacids, AminoacidsPalettes } from '../aminoacids';\nimport { Nucleotides, NucleotidesPalettes } from '../nucleotides';\nimport { UnknownSeqPalettes } from '../unknown';\nHTMLCanvasElement.prototype.getCursorPosition = function (event) {\n    const rect = this.getBoundingClientRect();\n    return new DG.Point(event.clientX - rect.left, event.clientY - rect.top);\n};\nDG.Rect.prototype.contains = function (x, y) {\n    return this.left <= x && x <= this.right && this.top <= y && y <= this.bottom;\n};\nexport class PositionMonomerInfo {\n    constructor() {\n        this.count = 0;\n        this.bounds = new DG.Rect(0, 0, 0, 0);\n    }\n}\nexport class PositionInfo {\n    /** freq = {}, rowCount = 0\n     * @param {string} name Name of position ('111A', '111.1', etc)\n     */\n    constructor(name) {\n        this.name = name;\n        this.freq = {};\n        this.rowCount = 0;\n    }\n}\nexport class WebLogo extends DG.JsViewer {\n    constructor() {\n        super();\n        this.viewerId = -1;\n        this.initialized = false;\n        // private readonly colorScheme: ColorScheme = ColorSchemes[NucleotidesWebLogo.residuesSet];\n        this.cp = null;\n        this.axisHeight = 12;\n        this.seqCol = null;\n        this.splitter = null;\n        // private maxLength: number = 100;\n        this.positions = [];\n        this.rowsMasked = 0;\n        this.rowsNull = 0;\n        this.positionNames = [];\n        this.startPosition = -1;\n        this.endPosition = -1;\n        this.viewSubs = [];\n        this.viewerId = WebLogo.viewerCount;\n        WebLogo.viewerCount += 1;\n        this.textBaseline = 'top';\n        this._positionWidth = this.positionWidth = this.float('positionWidth', 16 /*,\n          {editor: 'slider', min: 4, max: 64, postfix: 'px'}*/);\n        this.minHeight = this.float('minHeight', 50 /*,\n          {editor: 'slider', min: 25, max: 250, postfix: 'px'}*/);\n        this.maxHeight = this.float('maxHeight', 100 /*,\n          {editor: 'slider', min: 25, max: 500, postfix: 'px'}*/);\n        this.considerNullSequences = this.bool('considerNullSequences', false);\n        this.sequenceColumnName = this.string('sequenceColumnName', null);\n        this.startPositionName = this.string('startPositionName', null);\n        this.endPositionName = this.string('endPositionName', null);\n        this.fixWidth = this.bool('fixWidth', false);\n        this.verticalAlignment = this.string('verticalAlignment', 'middle', { choices: ['top', 'middle', 'bottom'] });\n        this.horizontalAlignment = this.string('horizontalAlignment', 'center', { choices: ['left', 'center', 'right'] });\n        this.fitArea = this.bool('fitArea', true);\n        this.shrinkEmptyTail = this.bool('shrinkEmptyTail', true);\n        this.skipEmptyPositions = this.bool('skipEmptyPositions', false);\n    }\n    /** For startPosition equals to endPosition Length is 1 */\n    get Length() {\n        return this.startPosition <= this.endPosition ? this.endPosition - this.startPosition + 1 : 0;\n    }\n    init() {\n        return __awaiter(this, void 0, void 0, function* () {\n            if (this.initialized) {\n                console.error('WebLogo second initialization!');\n                return;\n            }\n            this.initialized = true;\n            this.helpUrl = '/help/visualize/viewers/web-logo.md';\n            this.msgHost = ui.div('No message');\n            this.msgHost.style.display = 'none';\n            this.canvas = ui.canvas();\n            this.canvas.style.width = '100%';\n            this.host = ui.div([this.msgHost, this.canvas]);\n            // this.slider = ui.rangeSlider(0, 20, 2, 5);\n            // this.slider.root.style.width = '100%';\n            // this.slider.root.style.height = '12px';\n            const getMonomer = (p) => {\n                const jPos = Math.floor(p.x / this._positionWidth);\n                const position = this.positions[jPos];\n                if (position === void 0)\n                    return [jPos, null, null];\n                const monomer = Object.keys(position.freq)\n                    .find((m) => position.freq[m].bounds.contains(p.x, p.y));\n                if (monomer === undefined)\n                    return [jPos, null, null];\n                return [jPos, monomer, position.freq[monomer]];\n            };\n            // this.subs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mouseover').subscribe((e: MouseEvent) => {\n            // }));\n            this.viewSubs.push(rxjs.fromEvent(this.canvas, 'mousemove').subscribe((e) => {\n                if (!this.canvas)\n                    return;\n                const args = e;\n                const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n                if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n                    ui.tooltip.showRowGroup(this.dataFrame, (iRow) => {\n                        const seq = this.seqCol.get(iRow);\n                        const seqM = seq ? this.splitter(seq)[this.startPosition + jPos] : null;\n                        return seqM === monomer && this.dataFrame.filter.get(iRow);\n                    }, args.x + 16, args.y + 16);\n                }\n                else {\n                    ui.tooltip.hide();\n                }\n            }));\n            this.viewSubs.push(rxjs.fromEvent(this.canvas, 'mousedown').subscribe((e) => {\n                if (!this.canvas || e.button != 0)\n                    return;\n                const args = e;\n                const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n                // prevents deselect all rows if we miss monomer bounds\n                if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n                    this.dataFrame.selection.init((iRow) => {\n                        const seq = this.seqCol.get(iRow);\n                        const seqM = seq ? this.splitter(seq)[this.startPosition + jPos] : null;\n                        return seqM === monomer && this.dataFrame.filter.get(iRow);\n                    });\n                }\n            }));\n            this.viewSubs.push(ui.onSizeChanged(this.root).subscribe(this.rootOnSizeChanged.bind(this)));\n            this.root.append(this.host);\n            // this.root.appendChild(this.slider.root);\n            this.render(true);\n        });\n    }\n    rootOnSizeChanged(args) {\n        this.render(true);\n        // console.debug(`WebLogo.onRootSizeChanged() ` +\n        //   `root.width=${this.root.clientWidth}, root.height=${this.root.clientHeight}, ` +\n        //   `canvas.width=${this.canvas.width}, canvas.height=${this.canvas.height} .`);\n    }\n    /** Assigns {@link seqCol} and {@link cp} based on {@link sequenceColumnName} and calls {@link render}().\n     */\n    updateSeqCol() {\n        if (this.dataFrame) {\n            this.seqCol = this.sequenceColumnName ? this.dataFrame.col(this.sequenceColumnName) : null;\n            if (this.seqCol == null) {\n                this.seqCol = WebLogo.pickUpSeqCol2(this.dataFrame);\n                this.sequenceColumnName = this.seqCol ? this.seqCol.name : null;\n            }\n            if (this.seqCol) {\n                const units = this.seqCol.getTag(DG.TAGS.UNITS);\n                const separator = this.seqCol.getTag('separator');\n                this.splitter = WebLogo.getSplitter(units, separator);\n                this.updatePositions();\n                this.cp = WebLogo.pickUpPalette(this.seqCol);\n            }\n            else {\n                this.splitter = null;\n                this.positionNames = [];\n                this.startPosition = -1;\n                this.endPosition = -1;\n                this.cp = null;\n            }\n        }\n        this.render();\n    }\n    updatePositions() {\n        if (!this.seqCol)\n            return;\n        let categories;\n        if (this.shrinkEmptyTail) {\n            const indices = this.dataFrame.filter.getSelectedIndexes();\n            categories = Array.from(new Set(Array.from(Array(indices.length).keys()).map((i) => this.seqCol.get(indices[i]))));\n        }\n        else {\n            categories = this.seqCol.categories;\n        }\n        const maxLength = categories.length > 0 ? Math.max(...categories.map((s) => s !== null ? this.splitter(s).length : 0)) : 0;\n        // Get position names from data column tag 'positionNames'\n        const positionNamesTxt = this.seqCol.getTag('positionNames');\n        // Fallback if 'positionNames' tag is not provided\n        this.positionNames = positionNamesTxt ? positionNamesTxt.split(', ').map((n) => n.trim()) :\n            [...Array(maxLength).keys()].map((jPos) => `${jPos + 1}`);\n        this.startPosition = (this.startPositionName && this.positionNames &&\n            this.positionNames.includes(this.startPositionName)) ?\n            this.positionNames.indexOf(this.startPositionName) : 0;\n        this.endPosition = (this.endPositionName && this.positionNames &&\n            this.positionNames.includes(this.endPositionName)) ?\n            this.positionNames.indexOf(this.endPositionName) : (maxLength - 1);\n    }\n    onPropertyChanged(property) {\n        // console.debug(`WebLogo.onPropertyChanged( ${property.name} = '' })`);\n        super.onPropertyChanged(property);\n        switch (property.name) {\n            case 'considerNullSequences':\n                this.render(true);\n                break;\n            case 'sequenceColumnName':\n                this.updateSeqCol();\n                break;\n            case 'startPositionName':\n                this.updateSeqCol();\n                break;\n            case 'endPositionName':\n                this.updateSeqCol();\n                break;\n            case 'positionWidth':\n                this._positionWidth = this.positionWidth;\n                this.render(true);\n                break;\n            case 'minHeight':\n                this.render(true);\n                break;\n            case 'maxHeight':\n                this.render(true);\n                break;\n            case 'fixWidth':\n                this.render(true);\n                break;\n            case 'verticalAlignment':\n                this.render(true);\n                break;\n            case 'horizontalAlignment':\n                this.render(true);\n                break;\n            case 'fitArea':\n                this.render(true);\n                break;\n            case 'shrinkEmptyTail':\n                this.updatePositions();\n                this.render(true);\n                break;\n        }\n    }\n    onTableAttached() {\n        const _super = Object.create(null, {\n            onTableAttached: { get: () => super.onTableAttached }\n        });\n        return __awaiter(this, void 0, void 0, function* () {\n            const dataFrameTxt = this.dataFrame ? 'data' : 'null';\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n            _super.onTableAttached.call(this);\n            this.updateSeqCol();\n            if (this.dataFrame !== void 0) {\n                this.subs.push(this.dataFrame.selection.onChanged.subscribe((_) => this.render()));\n                this.subs.push(this.dataFrame.filter.onChanged.subscribe((_) => {\n                    this.updatePositions();\n                    this.render();\n                }));\n            }\n            yield this.init();\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n        });\n    }\n    detach() {\n        const _super = Object.create(null, {\n            detach: { get: () => super.detach }\n        });\n        return __awaiter(this, void 0, void 0, function* () {\n            const dataFrameTxt = `${this.dataFrame ? 'data' : 'null'}`;\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n            _super.detach.call(this);\n            this.viewSubs.forEach((sub) => sub.unsubscribe());\n            this.host.remove();\n            this.canvas = undefined;\n            this.msgHost = undefined;\n            this.host = undefined;\n            this.initialized = false;\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n        });\n    }\n    _nullSequence(fillerResidue = 'X') {\n        if (this.considerNullSequences)\n            return new Array(this.Length).fill(fillerResidue).join('');\n        return '';\n    }\n    _calculate() {\n        if (!this.canvas || !this.host || !this.seqCol || !this.dataFrame)\n            return;\n        this.calcSize();\n        this.positions = new Array(this.Length);\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            const posName = this.positionNames[this.startPosition + jPos];\n            this.positions[jPos] = new PositionInfo(posName);\n        }\n        // 2022-05-05 askalkin instructed to show WebLogo based on filter (not selection)\n        const indices = this.dataFrame.filter.getSelectedIndexes();\n        // const indices = this.dataFrame.selection.trueCount > 0 ? this.dataFrame.selection.getSelectedIndexes() :\n        //   this.dataFrame.filter.getSelectedIndexes();\n        this.rowsMasked = indices.length;\n        this.rowsNull = 0;\n        for (const i of indices) {\n            let s = (this.seqCol.get(i));\n            if (!s) {\n                s = this._nullSequence();\n                ++this.rowsNull;\n            }\n            const seqM = this.splitter(s);\n            for (let jPos = 0; jPos < this.Length; jPos++) {\n                const pmInfo = this.positions[jPos].freq;\n                const m = seqM[this.startPosition + jPos] || '-';\n                if (!(m in pmInfo))\n                    pmInfo[m] = new PositionMonomerInfo();\n                pmInfo[m].count++;\n            }\n        }\n        //#region Polish freq counts\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            // delete this.positions[jPos].freq['-'];\n            this.positions[jPos].rowCount = 0;\n            for (const m in this.positions[jPos].freq)\n                this.positions[jPos].rowCount += this.positions[jPos].freq[m].count;\n        }\n        //#endregion\n        const r = window.devicePixelRatio;\n        const maxHeight = this.canvas.height - this.axisHeight * r;\n        // console.debug(`WebLogo<${this.viewerId}>._calculate() maxHeight=${maxHeight}.`);\n        //#region Calculate screen\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            const freq = this.positions[jPos].freq;\n            const rowCount = this.positions[jPos].rowCount;\n            let y = this.axisHeight;\n            const entries = Object.entries(freq).sort((a, b) => {\n                if (a[0] !== '-' && b[0] !== '-')\n                    return b[1].count - a[1].count;\n                else if (a[0] === '-' && b[0] === '-')\n                    return 0;\n                else if (a[0] === '-')\n                    return -1;\n                else /* (b[0] === '-') */\n                    return +1;\n            });\n            for (const entry of entries) {\n                const pmInfo = entry[1];\n                // const m: string = entry[0];\n                const h = maxHeight * pmInfo.count / rowCount;\n                pmInfo.bounds = new DG.Rect(jPos * this._positionWidth, y, this._positionWidth, h);\n                y += h;\n            }\n        }\n        //#endregion\n    }\n    // reflect changes made to filter/selection\n    render(recalc = true) {\n        var _a;\n        if (this.msgHost) {\n            if (this.seqCol && !this.cp) {\n                this.msgHost.innerText = `Unknown palette (column semType: '${this.seqCol.semType}').`;\n                this.msgHost.style.display = '';\n            }\n            else {\n                this.msgHost.style.display = 'none';\n            }\n        }\n        if (!this.canvas || !this.seqCol || !this.dataFrame || !this.cp)\n            return;\n        const g = this.canvas.getContext('2d');\n        if (!g)\n            return;\n        if (recalc)\n            this._calculate();\n        g.resetTransform();\n        g.fillStyle = 'white';\n        g.fillRect(0, 0, this.canvas.width, this.canvas.height);\n        g.textBaseline = this.textBaseline;\n        // Prevents division by zero on Length = 0\n        if (this.startPosition === -1 || this.endPosition === -1)\n            return;\n        //#region Plot positionNames\n        g.resetTransform();\n        g.fillStyle = 'black';\n        g.textAlign = 'center';\n        g.font = '10px Roboto, Roboto Local, sans-serif';\n        const posNameMaxWidth = Math.max(...this.positions.map((pos) => g.measureText(pos.name).width));\n        const hScale = posNameMaxWidth < (this._positionWidth - 2) ? 1 : (this._positionWidth - 2) / posNameMaxWidth;\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            const pos = this.positions[jPos];\n            g.resetTransform();\n            g.setTransform(hScale, 0, 0, 1, jPos * this._positionWidth + this._positionWidth / 2, 0);\n            g.fillText(pos.name, 0, 0);\n        }\n        //#endregion Plot positionNames\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            for (const [monomer, pmInfo] of Object.entries(this.positions[jPos].freq)) {\n                if (monomer !== '-') {\n                    const b = pmInfo.bounds;\n                    const fontStyle = '16px Roboto, Roboto Local, sans-serif';\n                    // Hacks to scale uppercase characters to target rectangle\n                    const uppercaseLetterAscent = 0.25;\n                    const uppercaseLetterHeight = 12.2;\n                    g.resetTransform();\n                    g.strokeStyle = 'lightgray';\n                    g.lineWidth = 1;\n                    g.rect(b.left, b.top, b.width, b.height);\n                    g.fillStyle = (_a = this.cp.get(monomer)) !== null && _a !== void 0 ? _a : this.cp.get('other');\n                    g.textAlign = 'left';\n                    g.font = fontStyle;\n                    //g.fillRect(b.left, b.top, b.width, b.height);\n                    const mTm = g.measureText(monomer);\n                    // if (mM.actualBoundingBoxAscent != 0)\n                    //   console.debug(`m: ${m}, mM.actualBoundingBoxAscent: ${mM.actualBoundingBoxAscent}`);\n                    g.setTransform(b.width / mTm.width, 0, 0, b.height / uppercaseLetterHeight, b.left, b.top);\n                    g.fillText(monomer, 0, -uppercaseLetterAscent);\n                }\n            }\n        }\n    }\n    calcSize() {\n        if (!this.canvas || !this.host)\n            return;\n        let width = this.Length * this.positionWidth;\n        let height = Math.min(this.maxHeight, Math.max(this.minHeight, this.root.clientHeight));\n        if (this.fitArea) {\n            const xScale = this.root.clientHeight / height;\n            const yScale = this.root.clientWidth / width;\n            const scale = Math.max(1, Math.min(xScale, yScale));\n            width = width * scale;\n            height = height * scale;\n            this._positionWidth = this.positionWidth * scale;\n        }\n        const r = window.devicePixelRatio;\n        this.canvas.width = width * r;\n        this.canvas.style.width = `${width}px`;\n        // const canvasHeight: number = width > this.root.clientWidth ? height - 8 : height;\n        this.host.style.setProperty('height', `${height}px`);\n        const canvasHeight = this.host.clientHeight;\n        this.canvas.height = canvasHeight * r;\n        this.canvas.style.setProperty('height', `${canvasHeight}px`);\n        // Adjust host and root width\n        if (this.fixWidth) {\n            // full width for canvas host and root\n            this.root.style.width = this.host.style.width = `${width}px`;\n            this.root.style.height = `${height}px`;\n            this.host.style.setProperty('overflow', 'hidden', 'important');\n        }\n        else {\n            // allow scroll canvas in root\n            this.root.style.width = this.host.style.width = '100%';\n            this.host.style.overflowX = 'auto!important';\n            this.host.style.setProperty('overflow', null);\n            this.host.style.setProperty('text-align', this.horizontalAlignment);\n            // vertical alignment\n            let hostTopMargin = 0;\n            switch (this.verticalAlignment) {\n                case 'top':\n                    hostTopMargin = 0;\n                    break;\n                case 'middle':\n                    hostTopMargin = Math.max(0, (this.root.clientHeight - height) / 2);\n                    break;\n                case 'bottom':\n                    hostTopMargin = Math.max(0, this.root.clientHeight - height);\n                    break;\n            }\n            this.host.style.setProperty('margin-top', `${hostTopMargin}px`, 'important');\n            if (this.root.clientHeight < height) {\n                this.host.style.setProperty('height', `${this.root.clientHeight}px`);\n                this.host.style.setProperty('overflow-y', null);\n            }\n            else {\n                this.host.style.setProperty('overflow-y', 'hidden', 'important');\n            }\n        }\n        // console.debug(\n        //   `this.root.style.height = ${this.root.style.height}\\n` +\n        //   `this.root.clientHeight = ${this.root.clientHeight}\\n` +\n        //   `this.host.style.height = ${this.host.style.height}\\n` +\n        //   `this.host.clientHeight = ${this.host.clientHeight}\\n` +\n        //   '\\n' +\n        //   `this.canvas.height       = ${this.canvas.height}\\n` +\n        //   `this.canvas.style.height = ${this.canvas.style.height}`);\n    }\n    /**\n     * @param {DG.Column} seqCol Column to look for a palette\n     * @param {number}  minLength minimum length of sequence to detect palette (empty strings are allowed)\n     * @return {SeqPalette} Palette corresponding to the alphabet of the sequences in the column\n     */\n    static pickUpPalette(seqCol, minLength = 5) {\n        let res = null;\n        switch (seqCol.semType) {\n            case Aminoacids.SemTypeMultipleAlignment:\n                res = AminoacidsPalettes.GrokGroups;\n                break;\n            case Nucleotides.SemTypeMultipleAlignment:\n                res = NucleotidesPalettes.Chromatogram;\n                break;\n        }\n        const stats = WebLogo.getStats(seqCol, minLength, WebLogo.splitterAsFasta);\n        const alphabetCandidates = [\n            [new Set(Object.keys(Nucleotides.Names)), NucleotidesPalettes.Chromatogram],\n            [new Set(Object.keys(Aminoacids.Names)), AminoacidsPalettes.GrokGroups],\n        ];\n        // Calculate likelihoods for alphabet_candidates\n        const alphabetCandidatesSim = alphabetCandidates\n            .map((c) => WebLogo.getAlphabetSimilarity(stats.freq, c[0]));\n        const maxCos = Math.max(...alphabetCandidatesSim);\n        if (maxCos > 0.65)\n            res = alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][1];\n        else\n            res = UnknownSeqPalettes.Color;\n        return res;\n    }\n    /** Stats of sequences with specified splitter func, returns { freq, sameLength }.\n     * @param {DG.Column} seqCol\n     * @param {number} minLength\n     * @param {SplitterFunc} splitter\n     * @return { SeqColStats }, sameLength: boolean } stats of column sequences\n     */\n    static getStats(seqCol, minLength, splitter) {\n        const freq = {};\n        let sameLength = true;\n        let firstLength = null;\n        for (const seq of seqCol.categories) {\n            const mSeq = splitter(seq);\n            if (firstLength == null)\n                firstLength = mSeq.length;\n            else if (mSeq.length !== firstLength)\n                sameLength = false;\n            if (mSeq.length > minLength) {\n                for (const m of mSeq) {\n                    if (!(m in freq))\n                        freq[m] = 0;\n                    freq[m] += 1;\n                }\n            }\n        }\n        return { freq: freq, sameLength: sameLength };\n    }\n    static getAlphabetSimilarity(freq, alphabet, gapSymbol = '-') {\n        const keys = new Set([...new Set(Object.keys(freq)), ...alphabet]);\n        keys.delete(gapSymbol);\n        const freqA = [];\n        const alphabetA = [];\n        for (const m of keys) {\n            freqA.push(m in freq ? freq[m] : 0);\n            alphabetA.push(alphabet.has(m) ? 1 : 0);\n        }\n        /* There were a few ideas: chi-squared, pearson correlation (variance?), scalar product */\n        const freqV = new Vector(freqA);\n        const alphabetV = new Vector(alphabetA);\n        const cos = vectorDotProduct(freqV, alphabetV) / (vectorLength(freqV) * vectorLength(alphabetV));\n        return cos;\n    }\n    // /** First try to find column with semType 'alignedSequence'.\n    //  * Next look for column with data alphabet corresponding to any of the known palettes.\n    //  * @param {DG.DataFrame} dataFrame\n    //  * @return {DG.Column} The column we were looking for or null\n    //  */\n    // private pickUpSeqCol(dataFrame: DG.DataFrame): DG.Column | null {\n    //   let res: DG.Column | null = dataFrame.columns.bySemType('alignedSequence');\n    //   if (res == null) {\n    //     for (const col of dataFrame.columns) {\n    //       const cp = WebLogo.pickUpPalette(col as DG.Column, 5);\n    //       if (cp !== null && !(cp instanceof UnknownSeqPalette)) {\n    //         res = col;\n    //         break;\n    //       }\n    //     }\n    //   }\n    //   return res;\n    // }\n    static pickUpSeqCol2(df) {\n        var _a;\n        const semTypeColList = df.columns.bySemTypeAll(DG.SEMTYPE.MACROMOLECULE);\n        let resCol = (_a = semTypeColList.find((col) => {\n            const units = col.getTag(DG.TAGS.UNITS);\n            return units ? units.indexOf('MSA') !== -1 : false;\n        })) !== null && _a !== void 0 ? _a : null;\n        if (!resCol && semTypeColList.length > 0)\n            resCol = semTypeColList[0];\n        return resCol;\n    }\n    /** Split sequence for single character monomers, square brackets multichar monomer names or gap symbol.\n     * @param {any} seq object with sequence\n     * @return {string[]} array of monomers\n     */\n    static splitterAsFasta(seq) {\n        const res = wu(seq.toString().matchAll(WebLogo.monomerRe))\n            .map((ma) => {\n            let mRes;\n            const m = ma[0];\n            if (m.length > 1) {\n                if (m in WebLogo.aaSynonyms) {\n                    mRes = WebLogo.aaSynonyms[m];\n                }\n                else {\n                    mRes = '';\n                    console.debug(`Long monomer '${m}' has not a short synonym.`);\n                }\n            }\n            else {\n                mRes = m;\n            }\n            return mRes;\n        }).toArray();\n        return res;\n    }\n    /** Gets method to split sequence by separator\n     * @param {string} separator\n     * @return {SplitterFunc}\n     */\n    static getSplitterWithSeparator(separator) {\n        return (seq) => {\n            return seq.split(separator);\n        };\n    }\n    /** Get splitter method to split sequences to monomers\n     * @param {string} units\n     * @param {string} separator\n     * @return {SplitterFunc}\n     */\n    static getSplitter(units, separator) {\n        if (units.toLowerCase().startsWith('fasta'))\n            return WebLogo.splitterAsFasta;\n        else if (units.toLowerCase().startsWith('separator'))\n            return WebLogo.getSplitterWithSeparator(separator);\n        /*\n        else if (units.toLowerCase().startsWith('helm'))\n          return WebLogo.splitterAsHelm;\n        /**/\n        else\n            throw new Error(`Unexpected units ${units} .`);\n        // TODO: Splitter for HELM\n    }\n    static getSplitterForColumn(col) {\n        if (col.semType !== DG.SEMTYPE.MACROMOLECULE)\n            throw new Error(`Get splitter for semType \"${DG.SEMTYPE.MACROMOLECULE}\" only.`);\n        const units = col.getTag(DG.TAGS.UNITS);\n        const separator = col.getTag('separator');\n        return WebLogo.getSplitter(units, separator);\n    }\n}\nWebLogo.residuesSet = 'nucleotides';\nWebLogo.viewerCount = -1;\nWebLogo.monomerRe = /\\[(\\w+)\\]|(\\w)|(-)/g;\n/** Only some of the synonyms. These were obtained from the clustered oligopeptide dataset. */\nWebLogo.aaSynonyms = {\n    '[MeNle]': 'L',\n    '[MeA]': 'A',\n    '[MeG]': 'G',\n    '[MeF]': 'F',\n};\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web-logo.js","sourceRoot":"","sources":["web-logo.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n\nimport wu from 'wu';\nimport * as rxjs from 'rxjs';\n\nimport {Vector} from '@datagrok-libraries/utils/src/type-declarations';\nimport {vectorLength, vectorDotProduct} from '@datagrok-libraries/utils/src/vector-operations';\nimport {Aminoacids, AminoacidsPalettes} from '../aminoacids';\nimport {Nucleotides, NucleotidesPalettes} from '../nucleotides';\nimport {UnknownSeqPalette, UnknownSeqPalettes} from '../unknown';\nimport {SeqPalette} from '../seq-palettes';\nimport {Subscription} from 'rxjs';\n\ndeclare module 'datagrok-api/src/grid' {\n  interface Rect {\n    contains(x: number, y: number): boolean;\n  }\n}\n\ndeclare global {\n  interface HTMLCanvasElement {\n    getCursorPosition(event: MouseEvent): DG.Point;\n  }\n}\n\nexport type MonomerFreqs = { [m: string]: number };\nexport type SeqColStats = { freq: MonomerFreqs, sameLength: boolean }\nexport type SplitterFunc = (seq: string) => string[];\n\nHTMLCanvasElement.prototype.getCursorPosition = function(event: MouseEvent): DG.Point {\n  const rect = this.getBoundingClientRect();\n  return new DG.Point(event.clientX - rect.left, event.clientY - rect.top);\n};\n\nDG.Rect.prototype.contains = function(x: number, y: number): boolean {\n  return this.left <= x && x <= this.right && this.top <= y && y <= this.bottom;\n};\n\nexport class PositionMonomerInfo {\n  /** Sequences count with monomer in position\n   */\n  count: number;\n\n  /** Remember screen coords rect\n   */\n  bounds: DG.Rect;\n\n  constructor() {\n    this.count = 0;\n    this.bounds = new DG.Rect(0, 0, 0, 0);\n  }\n}\n\nexport class PositionInfo {\n  public readonly name: string;\n  freq: { [m: string]: PositionMonomerInfo };\n  rowCount: number;\n\n  /** freq = {}, rowCount = 0\n   * @param {string} name Name of position ('111A', '111.1', etc)\n   */\n  constructor(name: string) {\n    this.name = name;\n    this.freq = {};\n    this.rowCount = 0;\n  }\n}\n\nexport class WebLogo extends DG.JsViewer {\n  public static residuesSet = 'nucleotides';\n  private static viewerCount: number = -1;\n\n  private viewerId: number = -1;\n  private initialized: boolean = false;\n\n  // private readonly colorScheme: ColorScheme = ColorSchemes[NucleotidesWebLogo.residuesSet];\n  protected cp: SeqPalette | null = null;\n\n  private host?: HTMLDivElement;\n  private msgHost?: HTMLElement;\n  private canvas?: HTMLCanvasElement;\n  private slider?: DG.RangeSlider;\n  private textBaseline: CanvasTextBaseline;\n\n  private axisHeight: number = 12;\n\n  private seqCol: DG.Column<string> | null = null;\n  private splitter: SplitterFunc | null = null;\n  // private maxLength: number = 100;\n  private positions: PositionInfo[] = [];\n\n  private rowsMasked: number = 0;\n  private rowsNull: number = 0;\n\n  // Viewer's properties (likely they should be public so that they can be set outside)\n  private _positionWidth: number;\n  public positionWidth: number;\n  public minHeight: number;\n  public maxHeight: number;\n  public considerNullSequences: boolean;\n  public sequenceColumnName: string | null;\n  public startPositionName: string | null;\n  public endPositionName: string | null;\n  public fixWidth: boolean;\n  public verticalAlignment: string | null;\n  public horizontalAlignment: string | null;\n  public fitArea: boolean;\n  public shrinkEmptyTail: boolean;\n  public skipEmptyPositions: boolean;\n\n  private positionNames: string[] = [];\n\n  private startPosition: number = -1;\n\n  private endPosition: number = -1;\n\n  /** For startPosition equals to endPosition Length is 1 */\n  private get Length(): number {\n    return this.startPosition <= this.endPosition ? this.endPosition - this.startPosition + 1 : 0;\n  }\n\n  private viewSubs: Subscription[] = [];\n\n  constructor() {\n    super();\n\n    this.viewerId = WebLogo.viewerCount;\n    WebLogo.viewerCount += 1;\n\n    this.textBaseline = 'top';\n\n    this._positionWidth = this.positionWidth = this.float('positionWidth', 16/*,\n      {editor: 'slider', min: 4, max: 64, postfix: 'px'}*/);\n    this.minHeight = this.float('minHeight', 50/*,\n      {editor: 'slider', min: 25, max: 250, postfix: 'px'}*/);\n    this.maxHeight = this.float('maxHeight', 100/*,\n      {editor: 'slider', min: 25, max: 500, postfix: 'px'}*/);\n\n    this.considerNullSequences = this.bool('considerNullSequences', false);\n    this.sequenceColumnName = this.string('sequenceColumnName', null);\n\n    this.startPositionName = this.string('startPositionName', null);\n    this.endPositionName = this.string('endPositionName', null);\n\n    this.fixWidth = this.bool('fixWidth', false);\n\n    this.verticalAlignment = this.string('verticalAlignment', 'middle',\n      {choices: ['top', 'middle', 'bottom']});\n    this.horizontalAlignment = this.string('horizontalAlignment', 'center',\n      {choices: ['left', 'center', 'right']});\n    this.fitArea = this.bool('fitArea', true);\n    this.shrinkEmptyTail = this.bool('shrinkEmptyTail', true);\n    this.skipEmptyPositions = this.bool('skipEmptyPositions', false);\n  }\n\n  private async init(): Promise<void> {\n    if (this.initialized) {\n      console.error('WebLogo second initialization!');\n      return;\n    }\n\n    this.initialized = true;\n    this.helpUrl = '/help/visualize/viewers/web-logo.md';\n\n    this.msgHost = ui.div('No message');\n    this.msgHost.style.display = 'none';\n\n    this.canvas = ui.canvas();\n    this.canvas.style.width = '100%';\n\n    this.host = ui.div([this.msgHost, this.canvas]);\n\n    // this.slider = ui.rangeSlider(0, 20, 2, 5);\n    // this.slider.root.style.width = '100%';\n    // this.slider.root.style.height = '12px';\n\n    const getMonomer = (p: DG.Point): [number, string | null, PositionMonomerInfo | null] => {\n      const jPos = Math.floor(p.x / this._positionWidth);\n      const position = this.positions[jPos];\n\n      if (position === void 0)\n        return [jPos, null, null];\n\n      const monomer: string | undefined = Object.keys(position.freq)\n        .find((m) => position.freq[m].bounds.contains(p.x, p.y));\n      if (monomer === undefined)\n        return [jPos, null, null];\n\n      return [jPos, monomer, position.freq[monomer]];\n    };\n\n\n    // this.subs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mouseover').subscribe((e: MouseEvent) => {\n    // }));\n\n    this.viewSubs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mousemove').subscribe((e: MouseEvent) => {\n      if (!this.canvas)\n        return;\n\n      const args = e as MouseEvent;\n      const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n\n      if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n        ui.tooltip.showRowGroup(this.dataFrame, (iRow) => {\n          const seq = this.seqCol!.get(iRow);\n          const seqM = seq ? this.splitter!(seq)[this.startPosition + jPos] : null;\n          return seqM === monomer && this.dataFrame.filter.get(iRow);\n        }, args.x + 16, args.y + 16);\n      } else {\n        ui.tooltip.hide();\n      }\n    }));\n\n    this.viewSubs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mousedown').subscribe((e: MouseEvent) => {\n      if (!this.canvas || e.button != 0)\n        return;\n\n      const args = e as MouseEvent;\n      const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n\n      // prevents deselect all rows if we miss monomer bounds\n      if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n        this.dataFrame.selection.init((iRow) => {\n          const seq = this.seqCol!.get(iRow);\n          const seqM = seq ? this.splitter!(seq)[this.startPosition + jPos] : null;\n          return seqM === monomer && this.dataFrame.filter.get(iRow);\n        });\n      }\n    }));\n\n    this.viewSubs.push(ui.onSizeChanged(this.root).subscribe(this.rootOnSizeChanged.bind(this)));\n\n    this.root.append(this.host);\n    // this.root.appendChild(this.slider.root);\n\n    this.render(true);\n  }\n\n  private rootOnSizeChanged(args: any) {\n    this.render(true);\n\n    // console.debug(`WebLogo.onRootSizeChanged() ` +\n    //   `root.width=${this.root.clientWidth}, root.height=${this.root.clientHeight}, ` +\n    //   `canvas.width=${this.canvas.width}, canvas.height=${this.canvas.height} .`);\n  }\n\n  /** Assigns {@link seqCol} and {@link cp} based on {@link sequenceColumnName} and calls {@link render}().\n   */\n  private updateSeqCol(): void {\n    if (this.dataFrame) {\n      this.seqCol = this.sequenceColumnName ? this.dataFrame.col(this.sequenceColumnName) : null;\n      if (this.seqCol == null) {\n        this.seqCol = WebLogo.pickUpSeqCol2(this.dataFrame);\n        this.sequenceColumnName = this.seqCol ? this.seqCol.name : null;\n      }\n      if (this.seqCol) {\n        const units: string = this.seqCol!.getTag(DG.TAGS.UNITS);\n        const separator: string = this.seqCol!.getTag('separator');\n        this.splitter = WebLogo.getSplitter(units, separator);\n\n        this.updatePositions();\n        this.cp = WebLogo.pickUpPalette(this.seqCol);\n      } else {\n        this.splitter = null;\n        this.positionNames = [];\n        this.startPosition = -1;\n        this.endPosition = -1;\n        this.cp = null;\n      }\n    }\n    this.render();\n  }\n\n  private updatePositions(): void {\n    if (!this.seqCol)\n      return;\n\n    let categories: (string | null) [];\n    if (this.shrinkEmptyTail) {\n      const indices: Int32Array = this.dataFrame.filter.getSelectedIndexes();\n      categories = Array.from(new Set(\n        Array.from(Array(indices.length).keys()).map((i: number) => this.seqCol!.get(indices[i]))));\n    } else {\n      categories = this.seqCol.categories;\n    }\n    const maxLength = categories.length > 0 ? Math.max(...categories.map(\n      (s) => s !== null ? this.splitter!(s).length : 0)) : 0;\n\n    // Get position names from data column tag 'positionNames'\n    const positionNamesTxt = this.seqCol.getTag('positionNames');\n    // Fallback if 'positionNames' tag is not provided\n    this.positionNames = positionNamesTxt ? positionNamesTxt.split(', ').map((n) => n.trim()) :\n      [...Array(maxLength).keys()].map((jPos) => `${jPos + 1}`);\n\n    this.startPosition = (this.startPositionName && this.positionNames &&\n      this.positionNames.includes(this.startPositionName)) ?\n      this.positionNames.indexOf(this.startPositionName) : 0;\n    this.endPosition = (this.endPositionName && this.positionNames &&\n      this.positionNames.includes(this.endPositionName)) ?\n      this.positionNames.indexOf(this.endPositionName) : (maxLength - 1);\n  }\n\n  public override onPropertyChanged(property: DG.Property): void {\n    // console.debug(`WebLogo.onPropertyChanged( ${property.name} = '' })`);\n    super.onPropertyChanged(property);\n\n    switch (property.name) {\n    case 'considerNullSequences':\n      this.render(true);\n      break;\n    case 'sequenceColumnName':\n      this.updateSeqCol();\n      break;\n    case 'startPositionName':\n      this.updateSeqCol();\n      break;\n    case 'endPositionName':\n      this.updateSeqCol();\n      break;\n    case 'positionWidth':\n      this._positionWidth = this.positionWidth;\n      this.render(true);\n      break;\n    case 'minHeight':\n      this.render(true);\n      break;\n    case 'maxHeight':\n      this.render(true);\n      break;\n    case 'fixWidth':\n      this.render(true);\n      break;\n    case 'verticalAlignment':\n      this.render(true);\n      break;\n    case 'horizontalAlignment':\n      this.render(true);\n      break;\n    case 'fitArea':\n      this.render(true);\n      break;\n    case 'shrinkEmptyTail':\n      this.updatePositions();\n      this.render(true);\n      break;\n    }\n  }\n\n  public override async onTableAttached() {\n    const dataFrameTxt: string = this.dataFrame ? 'data' : 'null';\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n    super.onTableAttached();\n\n    this.updateSeqCol();\n\n    if (this.dataFrame !== void 0) {\n      this.subs.push(this.dataFrame.selection.onChanged.subscribe((_) => this.render()));\n      this.subs.push(this.dataFrame.filter.onChanged.subscribe((_) => {\n        this.updatePositions();\n        this.render();\n      }));\n    }\n\n    await this.init();\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n  }\n\n  public override async detach() {\n    const dataFrameTxt = `${this.dataFrame ? 'data' : 'null'}`;\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n    super.detach();\n\n    this.viewSubs.forEach((sub) => sub.unsubscribe());\n    this.host!.remove();\n    this.canvas = undefined;\n    this.msgHost = undefined;\n    this.host = undefined;\n\n    this.initialized = false;\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n  }\n\n  protected _nullSequence(fillerResidue = 'X'): string {\n    if (this.considerNullSequences)\n      return new Array(this.Length).fill(fillerResidue).join('');\n\n    return '';\n  }\n\n  protected _calculate() {\n    if (!this.canvas || !this.host || !this.seqCol || !this.dataFrame)\n      return;\n\n    this.calcSize();\n\n    this.positions = new Array(this.Length);\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      const posName: string = this.positionNames[this.startPosition + jPos];\n      this.positions[jPos] = new PositionInfo(posName);\n    }\n\n    // 2022-05-05 askalkin instructed to show WebLogo based on filter (not selection)\n    const indices = this.dataFrame.filter.getSelectedIndexes();\n    // const indices = this.dataFrame.selection.trueCount > 0 ? this.dataFrame.selection.getSelectedIndexes() :\n    //   this.dataFrame.filter.getSelectedIndexes();\n\n    this.rowsMasked = indices.length;\n    this.rowsNull = 0;\n\n    for (const i of indices) {\n      let s: string = <string>(this.seqCol.get(i));\n\n      if (!s) {\n        s = this._nullSequence();\n        ++this.rowsNull;\n      }\n\n      const seqM: string[] = this.splitter!(s);\n      for (let jPos = 0; jPos < this.Length; jPos++) {\n        const pmInfo = this.positions[jPos].freq;\n        const m: string = seqM[this.startPosition + jPos] || '-';\n        if (!(m in pmInfo))\n          pmInfo[m] = new PositionMonomerInfo();\n        pmInfo[m].count++;\n      }\n    }\n\n    //#region Polish freq counts\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      // delete this.positions[jPos].freq['-'];\n\n      this.positions[jPos].rowCount = 0;\n      for (const m in this.positions[jPos].freq)\n        this.positions[jPos].rowCount += this.positions[jPos].freq[m].count;\n    }\n    //#endregion\n\n    const r = window.devicePixelRatio;\n    const maxHeight = this.canvas.height - this.axisHeight * r;\n    // console.debug(`WebLogo<${this.viewerId}>._calculate() maxHeight=${maxHeight}.`);\n\n    //#region Calculate screen\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      const freq: { [c: string]: PositionMonomerInfo } = this.positions[jPos].freq;\n      const rowCount = this.positions[jPos].rowCount;\n\n      let y: number = this.axisHeight;\n\n      const entries = Object.entries(freq).sort((a, b) => {\n        if (a[0] !== '-' && b[0] !== '-')\n          return b[1].count - a[1].count;\n        else if (a[0] === '-' && b[0] === '-')\n          return 0;\n        else if (a[0] === '-')\n          return -1;\n        else /* (b[0] === '-') */\n          return +1;\n      });\n      for (const entry of entries) {\n        const pmInfo: PositionMonomerInfo = entry[1];\n        // const m: string = entry[0];\n        const h: number = maxHeight * pmInfo.count / rowCount;\n\n        pmInfo.bounds = new DG.Rect(jPos * this._positionWidth, y, this._positionWidth, h);\n        y += h;\n      }\n    }\n    //#endregion\n  }\n\n  // reflect changes made to filter/selection\n  render(recalc = true) {\n    if (this.msgHost) {\n      if (this.seqCol && !this.cp) {\n        this.msgHost!.innerText = `Unknown palette (column semType: '${this.seqCol.semType}').`;\n        this.msgHost!.style.display = '';\n      } else {\n        this.msgHost!.style.display = 'none';\n      }\n    }\n\n    if (!this.canvas || !this.seqCol || !this.dataFrame || !this.cp)\n      return;\n\n    const g = this.canvas.getContext('2d');\n    if (!g) return;\n\n    if (recalc)\n      this._calculate();\n\n    g.resetTransform();\n    g.fillStyle = 'white';\n    g.fillRect(0, 0, this.canvas.width, this.canvas.height);\n    g.textBaseline = this.textBaseline;\n\n    // Prevents division by zero on Length = 0\n    if (this.startPosition === -1 || this.endPosition === -1)\n      return;\n\n    //#region Plot positionNames\n    g.resetTransform();\n    g.fillStyle = 'black';\n    g.textAlign = 'center';\n    g.font = '10px Roboto, Roboto Local, sans-serif';\n    const posNameMaxWidth = Math.max(...this.positions.map((pos) => g.measureText(pos.name).width));\n    const hScale = posNameMaxWidth < (this._positionWidth - 2) ? 1 : (this._positionWidth - 2) / posNameMaxWidth;\n\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      const pos: PositionInfo = this.positions[jPos];\n      g.resetTransform();\n      g.setTransform(\n        hScale, 0, 0, 1,\n        jPos * this._positionWidth + this._positionWidth / 2, 0);\n      g.fillText(pos.name, 0, 0);\n    }\n    //#endregion Plot positionNames\n\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      for (const [monomer, pmInfo] of Object.entries(this.positions[jPos].freq)) {\n        if (monomer !== '-') {\n          const b = pmInfo.bounds;\n\n          const fontStyle = '16px Roboto, Roboto Local, sans-serif';\n          // Hacks to scale uppercase characters to target rectangle\n          const uppercaseLetterAscent = 0.25;\n          const uppercaseLetterHeight = 12.2;\n\n          g.resetTransform();\n          g.strokeStyle = 'lightgray';\n          g.lineWidth = 1;\n          g.rect(b.left, b.top, b.width, b.height);\n          g.fillStyle = this.cp.get(monomer) ?? this.cp.get('other');\n          g.textAlign = 'left';\n          g.font = fontStyle;\n          //g.fillRect(b.left, b.top, b.width, b.height);\n          const mTm: TextMetrics = g.measureText(monomer);\n\n          // if (mM.actualBoundingBoxAscent != 0)\n          //   console.debug(`m: ${m}, mM.actualBoundingBoxAscent: ${mM.actualBoundingBoxAscent}`);\n\n          g.setTransform(\n            b.width / mTm.width, 0, 0, b.height / uppercaseLetterHeight,\n            b.left, b.top);\n          g.fillText(monomer, 0, -uppercaseLetterAscent);\n        }\n      }\n    }\n  }\n\n  private calcSize() {\n    if (!this.canvas || !this.host)\n      return;\n\n    let width: number = this.Length * this.positionWidth;\n    let height = Math.min(this.maxHeight, Math.max(this.minHeight, this.root.clientHeight));\n\n    if (this.fitArea) {\n      const xScale: number = this.root.clientHeight / height;\n      const yScale: number = this.root.clientWidth / width;\n      const scale = Math.max(1, Math.min(xScale, yScale));\n      width = width * scale;\n      height = height * scale;\n      this._positionWidth = this.positionWidth * scale;\n    }\n\n    const r = window.devicePixelRatio;\n    this.canvas.width = width * r;\n    this.canvas.style.width = `${width}px`;\n\n    // const canvasHeight: number = width > this.root.clientWidth ? height - 8 : height;\n    this.host.style.setProperty('height', `${height}px`);\n    const canvasHeight: number = this.host.clientHeight;\n    this.canvas.height = canvasHeight * r;\n    this.canvas.style.setProperty('height', `${canvasHeight}px`);\n\n    // Adjust host and root width\n    if (this.fixWidth) {\n      // full width for canvas host and root\n      this.root.style.width = this.host.style.width = `${width}px`;\n      this.root.style.height = `${height}px`;\n      this.host.style.setProperty('overflow', 'hidden', 'important');\n    } else {\n      // allow scroll canvas in root\n      this.root.style.width = this.host.style.width = '100%';\n      this.host.style.overflowX = 'auto!important';\n      this.host.style.setProperty('overflow', null);\n\n      this.host.style.setProperty('text-align', this.horizontalAlignment);\n\n      // vertical alignment\n      let hostTopMargin = 0;\n      switch (this.verticalAlignment) {\n      case 'top':\n        hostTopMargin = 0;\n        break;\n      case 'middle':\n        hostTopMargin = Math.max(0, (this.root.clientHeight - height) / 2);\n        break;\n      case 'bottom':\n        hostTopMargin = Math.max(0, this.root.clientHeight - height);\n        break;\n      }\n      this.host.style.setProperty('margin-top', `${hostTopMargin}px`, 'important');\n\n      if (this.root.clientHeight < height) {\n        this.host.style.setProperty('height', `${this.root.clientHeight}px`);\n        this.host.style.setProperty('overflow-y', null);\n      } else {\n        this.host.style.setProperty('overflow-y', 'hidden', 'important');\n      }\n    }\n\n    // console.debug(\n    //   `this.root.style.height = ${this.root.style.height}\\n` +\n    //   `this.root.clientHeight = ${this.root.clientHeight}\\n` +\n    //   `this.host.style.height = ${this.host.style.height}\\n` +\n    //   `this.host.clientHeight = ${this.host.clientHeight}\\n` +\n    //   '\\n' +\n    //   `this.canvas.height       = ${this.canvas.height}\\n` +\n    //   `this.canvas.style.height = ${this.canvas.style.height}`);\n  }\n\n  /**\n   * @param {DG.Column} seqCol Column to look for a palette\n   * @param {number}  minLength minimum length of sequence to detect palette (empty strings are allowed)\n   * @return {SeqPalette} Palette corresponding to the alphabet of the sequences in the column\n   */\n  public static pickUpPalette(seqCol: DG.Column, minLength: number = 5): SeqPalette {\n    let res: SeqPalette | null = null;\n    switch (seqCol.semType) {\n    case Aminoacids.SemTypeMultipleAlignment:\n      res = AminoacidsPalettes.GrokGroups;\n      break;\n    case Nucleotides.SemTypeMultipleAlignment:\n      res = NucleotidesPalettes.Chromatogram;\n      break;\n    }\n    const stats: SeqColStats = WebLogo.getStats(seqCol, minLength, WebLogo.splitterAsFasta);\n\n    const alphabetCandidates: [Set<string>, SeqPalette][] = [\n      [new Set(Object.keys(Nucleotides.Names)), NucleotidesPalettes.Chromatogram],\n      [new Set(Object.keys(Aminoacids.Names)), AminoacidsPalettes.GrokGroups],\n    ];\n    // Calculate likelihoods for alphabet_candidates\n    const alphabetCandidatesSim: number[] = alphabetCandidates\n      .map((c) => WebLogo.getAlphabetSimilarity(stats.freq, c[0]));\n    const maxCos = Math.max(...alphabetCandidatesSim);\n    if (maxCos > 0.65)\n      res = alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][1];\n    else\n      res = UnknownSeqPalettes.Color;\n\n    return res;\n  }\n\n  /** Stats of sequences with specified splitter func, returns { freq, sameLength }.\n   * @param {DG.Column} seqCol\n   * @param {number} minLength\n   * @param {SplitterFunc} splitter\n   * @return { SeqColStats }, sameLength: boolean } stats of column sequences\n   */\n  static getStats(seqCol: DG.Column, minLength: number, splitter: SplitterFunc): SeqColStats {\n    const freq: { [m: string]: number } = {};\n    let sameLength = true;\n    let firstLength = null;\n\n    for (const seq of seqCol.categories) {\n      const mSeq = splitter(seq);\n\n      if (firstLength == null)\n        firstLength = mSeq.length;\n      else if (mSeq.length !== firstLength)\n        sameLength = false;\n\n      if (mSeq.length > minLength) {\n        for (const m of mSeq) {\n          if (!(m in freq))\n            freq[m] = 0;\n          freq[m] += 1;\n        }\n      }\n    }\n    return {freq: freq, sameLength: sameLength};\n  }\n\n  public static getAlphabetSimilarity(freq: MonomerFreqs, alphabet: Set<string>, gapSymbol: string = '-'): number {\n    const keys = new Set<string>([...new Set(Object.keys(freq)), ...alphabet]);\n    keys.delete(gapSymbol);\n\n    const freqA: number[] = [];\n    const alphabetA: number[] = [];\n    for (const m of keys) {\n      freqA.push(m in freq ? freq[m] : 0);\n      alphabetA.push(alphabet.has(m) ? 1 : 0);\n    }\n    /* There were a few ideas: chi-squared, pearson correlation (variance?), scalar product */\n    const freqV: Vector = new Vector(freqA);\n    const alphabetV: Vector = new Vector(alphabetA);\n    const cos: number = vectorDotProduct(freqV, alphabetV) / (vectorLength(freqV) * vectorLength(alphabetV));\n    return cos;\n  }\n\n  // /** First try to find column with semType 'alignedSequence'.\n  //  * Next look for column with data alphabet corresponding to any of the known palettes.\n  //  * @param {DG.DataFrame} dataFrame\n  //  * @return {DG.Column} The column we were looking for or null\n  //  */\n  // private pickUpSeqCol(dataFrame: DG.DataFrame): DG.Column | null {\n  //   let res: DG.Column | null = dataFrame.columns.bySemType('alignedSequence');\n  //   if (res == null) {\n  //     for (const col of dataFrame.columns) {\n  //       const cp = WebLogo.pickUpPalette(col as DG.Column, 5);\n  //       if (cp !== null && !(cp instanceof UnknownSeqPalette)) {\n  //         res = col;\n  //         break;\n  //       }\n  //     }\n  //   }\n  //   return res;\n  // }\n\n  public static pickUpSeqCol2(df: DG.DataFrame): DG.Column | null {\n    const semTypeColList = df.columns.bySemTypeAll(DG.SEMTYPE.MACROMOLECULE);\n    let resCol: DG.Column | null = semTypeColList.find((col) => {\n      const units = col.getTag(DG.TAGS.UNITS);\n      return units ? units.indexOf('MSA') !== -1 : false;\n    }) ?? null;\n    if (!resCol && semTypeColList.length > 0)\n      resCol = semTypeColList[0];\n    return resCol;\n  }\n\n  private static monomerRe = /\\[(\\w+)\\]|(\\w)|(-)/g;\n\n  /** Split sequence for single character monomers, square brackets multichar monomer names or gap symbol.\n   * @param {any} seq object with sequence\n   * @return {string[]} array of monomers\n   */\n  public static splitterAsFasta(seq: any): string[] {\n    const res: string[] = wu<RegExpMatchArray>(seq.toString().matchAll(WebLogo.monomerRe))\n      .map((ma: RegExpMatchArray) => {\n        let mRes: string;\n        const m: string = ma[0];\n        if (m.length > 1) {\n          if (m in WebLogo.aaSynonyms) {\n            mRes = WebLogo.aaSynonyms[m];\n          } else {\n            mRes = '';\n            console.debug(`Long monomer '${m}' has not a short synonym.`);\n          }\n        } else {\n          mRes = m;\n        }\n        return mRes;\n      }).toArray();\n\n    return res;\n  }\n\n  /** Gets method to split sequence by separator\n   * @param {string} separator\n   * @return {SplitterFunc}\n   */\n  public static getSplitterWithSeparator(separator: string): SplitterFunc {\n    return (seq: string) => {\n      return seq.split(separator);\n    };\n  }\n\n  /** Get splitter method to split sequences to monomers\n   * @param {string} units\n   * @param {string} separator\n   * @return {SplitterFunc}\n   */\n  public static getSplitter(units: string, separator: string): SplitterFunc {\n    if (units.toLowerCase().startsWith('fasta'))\n      return WebLogo.splitterAsFasta;\n    else if (units.toLowerCase().startsWith('separator'))\n      return WebLogo.getSplitterWithSeparator(separator);\n    /*\n    else if (units.toLowerCase().startsWith('helm'))\n      return WebLogo.splitterAsHelm;\n    /**/\n    else\n      throw new Error(`Unexpected units ${units} .`);\n\n    // TODO: Splitter for HELM\n  }\n\n  public static getSplitterForColumn(col: DG.Column): SplitterFunc {\n    if (col.semType !== DG.SEMTYPE.MACROMOLECULE)\n      throw new Error(`Get splitter for semType \"${DG.SEMTYPE.MACROMOLECULE}\" only.`);\n\n    const units = col.getTag(DG.TAGS.UNITS);\n    const separator = col.getTag('separator');\n    return WebLogo.getSplitter(units, separator);\n  }\n\n  /** Only some of the synonyms. These were obtained from the clustered oligopeptide dataset. */\n  private static aaSynonyms: { [name: string]: string } = {\n    '[MeNle]': 'L', // Nle - norleucine\n    '[MeA]': 'A',\n    '[MeG]': 'G',\n    '[MeF]': 'F',\n  };\n}\n"]}","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport { normalize } from '@datagrok-libraries/utils/src/vector-operations';\nimport { createDimensinalityReducingWorker } from './workers/dimensionality-reducing-worker-creator';\nexport function reduceDimensinalityWithNormalization(dataCol, methodName, similarityMetric, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const dimensionalityReduceRes = yield createDimensinalityReducingWorker({ data: dataCol, metric: similarityMetric }, methodName, options);\n        dimensionalityReduceRes.embedding = dimensionalityReduceRes.embedding.map(it => normalize(it));\n        return dimensionalityReduceRes;\n    });\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VxdWVuY2Utc3BhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzZXF1ZW5jZS1zcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFFQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saURBQWlELENBQUM7QUFHNUUsT0FBTyxFQUFFLGlDQUFpQyxFQUErQixNQUFNLGtEQUFrRCxDQUFDO0FBR2xJLE1BQU0sVUFBZ0Isb0NBQW9DLENBQ3RELE9BQXFDLEVBQ3JDLFVBQWtCLEVBQ2xCLGdCQUE2RCxFQUM3RCxPQUFhOztRQUViLE1BQU0sdUJBQXVCLEdBQ3pCLE1BQU0saUNBQWlDLENBQ25DLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsZ0JBQWdCLEVBQWdCLEVBQ3pELFVBQVUsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUU3Qix1QkFBdUIsQ0FBQyxTQUFTLEdBQUcsdUJBQXVCLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQy9GLE9BQU8sdUJBQXVCLENBQUM7SUFDbkMsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJpdEFycmF5IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL2JpdC1hcnJheSc7XG5pbXBvcnQgeyBNYXRyaXgsIFZlY3RvciB9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3R5cGUtZGVjbGFyYXRpb25zJztcbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3ZlY3Rvci1vcGVyYXRpb25zJztcbmltcG9ydCAqIGFzIERHIGZyb20gJ2RhdGFncm9rLWFwaS9kZyc7XG5pbXBvcnQgeyBCaXRBcnJheU1ldHJpY3MsIFN0cmluZ01ldHJpY3MsIFZhbGlkVHlwZXMsIFZlY3Rvck1ldHJpY3MgfSBmcm9tICcuL3R5cGVkLW1ldHJpY3MnO1xuaW1wb3J0IHsgY3JlYXRlRGltZW5zaW5hbGl0eVJlZHVjaW5nV29ya2VyLCBJUmVkdWNlRGltZW5zaW9uYWxpdHlSZXN1bHQgfSBmcm9tICcuL3dvcmtlcnMvZGltZW5zaW9uYWxpdHktcmVkdWNpbmctd29ya2VyLWNyZWF0b3InO1xuXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiByZWR1Y2VEaW1lbnNpbmFsaXR5V2l0aE5vcm1hbGl6YXRpb24oXG4gICAgZGF0YUNvbDogQml0QXJyYXlbXXxWZWN0b3JbXXxzdHJpbmdbXSwgXG4gICAgbWV0aG9kTmFtZTogc3RyaW5nLCBcbiAgICBzaW1pbGFyaXR5TWV0cmljOiBCaXRBcnJheU1ldHJpY3N8VmVjdG9yTWV0cmljc3xTdHJpbmdNZXRyaWNzLFxuICAgIG9wdGlvbnM/OiBhbnkpOiBQcm9taXNlPElSZWR1Y2VEaW1lbnNpb25hbGl0eVJlc3VsdD4ge1xuXG4gICAgY29uc3QgZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXM6IElSZWR1Y2VEaW1lbnNpb25hbGl0eVJlc3VsdCA9XG4gICAgICAgIGF3YWl0IGNyZWF0ZURpbWVuc2luYWxpdHlSZWR1Y2luZ1dvcmtlcihcbiAgICAgICAgICAgIHsgZGF0YTogZGF0YUNvbCwgbWV0cmljOiBzaW1pbGFyaXR5TWV0cmljIH0gYXMgVmFsaWRUeXBlcyxcbiAgICAgICAgICAgIG1ldGhvZE5hbWUsIG9wdGlvbnMpO1xuXG4gICAgZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXMuZW1iZWRkaW5nID0gZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXMuZW1iZWRkaW5nLm1hcChpdCA9PiBub3JtYWxpemUoaXQpKTtcbiAgICByZXR1cm4gZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXM7XG59Il19","import * as fl from 'fastest-levenshtein';\nimport { jaroWinkler } from 'jaro-winkler-typescript';\nimport { distanceMetrics } from '@datagrok-libraries/utils/src/similarity-metrics';\nimport { calculateEuclideanDistance } from '@datagrok-libraries/utils/src/vector-operations';\nexport const AvailableMetrics = {\n    'Vector': {\n        'EuclideanDistance': calculateEuclideanDistance,\n    },\n    'String': {\n        'Levenshtein': fl.distance,\n        'Jaro-Winkler': jaroWinkler,\n    },\n    'BitArray': {\n        'Tanimoto': distanceMetrics['Tanimoto'],\n        'Dice': distanceMetrics['Dice'],\n        'Asymmetric': distanceMetrics['Asymmetric'],\n        'Braun-Blanquet': distanceMetrics['Braun-Blanquet'],\n        'Cosine': distanceMetrics['Cosine'],\n        'Kulczynski': distanceMetrics['Kulczynski'],\n        'Mc-Connaughey': distanceMetrics['Mc-Connaughey'],\n        'Rogot-Goldberg': distanceMetrics['Rogot-Goldberg'],\n        'Russel': distanceMetrics['Russel'],\n        'Sokal': distanceMetrics['Sokal'],\n    },\n};\nexport const MetricToDataType = Object.keys(AvailableMetrics)\n    .reduce((ret, key) => {\n    for (const val of Object.keys(AvailableMetrics[key])) {\n        ret[val] = key;\n    }\n    return ret;\n}, {});\nexport function isStringMetric(name) {\n    return MetricToDataType[name] == 'String';\n}\nexport function isBitArrayMetric(name) {\n    return MetricToDataType[name] == 'BitArray';\n}\nexport function isVectorMetric(name) {\n    return MetricToDataType[name] == 'Vector';\n}\n/** Unified class implementing different string measures. */\nexport class Measure {\n    /**\n     * Creates an instance of Measure with .\n     * @param {string} method Method to calculate distance between strings.\n     * @memberof Measurer\n     */\n    constructor(method) {\n        this.method = method;\n        this.dataType = MetricToDataType[method];\n    }\n    /**\n     * Returns custom string distance function specified.\n     * @return {DistanceMetric} Callback of the measure chosen.\n     * @memberof Measurer\n     */\n    getMeasure() {\n        const dict = AvailableMetrics;\n        return dict[this.dataType][this.method];\n    }\n    /**\n     * Returns custom string distance by the given data type.\n     * @param {AvailableDataTypes} dataType Metric's data type\n     * @return {string[]} Metric names which expects the given data type\n     * @memberof Measurer\n     */\n    static getMetricByDataType(dataType) {\n        return Object.keys(AvailableMetrics[dataType]);\n    }\n    /** Returns metric names available.\n     * @memberof Measurer\n    */\n    static get availableMeasures() {\n        return Object.keys(AvailableMetrics);\n    }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZWQtbWV0cmljcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInR5cGVkLW1ldHJpY3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMxQyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFFcEQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLGtEQUFrRCxDQUFDO0FBQ2pGLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBSTNGLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHO0lBQzlCLFFBQVEsRUFBRTtRQUNSLG1CQUFtQixFQUFFLDBCQUEwQjtLQUNoRDtJQUNELFFBQVEsRUFBRTtRQUNSLGFBQWEsRUFBRSxFQUFFLENBQUMsUUFBUTtRQUMxQixjQUFjLEVBQUUsV0FBVztLQUM1QjtJQUNELFVBQVUsRUFBRTtRQUNWLFVBQVUsRUFBRSxlQUFlLENBQUMsVUFBVSxDQUFDO1FBQ3ZDLE1BQU0sRUFBRSxlQUFlLENBQUMsTUFBTSxDQUFDO1FBQy9CLFlBQVksRUFBRSxlQUFlLENBQUMsWUFBWSxDQUFDO1FBQzNDLGdCQUFnQixFQUFFLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQztRQUNuRCxRQUFRLEVBQUUsZUFBZSxDQUFDLFFBQVEsQ0FBQztRQUNuQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFlBQVksQ0FBQztRQUMzQyxlQUFlLEVBQUUsZUFBZSxDQUFDLGVBQWUsQ0FBQztRQUNqRCxnQkFBZ0IsRUFBRSxlQUFlLENBQUMsZ0JBQWdCLENBQUM7UUFDbkQsUUFBUSxFQUFFLGVBQWUsQ0FBQyxRQUFRLENBQUM7UUFDbkMsT0FBTyxFQUFFLGVBQWUsQ0FBQyxPQUFPLENBQUM7S0FDbEM7Q0FDRixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQXFCLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7S0FDNUUsTUFBTSxDQUFDLENBQUMsR0FBcUIsRUFBRSxHQUFHLEVBQUUsRUFBRTtJQUNyQyxLQUFLLE1BQU0sR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBeUIsQ0FBQyxDQUFDLEVBQUU7UUFDMUUsR0FBRyxDQUFDLEdBQXlCLENBQUMsR0FBRyxHQUFHLENBQUM7S0FDdEM7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztBQVdULE1BQU0sVUFBVSxjQUFjLENBQUMsSUFBa0I7SUFDL0MsT0FBTyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxRQUFRLENBQUM7QUFDNUMsQ0FBQztBQUVELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxJQUFrQjtJQUNqRCxPQUFPLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLFVBQVUsQ0FBQztBQUM5QyxDQUFDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FBQyxJQUFrQjtJQUMvQyxPQUFPLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLFFBQVEsQ0FBQztBQUM1QyxDQUFDO0FBRUQsNERBQTREO0FBQzVELE1BQU0sT0FBTyxPQUFPO0lBSWxCOzs7O09BSUc7SUFDSCxZQUFZLE1BQW9CO1FBQzlCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxDQUF1QixDQUFDO0lBQ2pFLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksVUFBVTtRQUNmLE1BQU0sSUFBSSxHQUFzRCxnQkFBZ0IsQ0FBQztRQUNqRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxRQUE0QjtRQUM1RCxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQ7O01BRUU7SUFDRixNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZsIGZyb20gJ2Zhc3Rlc3QtbGV2ZW5zaHRlaW4nO1xuaW1wb3J0IHtqYXJvV2lua2xlcn0gZnJvbSAnamFyby13aW5rbGVyLXR5cGVzY3JpcHQnO1xuaW1wb3J0IHtEaXN0YW5jZU1ldHJpY30gZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvdHlwZS1kZWNsYXJhdGlvbnMnO1xuaW1wb3J0IHtkaXN0YW5jZU1ldHJpY3N9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3NpbWlsYXJpdHktbWV0cmljcyc7XG5pbXBvcnQge2NhbGN1bGF0ZUV1Y2xpZGVhbkRpc3RhbmNlfSBmcm9tICdAZGF0YWdyb2stbGlicmFyaWVzL3V0aWxzL3NyYy92ZWN0b3Itb3BlcmF0aW9ucyc7XG5pbXBvcnQgQml0QXJyYXkgZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvYml0LWFycmF5JztcbmltcG9ydCB7VmVjdG9yLCBTdHJpbmdEaWN0aW9uYXJ5fSBmcm9tICdAZGF0YWdyb2stbGlicmFyaWVzL3V0aWxzL3NyYy90eXBlLWRlY2xhcmF0aW9ucyc7XG5cbmV4cG9ydCBjb25zdCBBdmFpbGFibGVNZXRyaWNzID0ge1xuICAnVmVjdG9yJzoge1xuICAgICdFdWNsaWRlYW5EaXN0YW5jZSc6IGNhbGN1bGF0ZUV1Y2xpZGVhbkRpc3RhbmNlLFxuICB9LFxuICAnU3RyaW5nJzoge1xuICAgICdMZXZlbnNodGVpbic6IGZsLmRpc3RhbmNlLFxuICAgICdKYXJvLVdpbmtsZXInOiBqYXJvV2lua2xlcixcbiAgfSxcbiAgJ0JpdEFycmF5Jzoge1xuICAgICdUYW5pbW90byc6IGRpc3RhbmNlTWV0cmljc1snVGFuaW1vdG8nXSxcbiAgICAnRGljZSc6IGRpc3RhbmNlTWV0cmljc1snRGljZSddLFxuICAgICdBc3ltbWV0cmljJzogZGlzdGFuY2VNZXRyaWNzWydBc3ltbWV0cmljJ10sXG4gICAgJ0JyYXVuLUJsYW5xdWV0JzogZGlzdGFuY2VNZXRyaWNzWydCcmF1bi1CbGFucXVldCddLFxuICAgICdDb3NpbmUnOiBkaXN0YW5jZU1ldHJpY3NbJ0Nvc2luZSddLFxuICAgICdLdWxjenluc2tpJzogZGlzdGFuY2VNZXRyaWNzWydLdWxjenluc2tpJ10sXG4gICAgJ01jLUNvbm5hdWdoZXknOiBkaXN0YW5jZU1ldHJpY3NbJ01jLUNvbm5hdWdoZXknXSxcbiAgICAnUm9nb3QtR29sZGJlcmcnOiBkaXN0YW5jZU1ldHJpY3NbJ1JvZ290LUdvbGRiZXJnJ10sXG4gICAgJ1J1c3NlbCc6IGRpc3RhbmNlTWV0cmljc1snUnVzc2VsJ10sXG4gICAgJ1Nva2FsJzogZGlzdGFuY2VNZXRyaWNzWydTb2thbCddLFxuICB9LFxufTtcblxuZXhwb3J0IGNvbnN0IE1ldHJpY1RvRGF0YVR5cGU6IFN0cmluZ0RpY3Rpb25hcnkgPSBPYmplY3Qua2V5cyhBdmFpbGFibGVNZXRyaWNzKVxuICAucmVkdWNlKChyZXQ6IFN0cmluZ0RpY3Rpb25hcnksIGtleSkgPT4ge1xuICAgIGZvciAoY29uc3QgdmFsIG9mIE9iamVjdC5rZXlzKEF2YWlsYWJsZU1ldHJpY3Nba2V5IGFzIEF2YWlsYWJsZURhdGFUeXBlc10pKSB7XG4gICAgICByZXRbdmFsIGFzIEF2YWlsYWJsZURhdGFUeXBlc10gPSBrZXk7XG4gICAgfVxuICAgIHJldHVybiByZXQ7XG4gIH0sIHt9KTtcblxuZXhwb3J0IHR5cGUgQXZhaWxhYmxlRGF0YVR5cGVzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3M7XG5leHBvcnQgdHlwZSBTdHJpbmdNZXRyaWNzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3NbJ1N0cmluZyddO1xuZXhwb3J0IHR5cGUgQml0QXJyYXlNZXRyaWNzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3NbJ0JpdEFycmF5J107XG5leHBvcnQgdHlwZSBWZWN0b3JNZXRyaWNzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3NbJ1ZlY3RvciddO1xuZXhwb3J0IHR5cGUgS25vd25NZXRyaWNzID0gU3RyaW5nTWV0cmljcyB8IEJpdEFycmF5TWV0cmljcyB8IFZlY3Rvck1ldHJpY3M7XG5cbmV4cG9ydCB0eXBlIFZhbGlkVHlwZXMgPSB7ZGF0YTogc3RyaW5nW10sIG1ldHJpYzogU3RyaW5nTWV0cmljc30gfCB7ZGF0YTogVmVjdG9yW10sIG1ldHJpYzogVmVjdG9yTWV0cmljc30gfFxuICAgICAgICAgICAgICAgICAgICAgICAgIHtkYXRhOiBCaXRBcnJheVtdLCBtZXRyaWM6IEJpdEFycmF5TWV0cmljc307XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1N0cmluZ01ldHJpYyhuYW1lOiBLbm93bk1ldHJpY3MpIHtcbiAgcmV0dXJuIE1ldHJpY1RvRGF0YVR5cGVbbmFtZV0gPT0gJ1N0cmluZyc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0JpdEFycmF5TWV0cmljKG5hbWU6IEtub3duTWV0cmljcykge1xuICByZXR1cm4gTWV0cmljVG9EYXRhVHlwZVtuYW1lXSA9PSAnQml0QXJyYXknO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNWZWN0b3JNZXRyaWMobmFtZTogS25vd25NZXRyaWNzKSB7XG4gIHJldHVybiBNZXRyaWNUb0RhdGFUeXBlW25hbWVdID09ICdWZWN0b3InO1xufVxuXG4vKiogVW5pZmllZCBjbGFzcyBpbXBsZW1lbnRpbmcgZGlmZmVyZW50IHN0cmluZyBtZWFzdXJlcy4gKi9cbmV4cG9ydCBjbGFzcyBNZWFzdXJlIHtcbiAgcHJvdGVjdGVkIG1ldGhvZDogS25vd25NZXRyaWNzO1xuICBwcm90ZWN0ZWQgZGF0YVR5cGU6IEF2YWlsYWJsZURhdGFUeXBlcztcblxuICAvKipcbiAgICogQ3JlYXRlcyBhbiBpbnN0YW5jZSBvZiBNZWFzdXJlIHdpdGggLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gbWV0aG9kIE1ldGhvZCB0byBjYWxjdWxhdGUgZGlzdGFuY2UgYmV0d2VlbiBzdHJpbmdzLlxuICAgKiBAbWVtYmVyb2YgTWVhc3VyZXJcbiAgICovXG4gIGNvbnN0cnVjdG9yKG1ldGhvZDogS25vd25NZXRyaWNzKSB7XG4gICAgdGhpcy5tZXRob2QgPSBtZXRob2Q7XG4gICAgdGhpcy5kYXRhVHlwZSA9IE1ldHJpY1RvRGF0YVR5cGVbbWV0aG9kXSBhcyBBdmFpbGFibGVEYXRhVHlwZXM7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBjdXN0b20gc3RyaW5nIGRpc3RhbmNlIGZ1bmN0aW9uIHNwZWNpZmllZC5cbiAgICogQHJldHVybiB7RGlzdGFuY2VNZXRyaWN9IENhbGxiYWNrIG9mIHRoZSBtZWFzdXJlIGNob3Nlbi5cbiAgICogQG1lbWJlcm9mIE1lYXN1cmVyXG4gICAqL1xuICBwdWJsaWMgZ2V0TWVhc3VyZSgpOiBEaXN0YW5jZU1ldHJpYyB7XG4gICAgY29uc3QgZGljdDoge1trZXk6IHN0cmluZ106IHtba2V5Mjogc3RyaW5nXTogRGlzdGFuY2VNZXRyaWN9fSA9IEF2YWlsYWJsZU1ldHJpY3M7XG4gICAgcmV0dXJuIGRpY3RbdGhpcy5kYXRhVHlwZV1bdGhpcy5tZXRob2RdO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgY3VzdG9tIHN0cmluZyBkaXN0YW5jZSBieSB0aGUgZ2l2ZW4gZGF0YSB0eXBlLlxuICAgKiBAcGFyYW0ge0F2YWlsYWJsZURhdGFUeXBlc30gZGF0YVR5cGUgTWV0cmljJ3MgZGF0YSB0eXBlXG4gICAqIEByZXR1cm4ge3N0cmluZ1tdfSBNZXRyaWMgbmFtZXMgd2hpY2ggZXhwZWN0cyB0aGUgZ2l2ZW4gZGF0YSB0eXBlXG4gICAqIEBtZW1iZXJvZiBNZWFzdXJlclxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBnZXRNZXRyaWNCeURhdGFUeXBlKGRhdGFUeXBlOiBBdmFpbGFibGVEYXRhVHlwZXMpOiBzdHJpbmdbXSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKEF2YWlsYWJsZU1ldHJpY3NbZGF0YVR5cGVdKTtcbiAgfVxuXG4gIC8qKiBSZXR1cm5zIG1ldHJpYyBuYW1lcyBhdmFpbGFibGUuXG4gICAqIEBtZW1iZXJvZiBNZWFzdXJlclxuICAqL1xuICBzdGF0aWMgZ2V0IGF2YWlsYWJsZU1lYXN1cmVzKCk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXMoQXZhaWxhYmxlTWV0cmljcyk7XG4gIH1cbn1cbiJdfQ==","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\nlet zoom = false;\n// Searches for activity cliffs in a chemical dataset by selected cutoff\nexport function getActivityCliffs(df, seqCol, axesNames, scatterTitle, activities, similarity, similarityMetric, methodName, semType, units, seqSpaceFunc, simFunc, tooltipDrawFunc, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const automaticSimilarityLimit = false;\n        const MIN_SIMILARITY = 80;\n        const initialSimilarityLimit = automaticSimilarityLimit ? MIN_SIMILARITY : similarity / 100;\n        const { distance, coordinates } = yield seqSpaceFunc({\n            seqCol: seqCol,\n            methodName: methodName,\n            similarityMetric: similarityMetric,\n            embedAxesNames: axesNames,\n            options: options\n        });\n        for (const col of coordinates)\n            df.columns.add(col);\n        const dfSeq = DG.DataFrame.fromColumns([DG.Column.fromList('string', 'seq', seqCol.toList())]);\n        const dim = seqCol.length;\n        const simArr = Array(dim - 1);\n        if (!distance)\n            yield getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc);\n        else\n            getSimilaritiesMarixFromDistances(dim, distance, simArr);\n        const optSimilarityLimit = initialSimilarityLimit;\n        const simVals = [];\n        const saliVals = [];\n        const n1 = [];\n        const n2 = [];\n        for (let i = 0; i != dim - 1; ++i) {\n            for (let j = 0; j != dim - 1 - i; ++j) {\n                const sim = simArr[i].get(j);\n                if (sim >= optSimilarityLimit) {\n                    n1.push(i);\n                    n2.push(i + j + 1);\n                    simVals.push(sim);\n                    const diff = Math.abs(activities.get(i) - activities.get(i + j + 1));\n                    if (sim != 1)\n                        saliVals.push(diff / (1 - sim));\n                    else\n                        saliVals.push(Infinity);\n                }\n            }\n        }\n        const saliValsWithoutInfinity = saliVals.filter(it => it !== Infinity);\n        const saliMin = Math.min(...saliValsWithoutInfinity);\n        const saliMax = Math.max(...saliValsWithoutInfinity);\n        const saliOpacityCoef = 0.8 / (saliMax - saliMin);\n        const neighboursCount = new Array(dim).fill(0);\n        const similarityCount = new Array(dim).fill(0);\n        const saliCount = new Array(dim).fill(0);\n        for (let i = 0; i != n1.length; ++i) {\n            neighboursCount[n1[i]] += 1;\n            neighboursCount[n2[i]] += 1;\n            similarityCount[n1[i]] += simVals[i];\n            similarityCount[n2[i]] += simVals[i];\n            if (saliVals[i] != Infinity) {\n                if (activities.get(n1[i]) > activities.get(n2[i]))\n                    saliCount[n1[i]] += saliVals[i];\n                else\n                    saliCount[n2[i]] += saliVals[i];\n            }\n        }\n        const sali = DG.Column.fromList('double', `sali_${axesNames[0].substring(axesNames[0].lastIndexOf('_'))}`, saliCount);\n        df.columns.add(sali);\n        const view = grok.shell.getTableView(df.name);\n        const sp = view.addViewer(DG.Viewer.scatterPlot(df, {\n            xColumnName: axesNames[0],\n            yColumnName: axesNames[1],\n            size: sali.name,\n            color: activities.name,\n            showXSelector: false,\n            showYSelector: false,\n            showSizeSelector: false,\n            showColorSelector: false,\n            markerMinSize: 5,\n            markerMaxSize: 25,\n            title: scatterTitle\n        }));\n        const canvas = sp.getInfo()['canvas'];\n        const linesRes = createLines(n1, n2, seqCol, activities, saliVals, semType, units);\n        const tooltips = {};\n        linesRes.linesDf.onCurrentCellChanged.subscribe(() => {\n            const currentMolIdx = linesRes.linesDf.currentCol && linesRes.linesDf.currentCol.name === '2_seq' ? 1 : 0;\n            sp.dataFrame.currentRowIdx =\n                linesRes.linesDf.currentRowIdx !== -1 ? linesRes.lines[linesRes.linesDf.currentRowIdx].mols[currentMolIdx] : -1;\n            sp.dataFrame.selection.set(0, !linesRes.lines[0].selected);\n            sp.dataFrame.selection.set(0, linesRes.lines[0].selected);\n            linesDfGrid.invalidate();\n        });\n        linesRes.linesDf.onSelectionChanged.subscribe((_) => {\n            if (linesRes.linesDf.mouseOverRowIdx !== -1) {\n                const line = linesRes.lines[linesRes.linesDf.mouseOverRowIdx];\n                line.selected = !line.selected;\n                if (!line.selected)\n                    df.selection.setAll(false);\n            }\n            linesRes.lines.forEach((l) => {\n                if (l.selected)\n                    l.mols.forEach((m) => df.selection.set(m, true));\n            });\n            linesDfGrid.invalidate();\n        });\n        const linesDfGrid = linesRes.linesDf.plot.grid().sort(['act_diff'], [false]);\n        linesDfGrid.onCellClick.subscribe(() => {\n            zoom = true;\n        });\n        const listCliffsLink = ui.button(`${linesRes.linesDf.rowCount} cliffs`, () => {\n            const cliffsDialog = ui.dialog({ title: 'Activity cliffs' })\n                .add(linesDfGrid.root)\n                .show();\n            cliffsDialog.root.id = 'cliffs_dialog';\n        });\n        listCliffsLink.style.position = 'absolute';\n        listCliffsLink.style.top = '10px';\n        listCliffsLink.style.right = '10px';\n        sp.root.append(listCliffsLink);\n        let timer;\n        canvas.addEventListener('mousemove', function (event) {\n            clearTimeout(timer);\n            timer = global.setTimeout(function () {\n                const line = checkCursorOnLine(event, canvas, linesRes.lines);\n                if (line && df.mouseOverRowIdx === -1) {\n                    if (!tooltips[line.id]) {\n                        const drawTooltipParams = {\n                            tooltips: tooltips,\n                            line: line,\n                            df: df,\n                            seqCol: seqCol,\n                            activity: activities,\n                            x: event.clientX,\n                            y: event.clientY\n                        };\n                        tooltipDrawFunc(drawTooltipParams);\n                    }\n                    ui.tooltip.show(tooltips[line.id], event.clientX, event.clientY);\n                }\n            }, 1000);\n        });\n        canvas.addEventListener('mousedown', function (event) {\n            const line = checkCursorOnLine(event, canvas, linesRes.lines);\n            if (line && df.mouseOverRowIdx === -1) {\n                if (event.ctrlKey) {\n                    line.selected = !line.selected;\n                    linesRes.linesDf.selection.set(line.id, line.selected);\n                    if (!line.selected)\n                        df.selection.setAll(false);\n                    linesRes.lines.forEach((l) => {\n                        if (l.selected)\n                            l.mols.forEach((m) => df.selection.set(m, true));\n                    });\n                }\n                else {\n                    if (linesRes.linesDf.currentRowIdx !== line.id) {\n                        linesRes.linesDf.currentRowIdx = line.id;\n                        df.currentRowIdx = line.mols[0];\n                        df.selection.set(0, !linesRes.lines[0].selected);\n                        df.selection.set(0, linesRes.lines[0].selected);\n                    }\n                }\n            }\n        });\n        sp.onEvent('d4-before-draw-scene')\n            .subscribe((_) => {\n            const lines = renderLines(sp, axesNames[0], axesNames[1], linesRes, saliVals, saliOpacityCoef, saliMin);\n            if (zoom) {\n                const currentLine = lines[linesRes.linesDf.currentRowIdx];\n                setTimeout(() => {\n                    const x1 = sp.dataFrame.get(axesNames[0], currentLine.mols[0]);\n                    const y1 = sp.dataFrame.get(axesNames[1], currentLine.mols[0]);\n                    const x2 = sp.dataFrame.get(axesNames[0], currentLine.mols[1]);\n                    const y2 = sp.dataFrame.get(axesNames[1], currentLine.mols[1]);\n                    const xDiff = Math.abs(x1 - x2) * 5;\n                    const yDiff = Math.abs(y1 - y2) * 5;\n                    sp.zoom(x1 < x2 ? x1 - xDiff : x2 - xDiff, y1 > y2 ? y1 + yDiff : y2 + yDiff, x1 > x2 ? x1 + xDiff : x2 + xDiff, y1 < y2 ? y1 - yDiff : y2 - yDiff);\n                }, 300);\n                zoom = false;\n            }\n        });\n        sp.addProperty('similarityLimit', 'double', optSimilarityLimit);\n        return sp;\n    });\n}\nfunction checkCursorOnLine(event, canvas, lines) {\n    const rect = canvas.getBoundingClientRect();\n    const x = event.clientX - rect.left;\n    const y = event.clientY - rect.top;\n    for (const line of lines) {\n        const dist = Math.abs(Math.hypot(line.a[0] - x, line.a[1] - y) +\n            Math.hypot(line.b[0] - x, line.b[1] - y) - Math.hypot(line.a[0] - line.b[0], line.a[1] - line.b[1]));\n        if (dist < 2)\n            return line;\n    }\n    return null;\n}\nfunction renderLines(sp, xAxis, yAxis, linesRes, saliVals, saliOpacityCoef, saliMin) {\n    const lines = linesRes.lines;\n    const canvas = sp.getInfo()['canvas'];\n    const ctx = canvas.getContext('2d');\n    const x = sp.dataFrame.columns.byName(xAxis);\n    const y = sp.dataFrame.columns.byName(yAxis);\n    for (let i = 0; i < lines.length; i++) {\n        const pointFrom = sp.worldToScreen(x.get(lines[i].mols[0]), y.get(lines[i].mols[0]));\n        const pointTo = sp.worldToScreen(x.get(lines[i].mols[1]), y.get(lines[i].mols[1]));\n        lines[i].a = [pointFrom.x, pointFrom.y];\n        lines[i].b = [pointTo.x, pointTo.y];\n        const line = new Path2D();\n        line.moveTo(lines[i].a[0], lines[i].a[1]);\n        const color = lines[i].selected ? '255,255,0' : '0,128,0';\n        const opacity = saliVals[i] === Infinity ? 1 : 0.2 + (saliVals[i] - saliMin) * saliOpacityCoef;\n        ctx.strokeStyle = `rgba(${color},${opacity})`;\n        ctx.lineWidth = lines[i].id === linesRes.linesDf.currentRowIdx ? 3 : 1;\n        line.lineTo(lines[i].b[0], lines[i].b[1]);\n        ctx.stroke(line);\n    }\n    return lines;\n}\nfunction createLines(n1, n2, seq, activities, saliVals, semType, units) {\n    const lines = [];\n    for (let i = 0; i < n1.length; i++) {\n        const num1 = n1[i];\n        const num2 = n2[i];\n        lines.push({ id: i, mols: [num1, num2], selected: false, a: [], b: [] });\n    }\n    const linesDf = DG.DataFrame.create(lines.length);\n    linesDf.columns.addNewString('1_seq').init((i) => seq.get(lines[i].mols[0]));\n    linesDf.columns.addNewString('2_seq').init((i) => seq.get(lines[i].mols[1]));\n    linesDf.columns.addNewFloat('act_diff')\n        .init((i) => Math.abs(activities.get(lines[i].mols[0]) - activities.get(lines[i].mols[1])));\n    linesDf.columns.addNewInt('line_index').init((i) => i);\n    linesDf.columns.addNewFloat('sali').init((i) => saliVals[i]);\n    linesDf.col('1_seq').tags[DG.TAGS.UNITS] = units;\n    linesDf.col('2_seq').tags[DG.TAGS.UNITS] = units;\n    linesDf.col('1_seq').semType = semType;\n    linesDf.col('2_seq').semType = semType;\n    return { lines, linesDf };\n}\nexport function getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc) {\n    return __awaiter(this, void 0, void 0, function* () {\n        for (let i = 0; i != dim - 1; ++i) {\n            const mol = seqCol.get(i);\n            dfSeq.rows.removeAt(0, 1, false);\n            simArr[i] = (yield simFunc(dfSeq.col('seq'), mol));\n        }\n        return simArr;\n    });\n}\nexport function getSimilaritiesMarixFromDistances(dim, distances, simArr) {\n    for (let i = 0; i < dim - 1; ++i) {\n        const similarityArr = [];\n        for (let j = i + 1; j < dim; ++j)\n            similarityArr.push(getSimilarityFromDistance(distances[i][j]));\n        simArr[i] = DG.Column.fromFloat32Array('similarity', Float32Array.from(similarityArr));\n    }\n    return simArr;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-cliffs.js","sourceRoot":"","sources":["activity-cliffs.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { Matrix } from '@datagrok-libraries/utils/src/type-declarations';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\n\nexport interface ILine {\n  id: number;\n  mols: number[];\n  selected: boolean;\n  a: number[]; // [x, y]\n  b: number[]; // [x, y]\n}\n\ninterface IRenderedLines {\n  lines: ILine[];\n  linesDf: DG.DataFrame;\n}\n\nexport interface ISequenceSpaceParams {\n    seqCol: DG.Column,\n    methodName: string,\n    similarityMetric: string,\n    embedAxesNames: string[],\n    options?: any\n}\n\nexport interface ISequenceSpaceResult {\n    distance: Matrix;\n    coordinates: DG.ColumnList;\n  }\n\nexport interface IDrawTooltipParams {\n  tooltips: any,\n  line: ILine,\n  df: DG.DataFrame,\n  seqCol: DG.Column,\n  activity: DG.Column,\n  x: number,\n  y: number\n}\n\nlet zoom = false;\n\n// Searches for activity cliffs in a chemical dataset by selected cutoff\nexport async function getActivityCliffs(\n    df: DG.DataFrame, \n    seqCol: DG.Column, \n    axesNames: string[],\n    scatterTitle: string,\n    activities: DG.Column, \n    similarity: number,\n    similarityMetric: string, \n    methodName: string, \n    semType: string,\n    units: string,\n    seqSpaceFunc: (params: ISequenceSpaceParams) => Promise<ISequenceSpaceResult>,\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>,\n    tooltipDrawFunc: (params: IDrawTooltipParams) => void,\n    options?: any) : Promise<DG.Viewer> {\n  const automaticSimilarityLimit = false;\n  const MIN_SIMILARITY = 80;\n\n  const initialSimilarityLimit = automaticSimilarityLimit ? MIN_SIMILARITY : similarity / 100;\n\n  const {distance, coordinates} = await seqSpaceFunc({\n    seqCol: seqCol,\n    methodName: methodName,\n    similarityMetric: similarityMetric,\n    embedAxesNames: axesNames,\n    options: options\n  });\n\n  for (const col of coordinates)\n    df.columns.add(col);\n\n  const dfSeq = DG.DataFrame.fromColumns([DG.Column.fromList('string', 'seq', seqCol.toList())]);\n  const dim = seqCol.length;\n  const simArr: DG.Column[] = Array(dim - 1);\n\n  if (!distance)\n    await getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc);\n  else\n    getSimilaritiesMarixFromDistances(dim, distance, simArr);\n\n  const optSimilarityLimit = initialSimilarityLimit;\n\n  const simVals: number[] = [];\n  const saliVals: number[] = [];\n  const n1: number[] = [];\n  const n2: number[] = [];\n\n  for (let i = 0; i != dim - 1; ++i) {\n    for (let j = 0; j != dim - 1 - i; ++j) {\n      const sim: number = simArr[i].get(j);\n\n      if (sim >= optSimilarityLimit) {\n        n1.push(i);\n        n2.push(i + j + 1);\n        simVals.push(sim);\n        const diff = Math.abs(activities.get(i) - activities.get(i + j + 1));\n        if (sim != 1)\n          saliVals.push(diff / (1 - sim));\n        else\n          saliVals.push(Infinity);\n      }\n    }\n  }\n\n  const saliValsWithoutInfinity = saliVals.filter(it => it !== Infinity);\n  const saliMin = Math.min(...saliValsWithoutInfinity);\n  const saliMax = Math.max(...saliValsWithoutInfinity);\n  const saliOpacityCoef = 0.8/(saliMax - saliMin);\n\n\n  const neighboursCount = new Array(dim).fill(0);\n  const similarityCount = new Array(dim).fill(0);\n  const saliCount = new Array(dim).fill(0);\n\n  for (let i = 0; i != n1.length; ++i) {\n    neighboursCount[n1[i]] += 1;\n    neighboursCount[n2[i]] += 1;\n    similarityCount[n1[i]] += simVals[i];\n    similarityCount[n2[i]] += simVals[i];\n    if (saliVals[i] != Infinity) {\n      if (activities.get(n1[i]) > activities.get(n2[i]))\n        saliCount[n1[i]] += saliVals[i];\n      else\n        saliCount[n2[i]] += saliVals[i];\n    }\n  }\n\n  const sali: DG.Column = DG.Column.fromList('double', `sali_${axesNames[0].substring(axesNames[0].lastIndexOf('_'))}`, saliCount);\n\n  df.columns.add(sali);\n\n  const view = grok.shell.getTableView(df.name);\n  const sp = view.addViewer(DG.Viewer.scatterPlot(df, {\n    xColumnName: axesNames[0],\n    yColumnName: axesNames[1],\n    size: sali.name,\n    color: activities.name,\n    showXSelector: false,\n    showYSelector: false,\n    showSizeSelector: false,\n    showColorSelector: false,\n    markerMinSize: 5,\n    markerMaxSize: 25,\n    title: scatterTitle\n  })) as DG.ScatterPlotViewer;\n\n  const canvas = (sp.getInfo() as any)['canvas'];\n  const linesRes = createLines(n1, n2, seqCol, activities, saliVals, semType, units);\n  const tooltips: any = {};\n\n  linesRes.linesDf.onCurrentCellChanged.subscribe(() => {\n    const currentMolIdx = linesRes.linesDf.currentCol && linesRes.linesDf.currentCol.name === '2_seq' ? 1 : 0;\n    sp.dataFrame.currentRowIdx =\n      linesRes.linesDf.currentRowIdx !== -1 ? linesRes.lines[linesRes.linesDf.currentRowIdx].mols[currentMolIdx] : -1;\n    sp.dataFrame.selection.set(0, !linesRes.lines[0].selected);\n    sp.dataFrame.selection.set(0, linesRes.lines[0].selected);\n    linesDfGrid.invalidate();\n  });\n\n  linesRes.linesDf.onSelectionChanged.subscribe((_) => {\n    if (linesRes.linesDf.mouseOverRowIdx !== -1) {\n      const line = linesRes.lines[linesRes.linesDf.mouseOverRowIdx];\n      line.selected = !line.selected;\n      if (!line.selected)\n        df.selection.setAll(false);\n    }\n    linesRes.lines.forEach((l) => {\n      if (l.selected)\n        l.mols.forEach((m) => df.selection.set(m, true));\n    });\n    linesDfGrid.invalidate();\n  });\n\n  const linesDfGrid = linesRes.linesDf.plot.grid().sort(['act_diff'], [false]);\n\n  linesDfGrid.onCellClick.subscribe(() => {\n    zoom = true;\n  });\n\n  const listCliffsLink = ui.button(`${linesRes.linesDf.rowCount} cliffs`, () => {\n    const cliffsDialog = ui.dialog({title: 'Activity cliffs'})\n      .add(linesDfGrid.root)\n      .show();\n    cliffsDialog.root.id = 'cliffs_dialog';\n  });\n  listCliffsLink.style.position = 'absolute';\n  listCliffsLink.style.top = '10px';\n  listCliffsLink.style.right = '10px';\n  sp.root.append(listCliffsLink);\n\n  let timer: NodeJS.Timeout;\n  canvas.addEventListener('mousemove', function (event: MouseEvent) {\n    clearTimeout(timer);\n    timer = global.setTimeout(function () {\n      const line = checkCursorOnLine(event, canvas, linesRes.lines);\n      if (line && df.mouseOverRowIdx === -1) {\n        if (!tooltips[line.id]) {\n          const drawTooltipParams = {\n            tooltips: tooltips,\n            line: line,\n            df: df,\n            seqCol: seqCol,\n            activity: activities,\n            x: event.clientX,\n            y: event.clientY\n          }\n          tooltipDrawFunc(drawTooltipParams);\n        }\n        ui.tooltip.show(tooltips[line.id], event.clientX, event.clientY);\n      }\n    }, 1000);\n  });\n\n  canvas.addEventListener('mousedown', function(event: MouseEvent) {\n    const line = checkCursorOnLine(event, canvas, linesRes.lines);\n    if (line && df.mouseOverRowIdx === -1) {\n      if (event.ctrlKey) {\n        line.selected = !line.selected;\n        linesRes.linesDf.selection.set(line.id, line.selected);\n\n        if (!line.selected)\n          df.selection.setAll(false);\n\n        linesRes.lines.forEach((l) => {\n          if (l.selected)\n            l.mols.forEach((m) => df.selection.set(m, true));\n        });\n      } else {\n        if (linesRes.linesDf.currentRowIdx !== line.id) {\n          linesRes.linesDf.currentRowIdx = line.id;\n          df.currentRowIdx = line.mols[0];\n          df.selection.set(0, !linesRes.lines[0].selected);\n          df.selection.set(0, linesRes.lines[0].selected);\n        }\n      }\n    }\n  });\n\n  sp.onEvent('d4-before-draw-scene')\n    .subscribe((_) => {\n      const lines = renderLines(sp,\n        axesNames[0], axesNames[1], linesRes, saliVals, saliOpacityCoef, saliMin);\n      if (zoom) {\n        const currentLine = lines[linesRes.linesDf.currentRowIdx];\n        setTimeout(()=> {\n          const x1 = sp.dataFrame.get(axesNames[0], currentLine.mols[0]);\n          const y1 = sp.dataFrame.get(axesNames[1], currentLine.mols[0]);\n          const x2 = sp.dataFrame.get(axesNames[0], currentLine.mols[1]);\n          const y2 = sp.dataFrame.get(axesNames[1], currentLine.mols[1]);\n          const xDiff = Math.abs(x1 - x2)*5;\n          const yDiff = Math.abs(y1 - y2)*5;\n          sp.zoom(x1 < x2 ? x1 - xDiff : x2 - xDiff,\n            y1 > y2 ? y1 + yDiff : y2  + yDiff,\n            x1 > x2 ? x1 + xDiff : x2 + xDiff,\n            y1 < y2 ? y1 - yDiff : y2 - yDiff);\n        }, 300);\n        zoom = false;\n      }\n    });\n\n  sp.addProperty('similarityLimit', 'double', optSimilarityLimit);\n  return sp;\n}\n\nfunction checkCursorOnLine(event: any, canvas: any, lines: ILine[]): ILine | null {\n  const rect = canvas.getBoundingClientRect();\n  const x = event.clientX - rect.left;\n  const y = event.clientY - rect.top;\n  for (const line of lines) {\n    const dist =\n      Math.abs(Math.hypot(line.a[0] - x, line.a[1] - y) +\n      Math.hypot(line.b[0] - x, line.b[1] - y) - Math.hypot(line.a[0] - line.b[0], line.a[1] - line.b[1]));\n    if (dist < 2)\n      return line;\n  }\n  return null;\n}\n\nfunction renderLines(sp: DG.ScatterPlotViewer,\n  xAxis: string, yAxis: string, linesRes: IRenderedLines, saliVals: number[], saliOpacityCoef: number, saliMin: number): ILine [] {\n  const lines = linesRes.lines;\n  const canvas = (sp.getInfo() as {[index: string] : any})['canvas'];\n  const ctx = canvas.getContext('2d') as CanvasRenderingContext2D;\n  const x = sp.dataFrame!.columns.byName(xAxis);\n  const y = sp.dataFrame!.columns.byName(yAxis);\n  for (let i = 0; i < lines.length; i++) {\n    const pointFrom = sp.worldToScreen(x.get(lines[i].mols[0]), y.get(lines[i].mols[0]));\n    const pointTo = sp.worldToScreen(x.get(lines[i].mols[1]), y.get(lines[i].mols[1]));\n    lines[i].a = [pointFrom.x, pointFrom.y];\n    lines[i].b = [pointTo.x, pointTo.y];\n    const line = new Path2D();\n    line.moveTo(lines[i].a[0], lines[i].a[1]);\n    const color = lines[i].selected ? '255,255,0' : '0,128,0';\n    const opacity = saliVals[i] === Infinity ? 1 : 0.2 + (saliVals[i] - saliMin)*saliOpacityCoef;\n    ctx.strokeStyle = `rgba(${color},${opacity})`;\n    ctx.lineWidth = lines[i].id === linesRes.linesDf.currentRowIdx ? 3 : 1;\n    line.lineTo(lines[i].b[0], lines[i].b[1]);\n    ctx.stroke(line);\n  }\n  return lines;\n}\n\nfunction createLines(\n  n1: number[], \n  n2: number[], \n  seq: DG.Column, \n  activities: DG.Column, \n  saliVals: number[],\n  semType: string,\n  units: string) : IRenderedLines {\n  const lines: ILine[] = [];\n  for (let i = 0; i < n1.length; i++) {\n    const num1 = n1[i];\n    const num2 = n2[i];\n    lines.push({id: i, mols: [num1, num2], selected: false, a: [], b: []});\n  }\n  const linesDf = DG.DataFrame.create(lines.length);\n  linesDf.columns.addNewString('1_seq').init((i: number) => seq.get(lines[i].mols[0]));\n  linesDf.columns.addNewString('2_seq').init((i: number) => seq.get(lines[i].mols[1]));\n  linesDf.columns.addNewFloat('act_diff')\n    .init((i: number) => Math.abs(activities.get(lines[i].mols[0]) - activities.get(lines[i].mols[1])));\n  linesDf.columns.addNewInt('line_index').init((i: number) => i);\n  linesDf.columns.addNewFloat('sali').init((i: number) => saliVals[i]);\n  linesDf.col('1_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('2_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('1_seq')!.semType = semType;\n  linesDf.col('2_seq')!.semType = semType;\n  return {lines, linesDf};\n}\n\nexport async function getSimilaritiesMarix(\n    dim: number, \n    seqCol: DG.Column, \n    dfSeq: DG.DataFrame, \n    simArr: DG.Column[],\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>\n    )\n  : Promise<DG.Column[]> {\n  for (let i = 0; i != dim - 1; ++i) {\n    const mol = seqCol.get(i);\n    dfSeq.rows.removeAt(0, 1, false);\n    simArr[i] = (await simFunc(dfSeq.col('seq')!, mol))!;\n  }\n  return simArr;\n}\n\nexport function getSimilaritiesMarixFromDistances(dim: number, distances: Matrix, simArr: DG.Column[])\n  : DG.Column[] {\n  for (let i = 0; i < dim - 1; ++i) {\n    const similarityArr = [];\n    for (let j = i + 1; j < dim; ++j)\n      similarityArr.push(getSimilarityFromDistance(distances[i][j]));\n    simArr[i] = DG.Column.fromFloat32Array('similarity', Float32Array.from(similarityArr));\n  }\n  return simArr;\n}"]}","export function createDimensinalityReducingWorker(dataMetric, method, options) {\n    return new Promise(function (resolve) {\n        const worker = new Worker(new URL('./dimensionality-reducer', import.meta.url));\n        worker.postMessage({\n            columnData: dataMetric.data,\n            method: method,\n            measure: dataMetric.metric,\n            options: options,\n        });\n        worker.onmessage = ({ data: { distance, embedding } }) => {\n            resolve({ distance: distance, embedding: embedding });\n        };\n    });\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltZW5zaW9uYWxpdHktcmVkdWNpbmctd29ya2VyLWNyZWF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJkaW1lbnNpb25hbGl0eS1yZWR1Y2luZy13b3JrZXItY3JlYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQkEsTUFBTSxVQUFVLGlDQUFpQyxDQUFDLFVBQXNCLEVBQUUsTUFBYyxFQUNsRixPQUFhO0lBRWpCLE9BQU8sSUFBSSxPQUFPLENBQUMsVUFBUyxPQUFPO1FBQ2pDLE1BQU0sTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDLDBCQUEwQixFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNoRixNQUFNLENBQUMsV0FBVyxDQUFDO1lBQ2pCLFVBQVUsRUFBRSxVQUFVLENBQUMsSUFBSTtZQUMzQixNQUFNLEVBQUUsTUFBTTtZQUNkLE9BQU8sRUFBRSxVQUFVLENBQUMsTUFBTTtZQUMxQixPQUFPLEVBQUUsT0FBTztTQUNqQixDQUFDLENBQUM7UUFDSCxNQUFNLENBQUMsU0FBUyxHQUFHLENBQUMsRUFBQyxJQUFJLEVBQUUsRUFBQyxRQUFRLEVBQUUsU0FBUyxFQUFDLEVBQUMsRUFBRSxFQUFFO1lBQ3BELE9BQU8sQ0FBQyxFQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBQyxDQUFDLENBQUM7UUFDckQsQ0FBQyxDQUFDO0lBQ0osQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF0cml4IH0gZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvdHlwZS1kZWNsYXJhdGlvbnMnO1xuaW1wb3J0IHtWYWxpZFR5cGVzfSBmcm9tICcuLi90eXBlZC1tZXRyaWNzJztcblxuLyoqXG4gKiBBIHdvcmtlciB0byBwZXJmb3JtIGRpbWVuc2lvbmFsaXR5IHJlZHVjdGlvbi5cbiAqXG4gKiBAcGFyYW0ge1ZhbGlkVHlwZXN9IGRhdGFNZXRyaWMgVGhlIGRhdGEgdG8gcHJvY2Vzcy5cbiAqIEBwYXJhbSB7c3RyaW5nfSBtZXRob2QgQSBtZXRob2Qgb2YgZGltZW5zaW9uYWxpdHkgcmVkdWN0aW9uLlxuICogQHBhcmFtIG9wdGlvbnMgLSBrZXktdmFsdWUgcGFpcnNcbiAqIEBwYXJhbSByZXR1cm5EaXN0YW5jZU1hdHJpeFxuICogQHJldHVybiB7UHJvbWlzZTxJUmVkdWNlRGltZW5zaW9uYWxpdHlSZXN1bHQ+fSBSZXN1bHRpbmcgZW1iZWRkaW5nIGFuZCBkaXN0YW5jZSBtYXRyaXguXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSVJlZHVjZURpbWVuc2lvbmFsaXR5UmVzdWx0IHtcbiAgZGlzdGFuY2U6IE1hdHJpeDtcbiAgZW1iZWRkaW5nOiBNYXRyaXg7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVEaW1lbnNpbmFsaXR5UmVkdWNpbmdXb3JrZXIoZGF0YU1ldHJpYzogVmFsaWRUeXBlcywgbWV0aG9kOiBzdHJpbmcsXG4gICAgICBvcHRpb25zPzogYW55KTogUHJvbWlzZTxJUmVkdWNlRGltZW5zaW9uYWxpdHlSZXN1bHQ+IHtcblxuICByZXR1cm4gbmV3IFByb21pc2UoZnVuY3Rpb24ocmVzb2x2ZSkge1xuICAgIGNvbnN0IHdvcmtlciA9IG5ldyBXb3JrZXIobmV3IFVSTCgnLi9kaW1lbnNpb25hbGl0eS1yZWR1Y2VyJywgaW1wb3J0Lm1ldGEudXJsKSk7XG4gICAgd29ya2VyLnBvc3RNZXNzYWdlKHtcbiAgICAgIGNvbHVtbkRhdGE6IGRhdGFNZXRyaWMuZGF0YSxcbiAgICAgIG1ldGhvZDogbWV0aG9kLFxuICAgICAgbWVhc3VyZTogZGF0YU1ldHJpYy5tZXRyaWMsXG4gICAgICBvcHRpb25zOiBvcHRpb25zLFxuICAgIH0pO1xuICAgIHdvcmtlci5vbm1lc3NhZ2UgPSAoe2RhdGE6IHtkaXN0YW5jZSwgZW1iZWRkaW5nfX0pID0+IHtcbiAgICAgcmVzb2x2ZSh7ZGlzdGFuY2U6IGRpc3RhbmNlLCBlbWJlZGRpbmc6IGVtYmVkZGluZ30pO1xuICAgIH07XG4gIH0pO1xufVxuIl19","/**\n * Generates single random float from 0 to range.\n *\n * @export\n * @param {number} range Max generating value.\n * @return {number} A random float generated.\n */\nexport function randomFloat(range) {\n    return Math.random() * range;\n}\n/**\n * Generates single random integer from 0 to range.\n *\n * @export\n * @param {number} range Max generating value.\n * @return {number} A random integer generated.\n */\nexport function randomInt(range) {\n    return Math.floor(randomFloat(range));\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZG9tLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicmFuZG9tLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxXQUFXLENBQUMsS0FBYTtJQUN2QyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxLQUFLLENBQUM7QUFDL0IsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxTQUFTLENBQUMsS0FBYTtJQUNyQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDeEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVzIHNpbmdsZSByYW5kb20gZmxvYXQgZnJvbSAwIHRvIHJhbmdlLlxuICpcbiAqIEBleHBvcnRcbiAqIEBwYXJhbSB7bnVtYmVyfSByYW5nZSBNYXggZ2VuZXJhdGluZyB2YWx1ZS5cbiAqIEByZXR1cm4ge251bWJlcn0gQSByYW5kb20gZmxvYXQgZ2VuZXJhdGVkLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmFuZG9tRmxvYXQocmFuZ2U6IG51bWJlcik6IG51bWJlciB7XG4gIHJldHVybiBNYXRoLnJhbmRvbSgpICogcmFuZ2U7XG59XG5cbi8qKlxuICogR2VuZXJhdGVzIHNpbmdsZSByYW5kb20gaW50ZWdlciBmcm9tIDAgdG8gcmFuZ2UuXG4gKlxuICogQGV4cG9ydFxuICogQHBhcmFtIHtudW1iZXJ9IHJhbmdlIE1heCBnZW5lcmF0aW5nIHZhbHVlLlxuICogQHJldHVybiB7bnVtYmVyfSBBIHJhbmRvbSBpbnRlZ2VyIGdlbmVyYXRlZC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJhbmRvbUludChyYW5nZTogbnVtYmVyKTogbnVtYmVyIHtcbiAgcmV0dXJuIE1hdGguZmxvb3IocmFuZG9tRmxvYXQocmFuZ2UpKTtcbn1cbiJdfQ==","import { randomInt } from './random';\nexport const similarityMetric = {\n    'Tanimoto': tanimotoSimilarity,\n    'Dice': diceSimilarity,\n    'Asymmetric': asymmetricSimilarity,\n    'Braun-Blanquet': braunBlanquetSimilarity,\n    'Cosine': cosineSimilarity,\n    'Kulczynski': kulczynskiSimilarity,\n    'Mc-Connaughey': mcConnaugheySimilarity,\n    'Rogot-Goldberg': rogotGoldbergSimilarity,\n    'Russel': russelSimilarity,\n    'Sokal': sokalSimilarity,\n    'Hamming': hammingSimilarity,\n    'Euclidean': euclideanSimilarity,\n};\nexport const distanceMetrics = {\n    'Tanimoto': tanimotoDistance,\n    'Dice': diceDistance,\n    'Asymmetric': asymmetricDistance,\n    'Braun-Blanquet': braunBlanquetDistance,\n    'Cosine': cosineDistance,\n    'Kulczynski': kulczynskiDistance,\n    'Mc-Connaughey': mcConnaugheyDistance,\n    'Rogot-Goldberg': rogotGoldbergDistance,\n    'Russel': russelDistance,\n    'Sokal': sokalDistance,\n    'Hamming': hammingDistance,\n    'Euclidean': euclideanDistance,\n};\nexport const CHEM_SIMILARITY_METRICS = ['Tanimoto', 'Dice', 'Cosine', 'Hamming', 'Euclidean'];\nexport function tanimotoSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    if (total == 0)\n        return 1.0;\n    const common = x.andWithCountBits(y, true);\n    return common / (total - common);\n}\nexport function tanimotoDistance(x, y) {\n    return getDistanceFromSimilarity(tanimotoSimilarity(x, y));\n}\nexport function diceSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    if (total == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return 2 * common / total;\n}\nexport function diceDistance(x, y) {\n    return getDistanceFromSimilarity(diceSimilarity(x, y));\n}\nexport function cosineSimilarity(x, y) {\n    const total = x.trueCount() * y.trueCount();\n    if (total == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / Math.sqrt(total);\n}\nexport function cosineDistance(x, y) {\n    return getDistanceFromSimilarity(cosineSimilarity(x, y));\n}\nexport function euclideanSimilarity(x, y) {\n    return getSimilarityFromDistance(euclideanDistance(x, y));\n}\nexport function euclideanDistance(x, y) {\n    return Math.sqrt(x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true));\n}\nexport function hammingSimilarity(x, y) {\n    return getSimilarityFromDistance(hammingDistance(x, y));\n}\nexport function hammingDistance(x, y) {\n    return x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true);\n}\nexport function sokalSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    const common = x.andWithCountBits(y, true);\n    return common / (2 * total - 3 * common);\n}\nexport function sokalDistance(x, y) {\n    return getDistanceFromSimilarity(sokalSimilarity(x, y));\n}\nexport function kulczynskiSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    const totalProd = x.trueCount() * y.trueCount();\n    if (totalProd == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return (common * total) / (2 * totalProd);\n}\nexport function kulczynskiDistance(x, y) {\n    return getDistanceFromSimilarity(kulczynskiSimilarity(x, y));\n}\nexport function mcConnaugheySimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    const totalProd = x.trueCount() * y.trueCount();\n    if (totalProd == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return (common * total - totalProd) / totalProd;\n}\nexport function mcConnaugheyDistance(x, y) {\n    return getDistanceFromSimilarity(mcConnaugheySimilarity(x, y));\n}\nexport function asymmetricSimilarity(x, y) {\n    const min = Math.min(x.trueCount(), y.trueCount());\n    if (min == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / min;\n}\nexport function asymmetricDistance(x, y) {\n    return getDistanceFromSimilarity(asymmetricSimilarity(x, y));\n}\nexport function braunBlanquetSimilarity(x, y) {\n    const max = Math.max(x.trueCount(), y.trueCount());\n    if (max == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / max;\n}\nexport function braunBlanquetDistance(x, y) {\n    return getDistanceFromSimilarity(braunBlanquetSimilarity(x, y));\n}\nexport function russelSimilarity(x, y) {\n    if (x.length == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / x.length;\n}\nexport function russelDistance(x, y) {\n    return getDistanceFromSimilarity(russelSimilarity(x, y));\n}\nexport function rogotGoldbergSimilarity(x, y) {\n    const common = x.andWithCountBits(y, true);\n    const total = x.countBits(true) + y.countBits(true);\n    const len = x.length;\n    const diff = len - total + common;\n    if ((common == len) || (diff == len))\n        return 1.0;\n    else\n        return common / total + diff / (2 * len - total);\n}\nexport function rogotGoldbergDistance(x, y) {\n    return getDistanceFromSimilarity(rogotGoldbergSimilarity(x, y));\n}\nexport function getSimilarityFromDistance(distance) {\n    return 1 / (1 + distance);\n}\nexport function getDistanceFromSimilarity(similarity) {\n    return 1 / similarity - 1;\n}\nexport function getDiverseSubset(length, n, dist) {\n    function maxBy(values, orderBy) {\n        let maxValue = null;\n        let maxOrderBy = null;\n        for (const element of values) {\n            const elementOrderBy = orderBy(element);\n            if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n                maxValue = element;\n                maxOrderBy = elementOrderBy;\n            }\n        }\n        return maxValue;\n    }\n    const subset = [randomInt(length - 1)];\n    const complement = new Set();\n    for (let i = 0; i < length; ++i) {\n        if (!subset.includes(i))\n            complement.add(i);\n    }\n    while (subset.length < n) {\n        const idx = maxBy(complement.values(), (i) => Math.min.apply(Math, subset.map(function (val, index) {\n            return dist(i, val);\n        })));\n        if (idx) {\n            subset.push(idx);\n            complement.delete(idx);\n        }\n    }\n    return subset;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"similarity-metrics.js","sourceRoot":"","sources":["similarity-metrics.ts"],"names":[],"mappings":"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","sourcesContent":["import BitArray from './bit-array';\nimport {randomInt} from './random';\n\nexport const similarityMetric: {[name: string]: (x: BitArray, y: BitArray) => number} = {\n  'Tanimoto': tanimotoSimilarity,\n  'Dice': diceSimilarity,\n  'Asymmetric': asymmetricSimilarity,\n  'Braun-Blanquet': braunBlanquetSimilarity,\n  'Cosine': cosineSimilarity,\n  'Kulczynski': kulczynskiSimilarity,\n  'Mc-Connaughey': mcConnaugheySimilarity,\n  'Rogot-Goldberg': rogotGoldbergSimilarity,\n  'Russel': russelSimilarity,\n  'Sokal': sokalSimilarity,\n  'Hamming': hammingSimilarity,\n  'Euclidean': euclideanSimilarity,\n};\n\nexport const distanceMetrics: {[name: string]: (x: BitArray, y: BitArray) => number} = {\n  'Tanimoto': tanimotoDistance,\n  'Dice': diceDistance,\n  'Asymmetric': asymmetricDistance,\n  'Braun-Blanquet': braunBlanquetDistance,\n  'Cosine': cosineDistance,\n  'Kulczynski': kulczynskiDistance,\n  'Mc-Connaughey': mcConnaugheyDistance,\n  'Rogot-Goldberg': rogotGoldbergDistance,\n  'Russel': russelDistance,\n  'Sokal': sokalDistance,\n  'Hamming': hammingDistance,\n  'Euclidean': euclideanDistance,\n};\n\nexport const CHEM_SIMILARITY_METRICS = ['Tanimoto', 'Dice', 'Cosine', 'Hamming', 'Euclidean'];\n\nexport function tanimotoSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  if (total == 0)\n    return 1.0;\n  const common = x.andWithCountBits(y, true);\n  return common / (total - common);\n}\n\nexport function tanimotoDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(tanimotoSimilarity(x, y));\n}\n\nexport function diceSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  if (total == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return 2 * common / total;\n}\n\nexport function diceDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(diceSimilarity(x, y));\n}\n\nexport function cosineSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() * y.trueCount();\n  if (total == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / Math.sqrt(total);\n}\n\nexport function cosineDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(cosineSimilarity(x, y));\n}\n\nexport function euclideanSimilarity(x: BitArray, y: BitArray): number {\n  return getSimilarityFromDistance(euclideanDistance(x, y));\n}\n\nexport function euclideanDistance(x: BitArray, y: BitArray): number {\n  return Math.sqrt(x.trueCount() + y.trueCount() - 2*x.andWithCountBits(y, true));\n}\n\nexport function hammingSimilarity(x: BitArray, y: BitArray): number {\n  return getSimilarityFromDistance(hammingDistance(x, y));\n}\n\nexport function hammingDistance(x: BitArray, y: BitArray): number {\n  return x.trueCount() + y.trueCount() - 2*x.andWithCountBits(y, true);\n}\n\nexport function sokalSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const common = x.andWithCountBits(y, true);\n  return common / (2 * total - 3 * common);\n}\n\nexport function sokalDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(sokalSimilarity(x, y));\n}\n\nexport function kulczynskiSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const totalProd = x.trueCount() * y.trueCount();\n  if (totalProd == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return (common * total) / (2 * totalProd);\n}\n\nexport function kulczynskiDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(kulczynskiSimilarity(x, y));\n}\n\nexport function mcConnaugheySimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const totalProd = x.trueCount() * y.trueCount();\n  if (totalProd == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return (common * total - totalProd) / totalProd;\n}\n\nexport function mcConnaugheyDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(mcConnaugheySimilarity(x, y));\n}\n\nexport function asymmetricSimilarity(x: BitArray, y: BitArray): number {\n  const min = Math.min(x.trueCount(), y.trueCount());\n  if (min == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / min;\n}\n\nexport function asymmetricDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(asymmetricSimilarity(x, y));\n}\n\nexport function braunBlanquetSimilarity(x: BitArray, y: BitArray): number {\n  const max = Math.max(x.trueCount(), y.trueCount());\n  if (max == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / max;\n}\n\nexport function braunBlanquetDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(braunBlanquetSimilarity(x, y));\n}\n\nexport function russelSimilarity(x: BitArray, y: BitArray): number {\n  if (x.length == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / x.length;\n}\n\nexport function russelDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(russelSimilarity(x, y));\n}\n\nexport function rogotGoldbergSimilarity(x: BitArray, y: BitArray): number {\n  const common = x.andWithCountBits(y, true);\n  const total = x.countBits(true) + y.countBits(true);\n  const len = x.length;\n  const diff = len - total + common;\n  if ((common == len) || (diff == len)) return 1.0;\n  else return common / total + diff / (2 * len - total);\n}\n\nexport function rogotGoldbergDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(rogotGoldbergSimilarity(x, y));\n}\n\nexport function getSimilarityFromDistance(distance: number) {\n  return 1 / ( 1 + distance);\n}\n\nexport function getDistanceFromSimilarity(similarity: number) {\n  return 1 / similarity - 1;\n}\n\nexport function getDiverseSubset(length: number, n: number, dist: (i1: number, i2: number) => number) {\n  function maxBy(values: IterableIterator<number>, orderBy: (i: number) => number) {\n    let maxValue = null;\n    let maxOrderBy = null;\n\n    for (const element of values) {\n      const elementOrderBy = orderBy(element);\n      if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n        maxValue = element;\n        maxOrderBy = elementOrderBy;\n      }\n    }\n    return maxValue;\n  }\n\n  const subset = [randomInt(length - 1)];\n  const complement = new Set();\n\n  for (let i = 0; i < length; ++i) {\n    if (!subset.includes(i))\n      complement.add(i);\n  }\n\n  while (subset.length < n) {\n    const idx = maxBy(\n      complement.values() as IterableIterator<number>,\n      (i) => Math.min.apply(Math, subset.map(function(val, index) {\n        return dist(i, val);\n      })));\n    if (idx) {\n      subset.push(idx);\n      complement.delete(idx);\n    }\n  }\n  return subset;\n}\n"]}","/**\n * Denotes a vector of floating poit values.\n *\n * @export\n * @class Vector\n * @extends {Float32Array}\n */\nexport class Vector extends Float32Array {\n}\n/**\n * Denotes a two-dimensional matrix.\n *\n * @export\n * @class Matrix\n * @extends {Array<Vector>}\n */\nexport class Matrix extends Array {\n}\n/**\n * Denotes cartesian coordinates.\n *\n * @export\n * @class Coordinates\n * @extends {Matrix}\n */\nexport class Coordinates extends Matrix {\n}\n/**\n * Denotes an array of arbitrary-typed vectors.\n *\n * @export\n * @class Vectors\n * @extends {Array<any>}\n */\nexport class Vectors extends Array {\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS1kZWNsYXJhdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0eXBlLWRlY2xhcmF0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sTUFBTyxTQUFRLFlBQVk7Q0FBRztBQUUzQzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sTUFBTyxTQUFRLEtBQWE7Q0FBRztBQUU1Qzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sV0FBWSxTQUFRLE1BQU07Q0FBRztBQUUxQzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sT0FBUSxTQUFRLEtBQVU7Q0FBRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRGVub3RlcyBhIHZlY3RvciBvZiBmbG9hdGluZyBwb2l0IHZhbHVlcy5cbiAqXG4gKiBAZXhwb3J0XG4gKiBAY2xhc3MgVmVjdG9yXG4gKiBAZXh0ZW5kcyB7RmxvYXQzMkFycmF5fVxuICovXG5leHBvcnQgY2xhc3MgVmVjdG9yIGV4dGVuZHMgRmxvYXQzMkFycmF5IHt9XG5cbi8qKlxuICogRGVub3RlcyBhIHR3by1kaW1lbnNpb25hbCBtYXRyaXguXG4gKlxuICogQGV4cG9ydFxuICogQGNsYXNzIE1hdHJpeFxuICogQGV4dGVuZHMge0FycmF5PFZlY3Rvcj59XG4gKi9cbmV4cG9ydCBjbGFzcyBNYXRyaXggZXh0ZW5kcyBBcnJheTxWZWN0b3I+IHt9XG5cbi8qKlxuICogRGVub3RlcyBjYXJ0ZXNpYW4gY29vcmRpbmF0ZXMuXG4gKlxuICogQGV4cG9ydFxuICogQGNsYXNzIENvb3JkaW5hdGVzXG4gKiBAZXh0ZW5kcyB7TWF0cml4fVxuICovXG5leHBvcnQgY2xhc3MgQ29vcmRpbmF0ZXMgZXh0ZW5kcyBNYXRyaXgge31cblxuLyoqXG4gKiBEZW5vdGVzIGFuIGFycmF5IG9mIGFyYml0cmFyeS10eXBlZCB2ZWN0b3JzLlxuICpcbiAqIEBleHBvcnRcbiAqIEBjbGFzcyBWZWN0b3JzXG4gKiBAZXh0ZW5kcyB7QXJyYXk8YW55Pn1cbiAqL1xuZXhwb3J0IGNsYXNzIFZlY3RvcnMgZXh0ZW5kcyBBcnJheTxhbnk+IHt9XG5cbi8qKlxuICogRGVub3RlcyBhIGRpY3Rpb25hcnkgY29udGFpbmluZyBmdW5jdGlvbiBvcHRpb25zLlxuICpcbiAqIEBleHBvcnRcbiAqIEB0eXBlIE9wdGlvbnNcbiAqL1xuZXhwb3J0IHR5cGUgT3B0aW9ucyA9IHtbbmFtZTogc3RyaW5nXTogYW55fTtcblxuLyoqXG4gKiBEZW5vdGVzIGN1c3RvbSBkaXN0YW5jZSBtZXRyaWMgYmV0d2VlbiB0aGUgdHdvIGdpdmVuIHZlY3RvcnMuXG4gKlxuICogQGV4cG9ydFxuICogQHR5cGUgRGlzdGFuY2VNZXRyaWNcbiAqIEBwYXJhbSB7YW55fSB2MSBUaGUgZmlyc3QgdmVjdG9yLlxuICogQHBhcmFtIHthbnl9IHYyIFRoZSBzZWNvbmQgdmVjdG9yLlxuICogQHJldHVybiB7bnVtYmVyfSBEaXN0YW5jZSBiZXR3ZWVuIHRoZXNlIHR3byB2ZWN0b3JzLlxuICovXG5leHBvcnQgdHlwZSBEaXN0YW5jZU1ldHJpYyA9ICh2MTogYW55LCB2MjogYW55KSA9PiAobnVtYmVyKTtcblxuLyoqXG4gKiBEZW5vdGVzIGEgc2ltcGxlIHN0cmluZyB0byBzdHJpbmcgZGljdGlvbmFyeS5cbiAqXG4gKiBAZXhwb3J0XG4gKiBAdHlwZSBTdHJpbmdEaWN0aW9uYXJ5XG4gKi9cbmV4cG9ydCB0eXBlIFN0cmluZ0RpY3Rpb25hcnkgPSB7W2tleTogc3RyaW5nXTogc3RyaW5nfTtcbiJdfQ==","import { Vector } from './type-declarations';\nimport { randomFloat, randomInt } from './random';\n/**\n * Asserts a condition by throwing an Error.\n *\n * @export\n * @param {boolean} [condition=false] Condition to assert.\n * @param {string} [message='Assertion error.'] Message to output.\n * @throws {Error}\n */\nexport function assert(condition = false, message = 'Assertion error.') {\n    if (!condition)\n        throw new Error(message);\n}\n/**\n * Creates new two-dimensional array and fills it with the value given.\n *\n * @param {number} dimension1 The first dimension of the coordinates (number of rows).\n * @param {number} dimension2 The second dimension of the coordinates (number of columns).\n * @param {number} [fill=0] A value to fill the coordinates with.\n * @return {Coordinates} A two-dimensional filled with the value given.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nfunction initCoordinates(dimension1, dimension2, fill = 0) {\n    return new Array(dimension1).fill(fill).map(() => (new Vector(dimension2).fill(fill)));\n}\n/**\n * Transpose matrix.\n *\n * @export\n * @param {Matrix} matrix The matrix to be transposed.\n * @return {Matrix} Transposed matrix.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nexport function transposeMatrix(matrix) {\n    return new Array(matrix[0].length).fill(0)\n        .map((_, i) => (new Vector(matrix.length).fill(0).map((_, j) => (matrix[j][i]))));\n}\n/**\n * Adds two vectors with the second one to be multiplied by the given ratio.\n *\n * @export\n * @param {Vector} p The first vector to add.\n * @param {Vector} q The second vector to add.\n * @param {number} [multiplier=1] A multiplier to be used before the second vector is added.\n * @return {Vector} New vector contained the result of operation p+multiplier*q.\n */\nexport function vectorAdd(p, q, multiplier = 1) {\n    const nItems = p.length;\n    assert(nItems == q.length, 'Vector lengths do not match.');\n    const total = new Vector(nItems);\n    for (let i = 0; i < p.length; ++i)\n        total[i] = p[i] + multiplier * q[i];\n    return total;\n}\n/**\n * Sums the vector's items.\n *\n * @param {Vector} v The vector to be summed.\n * @return {number} The vector's items sum.\n */\nfunction itemsSum(v) {\n    let total = 0;\n    for (let i = 0; i < v.length; ++i)\n        total += v[i];\n    return total;\n}\n/**\n * Suqares the vector's items.\n *\n * @param {Vector} v The vector to square.\n * @return {Vector} A new vector containing the original's items squared.\n */\nfunction vectorSquare(v) {\n    const nItems = v.length;\n    const total = new Vector(nItems);\n    for (let i = 0; i < v.length; ++i)\n        total[i] = v[i] * v[i];\n    return total;\n}\nexport function vectorLength(v) {\n    let sqrSum = 0;\n    for (let i = 0; i < v.length; i++)\n        sqrSum += v[i] * v[i];\n    return Math.sqrt(sqrSum);\n}\nexport function vectorDotProduct(v1, v2) {\n    if (v1.length != v2.length)\n        throw Error('The dimensionality of the vectors must match');\n    let prod = 0;\n    for (let i = 0; i < v1.length; i++)\n        prod += v1[i] * v2[i];\n    return prod;\n}\n/**\n * Creates a matrix filled with random floating point values.\n *\n * @export\n * @param {number} dimension1 The first dimension of the matrix.\n * @param {number} dimension2 The second dimension of the matrix.\n * @param {number} [scale=1.] Max value given by random generator.\n * @return {Matrix} A new matrix filled with random floating point  values.\n */\nexport function fillRandomMatrix(dimension1, dimension2, scale = 1.) {\n    const matrix = initCoordinates(dimension1, dimension2);\n    for (let i = 0; i < dimension1; ++i) {\n        for (let j = 0; j < dimension2; ++j)\n            matrix[i][j] = randomFloat(scale);\n    }\n    return matrix;\n}\n/**\n * Calculates Euclidean distance between two vectors.\n *\n * @export\n * @param {Vector} p The first vector.\n * @param {Vector} q The second vector.\n * @return {number} Euclidean distance between the given vectors.\n */\nexport function calculateEuclideanDistance(p, q) {\n    const diff = vectorAdd(p, q, -1);\n    const sqdiff = vectorSquare(diff);\n    const sqdiffSumm = itemsSum(sqdiff);\n    return Math.sqrt(sqdiffSumm);\n}\n/**\n * Creates a distance matrix using a custom distance function.\n *\n * @export\n * @param {Vectors} data Input vectors to calculate distances.\n * @param {DistanceMetric} distance Custom distance function.\n * @return {Matrix} Calculated custom distance matrix.\n */\nexport function calcDistanceMatrix(data, distance) {\n    const nItems = data.length;\n    const matrix = initCoordinates(nItems, nItems, 0);\n    for (let i = 0; i < nItems; ++i) {\n        for (let j = i + 1; j < nItems; ++j) {\n            const d = (data[i] == null) || (data[j] == null) ? 0 : distance(data[i], data[j]);\n            matrix[i][j] = matrix[j][i] = d;\n        }\n    }\n    return matrix;\n}\n/** Generates array from a range [begin; end] or [begin; end) if endExclusive. **/\nexport function genRange(begin, end, endExclusive = false) {\n    const nItems = end - begin + (endExclusive ? 0 : 1);\n    const series = new Int32Array(nItems);\n    for (let i = 0; i < nItems; ++i)\n        series[i] = begin + i;\n    return series;\n}\n/**\n* Returns order of values as if they are sorted.\n*\n* @export\n* @param {any[]} values Input array.\n* @param {boolean} [reverse=false] Whether to return reversed order.\n* @return {number[]} The order computed.\n*/\nexport function argSort(values, reverse = false) {\n    const sortfn = reverse ? (a, b) => (b[0] - a[0]) : (a, b) => (a[0] - b[0]);\n    const decor = (v, i) => [v, i]; // set index to value\n    const undecor = (a) => a[1]; // leave only index\n    const _argsort = (arr) => arr.map(decor).sort(sortfn).map(undecor);\n    return _argsort(values);\n}\n/**\n * Returns the indexes of the most diverse objects according to the dist function\n * @param {number} length total number of objects\n * @param {number} n number of diverse elements to find\n * @param {(i1: number, i2: number) => number} dist a function which calculates distance between\n *                                                  two objects using their indexes\n * @returns {number[]} The indexes of the most diverse objects\n */\nexport function getDiverseSubset(length, n, dist) {\n    function maxBy(values, orderBy) {\n        let maxValue = null;\n        let maxOrderBy = null;\n        for (const element of values) {\n            const elementOrderBy = orderBy(element);\n            if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n                maxValue = element;\n                maxOrderBy = elementOrderBy;\n            }\n        }\n        return maxValue;\n    }\n    const subset = [randomInt(length - 1)];\n    const complement = new Set();\n    for (let i = 0; i < length; ++i) {\n        if (!subset.includes(i))\n            complement.add(i);\n    }\n    while (subset.length < n) {\n        const idx = maxBy(complement.values(), (i) => Math.min.apply(Math, subset.map(function (val, index) {\n            return dist(i, val);\n        })));\n        if (idx) {\n            subset.push(idx);\n            complement.delete(idx);\n        }\n    }\n    return subset;\n}\n/**\n * Returns normalized vector\n * @param {Vector} data numerical array\n */\nexport function normalize(data) {\n    let mean = 0;\n    let std = 0;\n    for (let i = 0; i < data.length; ++i)\n        mean += data[i];\n    mean /= data.length;\n    for (let i = 0; i < data.length; ++i)\n        std += (data[i] - mean) * (data[i] - mean);\n    std = Math.sqrt(std / data.length);\n    for (let i = 0; i < data.length; ++i)\n        data[i] = (data[i] - mean) / std;\n    return data;\n}\n/**\n * Finds set difference between two lists.\n * @param {any[]} a The first list.\n * @param {any[]} b The second list.\n * @return {any[]}\n */\nexport function setDifference(a, b) {\n    const bSet = new Set(b);\n    return Array.from(new Set(a.filter((x) => !bSet.has(x))).values());\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vector-operations.js","sourceRoot":"","sources":["vector-operations.ts"],"names":[],"mappings":"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","sourcesContent":["import {Matrix, Vector, Coordinates, Vectors, DistanceMetric} from './type-declarations';\nimport {randomFloat, randomInt} from './random';\n\n/**\n * Asserts a condition by throwing an Error.\n *\n * @export\n * @param {boolean} [condition=false] Condition to assert.\n * @param {string} [message='Assertion error.'] Message to output.\n * @throws {Error}\n */\nexport function assert(condition: boolean = false, message: string = 'Assertion error.') {\n  if (!condition)\n    throw new Error(message);\n}\n\n/**\n * Creates new two-dimensional array and fills it with the value given.\n *\n * @param {number} dimension1 The first dimension of the coordinates (number of rows).\n * @param {number} dimension2 The second dimension of the coordinates (number of columns).\n * @param {number} [fill=0] A value to fill the coordinates with.\n * @return {Coordinates} A two-dimensional filled with the value given.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nfunction initCoordinates(dimension1: number, dimension2: number, fill: number = 0): Coordinates {\n  return new Array(dimension1).fill(fill).map(() => (new Vector(dimension2).fill(fill)));\n}\n\n/**\n * Transpose matrix.\n *\n * @export\n * @param {Matrix} matrix The matrix to be transposed.\n * @return {Matrix} Transposed matrix.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nexport function transposeMatrix(matrix: Matrix): Matrix {\n  return new Array(matrix[0].length).fill(0)\n    .map((_, i) => (new Vector(matrix.length).fill(0).map((_, j) => (matrix[j][i]))));\n}\n\n/**\n * Adds two vectors with the second one to be multiplied by the given ratio.\n *\n * @export\n * @param {Vector} p The first vector to add.\n * @param {Vector} q The second vector to add.\n * @param {number} [multiplier=1] A multiplier to be used before the second vector is added.\n * @return {Vector} New vector contained the result of operation p+multiplier*q.\n */\nexport function vectorAdd(p: Vector, q: Vector, multiplier: number = 1): Vector {\n  const nItems = p.length;\n\n  assert(nItems == q.length, 'Vector lengths do not match.');\n\n  const total = new Vector(nItems);\n\n  for (let i = 0; i < p.length; ++i)\n    total[i] = p[i] + multiplier * q[i];\n\n  return total;\n}\n\n/**\n * Sums the vector's items.\n *\n * @param {Vector} v The vector to be summed.\n * @return {number} The vector's items sum.\n */\nfunction itemsSum(v: Vector): number {\n  let total = 0;\n\n  for (let i = 0; i < v.length; ++i)\n    total += v[i];\n\n  return total;\n}\n\n/**\n * Suqares the vector's items.\n *\n * @param {Vector} v The vector to square.\n * @return {Vector} A new vector containing the original's items squared.\n */\nfunction vectorSquare(v: Vector): Vector {\n  const nItems = v.length;\n  const total = new Vector(nItems);\n\n  for (let i = 0; i < v.length; ++i)\n    total[i] = v[i] * v[i];\n\n  return total;\n}\n\nexport function vectorLength(v: Vector): number {\n  let sqrSum: number = 0;\n  for (let i: number = 0; i < v.length; i++)\n    sqrSum += v[i] * v[i];\n  return Math.sqrt(sqrSum);\n}\n\nexport function vectorDotProduct(v1: Vector, v2: Vector): number {\n  if (v1.length != v2.length)\n    throw Error('The dimensionality of the vectors must match');\n  let prod: number = 0;\n  for (let i: number = 0; i < v1.length; i++)\n    prod += v1[i] * v2[i];\n  return prod;\n}\n\n/**\n * Creates a matrix filled with random floating point values.\n *\n * @export\n * @param {number} dimension1 The first dimension of the matrix.\n * @param {number} dimension2 The second dimension of the matrix.\n * @param {number} [scale=1.] Max value given by random generator.\n * @return {Matrix} A new matrix filled with random floating point  values.\n */\nexport function fillRandomMatrix(dimension1: number, dimension2: number, scale: number = 1.): Matrix {\n  const matrix = initCoordinates(dimension1, dimension2);\n\n  for (let i = 0; i < dimension1; ++i) {\n    for (let j = 0; j < dimension2; ++j)\n      matrix[i][j] = randomFloat(scale);\n  }\n  return matrix;\n}\n\n/**\n * Calculates Euclidean distance between two vectors.\n *\n * @export\n * @param {Vector} p The first vector.\n * @param {Vector} q The second vector.\n * @return {number} Euclidean distance between the given vectors.\n */\nexport function calculateEuclideanDistance(p: Vector, q: Vector): number {\n  const diff = vectorAdd(p, q, -1);\n  const sqdiff = vectorSquare(diff);\n  const sqdiffSumm = itemsSum(sqdiff);\n  return Math.sqrt(sqdiffSumm);\n}\n\n/**\n * Creates a distance matrix using a custom distance function.\n *\n * @export\n * @param {Vectors} data Input vectors to calculate distances.\n * @param {DistanceMetric} distance Custom distance function.\n * @return {Matrix} Calculated custom distance matrix.\n */\nexport function calcDistanceMatrix(data: Vectors, distance: DistanceMetric): Matrix {\n  const nItems = data.length;\n  const matrix = initCoordinates(nItems, nItems, 0);\n\n  for (let i = 0; i < nItems; ++i) {\n    for (let j = i + 1; j < nItems; ++j) {\n      const d: number = (data[i] == null) || (data[j] == null) ? 0 : distance(data[i], data[j]);\n      matrix[i][j] = matrix[j][i] = d;\n    }\n  }\n  return matrix;\n}\n\n/** Generates array from a range [begin; end] or [begin; end) if endExclusive. **/\nexport function genRange(begin: number, end: number, endExclusive = false): Int32Array {\n  const nItems = end - begin + (endExclusive ? 0 : 1);\n  const series = new Int32Array(nItems);\n\n  for (let i = 0; i < nItems; ++i)\n    series[i] = begin + i;\n\n  return series;\n}\n\n /**\n * Returns order of values as if they are sorted.\n *\n * @export\n * @param {any[]} values Input array.\n * @param {boolean} [reverse=false] Whether to return reversed order.\n * @return {number[]} The order computed.\n */\nexport function argSort(values: any[], reverse = false): number[] {\n  const sortfn = reverse ? (a: any[], b: any[]) => (b[0] - a[0]) : (a: any[], b: any[]) => (a[0] - b[0]);\n  const decor = (v: any, i: number) => [v, i]; // set index to value\n  const undecor = (a: any[]) => a[1]; // leave only index\n  const _argsort = (arr: any[]) => arr.map(decor).sort(sortfn).map(undecor);\n  return _argsort(values);\n}\n\n/**\n * Returns the indexes of the most diverse objects according to the dist function\n * @param {number} length total number of objects\n * @param {number} n number of diverse elements to find\n * @param {(i1: number, i2: number) => number} dist a function which calculates distance between\n *                                                  two objects using their indexes\n * @returns {number[]} The indexes of the most diverse objects\n */\nexport function getDiverseSubset(length: number, n: number, dist: (i1: number, i2: number) => number): number[] {\n  function maxBy(values: IterableIterator<number>, orderBy: (i: number) => number) {\n    let maxValue = null;\n    let maxOrderBy = null;\n\n    for (const element of values) {\n      const elementOrderBy = orderBy(element);\n      if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n        maxValue = element;\n        maxOrderBy = elementOrderBy;\n      }\n    }\n    return maxValue;\n  }\n\n  const subset = [randomInt(length - 1)];\n  const complement = new Set();\n\n  for (let i = 0; i < length; ++i) {\n    if (!subset.includes(i))\n      complement.add(i);\n  }\n\n  while (subset.length < n) {\n    const idx = maxBy(\n      complement.values() as IterableIterator<number>,\n      (i) => Math.min.apply(Math, subset.map(function(val, index) {\n        return dist(i, val);\n      })));\n    if (idx) {\n      subset.push(idx);\n      complement.delete(idx);\n    }\n  }\n  return subset;\n}\n\n/**\n * Returns normalized vector\n * @param {Vector} data numerical array\n */\nexport function normalize(data: Vector): Vector {\n  let mean = 0;\n  let std = 0;\n\n  for (let i = 0; i < data.length; ++i)\n    mean += data[i];\n\n  mean /= data.length;\n\n  for (let i = 0; i < data.length; ++i)\n    std += (data[i] - mean) * (data[i] - mean);\n\n  std = Math.sqrt(std / data.length);\n\n  for (let i = 0; i < data.length; ++i)\n    data[i] = (data[i] - mean) / std;\n\n  return data;\n}\n\n/**\n * Finds set difference between two lists.\n * @param {any[]} a The first list.\n * @param {any[]} b The second list.\n * @return {any[]}\n */\nexport function setDifference(a: any[], b: any[]): any[] {\n  const bSet = new Set(b);\n  return Array.from(new Set(a.filter((x) => !bSet.has(x))).values());\n}\n"]}","\"use strict\";\nconst peq = new Uint32Array(0x10000);\nconst myers_32 = (a, b) => {\n  const n = a.length;\n  const m = b.length;\n  const lst = 1 << (n - 1);\n  let pv = -1;\n  let mv = 0;\n  let sc = n;\n  let i = n;\n  while (i--) {\n    peq[a.charCodeAt(i)] |= 1 << i;\n  }\n  for (i = 0; i < m; i++) {\n    let eq = peq[b.charCodeAt(i)];\n    const xv = eq | mv;\n    eq |= ((eq & pv) + pv) ^ pv;\n    mv |= ~(eq | pv);\n    pv &= eq;\n    if (mv & lst) {\n      sc++;\n    }\n    if (pv & lst) {\n      sc--;\n    }\n    mv = (mv << 1) | 1;\n    pv = (pv << 1) | ~(xv | mv);\n    mv &= xv;\n  }\n  i = n;\n  while (i--) {\n    peq[a.charCodeAt(i)] = 0;\n  }\n  return sc;\n};\n\nconst myers_x = (a, b) => {\n  const n = a.length;\n  const m = b.length;\n  const mhc = [];\n  const phc = [];\n  const hsize = Math.ceil(n / 32);\n  const vsize = Math.ceil(m / 32);\n  let score = m;\n  for (let i = 0; i < hsize; i++) {\n    phc[i] = -1;\n    mhc[i] = 0;\n  }\n  let j = 0;\n  for (; j < vsize - 1; j++) {\n    let mv = 0;\n    let pv = -1;\n    const start = j * 32;\n    const end = Math.min(32, m) + start;\n    for (let k = start; k < end; k++) {\n      peq[b.charCodeAt(k)] |= 1 << k;\n    }\n    score = m;\n    for (let i = 0; i < n; i++) {\n      const eq = peq[a.charCodeAt(i)];\n      const pb = (phc[(i / 32) | 0] >>> i) & 1;\n      const mb = (mhc[(i / 32) | 0] >>> i) & 1;\n      const xv = eq | mv;\n      const xh = ((((eq | mb) & pv) + pv) ^ pv) | eq | mb;\n      let ph = mv | ~(xh | pv);\n      let mh = pv & xh;\n      if ((ph >>> 31) ^ pb) {\n        phc[(i / 32) | 0] ^= 1 << i;\n      }\n      if ((mh >>> 31) ^ mb) {\n        mhc[(i / 32) | 0] ^= 1 << i;\n      }\n      ph = (ph << 1) | pb;\n      mh = (mh << 1) | mb;\n      pv = mh | ~(xv | ph);\n      mv = ph & xv;\n    }\n    for (let k = start; k < end; k++) {\n      peq[b.charCodeAt(k)] = 0;\n    }\n  }\n  let mv = 0;\n  let pv = -1;\n  const start = j * 32;\n  const end = Math.min(32, m - start) + start;\n  for (let k = start; k < end; k++) {\n    peq[b.charCodeAt(k)] |= 1 << k;\n  }\n  score = m;\n  for (let i = 0; i < n; i++) {\n    const eq = peq[a.charCodeAt(i)];\n    const pb = (phc[(i / 32) | 0] >>> i) & 1;\n    const mb = (mhc[(i / 32) | 0] >>> i) & 1;\n    const xv = eq | mv;\n    const xh = ((((eq | mb) & pv) + pv) ^ pv) | eq | mb;\n    let ph = mv | ~(xh | pv);\n    let mh = pv & xh;\n    score += (ph >>> (m - 1)) & 1;\n    score -= (mh >>> (m - 1)) & 1;\n    if ((ph >>> 31) ^ pb) {\n      phc[(i / 32) | 0] ^= 1 << i;\n    }\n    if ((mh >>> 31) ^ mb) {\n      mhc[(i / 32) | 0] ^= 1 << i;\n    }\n    ph = (ph << 1) | pb;\n    mh = (mh << 1) | mb;\n    pv = mh | ~(xv | ph);\n    mv = ph & xv;\n  }\n  for (let k = start; k < end; k++) {\n    peq[b.charCodeAt(k)] = 0;\n  }\n  return score;\n};\n\nconst distance = (a, b) => {\n  if (a.length > b.length) {\n    const tmp = b;\n    b = a;\n    a = tmp;\n  }\n  if (a.length === 0) {\n    return b.length;\n  }\n  if (a.length <= 32) {\n    return myers_32(a, b);\n  }\n  return myers_x(a, b);\n};\n\nconst closest = (str, arr) => {\n  let min_distance = Infinity;\n  let min_index = 0;\n  for (let i = 0; i < arr.length; i++) {\n    const dist = distance(str, arr[i]);\n    if (dist < min_distance) {\n      min_distance = dist;\n      min_index = i;\n    }\n  }\n  return arr[min_index];\n};\n\nmodule.exports = {\n  closest, distance\n}\n","\"use strict\";\n// Reference: https://www.geeksforgeeks.org/jaro-and-jaro-winkler-similarity/\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.jaroWinkler = exports.jaro = void 0;\n/**\n *\n * @param str1 String 1 for compare\n * @param str2 String 2 for compare\n * @param options to control case sensitive or not\n */\nfunction jaro(str1, str2, options) {\n    // Exit early if either are empty.\n    if (str1.length === 0 || str2.length === 0) {\n        return 0;\n    }\n    // Convert to upper if case-sensitive is false.\n    if (options && !options.caseSensitive) {\n        str1 = str1.toUpperCase();\n        str2 = str2.toUpperCase();\n    }\n    // Exact match\n    if (str1 === str2) {\n        return 1;\n    }\n    // Number of matches\n    var m = 0;\n    // Length of two Strings\n    var len1 = str1.length;\n    var len2 = str2.length;\n    // Maximum distance\n    var window = Math.floor(Math.max(len1, len2) / 2) - 1;\n    // Hash for matches\n    var str1Hash = new Array(len1);\n    var str2Hash = new Array(len2);\n    for (var i = 0; i < len1; i++) {\n        for (var j = Math.max(0, i - window); j <= Math.min(len2, i + window + 1); j++) {\n            if (!str1Hash[i] && !str2Hash[j] && str1[i] === str2[j]) {\n                ++m;\n                str1Hash[i] = str2Hash[j] = true;\n                break;\n            }\n        }\n    }\n    // Exit early if no matches were found.\n    if (m === 0) {\n        return 0;\n    }\n    // Count the transpositions.\n    var t = 0;\n    var point = 0;\n    for (var i = 0; i < len1; i++) {\n        if (str1Hash[i]) {\n            while (!str2Hash[point]) {\n                point++;\n            }\n            if (str1.charAt(i) !== str2.charAt(point++)) {\n                t++;\n            }\n        }\n    }\n    t /= 2;\n    return (m / len1 + m / len2 + (m - t) / m) / 3;\n}\nexports.jaro = jaro;\n/**\n *\n * @param str1 String 1 for compare\n * @param str2 String 2 for compare\n * @param options to control case sensitive or not\n */\nfunction jaroWinkler(str1, str2, options) {\n    // Jaro Distance\n    var jaroDist = jaro(str1, str2, options);\n    // Same prefix length, maxium is 4\n    var prefix = 0;\n    if (jaroDist > 0.7) {\n        var minIndex = Math.min(str1.length, str2.length);\n        var i = 0;\n        while (str1[i] === str2[i] && i < 4 && i < minIndex) {\n            ++prefix;\n            i++;\n        }\n        jaroDist += 0.1 * prefix * (1 - jaroDist);\n    }\n    return jaroDist;\n}\nexports.jaroWinkler = jaroWinkler;\n","class Cell {\n    constructor() {\n        this.value = 0;\n        this.parentI = 0;\n        this.parentJ = 0;\n    }\n}\n;\nexport class Aligned {\n    constructor(seq1_, seq2_, score_) {\n        this.seq1 = seq1_;\n        this.seq2 = seq2_;\n        this.score = score_;\n    }\n}\n;\nexport class SequenceAlignment {\n    constructor(seq1_, seq2_, gap_, alignGrid_ = \"\") {\n        this.seq1 = '';\n        this.seq2 = '';\n        this.gap = 1;\n        this.len1 = 0;\n        this.len2 = 0;\n        this.step = 1;\n        this.alignGrid = [];\n        this.scores = [];\n        this.dpGrid = [];\n        this.connections = {};\n        this.BLOSUM45 = [[5, -2, -1, -2, -1, -1, -1, 0, -2, -1, -1, -1, -1, -2, -1, 1, 0, -2, -2, 0, -1, -1, 0, -5],\n            [-2, 7, 0, -1, -3, 1, 0, -2, 0, -3, -2, 3, -1, -2, -2, -1, -1, -2, -1, -2, -1, 0, -1, -5],\n            [-1, 0, 6, 2, -2, 0, 0, 0, 1, -2, -3, 0, -2, -2, -2, 1, 0, -4, -2, -3, 4, 0, -1, -5],\n            [-2, -1, 2, 7, -3, 0, 2, -1, 0, -4, -3, 0, -3, -4, -1, 0, -1, -4, -2, -3, 5, 1, -1, -5],\n            [-1, -3, -2, -3, 12, -3, -3, -3, -3, -3, -2, -3, -2, -2, -4, -1, -1, -5, -3, -1, -2, -3, -2, -5],\n            [-1, 1, 0, 0, -3, 6, 2, -2, 1, -2, -2, 1, 0, -4, -1, 0, -1, -2, -1, -3, 0, 4, -1, -5],\n            [-1, 0, 0, 2, -3, 2, 6, -2, 0, -3, -2, 1, -2, -3, 0, 0, -1, -3, -2, -3, 1, 4, -1, -5],\n            [0, -2, 0, -1, -3, -2, -2, 7, -2, -4, -3, -2, -2, -3, -2, 0, -2, -2, -3, -3, -1, -2, -1, -5],\n            [-2, 0, 1, 0, -3, 1, 0, -2, 10, -3, -2, -1, 0, -2, -2, -1, -2, -3, 2, -3, 0, 0, -1, -5],\n            [-1, -3, -2, -4, -3, -2, -3, -4, -3, 5, 2, -3, 2, 0, -2, -2, -1, -2, 0, 3, -3, -3, -1, -5],\n            [-1, -2, -3, -3, -2, -2, -2, -3, -2, 2, 5, -3, 2, 1, -3, -3, -1, -2, 0, 1, -3, -2, -1, -5],\n            [-1, 3, 0, 0, -3, 1, 1, -2, -1, -3, -3, 5, -1, -3, -1, -1, -1, -2, -1, -2, 0, 1, -1, -5],\n            [-1, -1, -2, -3, -2, 0, -2, -2, 0, 2, 2, -1, 6, 0, -2, -2, -1, -2, 0, 1, -2, -1, -1, -5],\n            [-2, -2, -2, -4, -2, -4, -3, -3, -2, 0, 1, -3, 0, 8, -3, -2, -1, 1, 3, 0, -3, -3, -1, -5],\n            [-1, -2, -2, -1, -4, -1, 0, -2, -2, -2, -3, -1, -2, -3, 9, -1, -1, -3, -3, -3, -2, -1, -1, -5],\n            [1, -1, 1, 0, -1, 0, 0, 0, -1, -2, -3, -1, -2, -2, -1, 4, 2, -4, -2, -1, 0, 0, 0, -5],\n            [0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -1, -1, 2, 5, -3, -1, 0, 0, -1, 0, -5],\n            [-2, -2, -4, -4, -5, -2, -3, -2, -3, -2, -2, -2, -2, 1, -3, -4, -3, 15, 3, -3, -4, -2, -2, -5],\n            [-2, -1, -2, -2, -3, -1, -2, -3, 2, 0, 0, -1, 0, 3, -3, -2, -1, 3, 8, -1, -2, -2, -1, -5],\n            [0, -2, -3, -3, -1, -3, -3, -3, -3, 3, 1, -2, 1, 0, -3, -1, 0, -3, -1, 5, -3, -3, -1, -5],\n            [-1, -1, 4, 5, -2, 0, 1, -1, 0, -3, -3, 0, -2, -3, -2, 0, 0, -4, -2, -3, 4, 2, -1, -5],\n            [-1, 0, 0, 1, -3, 4, 4, -2, 0, -3, -2, 1, -1, -3, -1, 0, -1, -2, -2, -3, 2, 4, -1, -5],\n            [0, -1, -1, -1, -2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, 0, -2, -1, -1, -1, -1, -1, -5],\n            [-5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, 1]];\n        this.BLOSUM50 = [[5, -2, -1, -2, -1, -1, -1, 0, -2, -1, -2, -1, -1, -3, -1, 1, 0, -3, -2, 0, -2, -1, -1, -5],\n            [-2, 7, -1, -2, -4, 1, 0, -3, 0, -4, -3, 3, -2, -3, -3, -1, -1, -3, -1, -3, -1, 0, -1, -5],\n            [-1, -1, 7, 2, -2, 0, 0, 0, 1, -3, -4, 0, -2, -4, -2, 1, 0, -4, -2, -3, 4, 0, -1, -5],\n            [-2, -2, 2, 8, -4, 0, 2, -1, -1, -4, -4, -1, -4, -5, -1, 0, -1, -5, -3, -4, 5, 1, -1, -5],\n            [-1, -4, -2, -4, 13, -3, -3, -3, -3, -2, -2, -3, -2, -2, -4, -1, -1, -5, -3, -1, -3, -3, -2, -5],\n            [-1, 1, 0, 0, -3, 7, 2, -2, 1, -3, -2, 2, 0, -4, -1, 0, -1, -1, -1, -3, 0, 4, -1, -5],\n            [-1, 0, 0, 2, -3, 2, 6, -3, 0, -4, -3, 1, -2, -3, -1, -1, -1, -3, -2, -3, 1, 5, -1, -5],\n            [0, -3, 0, -1, -3, -2, -3, 8, -2, -4, -4, -2, -3, -4, -2, 0, -2, -3, -3, -4, -1, -2, -2, -5],\n            [-2, 0, 1, -1, -3, 1, 0, -2, 10, -4, -3, 0, -1, -1, -2, -1, -2, -3, 2, -4, 0, 0, -1, -5],\n            [-1, -4, -3, -4, -2, -3, -4, -4, -4, 5, 2, -3, 2, 0, -3, -3, -1, -3, -1, 4, -4, -3, -1, -5],\n            [-2, -3, -4, -4, -2, -2, -3, -4, -3, 2, 5, -3, 3, 1, -4, -3, -1, -2, -1, 1, -4, -3, -1, -5],\n            [-1, 3, 0, -1, -3, 2, 1, -2, 0, -3, -3, 6, -2, -4, -1, 0, -1, -3, -2, -3, 0, 1, -1, -5],\n            [-1, -2, -2, -4, -2, 0, -2, -3, -1, 2, 3, -2, 7, 0, -3, -2, -1, -1, 0, 1, -3, -1, -1, -5],\n            [-3, -3, -4, -5, -2, -4, -3, -4, -1, 0, 1, -4, 0, 8, -4, -3, -2, 1, 4, -1, -4, -4, -2, -5],\n            [-1, -3, -2, -1, -4, -1, -1, -2, -2, -3, -4, -1, -3, -4, 10, -1, -1, -4, -3, -3, -2, -1, -2, -5],\n            [1, -1, 1, 0, -1, 0, -1, 0, -1, -3, -3, 0, -2, -3, -1, 5, 2, -4, -2, -2, 0, 0, -1, -5],\n            [0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -2, -1, 2, 5, -3, -2, 0, 0, -1, 0, -5],\n            [-3, -3, -4, -5, -5, -1, -3, -3, -3, -3, -2, -3, -1, 1, -4, -4, -3, 15, 2, -3, -5, -2, -3, -5],\n            [-2, -1, -2, -3, -3, -1, -2, -3, 2, -1, -1, -2, 0, 4, -3, -2, -2, 2, 8, -1, -3, -2, -1, -5],\n            [0, -3, -3, -4, -1, -3, -3, -4, -4, 4, 1, -3, 1, -1, -3, -2, 0, -3, -1, 5, -4, -3, -1, -5],\n            [-2, -1, 4, 5, -3, 0, 1, -1, 0, -4, -4, 0, -3, -4, -2, 0, 0, -5, -3, -4, 5, 2, -1, -5],\n            [-1, 0, 0, 1, -3, 4, 5, -2, 0, -3, -3, 1, -1, -4, -1, 0, -1, -2, -2, -3, 2, 5, -1, -5],\n            [-1, -1, -1, -1, -2, -1, -1, -2, -1, -1, -1, -1, -1, -2, -2, -1, 0, -3, -1, -1, -1, -1, -1, -5],\n            [-5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, 1]];\n        this.BLOSUM62 = [[4, -1, -2, -2, 0, -1, -1, 0, -2, -1, -1, -1, -1, -2, -1, 1, 0, -3, -2, 0, -2, -1, 0, -4],\n            [-1, 5, 0, -2, -3, 1, 0, -2, 0, -3, -2, 2, -1, -3, -2, -1, -1, -3, -2, -3, -1, 0, -1, -4],\n            [-2, 0, 6, 1, -3, 0, 0, 0, 1, -3, -3, 0, -2, -3, -2, 1, 0, -4, -2, -3, 3, 0, -1, -4],\n            [-2, -2, 1, 6, -3, 0, 2, -1, -1, -3, -4, -1, -3, -3, -1, 0, -1, -4, -3, -3, 4, 1, -1, -4],\n            [0, -3, -3, -3, 9, -3, -4, -3, -3, -1, -1, -3, -1, -2, -3, -1, -1, -2, -2, -1, -3, -3, -2, -4],\n            [-1, 1, 0, 0, -3, 5, 2, -2, 0, -3, -2, 1, 0, -3, -1, 0, -1, -2, -1, -2, 0, 3, -1, -4],\n            [-1, 0, 0, 2, -4, 2, 5, -2, 0, -3, -3, 1, -2, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],\n            [0, -2, 0, -1, -3, -2, -2, 6, -2, -4, -4, -2, -3, -3, -2, 0, -2, -2, -3, -3, -1, -2, -1, -4],\n            [-2, 0, 1, -1, -3, 0, 0, -2, 8, -3, -3, -1, -2, -1, -2, -1, -2, -2, 2, -3, 0, 0, -1, -4],\n            [-1, -3, -3, -3, -1, -3, -3, -4, -3, 4, 2, -3, 1, 0, -3, -2, -1, -3, -1, 3, -3, -3, -1, -4],\n            [-1, -2, -3, -4, -1, -2, -3, -4, -3, 2, 4, -2, 2, 0, -3, -2, -1, -2, -1, 1, -4, -3, -1, -4],\n            [-1, 2, 0, -1, -3, 1, 1, -2, -1, -3, -2, 5, -1, -3, -1, 0, -1, -3, -2, -2, 0, 1, -1, -4],\n            [-1, -1, -2, -3, -1, 0, -2, -3, -2, 1, 2, -1, 5, 0, -2, -1, -1, -1, -1, 1, -3, -1, -1, -4],\n            [-2, -3, -3, -3, -2, -3, -3, -3, -1, 0, 0, -3, 0, 6, -4, -2, -2, 1, 3, -1, -3, -3, -1, -4],\n            [-1, -2, -2, -1, -3, -1, -1, -2, -2, -3, -3, -1, -2, -4, 7, -1, -1, -4, -3, -2, -2, -1, -2, -4],\n            [1, -1, 1, 0, -1, 0, 0, 0, -1, -2, -2, 0, -1, -2, -1, 4, 1, -3, -2, -2, 0, 0, 0, -4],\n            [0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -2, -1, 1, 5, -2, -2, 0, -1, -1, 0, -4],\n            [-3, -3, -4, -4, -2, -2, -3, -2, -2, -3, -2, -3, -1, 1, -4, -3, -2, 11, 2, -3, -4, -3, -2, -4],\n            [-2, -2, -2, -3, -2, -1, -2, -3, 2, -1, -1, -2, -1, 3, -3, -2, -2, 2, 7, -1, -3, -2, -1, -4],\n            [0, -3, -3, -3, -1, -2, -2, -3, -3, 3, 1, -2, 1, -1, -2, -2, 0, -3, -1, 4, -3, -2, -1, -4],\n            [-2, -1, 3, 4, -3, 0, 1, -1, 0, -3, -4, 0, -3, -3, -2, 0, -1, -4, -3, -3, 4, 1, -1, -4],\n            [-1, 0, 0, 1, -3, 3, 4, -2, 0, -3, -3, 1, -1, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],\n            [0, -1, -1, -1, -2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -2, 0, 0, -2, -1, -1, -1, -1, -1, -4],\n            [-4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, 1]];\n        this.BLOSUM80 = [[7, -3, -3, -3, -1, -2, -2, 0, -3, -3, -3, -1, -2, -4, -1, 2, 0, -5, -4, -1, -3, -2, -1, -8],\n            [-3, 9, -1, -3, -6, 1, -1, -4, 0, -5, -4, 3, -3, -5, -3, -2, -2, -5, -4, -4, -2, 0, -2, -8],\n            [-3, -1, 9, 2, -5, 0, -1, -1, 1, -6, -6, 0, -4, -6, -4, 1, 0, -7, -4, -5, 5, -1, -2, -8],\n            [-3, -3, 2, 10, -7, -1, 2, -3, -2, -7, -7, -2, -6, -6, -3, -1, -2, -8, -6, -6, 6, 1, -3, -8],\n            [-1, -6, -5, -7, 13, -5, -7, -6, -7, -2, -3, -6, -3, -4, -6, -2, -2, -5, -5, -2, -6, -7, -4, -8],\n            [-2, 1, 0, -1, -5, 9, 3, -4, 1, -5, -4, 2, -1, -5, -3, -1, -1, -4, -3, -4, -1, 5, -2, -8],\n            [-2, -1, -1, 2, -7, 3, 8, -4, 0, -6, -6, 1, -4, -6, -2, -1, -2, -6, -5, -4, 1, 6, -2, -8],\n            [0, -4, -1, -3, -6, -4, -4, 9, -4, -7, -7, -3, -5, -6, -5, -1, -3, -6, -6, -6, -2, -4, -3, -8],\n            [-3, 0, 1, -2, -7, 1, 0, -4, 12, -6, -5, -1, -4, -2, -4, -2, -3, -4, 3, -5, -1, 0, -2, -8],\n            [-3, -5, -6, -7, -2, -5, -6, -7, -6, 7, 2, -5, 2, -1, -5, -4, -2, -5, -3, 4, -6, -6, -2, -8],\n            [-3, -4, -6, -7, -3, -4, -6, -7, -5, 2, 6, -4, 3, 0, -5, -4, -3, -4, -2, 1, -7, -5, -2, -8],\n            [-1, 3, 0, -2, -6, 2, 1, -3, -1, -5, -4, 8, -3, -5, -2, -1, -1, -6, -4, -4, -1, 1, -2, -8],\n            [-2, -3, -4, -6, -3, -1, -4, -5, -4, 2, 3, -3, 9, 0, -4, -3, -1, -3, -3, 1, -5, -3, -2, -8],\n            [-4, -5, -6, -6, -4, -5, -6, -6, -2, -1, 0, -5, 0, 10, -6, -4, -4, 0, 4, -2, -6, -6, -3, -8],\n            [-1, -3, -4, -3, -6, -3, -2, -5, -4, -5, -5, -2, -4, -6, 12, -2, -3, -7, -6, -4, -4, -2, -3, -8],\n            [2, -2, 1, -1, -2, -1, -1, -1, -2, -4, -4, -1, -3, -4, -2, 7, 2, -6, -3, -3, 0, -1, -1, -8],\n            [0, -2, 0, -2, -2, -1, -2, -3, -3, -2, -3, -1, -1, -4, -3, 2, 8, -5, -3, 0, -1, -2, -1, -8],\n            [-5, -5, -7, -8, -5, -4, -6, -6, -4, -5, -4, -6, -3, 0, -7, -6, -5, 16, 3, -5, -8, -5, -5, -8],\n            [-4, -4, -4, -6, -5, -3, -5, -6, 3, -3, -2, -4, -3, 4, -6, -3, -3, 3, 11, -3, -5, -4, -3, -8],\n            [-1, -4, -5, -6, -2, -4, -4, -6, -5, 4, 1, -4, 1, -2, -4, -3, 0, -5, -3, 7, -6, -4, -2, -8],\n            [-3, -2, 5, 6, -6, -1, 1, -2, -1, -6, -7, -1, -5, -6, -4, 0, -1, -8, -5, -6, 6, 0, -3, -8],\n            [-2, 0, -1, 1, -7, 5, 6, -4, 0, -6, -5, 1, -3, -6, -2, -1, -2, -5, -4, -4, 0, 6, -1, -8],\n            [-1, -2, -2, -3, -4, -2, -2, -3, -2, -2, -2, -2, -2, -3, -3, -1, -1, -5, -3, -2, -3, -1, -2, -8],\n            [-8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, 1]];\n        this.BLOSUM90 = [[5, -2, -2, -3, -1, -1, -1, 0, -2, -2, -2, -1, -2, -3, -1, 1, 0, -4, -3, -1, -2, -1, -1, -6],\n            [-2, 6, -1, -3, -5, 1, -1, -3, 0, -4, -3, 2, -2, -4, -3, -1, -2, -4, -3, -3, -2, 0, -2, -6],\n            [-2, -1, 7, 1, -4, 0, -1, -1, 0, -4, -4, 0, -3, -4, -3, 0, 0, -5, -3, -4, 4, -1, -2, -6],\n            [-3, -3, 1, 7, -5, -1, 1, -2, -2, -5, -5, -1, -4, -5, -3, -1, -2, -6, -4, -5, 4, 0, -2, -6],\n            [-1, -5, -4, -5, 9, -4, -6, -4, -5, -2, -2, -4, -2, -3, -4, -2, -2, -4, -4, -2, -4, -5, -3, -6],\n            [-1, 1, 0, -1, -4, 7, 2, -3, 1, -4, -3, 1, 0, -4, -2, -1, -1, -3, -3, -3, -1, 4, -1, -6],\n            [-1, -1, -1, 1, -6, 2, 6, -3, -1, -4, -4, 0, -3, -5, -2, -1, -1, -5, -4, -3, 0, 4, -2, -6],\n            [0, -3, -1, -2, -4, -3, -3, 6, -3, -5, -5, -2, -4, -5, -3, -1, -3, -4, -5, -5, -2, -3, -2, -6],\n            [-2, 0, 0, -2, -5, 1, -1, -3, 8, -4, -4, -1, -3, -2, -3, -2, -2, -3, 1, -4, -1, 0, -2, -6],\n            [-2, -4, -4, -5, -2, -4, -4, -5, -4, 5, 1, -4, 1, -1, -4, -3, -1, -4, -2, 3, -5, -4, -2, -6],\n            [-2, -3, -4, -5, -2, -3, -4, -5, -4, 1, 5, -3, 2, 0, -4, -3, -2, -3, -2, 0, -5, -4, -2, -6],\n            [-1, 2, 0, -1, -4, 1, 0, -2, -1, -4, -3, 6, -2, -4, -2, -1, -1, -5, -3, -3, -1, 1, -1, -6],\n            [-2, -2, -3, -4, -2, 0, -3, -4, -3, 1, 2, -2, 7, -1, -3, -2, -1, -2, -2, 0, -4, -2, -1, -6],\n            [-3, -4, -4, -5, -3, -4, -5, -5, -2, -1, 0, -4, -1, 7, -4, -3, -3, 0, 3, -2, -4, -4, -2, -6],\n            [-1, -3, -3, -3, -4, -2, -2, -3, -3, -4, -4, -2, -3, -4, 8, -2, -2, -5, -4, -3, -3, -2, -2, -6],\n            [1, -1, 0, -1, -2, -1, -1, -1, -2, -3, -3, -1, -2, -3, -2, 5, 1, -4, -3, -2, 0, -1, -1, -6],\n            [0, -2, 0, -2, -2, -1, -1, -3, -2, -1, -2, -1, -1, -3, -2, 1, 6, -4, -2, -1, -1, -1, -1, -6],\n            [-4, -4, -5, -6, -4, -3, -5, -4, -3, -4, -3, -5, -2, 0, -5, -4, -4, 11, 2, -3, -6, -4, -3, -6],\n            [-3, -3, -3, -4, -4, -3, -4, -5, 1, -2, -2, -3, -2, 3, -4, -3, -2, 2, 8, -3, -4, -3, -2, -6],\n            [-1, -3, -4, -5, -2, -3, -3, -5, -4, 3, 0, -3, 0, -2, -3, -2, -1, -3, -3, 5, -4, -3, -2, -6],\n            [-2, -2, 4, 4, -4, -1, 0, -2, -1, -5, -5, -1, -4, -4, -3, 0, -1, -6, -4, -4, 4, 0, -2, -6],\n            [-1, 0, -1, 0, -5, 4, 4, -3, 0, -4, -4, 1, -2, -4, -2, -1, -1, -4, -3, -3, 0, 4, -1, -6],\n            [-1, -2, -2, -2, -3, -1, -2, -2, -2, -2, -2, -1, -1, -2, -2, -1, -1, -3, -2, -2, -2, -1, -2, -6],\n            [-6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, 1]];\n        this.NUCLEOTIDES = [[1, -1, -1, -1],\n            [-1, 1, -1, -1],\n            [-1, -1, 1, -1],\n            [-1, -1, -1, 1]];\n        this.PAM30 = [[6, -7, -4, -3, -6, -4, -2, -2, -7, -5, -6, -7, -5, -8, -2, 0, -1, -13, -8, -2, -3, -3, -3, -17],\n            [-7, 8, -6, -10, -8, -2, -9, -9, -2, -5, -8, 0, -4, -9, -4, -3, -6, -2, -10, -8, -7, -4, -6, -17],\n            [-4, -6, 8, 2, -11, -3, -2, -3, 0, -5, -7, -1, -9, -9, -6, 0, -2, -8, -4, -8, 6, -3, -3, -17],\n            [-3, -10, 2, 8, -14, -2, 2, -3, -4, -7, -12, -4, -11, -15, -8, -4, -5, -15, -11, -8, 6, 1, -5, -17],\n            [-6, -8, -11, -14, 10, -14, -14, -9, -7, -6, -15, -14, -13, -13, -8, -3, -8, -15, -4, -6, -12, -14, -9, -17],\n            [-4, -2, -3, -2, -14, 8, 1, -7, 1, -8, -5, -3, -4, -13, -3, -5, -5, -13, -12, -7, -3, 6, -5, -17],\n            [-2, -9, -2, 2, -14, 1, 8, -4, -5, -5, -9, -4, -7, -14, -5, -4, -6, -17, -8, -6, 1, 6, -5, -17],\n            [-2, -9, -3, -3, -9, -7, -4, 6, -9, -11, -10, -7, -8, -9, -6, -2, -6, -15, -14, -5, -3, -5, -5, -17],\n            [-7, -2, 0, -4, -7, 1, -5, -9, 9, -9, -6, -6, -10, -6, -4, -6, -7, -7, -3, -6, -1, -1, -5, -17],\n            [-5, -5, -5, -7, -6, -8, -5, -11, -9, 8, -1, -6, -1, -2, -8, -7, -2, -14, -6, 2, -6, -6, -5, -17],\n            [-6, -8, -7, -12, -15, -5, -9, -10, -6, -1, 7, -8, 1, -3, -7, -8, -7, -6, -7, -2, -9, -7, -6, -17],\n            [-7, 0, -1, -4, -14, -3, -4, -7, -6, -6, -8, 7, -2, -14, -6, -4, -3, -12, -9, -9, -2, -4, -5, -17],\n            [-5, -4, -9, -11, -13, -4, -7, -8, -10, -1, 1, -2, 11, -4, -8, -5, -4, -13, -11, -1, -10, -5, -5, -17],\n            [-8, -9, -9, -15, -13, -13, -14, -9, -6, -2, -3, -14, -4, 9, -10, -6, -9, -4, 2, -8, -10, -13, -8, -17],\n            [-2, -4, -6, -8, -8, -3, -5, -6, -4, -8, -7, -6, -8, -10, 8, -2, -4, -14, -13, -6, -7, -4, -5, -17],\n            [0, -3, 0, -4, -3, -5, -4, -2, -6, -7, -8, -4, -5, -6, -2, 6, 0, -5, -7, -6, -1, -5, -3, -17],\n            [-1, -6, -2, -5, -8, -5, -6, -6, -7, -2, -7, -3, -4, -9, -4, 0, 7, -13, -6, -3, -3, -6, -4, -17],\n            [-13, -2, -8, -15, -15, -13, -17, -15, -7, -14, -6, -12, -13, -4, -14, -5, -13, 13, -5, -15, -10, -14, -11, -17],\n            [-8, -10, -4, -11, -4, -12, -8, -14, -3, -6, -7, -9, -11, 2, -13, -7, -6, -5, 10, -7, -6, -9, -7, -17],\n            [-2, -8, -8, -8, -6, -7, -6, -5, -6, 2, -2, -9, -1, -8, -6, -6, -3, -15, -7, 7, -8, -6, -5, -17],\n            [-3, -7, 6, 6, -12, -3, 1, -3, -1, -6, -9, -2, -10, -10, -7, -1, -3, -10, -6, -8, 6, 0, -5, -17],\n            [-3, -4, -3, 1, -14, 6, 6, -5, -1, -6, -7, -4, -5, -13, -4, -5, -6, -14, -9, -6, 0, 6, -5, -17],\n            [-3, -6, -3, -5, -9, -5, -5, -5, -5, -5, -6, -5, -5, -8, -5, -3, -4, -11, -7, -5, -5, -5, -5, -17],\n            [-17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, 1]];\n        this.PAM70 = [[5, -4, -2, -1, -4, -2, -1, 0, -4, -2, -4, -4, -3, -6, 0, 1, 1, -9, -5, -1, -1, -1, -2, -11],\n            [-4, 8, -3, -6, -5, 0, -5, -6, 0, -3, -6, 2, -2, -7, -2, -1, -4, 0, -7, -5, -4, -2, -3, -11],\n            [-2, -3, 6, 3, -7, -1, 0, -1, 1, -3, -5, 0, -5, -6, -3, 1, 0, -6, -3, -5, 5, -1, -2, -11],\n            [-1, -6, 3, 6, -9, 0, 3, -1, -1, -5, -8, -2, -7, -10, -4, -1, -2, -10, -7, -5, 5, 2, -3, -11],\n            [-4, -5, -7, -9, 9, -9, -9, -6, -5, -4, -10, -9, -9, -8, -5, -1, -5, -11, -2, -4, -8, -9, -6, -11],\n            [-2, 0, -1, 0, -9, 7, 2, -4, 2, -5, -3, -1, -2, -9, -1, -3, -3, -8, -8, -4, -1, 5, -2, -11],\n            [-1, -5, 0, 3, -9, 2, 6, -2, -2, -4, -6, -2, -4, -9, -3, -2, -3, -11, -6, -4, 2, 5, -3, -11],\n            [0, -6, -1, -1, -6, -4, -2, 6, -6, -6, -7, -5, -6, -7, -3, 0, -3, -10, -9, -3, -1, -3, -3, -11],\n            [-4, 0, 1, -1, -5, 2, -2, -6, 8, -6, -4, -3, -6, -4, -2, -3, -4, -5, -1, -4, 0, 1, -3, -11],\n            [-2, -3, -3, -5, -4, -5, -4, -6, -6, 7, 1, -4, 1, 0, -5, -4, -1, -9, -4, 3, -4, -4, -3, -11],\n            [-4, -6, -5, -8, -10, -3, -6, -7, -4, 1, 6, -5, 2, -1, -5, -6, -4, -4, -4, 0, -6, -4, -4, -11],\n            [-4, 2, 0, -2, -9, -1, -2, -5, -3, -4, -5, 6, 0, -9, -4, -2, -1, -7, -7, -6, -1, -2, -3, -11],\n            [-3, -2, -5, -7, -9, -2, -4, -6, -6, 1, 2, 0, 10, -2, -5, -3, -2, -8, -7, 0, -6, -3, -3, -11],\n            [-6, -7, -6, -10, -8, -9, -9, -7, -4, 0, -1, -9, -2, 8, -7, -4, -6, -2, 4, -5, -7, -9, -5, -11],\n            [0, -2, -3, -4, -5, -1, -3, -3, -2, -5, -5, -4, -5, -7, 7, 0, -2, -9, -9, -3, -4, -2, -3, -11],\n            [1, -1, 1, -1, -1, -3, -2, 0, -3, -4, -6, -2, -3, -4, 0, 5, 2, -3, -5, -3, 0, -2, -1, -11],\n            [1, -4, 0, -2, -5, -3, -3, -3, -4, -1, -4, -1, -2, -6, -2, 2, 6, -8, -4, -1, -1, -3, -2, -11],\n            [-9, 0, -6, -10, -11, -8, -11, -10, -5, -9, -4, -7, -8, -2, -9, -3, -8, 13, -3, -10, -7, -10, -7, -11],\n            [-5, -7, -3, -7, -2, -8, -6, -9, -1, -4, -4, -7, -7, 4, -9, -5, -4, -3, 9, -5, -4, -7, -5, -11],\n            [-1, -5, -5, -5, -4, -4, -4, -3, -4, 3, 0, -6, 0, -5, -3, -3, -1, -10, -5, 6, -5, -4, -2, -11],\n            [-1, -4, 5, 5, -8, -1, 2, -1, 0, -4, -6, -1, -6, -7, -4, 0, -1, -7, -4, -5, 5, 1, -2, -11],\n            [-1, -2, -1, 2, -9, 5, 5, -3, 1, -4, -4, -2, -3, -9, -2, -2, -3, -10, -7, -4, 1, 5, -3, -11],\n            [-2, -3, -2, -3, -6, -2, -3, -3, -3, -3, -4, -3, -3, -5, -3, -1, -2, -7, -5, -2, -2, -3, -3, -11],\n            [-11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, 1]];\n        this.PAM250 = [[2, -2, 0, 0, -2, 0, 0, 1, -1, -1, -2, -1, -1, -3, 1, 1, 1, -6, -3, 0, 0, 0, 0, -8],\n            [-2, 6, 0, -1, -4, 1, -1, -3, 2, -2, -3, 3, 0, -4, 0, 0, -1, 2, -4, -2, -1, 0, -1, -8],\n            [0, 0, 2, 2, -4, 1, 1, 0, 2, -2, -3, 1, -2, -3, 0, 1, 0, -4, -2, -2, 2, 1, 0, -8],\n            [0, -1, 2, 4, -5, 2, 3, 1, 1, -2, -4, 0, -3, -6, -1, 0, 0, -7, -4, -2, 3, 3, -1, -8],\n            [-2, -4, -4, -5, 12, -5, -5, -3, -3, -2, -6, -5, -5, -4, -3, 0, -2, -8, 0, -2, -4, -5, -3, -8],\n            [0, 1, 1, 2, -5, 4, 2, -1, 3, -2, -2, 1, -1, -5, 0, -1, -1, -5, -4, -2, 1, 3, -1, -8],\n            [0, -1, 1, 3, -5, 2, 4, 0, 1, -2, -3, 0, -2, -5, -1, 0, 0, -7, -4, -2, 3, 3, -1, -8],\n            [1, -3, 0, 1, -3, -1, 0, 5, -2, -3, -4, -2, -3, -5, 0, 1, 0, -7, -5, -1, 0, 0, -1, -8],\n            [-1, 2, 2, 1, -3, 3, 1, -2, 6, -2, -2, 0, -2, -2, 0, -1, -1, -3, 0, -2, 1, 2, -1, -8],\n            [-1, -2, -2, -2, -2, -2, -2, -3, -2, 5, 2, -2, 2, 1, -2, -1, 0, -5, -1, 4, -2, -2, -1, -8],\n            [-2, -3, -3, -4, -6, -2, -3, -4, -2, 2, 6, -3, 4, 2, -3, -3, -2, -2, -1, 2, -3, -3, -1, -8],\n            [-1, 3, 1, 0, -5, 1, 0, -2, 0, -2, -3, 5, 0, -5, -1, 0, 0, -3, -4, -2, 1, 0, -1, -8],\n            [-1, 0, -2, -3, -5, -1, -2, -3, -2, 2, 4, 0, 6, 0, -2, -2, -1, -4, -2, 2, -2, -2, -1, -8],\n            [-3, -4, -3, -6, -4, -5, -5, -5, -2, 1, 2, -5, 0, 9, -5, -3, -3, 0, 7, -1, -4, -5, -2, -8],\n            [1, 0, 0, -1, -3, 0, -1, 0, 0, -2, -3, -1, -2, -5, 6, 1, 0, -6, -5, -1, -1, 0, -1, -8],\n            [1, 0, 1, 0, 0, -1, 0, 1, -1, -1, -3, 0, -2, -3, 1, 2, 1, -2, -3, -1, 0, 0, 0, -8],\n            [1, -1, 0, 0, -2, -1, 0, 0, -1, 0, -2, 0, -1, -3, 0, 1, 3, -5, -3, 0, 0, -1, 0, -8],\n            [-6, 2, -4, -7, -8, -5, -7, -7, -3, -5, -2, -3, -4, 0, -6, -2, -5, 17, 0, -6, -5, -6, -4, -8],\n            [-3, -4, -2, -4, 0, -4, -4, -5, 0, -1, -1, -4, -2, 7, -5, -3, -3, 0, 10, -2, -3, -4, -2, -8],\n            [0, -2, -2, -2, -2, -2, -2, -1, -2, 4, 2, -2, 2, -1, -1, -1, 0, -6, -2, 4, -2, -2, -1, -8],\n            [0, -1, 2, 3, -4, 1, 3, 0, 1, -2, -3, 1, -2, -4, -1, 0, 0, -5, -3, -2, 3, 2, -1, -8],\n            [0, 0, 1, 3, -5, 3, 3, 0, 2, -2, -3, 0, -2, -5, 0, 0, -1, -6, -4, -2, 2, 3, -1, -8],\n            [0, -1, 0, -1, -3, -1, -1, -1, -1, -1, -1, -1, -1, -2, -1, 0, 0, -4, -2, -1, -1, -1, -1, -8],\n            [-8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, 1]];\n        this.SCHNEIDER = [[11.6, -2.7, 9.7, -1.7, -2.7, -6.4, -3.9, -5.6, 5.1, -5.0, 3.6, -4.2, -6.3, -13.0, -7.1, -11.5, 0.4, -6.0, -1.9, -5.3, -8.5, -11.2, -8.9, -10.8, 2.1, 0.0, 1.4, 0.2, -10.2, -13.5, -13.0, -12.5, -2.6, -8.5, -5.0, -8.1, -6.3, -9.9, -7.5, -9.0, -7.1, -10.2, -8.2, -9.2, -8.2, -12.5, -11.1, -11.4, -50.0, -14.8, -50.0, -13.8, -7.3, -10.1, -8.4, -9.1, -50.0, -13.0, -13.5, -12.4, -10.7, -18.1, -11.8, -17.2,],\n            [-2.7, 13.0, -3.3, 10.9, -3.5, -0.4, -3.3, -1.8, -5.4, 4.6, -5.5, 3.0, -10.2, -7.9, -9.9, -9.6, -5.0, 0.5, -5.5, -1.0, -10.3, -8.1, -9.4, -9.6, -8.1, -5.0, -7.3, -6.3, -13.4, -11.3, -14.4, -12.9, -6.3, 0.8, -6.4, -1.1, -7.4, -5.0, -6.2, -6.5, -5.6, -1.6, -4.7, -3.0, -10.8, -8.7, -11.9, -10.0, -50.0, -6.2, -50.0, -7.5, -6.3, -4.3, -6.2, -5.4, -50.0, -7.0, -16.3, -8.2, -13.2, -12.3, -13.1, -13.3,],\n            [9.7, -3.3, 11.6, -2.8, -4.5, -6.7, -3.1, -6.9, 3.3, -5.5, 4.8, -5.1, -8.9, -13.2, -5.7, -12.6, -1.5, -6.1, -0.6, -6.1, -10.0, -11.8, -8.6, -11.9, 1.2, 0.5, 2.2, 0.1, -11.8, -14.0, -11.9, -13.4, -4.9, -9.1, -3.4, -8.9, -8.0, -10.0, -7.2, -10.0, -9.1, -10.2, -7.1, -9.9, -10.1, -13.0, -10.6, -12.7, -50.0, -14.9, -50.0, -14.4, -8.9, -10.8, -8.9, -10.4, -50.0, -13.1, -11.8, -13.0, -12.4, -19.4, -11.5, -17.8,],\n            [-1.7, 10.9, -2.8, 12.9, -2.7, -2.2, -2.8, 0.2, -4.8, 2.9, -5.2, 5.2, -9.1, -9.5, -9.0, -7.0, -4.0, -1.0, -5.0, 1.0, -9.0, -8.8, -8.9, -7.7, -7.0, -6.8, -7.1, -4.3, -12.4, -12.9, -13.9, -10.0, -4.9, -0.7, -5.6, 1.4, -6.0, -6.5, -6.2, -4.8, -5.1, -3.2, -5.0, -1.2, -9.8, -9.9, -11.3, -8.2, -50.0, -7.6, -50.0, -5.1, -5.5, -5.8, -5.9, -4.2, -50.0, -8.3, -15.5, -5.9, -11.6, -14.2, -12.0, -11.6,],\n            [-2.7, -3.5, -4.5, -2.7, 11.7, 9.0, 10.6, 9.6, -3.2, -0.7, -5.1, -0.4, 0.7, -4.6, -0.4, -3.6, -4.8, -8.9, -6.5, -7.8, -1.4, -4.1, -2.9, -3.3, -8.0, -9.1, -8.0, -8.2, -6.0, -9.3, -7.7, -8.5, -6.4, -10.1, -7.5, -8.6, 2.8, -0.7, 0.9, 0.1, -5.9, -7.3, -6.5, -6.5, -0.4, -3.9, -2.6, -3.1, -50.0, -14.6, -50.0, -12.6, 2.9, 0.1, 1.8, 1.0, -50.0, -9.2, -13.6, -7.7, -4.8, -12.2, -6.2, -11.0,],\n            [-6.4, -0.4, -6.7, -2.2, 9.0, 12.3, 9.8, 9.6, -7.1, 2.4, -7.2, 0.3, -2.9, -1.2, -3.0, -3.3, -7.6, -6.7, -8.1, -7.9, -4.9, -1.9, -4.5, -3.8, -9.5, -7.8, -9.3, -8.9, -9.4, -7.1, -9.0, -9.0, -9.4, -7.5, -9.3, -9.2, -0.7, 2.6, 0.2, -0.1, -8.0, -4.6, -7.7, -6.1, -3.6, -1.0, -4.1, -3.1, -50.0, -11.6, -50.0, -11.6, 0.2, 2.3, 0.4, 0.5, -50.0, -6.5, -15.3, -7.8, -8.4, -9.5, -8.3, -11.1,],\n            [-3.9, -3.3, -3.1, -2.8, 10.6, 9.8, 12.2, 9.8, -4.9, 0.1, -3.6, -0.2, -1.7, -4.1, 0.9, -3.5, -5.9, -8.9, -5.6, -8.5, -3.9, -3.9, -2.2, -4.5, -7.3, -7.5, -6.4, -8.5, -7.1, -8.2, -6.7, -7.8, -7.9, -9.1, -7.1, -9.4, 0.9, -0.2, 2.5, -0.3, -6.9, -6.5, -5.5, -6.8, -1.7, -3.4, -1.7, -2.8, -50.0, -13.0, -50.0, -11.5, 1.5, 0.7, 2.7, 0.6, -50.0, -8.9, -12.1, -7.4, -6.1, -11.5, -5.4, -10.4,],\n            [-5.6, -1.8, -6.9, 0.2, 9.6, 9.6, 9.8, 11.6, -6.6, 0.9, -7.2, 2.5, -2.3, -3.4, -2.3, -0.6, -6.5, -8.2, -8.0, -6.3, -3.7, -3.5, -3.9, -1.6, -9.9, -8.9, -9.6, -7.0, -8.6, -8.9, -8.8, -6.8, -8.6, -8.2, -8.8, -6.8, 0.3, 0.1, 0.2, 2.4, -7.4, -6.2, -6.9, -4.4, -2.9, -2.9, -3.5, -0.9, -50.0, -12.2, -50.0, -10.1, 1.2, 0.6, 1.2, 2.4, -50.0, -7.6, -16.1, -5.8, -7.2, -10.8, -7.4, -9.0,],\n            [5.1, -5.4, 3.3, -4.8, -3.2, -7.1, -4.9, -6.6, 13.3, -2.8, 11.2, -1.9, -5.7, -12.5, -7.2, -11.6, -0.7, -4.8, -3.1, -4.3, -10.0, -11.6, -8.8, -11.7, 10.5, 7.7, 9.1, 8.5, -9.8, -12.7, -11.7, -11.8, -6.3, -11.4, -8.8, -11.0, -7.5, -10.3, -8.3, -9.9, -1.9, -6.7, -4.1, -6.4, -7.9, -12.5, -11.4, -11.7, -50.0, -14.0, -50.0, -13.2, -8.5, -10.4, -9.1, -9.6, -50.0, -9.8, -7.7, -8.8, -10.3, -17.9, -11.8, -16.0,],\n            [-5.0, 4.6, -5.5, 2.9, -0.7, 2.4, 0.1, 0.9, -2.8, 12.8, -2.6, 11.0, -8.4, -6.3, -8.3, -7.7, -6.1, -2.9, -6.5, -4.2, -8.5, -5.9, -7.5, -7.7, -5.5, -2.4, -5.5, -4.1, -12.9, -10.3, -12.7, -11.3, -7.4, -3.1, -7.4, -4.9, -4.4, -1.8, -3.5, -3.5, -1.6, 3.0, -0.8, 0.9, -8.4, -6.3, -9.6, -7.3, -50.0, -9.0, -50.0, -9.7, -2.3, -0.2, -1.2, -1.5, -50.0, -0.7, -13.3, -2.0, -11.8, -11.9, -12.3, -12.7,],\n            [3.6, -5.5, 4.8, -5.2, -5.1, -7.2, -3.6, -7.2, 11.2, -2.6, 13.4, -2.1, -7.7, -12.5, -5.3, -11.9, -2.2, -4.4, -1.9, -4.8, -10.2, -11.5, -8.1, -12.0, 9.3, 8.2, 10.0, 8.0, -10.8, -11.9, -10.7, -12.4, -8.2, -11.8, -6.9, -11.5, -8.4, -9.9, -7.1, -10.6, -4.7, -6.8, -1.2, -7.0, -9.8, -11.6, -9.6, -12.1, -50.0, -14.1, -50.0, -12.7, -10.0, -10.8, -8.8, -10.5, -50.0, -9.2, -4.2, -9.3, -11.0, -18.2, -11.1, -16.1,],\n            [-4.2, 3.0, -5.1, 5.2, -0.4, 0.3, -0.2, 2.5, -1.9, 11.0, -2.1, 13.2, -7.6, -8.5, -8.0, -5.3, -5.6, -4.5, -6.8, -2.4, -7.8, -7.9, -7.9, -6.2, -5.7, -5.1, -5.4, -2.1, -12.4, -12.3, -13.1, -10.1, -6.6, -4.4, -6.9, -2.6, -3.6, -3.8, -3.7, -2.0, -1.4, 0.8, -0.9, 3.0, -8.2, -8.1, -9.2, -5.8, -50.0, -10.1, -50.0, -7.4, -1.7, -2.0, -1.5, -0.5, -50.0, -2.1, -12.6, -0.4, -11.6, -13.9, -11.4, -11.1,],\n            [-6.3, -10.2, -8.9, -9.1, 0.7, -2.9, -1.7, -2.3, -5.7, -8.4, -7.7, -7.6, 13.2, 9.6, 3.5, 9.7, -8.7, -12.4, -10.7, -10.7, -7.8, -10.2, -8.8, -9.6, -9.5, -11.9, -10.9, -10.5, 2.3, -0.4, -0.2, -0.3, -9.7, -15.5, -11.4, -13.7, -3.0, -6.4, -4.1, -5.4, -9.6, -11.9, -10.5, -11.8, 6.2, 3.3, 3.7, 3.6, -50.0, -13.6, -50.0, -11.9, -5.6, -8.8, -7.2, -8.9, -50.0, -12.4, -14.1, -11.6, 2.8, -6.4, 0.5, -5.2,],\n            [-13.0, -7.9, -13.2, -9.5, -4.6, -1.2, -4.1, -3.4, -12.5, -6.3, -12.5, -8.5, 9.6, 12.7, 0.2, 10.5, -12.4, -11.6, -13.2, -12.0, -12.4, -10.1, -11.6, -12.0, -15.1, -13.1, -14.3, -13.4, -1.4, 1.4, -1.6, -0.5, -14.9, -14.3, -15.2, -16.8, -7.7, -4.7, -6.3, -6.6, -14.6, -10.8, -12.8, -13.0, 2.3, 6.0, 2.5, 3.6, -50.0, -11.2, -50.0, -11.9, -10.5, -9.2, -10.5, -10.5, -50.0, -10.3, -16.2, -11.3, -1.7, -3.7, -2.5, -5.4,],\n            [-7.1, -9.9, -5.7, -9.0, -0.4, -3.0, 0.9, -2.3, -7.2, -8.3, -5.3, -8.0, 3.5, 0.2, 14.3, 1.0, -7.3, -11.2, -6.9, -9.7, -8.5, -10.2, -7.7, -9.8, -10.0, -10.4, -8.4, -10.2, 1.0, -0.6, 1.7, -0.5, -11.1, -14.8, -9.7, -14.5, -3.7, -5.8, -3.1, -5.6, -10.4, -11.5, -8.2, -11.1, 0.6, -1.6, 1.6, -1.1, -50.0, -12.4, -50.0, -11.5, -5.5, -8.0, -4.9, -7.2, -50.0, -12.4, -10.3, -11.6, 0.7, -6.8, 2.4, -6.0,],\n            [-11.5, -9.6, -12.6, -7.0, -3.6, -3.3, -3.5, -0.6, -11.6, -7.7, -11.9, -5.3, 9.7, 10.5, 1.0, 12.6, -12.0, -12.2, -12.5, -9.7, -11.1, -11.2, -11.9, -9.4, -12.9, -14.3, -14.0, -11.9, -1.0, -0.4, -1.6, 1.2, -13.9, -15.4, -13.7, -12.6, -6.2, -6.7, -6.3, -4.4, -13.0, -12.2, -13.0, -10.4, 2.9, 3.8, 2.5, 5.8, -50.0, -12.5, -50.0, -10.2, -9.6, -9.7, -9.6, -8.3, -50.0, -11.6, -15.4, -9.4, -1.1, -5.4, -1.6, -3.3,],\n            [0.4, -5.0, -1.5, -4.0, -4.8, -7.6, -5.9, -6.5, -0.7, -6.1, -2.2, -5.6, -8.7, -12.4, -7.3, -12.0, 12.8, 2.3, 10.2, 3.0, 0.0, -3.4, -0.7, -3.2, 2.5, -0.8, 0.9, 0.2, -3.0, -7.2, -5.7, -6.1, -0.2, -6.6, -1.8, -6.0, -5.3, -8.2, -5.7, -7.6, -6.7, -9.6, -7.5, -9.3, -7.1, -10.5, -9.6, -9.4, -50.0, -8.1, -50.0, -7.2, -4.3, -6.8, -5.7, -6.3, -50.0, -9.5, -9.6, -8.9, -6.2, -12.8, -6.8, -11.8,],\n            [-6.0, 0.5, -6.1, -1.0, -8.9, -6.7, -8.9, -8.2, -4.8, -2.9, -4.4, -4.5, -12.4, -11.6, -11.2, -12.2, 2.3, 14.6, 1.9, 12.9, -5.5, -2.6, -4.1, -4.7, -1.2, 3.0, -1.1, 1.6, -8.0, -4.7, -8.7, -6.0, -8.2, -4.7, -7.8, -6.7, -10.0, -8.3, -8.9, -9.9, -10.8, -7.1, -10.0, -9.2, -11.6, -10.1, -12.3, -11.9, -50.0, 2.2, -50.0, 0.9, -7.9, -5.9, -7.4, -6.9, -50.0, -4.6, -11.6, -5.6, -9.7, -5.9, -9.9, -7.3,],\n            [-1.9, -5.5, -0.6, -5.0, -6.5, -8.1, -5.6, -8.0, -3.1, -6.5, -1.9, -6.8, -10.7, -13.2, -6.9, -12.5, 10.2, 1.9, 11.9, 2.1, -2.3, -4.1, -0.5, -4.6, -0.1, -0.9, 2.4, -0.8, -5.1, -6.9, -4.8, -6.7, -2.3, -7.1, -0.8, -7.2, -7.2, -8.0, -5.6, -8.5, -9.4, -9.7, -7.2, -9.8, -9.2, -11.1, -9.5, -10.7, -50.0, -8.7, -50.0, -8.6, -6.1, -7.5, -5.5, -7.7, -50.0, -10.4, -7.7, -10.0, -7.3, -13.6, -6.4, -13.3,],\n            [-5.3, -1.0, -6.1, 1.0, -7.8, -7.9, -8.5, -6.3, -4.3, -4.2, -4.8, -2.4, -10.7, -12.0, -9.7, -9.7, 3.0, 12.9, 2.1, 14.7, -4.9, -3.8, -4.0, -2.4, -1.0, 0.8, -1.3, 3.4, -7.6, -5.7, -8.1, -3.5, -6.8, -5.8, -7.2, -4.2, -8.9, -10.2, -8.4, -8.2, -9.9, -8.4, -9.7, -6.4, -11.1, -11.1, -11.8, -10.0, -50.0, 0.4, -50.0, 2.6, -7.2, -7.0, -7.4, -5.1, -50.0, -5.7, -9.8, -3.2, -8.4, -7.4, -8.9, -5.9,],\n            [-8.5, -10.3, -10.0, -9.0, -1.4, -4.9, -3.9, -3.7, -10.0, -8.5, -10.2, -7.8, -7.8, -12.4, -8.5, -11.1, 0.0, -5.5, -2.3, -4.9, 12.6, 10.0, 11.1, 10.5, -6.0, -8.3, -6.9, -7.5, -2.2, -7.4, -5.3, -5.9, -8.9, -12.5, -9.4, -11.6, -0.7, -3.9, -2.3, -3.0, -9.1, -9.8, -9.2, -9.5, -5.6, -9.0, -8.0, -8.5, -50.0, -15.3, -50.0, -14.1, 2.3, -1.4, 0.3, -0.5, -50.0, -13.6, -14.3, -11.5, -5.3, -13.7, -6.1, -12.7,],\n            [-11.2, -8.1, -11.8, -8.8, -4.1, -1.9, -3.9, -3.5, -11.6, -5.9, -11.5, -7.9, -10.2, -10.1, -10.2, -11.2, -3.4, -2.6, -4.1, -3.8, 10.0, 13.1, 10.7, 10.6, -8.1, -5.2, -8.0, -6.7, -6.1, -3.7, -7.5, -5.6, -11.1, -10.3, -10.6, -11.9, -3.2, -1.0, -2.2, -2.8, -10.5, -8.1, -9.4, -9.5, -8.3, -6.9, -9.4, -8.8, -50.0, -11.3, -50.0, -12.8, -0.6, 2.2, -0.3, 0.1, -50.0, -10.1, -17.5, -11.1, -8.6, -9.9, -8.6, -11.9,],\n            [-8.9, -9.4, -8.6, -8.9, -2.9, -4.5, -2.2, -3.9, -8.8, -7.5, -8.1, -7.9, -8.8, -11.6, -7.7, -11.9, -0.7, -4.1, -0.5, -4.0, 11.1, 10.7, 13.2, 10.4, -5.7, -5.8, -3.5, -6.1, -3.6, -6.5, -3.3, -5.5, -9.4, -11.0, -8.7, -11.2, -1.8, -2.7, 0.7, -3.0, -9.1, -8.2, -7.3, -9.4, -7.2, -8.2, -7.2, -8.2, -50.0, -13.2, -50.0, -13.3, 0.5, -0.9, 1.8, -0.6, -50.0, -11.4, -11.1, -10.5, -6.1, -12.9, -5.0, -11.9,],\n            [-10.8, -9.6, -11.9, -7.7, -3.3, -3.8, -4.5, -1.6, -11.7, -7.7, -12.0, -6.2, -9.6, -12.0, -9.8, -9.4, -3.2, -4.7, -4.6, -2.4, 10.5, 10.6, 10.4, 12.6, -8.2, -7.9, -9.0, -4.7, -6.1, -6.0, -7.5, -2.9, -10.9, -12.2, -11.2, -10.9, -2.4, -2.9, -2.7, -0.9, -10.4, -9.7, -10.2, -8.0, -8.4, -9.1, -9.3, -6.5, -50.0, -13.3, -50.0, -11.0, -0.0, -0.4, -0.4, 2.3, -50.0, -10.9, -17.2, -8.3, -8.3, -12.7, -7.8, -9.3,],\n            [2.1, -8.1, 1.2, -7.0, -8.0, -9.5, -7.3, -9.9, 10.5, -5.5, 9.3, -5.7, -9.5, -15.1, -10.0, -12.9, 2.5, -1.2, -0.1, -1.0, -6.0, -8.1, -5.7, -8.2, 13.8, 11.3, 11.8, 12.1, -6.0, -9.1, -9.0, -9.5, -8.9, -13.4, -10.0, -13.1, -9.9, -11.7, -9.8, -12.8, -5.9, -9.4, -6.5, -8.1, -10.7, -14.0, -13.3, -13.9, -50.0, -11.9, -50.0, -9.7, -8.9, -10.8, -9.0, -11.1, -50.0, -6.5, -5.3, -6.3, -10.5, -16.2, -10.4, -15.2,],\n            [0.0, -5.0, 0.5, -6.8, -9.1, -7.8, -7.5, -8.9, 7.7, -2.4, 8.2, -5.1, -11.9, -13.1, -10.4, -14.3, -0.8, 3.0, -0.9, 0.8, -8.3, -5.2, -5.8, -7.9, 11.3, 15.0, 11.2, 12.8, -9.7, -5.3, -9.2, -7.8, -11.7, -10.6, -10.1, -12.2, -11.7, -8.8, -8.9, -11.8, -9.3, -5.0, -8.0, -8.2, -13.6, -11.4, -12.8, -13.0, -50.0, -7.2, -50.0, -8.4, -11.0, -7.7, -8.7, -10.2, -50.0, -1.5, -7.1, -4.9, -11.2, -11.6, -11.6, -15.0,],\n            [1.4, -7.3, 2.2, -7.1, -8.0, -9.3, -6.4, -9.6, 9.1, -5.5, 10.0, -5.4, -10.9, -14.3, -8.4, -14.0, 0.9, -1.1, 2.4, -1.3, -6.9, -8.0, -3.5, -9.0, 11.8, 11.2, 13.4, 11.4, -7.3, -8.8, -6.5, -8.5, -10.0, -12.5, -7.8, -12.5, -9.6, -11.0, -7.1, -10.7, -7.9, -8.0, -4.3, -9.4, -11.4, -12.3, -10.9, -12.9, -50.0, -11.8, -50.0, -11.2, -9.4, -9.8, -7.3, -10.5, -50.0, -6.2, -2.2, -6.7, -9.8, -15.2, -8.5, -14.9,],\n            [0.2, -6.3, 0.1, -4.3, -8.2, -8.9, -8.5, -7.0, 8.5, -4.1, 8.0, -2.1, -10.5, -13.4, -10.2, -11.9, 0.2, 1.6, -0.8, 3.4, -7.5, -6.7, -6.1, -4.7, 12.1, 12.8, 11.4, 14.7, -8.7, -7.4, -9.4, -5.3, -9.9, -11.8, -10.5, -10.3, -9.9, -10.1, -9.3, -9.3, -8.1, -7.2, -8.0, -5.2, -12.0, -12.1, -12.6, -10.9, -50.0, -7.9, -50.0, -5.3, -9.3, -8.8, -8.9, -7.0, -50.0, -3.6, -7.1, -1.2, -10.2, -12.7, -9.9, -11.0,],\n            [-10.2, -13.4, -11.8, -12.4, -6.0, -9.4, -7.1, -8.6, -9.8, -12.9, -10.8, -12.4, 2.3, -1.4, 1.0, -1.0, -3.0, -8.0, -5.1, -7.6, -2.2, -6.1, -3.6, -6.1, -6.0, -9.7, -7.3, -8.7, 11.2, 7.9, 8.9, 8.1, -12.1, -17.4, -13.2, -16.8, -6.3, -9.5, -7.5, -8.8, -12.7, -15.2, -13.1, -14.2, 0.0, -3.1, -1.8, -3.1, -50.0, -10.7, -50.0, -9.3, -4.6, -8.9, -5.9, -8.3, -50.0, -12.8, -9.6, -10.6, 9.5, -3.2, 8.2, -2.8,],\n            [-13.5, -11.3, -14.0, -12.9, -9.3, -7.1, -8.2, -8.9, -12.7, -10.3, -11.9, -12.3, -0.4, 1.4, -0.6, -0.4, -7.2, -4.7, -6.9, -5.7, -7.4, -3.7, -6.5, -6.0, -9.1, -5.3, -8.8, -7.4, 7.9, 11.9, 7.8, 9.3, -15.2, -15.1, -14.6, -17.2, -9.7, -7.3, -8.2, -9.2, -15.0, -12.8, -14.1, -14.9, -2.8, 0.2, -2.9, -2.3, -50.0, -7.4, -50.0, -8.7, -9.4, -7.3, -9.4, -9.4, -50.0, -8.0, -11.9, -9.7, 6.5, 0.5, 6.4, -1.8,],\n            [-13.0, -14.4, -11.9, -13.9, -7.7, -9.0, -6.7, -8.8, -11.7, -12.7, -10.7, -13.1, -0.2, -1.6, 1.7, -1.6, -5.7, -8.7, -4.8, -8.1, -5.3, -7.5, -3.3, -7.5, -9.0, -9.2, -6.5, -9.4, 8.9, 7.8, 10.1, 7.8, -14.3, -17.7, -13.0, -17.8, -8.0, -9.4, -6.2, -9.2, -15.1, -14.9, -12.2, -14.9, -1.8, -3.2, -0.8, -3.2, -50.0, -10.8, -50.0, -9.9, -7.3, -9.6, -6.4, -9.4, -50.0, -12.3, -8.7, -11.3, 7.6, -3.3, 8.7, -2.9,],\n            [-12.5, -12.9, -13.4, -10.0, -8.5, -9.0, -7.8, -6.8, -11.8, -11.3, -12.4, -10.1, -0.3, -0.5, -0.5, 1.2, -6.1, -6.0, -6.7, -3.5, -5.9, -5.6, -5.5, -2.9, -9.5, -7.8, -8.5, -5.3, 8.1, 9.3, 7.8, 11.8, -14.4, -15.7, -14.5, -14.6, -8.4, -8.7, -7.9, -7.1, -14.3, -13.8, -13.8, -12.3, -2.4, -2.2, -2.9, -0.2, -50.0, -8.9, -50.0, -7.1, -8.1, -9.1, -8.7, -6.6, -50.0, -9.7, -11.4, -8.0, 6.8, -1.8, 6.9, 0.4,],\n            [-2.6, -6.3, -4.9, -4.9, -6.4, -9.4, -7.9, -8.6, -6.3, -7.4, -8.2, -6.6, -9.7, -14.9, -11.1, -13.9, -0.2, -8.2, -2.3, -6.8, -8.9, -11.1, -9.4, -10.9, -8.9, -11.7, -10.0, -9.9, -12.1, -15.2, -14.3, -14.4, 11.1, 2.9, 9.2, 3.5, -3.0, -7.0, -4.3, -6.2, -2.2, -6.6, -3.7, -5.7, -6.0, -10.4, -8.6, -9.5, -50.0, -15.5, -50.0, -13.9, -7.8, -10.5, -8.7, -9.6, -50.0, -16.5, -17.1, -14.8, -12.1, -18.9, -12.4, -17.4,],\n            [-8.5, 0.8, -9.1, -0.7, -10.1, -7.5, -9.1, -8.2, -11.4, -3.1, -11.8, -4.4, -15.5, -14.3, -14.8, -15.4, -6.6, -4.7, -7.1, -5.8, -12.5, -10.3, -11.0, -12.2, -13.4, -10.6, -12.5, -11.8, -17.4, -15.1, -17.7, -15.7, 2.9, 12.5, 3.1, 10.3, -7.7, -5.2, -6.2, -7.3, -5.4, -1.7, -5.4, -3.7, -11.6, -9.1, -13.0, -10.8, -50.0, -10.3, -50.0, -11.2, -9.8, -8.3, -9.1, -9.7, -50.0, -12.7, -20.6, -13.1, -16.0, -16.6, -17.0, -18.4,],\n            [-5.0, -6.4, -3.4, -5.6, -7.5, -9.3, -7.1, -8.8, -8.8, -7.4, -6.9, -6.9, -11.4, -15.2, -9.7, -13.7, -1.8, -7.8, -0.8, -7.2, -9.4, -10.6, -8.7, -11.2, -10.0, -10.1, -7.8, -10.5, -13.2, -14.6, -13.0, -14.5, 9.2, 3.1, 10.8, 3.0, -4.5, -6.7, -2.7, -6.7, -5.0, -6.8, -2.5, -6.7, -7.5, -10.4, -7.4, -10.2, -50.0, -15.5, -50.0, -14.2, -8.9, -10.2, -8.5, -10.0, -50.0, -15.6, -15.3, -15.5, -13.0, -18.8, -12.6, -18.3,],\n            [-8.1, -1.1, -8.9, 1.4, -8.6, -9.2, -9.4, -6.8, -11.0, -4.9, -11.5, -2.6, -13.7, -16.8, -14.5, -12.6, -6.0, -6.7, -7.2, -4.2, -11.6, -11.9, -11.2, -10.9, -13.1, -12.2, -12.5, -10.3, -16.8, -17.2, -17.8, -14.6, 3.5, 10.3, 3.0, 12.4, -6.9, -7.5, -6.8, -4.9, -5.4, -4.2, -5.4, -1.3, -10.8, -11.5, -12.4, -8.2, -50.0, -12.5, -50.0, -8.9, -9.2, -10.0, -9.4, -7.9, -50.0, -14.3, -19.9, -11.4, -16.2, -19.2, -15.8, -15.9,],\n            [-6.3, -7.4, -8.0, -6.0, 2.8, -0.7, 0.9, 0.3, -7.5, -4.4, -8.4, -3.6, -3.0, -7.7, -3.7, -6.2, -5.3, -10.0, -7.2, -8.9, -0.7, -3.2, -1.8, -2.4, -9.9, -11.7, -9.6, -9.9, -6.3, -9.7, -8.0, -8.4, -3.0, -7.7, -4.5, -6.9, 11.3, 8.2, 9.4, 9.1, -1.0, -3.3, -1.8, -2.4, 1.5, -2.1, -0.4, -1.1, -50.0, -14.5, -50.0, -12.9, 2.8, -0.0, 1.4, 0.7, -50.0, -8.7, -14.1, -7.5, -5.2, -12.5, -6.5, -10.7,],\n            [-9.9, -5.0, -10.0, -6.5, -0.7, 2.6, -0.2, 0.1, -10.3, -1.8, -9.9, -3.8, -6.4, -4.7, -5.8, -6.7, -8.2, -8.3, -8.0, -10.2, -3.9, -1.0, -2.7, -2.9, -11.7, -8.8, -11.0, -10.1, -9.5, -7.3, -9.4, -8.7, -7.0, -5.2, -6.7, -7.5, 8.2, 11.6, 8.8, 9.1, -3.7, -0.9, -3.1, -3.0, -2.0, 1.2, -2.3, -1.3, -50.0, -12.1, -50.0, -12.6, 0.1, 2.5, 0.7, 0.6, -50.0, -6.0, -14.8, -7.5, -8.6, -9.4, -8.5, -11.2,],\n            [-7.5, -6.2, -7.2, -6.2, 0.9, 0.2, 2.5, 0.2, -8.3, -3.5, -7.1, -3.7, -4.1, -6.3, -3.1, -6.3, -5.7, -8.9, -5.6, -8.4, -2.3, -2.2, 0.7, -2.7, -9.8, -8.9, -7.1, -9.3, -7.5, -8.2, -6.2, -7.9, -4.3, -6.2, -2.7, -6.8, 9.4, 8.8, 12.1, 8.8, -2.1, -2.0, 0.1, -2.4, 0.0, -1.1, 1.3, -0.8, -50.0, -11.9, -50.0, -12.6, 1.2, 0.7, 3.5, 0.8, -50.0, -7.1, -12.4, -7.1, -7.1, -10.6, -5.0, -10.6,],\n            [-9.0, -6.5, -10.0, -4.8, 0.1, -0.1, -0.3, 2.4, -9.9, -3.5, -10.6, -2.0, -5.4, -6.6, -5.6, -4.4, -7.6, -9.9, -8.5, -8.2, -3.0, -2.8, -3.0, -0.9, -12.8, -11.8, -10.7, -9.3, -8.8, -9.2, -9.2, -7.1, -6.2, -7.3, -6.7, -4.9, 9.1, 9.1, 8.8, 11.2, -3.1, -3.0, -3.3, -1.0, -1.1, -1.4, -2.0, 1.2, -50.0, -12.8, -50.0, -10.9, 0.8, 0.5, 0.7, 2.3, -50.0, -7.5, -16.5, -5.9, -7.8, -11.1, -7.8, -9.0,],\n            [-7.1, -5.6, -9.1, -5.1, -5.9, -8.0, -6.9, -7.4, -1.9, -1.6, -4.7, -1.4, -9.6, -14.6, -10.4, -13.0, -6.7, -10.8, -9.4, -9.9, -9.1, -10.5, -9.1, -10.4, -5.9, -9.3, -7.9, -8.1, -12.7, -15.0, -15.1, -14.3, -2.2, -5.4, -5.0, -5.4, -1.0, -3.7, -2.1, -3.1, 12.8, 9.6, 11.1, 10.1, -4.8, -9.4, -8.1, -8.6, -50.0, -18.3, -50.0, -15.4, -5.9, -7.5, -6.6, -7.1, -50.0, -9.5, -11.7, -8.4, -12.5, -17.3, -13.2, -15.4,],\n            [-10.2, -1.6, -10.2, -3.2, -7.3, -4.6, -6.5, -6.2, -6.7, 3.0, -6.8, 0.8, -11.9, -10.8, -11.5, -12.2, -9.6, -7.1, -9.7, -8.4, -9.8, -8.1, -8.2, -9.7, -9.4, -5.0, -8.0, -7.2, -15.2, -12.8, -14.9, -13.8, -6.6, -1.7, -6.8, -4.2, -3.3, -0.9, -2.0, -3.0, 9.6, 12.8, 9.7, 10.5, -8.5, -5.6, -9.3, -7.8, -50.0, -12.7, -50.0, -13.8, -6.8, -5.1, -5.3, -6.5, -50.0, -4.1, -12.8, -5.8, -14.4, -14.1, -13.6, -14.8,],\n            [-8.2, -4.7, -7.1, -5.0, -6.5, -7.7, -5.5, -6.9, -4.1, -0.8, -1.2, -0.9, -10.5, -12.8, -8.2, -13.0, -7.5, -10.0, -7.2, -9.7, -9.2, -9.4, -7.3, -10.2, -6.5, -8.0, -4.3, -8.0, -13.1, -14.1, -12.2, -13.8, -3.7, -5.4, -2.5, -5.4, -1.8, -3.1, 0.1, -3.3, 11.1, 9.7, 12.9, 9.8, -5.5, -8.1, -5.4, -7.8, -50.0, -16.4, -50.0, -14.8, -5.9, -7.1, -4.7, -7.2, -50.0, -8.4, -6.4, -8.1, -12.1, -16.2, -10.3, -15.8,],\n            [-9.2, -3.0, -9.9, -1.2, -6.5, -6.1, -6.8, -4.4, -6.4, 0.9, -7.0, 3.0, -11.8, -13.0, -11.1, -10.4, -9.3, -9.2, -9.8, -6.4, -9.5, -9.5, -9.4, -8.0, -8.1, -8.2, -9.4, -5.2, -14.2, -14.9, -14.9, -12.3, -5.7, -3.7, -6.7, -1.3, -2.4, -3.0, -2.4, -1.0, 10.1, 10.5, 9.8, 13.1, -7.2, -8.0, -8.4, -5.0, -50.0, -14.7, -50.0, -11.4, -6.3, -6.7, -5.8, -5.0, -50.0, -6.1, -13.4, -3.6, -13.0, -16.0, -13.7, -13.3,],\n            [-8.2, -10.8, -10.1, -9.8, -0.4, -3.6, -1.7, -2.9, -7.9, -8.4, -9.8, -8.2, 6.2, 2.3, 0.6, 2.9, -7.1, -11.6, -9.2, -11.1, -5.6, -8.3, -7.2, -8.4, -10.7, -13.6, -11.4, -12.0, 0.0, -2.8, -1.8, -2.4, -6.0, -11.6, -7.5, -10.8, 1.5, -2.0, 0.0, -1.1, -4.8, -8.5, -5.5, -7.2, 11.9, 8.6, 10.0, 9.0, -50.0, -14.2, -50.0, -12.8, -4.1, -7.4, -5.7, -6.5, -50.0, -11.0, -14.3, -9.9, 1.4, -7.9, -0.7, -6.8,],\n            [-12.5, -8.7, -13.0, -9.9, -3.9, -1.0, -3.4, -2.9, -12.5, -6.3, -11.6, -8.1, 3.3, 6.0, -1.6, 3.8, -10.5, -10.1, -11.1, -11.1, -9.0, -6.9, -8.2, -9.1, -14.0, -11.4, -12.3, -12.1, -3.1, 0.2, -3.2, -2.2, -10.4, -9.1, -10.4, -11.5, -2.1, 1.2, -1.1, -1.4, -9.4, -5.6, -8.1, -8.0, 8.6, 12.4, 8.6, 9.5, -50.0, -10.4, -50.0, -11.6, -7.2, -5.7, -7.5, -7.4, -50.0, -8.6, -15.7, -9.7, -3.0, -3.7, -3.2, -5.9,],\n            [-11.1, -11.9, -10.6, -11.3, -2.6, -4.1, -1.7, -3.5, -11.4, -9.6, -9.6, -9.2, 3.7, 2.5, 1.6, 2.5, -9.6, -12.3, -9.5, -11.8, -8.0, -9.4, -7.2, -9.3, -13.3, -12.8, -10.9, -12.6, -1.8, -2.9, -0.8, -2.9, -8.6, -13.0, -7.4, -12.4, -0.4, -2.3, 1.3, -2.0, -8.1, -9.3, -5.4, -8.4, 10.0, 8.6, 11.4, 8.9, -50.0, -13.7, -50.0, -13.2, -6.1, -8.1, -5.5, -7.5, -50.0, -11.3, -12.7, -10.1, -1.6, -7.8, -0.3, -7.2,],\n            [-11.4, -10.0, -12.7, -8.2, -3.1, -3.1, -2.8, -0.9, -11.7, -7.3, -12.1, -5.8, 3.6, 3.6, -1.1, 5.8, -9.4, -11.9, -10.7, -10.0, -8.5, -8.8, -8.2, -6.5, -13.9, -13.0, -12.9, -10.9, -3.1, -2.3, -3.2, -0.2, -9.5, -10.8, -10.2, -8.2, -1.1, -1.3, -0.8, 1.2, -8.6, -7.8, -7.8, -5.0, 9.0, 9.5, 8.9, 12.0, -50.0, -13.0, -50.0, -10.3, -6.2, -7.0, -7.1, -5.4, -50.0, -9.3, -14.0, -8.2, -2.4, -6.3, -2.4, -3.9,],\n            [-50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, 33.3, -50.0, 30.6, -50.0, -50.0, -50.0, -50.0, -50.0, 29.2, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0,],\n            [-14.8, -6.2, -14.9, -7.6, -14.6, -11.6, -13.0, -12.2, -14.0, -9.0, -14.1, -10.1, -13.6, -11.2, -12.4, -12.5, -8.1, 2.2, -8.7, 0.4, -15.3, -11.3, -13.2, -13.3, -11.9, -7.2, -11.8, -7.9, -10.7, -7.4, -10.8, -8.9, -15.5, -10.3, -15.5, -12.5, -14.5, -12.1, -11.9, -12.8, -18.3, -12.7, -16.4, -14.7, -14.2, -10.4, -13.7, -13.0, -50.0, 15.1, -50.0, 13.3, -9.9, -5.8, -8.9, -7.6, -50.0, -1.5, -7.8, -3.0, -8.1, 3.6, -9.4, 2.0,],\n            [-50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, 30.6, -50.0, 35.2, -50.0, -50.0, -50.0, -50.0, -50.0, 28.5, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0,],\n            [-13.8, -7.5, -14.4, -5.1, -12.6, -11.6, -11.5, -10.1, -13.2, -9.7, -12.7, -7.4, -11.9, -11.9, -11.5, -10.2, -7.2, 0.9, -8.6, 2.6, -14.1, -12.8, -13.3, -11.0, -9.7, -8.4, -11.2, -5.3, -9.3, -8.7, -9.9, -7.1, -13.9, -11.2, -14.2, -8.9, -12.9, -12.6, -12.6, -10.9, -15.4, -13.8, -14.8, -11.4, -12.8, -11.6, -13.2, -10.3, -50.0, 13.3, -50.0, 15.2, -8.6, -7.0, -8.4, -4.8, -50.0, -3.0, -7.1, -0.1, -7.3, 2.3, -8.7, 3.9,],\n            [-7.3, -6.3, -8.9, -5.5, 2.9, 0.2, 1.5, 1.2, -8.5, -2.3, -10.0, -1.7, -5.6, -10.5, -5.5, -9.6, -4.3, -7.9, -6.1, -7.2, 2.3, -0.6, 0.5, -0.0, -8.9, -11.0, -9.4, -9.3, -4.6, -9.4, -7.3, -8.1, -7.8, -9.8, -8.9, -9.2, 2.8, 0.1, 1.2, 0.8, -5.9, -6.8, -5.9, -6.3, -4.1, -7.2, -6.1, -6.2, -50.0, -9.9, -50.0, -8.6, 12.5, 9.4, 11.0, 9.8, -50.0, -4.8, -8.7, -3.5, -0.0, -8.6, -2.1, -7.0,],\n            [-10.1, -4.3, -10.8, -5.8, 0.1, 2.3, 0.7, 0.6, -10.4, -0.2, -10.8, -2.0, -8.8, -9.2, -8.0, -9.7, -6.8, -5.9, -7.5, -7.0, -1.4, 2.2, -0.9, -0.4, -10.8, -7.7, -9.8, -8.8, -8.9, -7.3, -9.6, -9.1, -10.5, -8.3, -10.2, -10.0, -0.0, 2.5, 0.7, 0.5, -7.5, -5.1, -7.1, -6.7, -7.4, -5.7, -8.1, -7.0, -50.0, -5.8, -50.0, -7.0, 9.4, 12.7, 10.1, 10.0, -50.0, -1.5, -11.3, -3.3, -5.4, -4.2, -5.6, -6.8,],\n            [-8.4, -6.2, -8.9, -5.9, 1.8, 0.4, 2.7, 1.2, -9.1, -1.2, -8.8, -1.5, -7.2, -10.5, -4.9, -9.6, -5.7, -7.4, -5.5, -7.4, 0.3, -0.3, 1.8, -0.4, -9.0, -8.7, -7.3, -8.9, -5.9, -9.4, -6.4, -8.7, -8.7, -9.1, -8.5, -9.4, 1.4, 0.7, 3.5, 0.7, -6.6, -5.3, -4.7, -5.8, -5.7, -7.5, -5.5, -7.1, -50.0, -8.9, -50.0, -8.4, 11.0, 10.1, 13.2, 10.2, -50.0, -4.2, -6.1, -3.6, -3.5, -8.4, -1.2, -6.8,],\n            [-9.1, -5.4, -10.4, -4.2, 1.0, 0.5, 0.6, 2.4, -9.6, -1.5, -10.5, -0.5, -8.9, -10.5, -7.2, -8.3, -6.3, -6.9, -7.7, -5.1, -0.5, 0.1, -0.6, 2.3, -11.1, -10.2, -10.5, -7.0, -8.3, -9.4, -9.4, -6.6, -9.6, -9.7, -10.0, -7.9, 0.7, 0.6, 0.8, 2.3, -7.1, -6.5, -7.2, -5.0, -6.5, -7.4, -7.5, -5.4, -50.0, -7.6, -50.0, -4.8, 9.8, 10.0, 10.2, 12.1, -50.0, -3.1, -11.4, -0.7, -4.6, -6.6, -4.9, -3.9,],\n            [-50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, 29.2, -50.0, 28.5, -50.0, -50.0, -50.0, -50.0, -50.0, 33.3, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0,],\n            [-13.0, -7.0, -13.1, -8.3, -9.2, -6.5, -8.9, -7.6, -9.8, -0.7, -9.2, -2.1, -12.4, -10.3, -12.4, -11.6, -9.5, -4.6, -10.4, -5.7, -13.6, -10.1, -11.4, -10.9, -6.5, -1.5, -6.2, -3.6, -12.8, -8.0, -12.3, -9.7, -16.5, -12.7, -15.6, -14.3, -8.7, -6.0, -7.1, -7.5, -9.5, -4.1, -8.4, -6.1, -11.0, -8.6, -11.3, -9.3, -50.0, -1.5, -50.0, -3.0, -4.8, -1.5, -4.2, -3.1, -50.0, 16.4, -5.1, 14.2, -10.1, -4.3, -10.0, -5.4,],\n            [-13.5, -16.3, -11.8, -15.5, -13.6, -15.3, -12.1, -16.1, -7.7, -13.3, -4.2, -12.6, -14.1, -16.2, -10.3, -15.4, -9.6, -11.6, -7.7, -9.8, -14.3, -17.5, -11.1, -17.2, -5.3, -7.1, -2.2, -7.1, -9.6, -11.9, -8.7, -11.4, -17.1, -20.6, -15.3, -19.9, -14.1, -14.8, -12.4, -16.5, -11.7, -12.8, -6.4, -13.4, -14.3, -15.7, -12.7, -14.0, -50.0, -7.8, -50.0, -7.1, -8.7, -11.3, -6.1, -11.4, -50.0, -5.1, 18.6, -4.8, -8.6, -8.1, -4.5, -7.3,],\n            [-12.4, -8.2, -13.0, -5.9, -7.7, -7.8, -7.4, -5.8, -8.8, -2.0, -9.3, -0.4, -11.6, -11.3, -11.6, -9.4, -8.9, -5.6, -10.0, -3.2, -11.5, -11.1, -10.5, -8.3, -6.3, -4.9, -6.7, -1.2, -10.6, -9.7, -11.3, -8.0, -14.8, -13.1, -15.5, -11.4, -7.5, -7.5, -7.1, -5.9, -8.4, -5.8, -8.1, -3.6, -9.9, -9.7, -10.1, -8.2, -50.0, -3.0, -50.0, -0.1, -3.5, -3.3, -3.6, -0.7, -50.0, 14.2, -4.8, 16.4, -8.9, -5.8, -8.9, -3.4,],\n            [-10.7, -13.2, -12.4, -11.6, -4.8, -8.4, -6.1, -7.2, -10.3, -11.8, -11.0, -11.6, 2.8, -1.7, 0.7, -1.1, -6.2, -9.7, -7.3, -8.4, -5.3, -8.6, -6.1, -8.3, -10.5, -11.2, -9.8, -10.2, 9.5, 6.5, 7.6, 6.8, -12.1, -16.0, -13.0, -16.2, -5.2, -8.6, -7.1, -7.8, -12.5, -14.4, -12.1, -13.0, 1.4, -3.0, -1.6, -2.4, -50.0, -8.1, -50.0, -7.3, -0.0, -5.4, -3.5, -4.6, -50.0, -10.1, -8.6, -8.9, 13.2, -0.9, 9.7, -0.3,],\n            [-18.1, -12.3, -19.4, -14.2, -12.2, -9.5, -11.5, -10.8, -17.9, -11.9, -18.2, -13.9, -6.4, -3.7, -6.8, -5.4, -12.8, -5.9, -13.6, -7.4, -13.7, -9.9, -12.9, -12.7, -16.2, -11.6, -15.2, -12.7, -3.2, 0.5, -3.3, -1.8, -18.9, -16.6, -18.8, -19.2, -12.5, -9.4, -10.6, -11.1, -17.3, -14.1, -16.2, -16.0, -7.9, -3.7, -7.8, -6.3, -50.0, 3.6, -50.0, 2.3, -8.6, -4.2, -8.4, -6.6, -50.0, -4.3, -8.1, -5.8, -0.9, 14.2, -1.8, 11.6,],\n            [-11.8, -13.1, -11.5, -12.0, -6.2, -8.3, -5.4, -7.4, -11.8, -12.3, -11.1, -11.4, 0.5, -2.5, 2.4, -1.6, -6.8, -9.9, -6.4, -8.9, -6.1, -8.6, -5.0, -7.8, -10.4, -11.6, -8.5, -9.9, 8.2, 6.4, 8.7, 6.9, -12.4, -17.0, -12.6, -15.8, -6.5, -8.5, -5.0, -7.8, -13.2, -13.6, -10.3, -13.7, -0.7, -3.2, -0.3, -2.4, -50.0, -9.4, -50.0, -8.7, -2.1, -5.6, -1.2, -4.9, -50.0, -10.0, -4.5, -8.9, 9.7, -1.8, 11.3, -0.9,],\n            [-17.2, -13.3, -17.8, -11.6, -11.0, -11.1, -10.4, -9.0, -16.0, -12.7, -16.1, -11.1, -5.2, -5.4, -6.0, -3.3, -11.8, -7.3, -13.3, -5.9, -12.7, -11.9, -11.9, -9.3, -15.2, -15.0, -14.9, -11.0, -2.8, -1.8, -2.9, 0.4, -17.4, -18.4, -18.3, -15.9, -10.7, -11.2, -10.6, -9.0, -15.4, -14.8, -15.8, -13.3, -6.8, -5.9, -7.2, -3.9, -50.0, 2.0, -50.0, 3.9, -7.0, -6.8, -6.8, -3.9, -50.0, -5.4, -7.3, -3.4, -0.3, 11.6, -0.9, 14.1,]];\n        this.TRANS = [[5, 0, 0, 4],\n            [0, 5, 4, 0],\n            [0, 4, 5, 0],\n            [4, 0, 0, 5]];\n        this.CONBLO = { 'A': 0, 'R': 1, 'N': 2, 'D': 3, 'C': 4, 'Q': 5, 'E': 6, 'G': 7, 'H': 8, 'I': 9, 'L': 10, 'K': 11, 'M': 12, 'F': 13, 'P': 14, 'S': 15, 'T': 16, 'W': 17, 'Y': 18, 'V': 19, 'B': 20, 'Z': 21, 'X': 22, '*': 23 };\n        this.CONNUCL = { 'A': 0, 'T': 1, 'C': 2, 'G': 3 };\n        this.CONSCHN = { 'AAA': 0, 'AAC': 1, 'AAG': 2, 'AAT': 3, 'ACA': 4, 'ACC': 5, 'ACG': 6, 'ACT': 7, 'AGA': 8, 'AGC': 9, 'AGG': 10, 'AGT': 11, 'ATA': 12, 'ATC': 13, 'ATG': 14, 'ATT': 15, 'CAA': 16, 'CAC': 17, 'CAG': 18, 'CAT': 19, 'CCA': 20, 'CCC': 21, 'CCG': 22, 'CCT': 23, 'CGA': 24, 'CGC': 25, 'CGG': 26, 'CGT': 27, 'CTA': 28, 'CTC': 29, 'CTG': 30, 'CTT': 31, 'GAA': 32, 'GAC': 33, 'GAG': 34, 'GAT': 35, 'GCA': 36, 'GCC': 37, 'GCG': 38, 'GCT': 39, 'GGA': 40, 'GGC': 41, 'GGG': 42, 'GGT': 43, 'GTA': 44, 'GTC': 45, 'GTG': 46, 'GTT': 47, 'TAA': 48, 'TAC': 49, 'TAG': 50, 'TAT': 51, 'TCA': 52, 'TCC': 53, 'TCG': 54, 'TCT': 55, 'TGA': 56, 'TGC': 57, 'TGG': 58, 'TGT': 59, 'TTA': 60, 'TTC': 61, 'TTG': 62, 'TTT': 63 };\n        this.setMethod(alignGrid_);\n        this.setSequences(seq1_, seq2_);\n        this.setGap(gap_);\n    }\n    fillNeedleman() {\n        for (let i = 0; i <= this.len1; i++) {\n            this.dpGrid[i][0].value = -i * this.gap;\n            this.dpGrid[i][0].parentI = i - 1;\n            this.dpGrid[i][0].parentJ = 0;\n        }\n        for (let i = 1; i <= this.len2; i++) {\n            this.dpGrid[0][i].value = -i * this.gap;\n            this.dpGrid[0][i].parentI = 0;\n            this.dpGrid[0][i].parentJ = i - 1;\n        }\n    }\n    fillOne(i, j) {\n        this.dpGrid[i][j].value = Math.max(this.dpGrid[i - 1][j - 1].value + this.scores[i - 1][j - 1], Math.max(this.dpGrid[i - 1][j].value - this.gap, this.dpGrid[i][j - 1].value - this.gap));\n        if (this.dpGrid[i][j].value == this.dpGrid[i - 1][j - 1].value + this.scores[i - 1][j - 1]) {\n            this.dpGrid[i][j].parentI = i - 1;\n            this.dpGrid[i][j].parentJ = j - 1;\n        }\n        else if (this.dpGrid[i][j].value == this.dpGrid[i - 1][j].value - this.gap) {\n            this.dpGrid[i][j].parentI = i - 1;\n            this.dpGrid[i][j].parentJ = j;\n        }\n        else {\n            this.dpGrid[i][j].parentI = i;\n            this.dpGrid[i][j].parentJ = j - 1;\n        }\n    }\n    gridFromName(path) {\n        switch (path) {\n            case 'BLOSUM45':\n                this.alignGrid = this.BLOSUM45;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM50':\n                this.alignGrid = this.BLOSUM50;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM62':\n                this.alignGrid = this.BLOSUM62;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM80':\n                this.alignGrid = this.BLOSUM80;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM90':\n                this.alignGrid = this.BLOSUM90;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'PAM30':\n                this.alignGrid = this.PAM30;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'PAM70':\n                this.alignGrid = this.PAM70;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'PAM250':\n                this.alignGrid = this.PAM250;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'NUCLEOTIDES':\n                this.alignGrid = this.NUCLEOTIDES;\n                this.connections = this.CONNUCL;\n                this.step = 1;\n                break;\n            case 'TRANS':\n                this.alignGrid = this.TRANS;\n                this.connections = this.CONNUCL;\n                this.step = 1;\n                break;\n            case 'SCHNEIDER':\n                this.alignGrid = this.SCHNEIDER;\n                this.connections = this.CONSCHN;\n                this.step = 3;\n                break;\n        }\n        this.fillScores();\n    }\n    constructResult(i, j) {\n        let res1 = \"\", res2 = \"\", gapS = \"\";\n        let total = this.dpGrid[i][j].value;\n        for (let i = 0; i < this.step; i++) {\n            gapS += '|';\n        }\n        while (i > 0 || j > 0) {\n            if (this.dpGrid[i][j].parentI == i) {\n                res1 = gapS + res1;\n                res2 = this.seq2.substr((j - 1) * this.step, this.step) + res2;\n            }\n            else if (this.dpGrid[i][j].parentJ == j) {\n                res2 = gapS + res2;\n                res1 = this.seq1.substr((i - 1) * this.step, this.step) + res1;\n            }\n            else {\n                if (i - 1 >= 0)\n                    res1 = this.seq1.substr((i - 1) * this.step, this.step) + res1;\n                else\n                    res1 = gapS + res1;\n                if (j - 1 >= 0)\n                    res2 = this.seq2.substr((j - 1) * this.step, this.step) + res2;\n                else\n                    res2 = gapS + res2;\n            }\n            let tempI = i;\n            i = this.dpGrid[i][j].parentI;\n            j = this.dpGrid[tempI][j].parentJ;\n        }\n        return new Aligned(res1, res2, total);\n    }\n    fillScores() {\n        this.scores = [];\n        for (let i = 0; i < this.len1; i++) {\n            this.scores.push([]);\n            for (let j = 0; j < this.len2; j++) {\n                this.scores[i].push(this.alignGrid[this.connections[this.seq1.substr(i * this.step, this.step)]][this.connections[this.seq2.substr(j * this.step, this.step)]]);\n            }\n        }\n    }\n    typeRec() {\n        if (/[ATGC]*/.test(this.seq1) && /[ATGC]*/.test(this.seq2))\n            return \"NUCLEOTIDES\";\n        if (/[ARNDCQEGHILKMFPSTWYVBZX*]*/.test(this.seq1) && /[ARNDCQEGHILKMFPSTWYVBZX*]*/.test(this.seq2))\n            return \"BLOSUM62\";\n        throw Error(\"Can't recognize sequence type\");\n    }\n    needlemanWunch() {\n        this.dpGrid = [];\n        for (let i = 0; i < this.len1 + 1; i++) {\n            let row = [];\n            for (let j = 0; j < this.len2 + 1; j++)\n                row.push(new Cell());\n            this.dpGrid.push(row);\n        }\n        this.fillNeedleman();\n        for (let i = 1; i <= this.len1; i++) {\n            for (let j = 1; j <= this.len2; j++) {\n                this.fillOne(i, j);\n            }\n        }\n        return this.constructResult(this.len1, this.len2);\n    }\n    smithWaterman() {\n        this.dpGrid = [];\n        for (let i = 0; i < this.len1 + 1; i++) {\n            let row = [];\n            for (let j = 0; j < this.len2 + 1; j++)\n                row.push(new Cell());\n            this.dpGrid.push(row);\n        }\n        let bestVal = 0;\n        let bestI = 0, bestJ = 0;\n        for (let i = 1; i <= this.len1; i++) {\n            for (let j = 1; j <= this.len2; j++) {\n                this.fillOne(i, j);\n                if (this.dpGrid[i][j].value <= 0) {\n                    this.dpGrid[i][j].value = 0;\n                    this.dpGrid[i][j].parentI = 0;\n                    this.dpGrid[i][j].parentJ = 0;\n                }\n                else if (this.dpGrid[this.dpGrid[i][j].parentI][this.dpGrid[i][j].parentJ].value == 0) {\n                    this.dpGrid[i][j].parentI = 0;\n                    this.dpGrid[i][j].parentJ = 0;\n                }\n                if (this.dpGrid[i][j].value > bestVal) {\n                    bestVal = this.dpGrid[i][j].value;\n                    bestI = i;\n                    bestJ = j;\n                }\n            }\n        }\n        return this.constructResult(bestI, bestJ);\n    }\n    setSequences(seq1_, seq2_) {\n        this.seq1 = seq1_;\n        this.seq2 = seq2_;\n        this.len1 = this.seq1.length / this.step;\n        this.len2 = this.seq2.length / this.step;\n        this.fillScores();\n    }\n    setGap(gap_) {\n        this.gap = gap_;\n    }\n    setMethod(alignGrid_ = \"\") {\n        if (alignGrid_ == \"AUTO\") {\n            alignGrid_ = this.typeRec();\n        }\n        this.gridFromName(alignGrid_);\n    }\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as grok from 'datagrok-api/grok';\nexport function getMacroMol(monomers) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let result = [];\n        const moduleRdkit = yield grok.functions.call('Chem:getRdKitModule');\n        for (let i = 0; i < monomers.length; i++) {\n            for (let j = 0; j < monomers[i].length; j++) {\n                const mol = moduleRdkit.get_mol(monomers[i][j]['molfile']);\n                const a = mol.get_v3Kmolblock();\n                const indices = getIndices(monomers[i][j], a);\n                monomers[i][j]['indices'] = indices;\n                monomers[i][j]['molfile'] = yield rotateBackboneV3000(a, indices);\n                mol === null || mol === void 0 ? void 0 : mol.delete();\n            }\n            result.push(linkV3000(monomers[i]));\n        }\n        return result;\n    });\n}\nfunction getIndices(monomer, molV3000) {\n    const molfile = monomer[\"molfile\"];\n    let indexStart = molfile.indexOf('M  RGP', 0) + 8;\n    let indexEnd = molfile.indexOf('\\n', indexStart);\n    const indicesData = molfile.substring(indexStart, indexEnd).replaceAll('  ', ' ').replaceAll('  ', ' ');\n    let parsedData = indicesData.split(' ');\n    const remFirst = parsedData[2] == '1' ? parseInt(parsedData[1]) : parseInt(parsedData[3]);\n    const remLast = parsedData[2] == '2' ? parseInt(parsedData[1]) : parseInt(parsedData[3]);\n    const numbers = extractAtomsBondsNumbersV3000(molV3000);\n    let indexBonds = molV3000.indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n    indexBonds = molV3000.indexOf('\\n', indexBonds);\n    indexStart = indexBonds;\n    indexEnd = indexBonds;\n    let first = 0;\n    let last = 0;\n    let remBondFirst = 0;\n    let remBondLast = 0;\n    for (let j = 0; j < numbers.nbond; j++) {\n        if (first == 0 || last == 0) {\n            indexStart = molV3000.indexOf('V30', indexStart) + 4;\n            indexEnd = molV3000.indexOf('\\n', indexStart);\n            const bondData = molV3000.substring(indexStart, indexEnd).replaceAll('  ', ' ').replaceAll('  ', ' ');\n            parsedData = bondData.split(' ');\n            if (parseInt(parsedData[2]) == remFirst) {\n                first = parseInt(parsedData[3]);\n                remBondFirst = parseInt(parsedData[0]);\n            }\n            else if (parseInt(parsedData[3]) == remFirst) {\n                first = parseInt(parsedData[2]);\n                remBondFirst = parseInt(parsedData[0]);\n            }\n            else if (parseInt(parsedData[2]) == remLast) {\n                last = parseInt(parsedData[3]);\n                remBondLast = parseInt(parsedData[0]);\n            }\n            else if (parseInt(parsedData[3]) == remLast) {\n                last = parseInt(parsedData[2]);\n                remBondLast = parseInt(parsedData[0]);\n            }\n        }\n    }\n    return { first, last, remFirst, remLast, remBondFirst, remBondLast };\n}\nfunction rotateBackboneV3000(molBlock, indices) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const coordinates = extractAtomDataV3000(molBlock);\n        const natom = coordinates.atomIndex.length;\n        const first = indices['first'];\n        const last = indices['last'];\n        const xCenter = (coordinates.x[last] + coordinates.x[first]) / 2;\n        const yCenter = (coordinates.y[last] + coordinates.y[first]) / 2;\n        //place to center\n        for (let i = 0; i < natom; i++) {\n            coordinates.x[i] -= xCenter;\n            coordinates.y[i] -= yCenter;\n        }\n        let angle = 0;\n        if (coordinates.x[first] == 0)\n            angle = coordinates.y[first] > coordinates.y[last] ? Math.PI / 2 : 3 * Math.PI / 2;\n        else if (coordinates.y[first] == 0)\n            angle = coordinates.x[first] > coordinates.x[last] ? Math.PI : 0;\n        else {\n            const derivative = coordinates.y[first] / coordinates.x[first];\n            if (coordinates.x[first] < coordinates.x[last])\n                angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);\n            else\n                angle = derivative > 0 ? Math.atan(derivative) : Math.PI - Math.atan(derivative);\n        }\n        const cos = Math.cos(angle);\n        const sin = Math.sin(angle);\n        for (let i = 0; i < natom; i++) {\n            const xAdd = coordinates.x[i];\n            coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n            coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n        }\n        //place to right\n        const xShift = coordinates.x[first];\n        for (let i = 0; i < natom; i++)\n            coordinates.x[i] -= xShift;\n        //rewrite molBlock\n        let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        index = molBlock.indexOf('\\n', index);\n        let indexEnd = index;\n        for (let i = 0; i < natom; i++) {\n            index = molBlock.indexOf('V30', index) + 4;\n            index = molBlock.indexOf(' ', index) + 1;\n            index = molBlock.indexOf(' ', index) + 1;\n            indexEnd = molBlock.indexOf(' ', index) + 1;\n            indexEnd = molBlock.indexOf(' ', indexEnd);\n            molBlock = molBlock.slice(0, index) +\n                coordinates.x[i] + ' ' + coordinates.y[i] +\n                molBlock.slice(indexEnd);\n            index = molBlock.indexOf('\\n', index) + 1;\n        }\n        return molBlock;\n    });\n}\nfunction extractAtomDataV3000(molBlock) {\n    const numbers = extractAtomsBondsNumbersV3000(molBlock);\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    const indexes = Array(numbers.natom);\n    const types = Array(numbers.natom);\n    const x = Array(numbers.natom);\n    const y = Array(numbers.natom);\n    for (let i = 0; i < numbers.natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        indexEnd = molBlock.indexOf(' ', index);\n        indexes[i] = parseInt(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        types[i] = molBlock.substring(index, indexEnd);\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        x[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        y[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return { atomIndex: indexes, atomType: types, x: x, y: y };\n}\nfunction linkV3000(monomers) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let xShift = 0;\n    for (let i = 0; i < monomers.length; i++) {\n        let molfile = monomers[i]['molfile'];\n        const first = monomers[i]['indices']['first'];\n        const last = monomers[i]['indices']['last'];\n        const remFirst = monomers[i]['indices']['remFirst'];\n        const remLast = monomers[i]['indices']['remLast'];\n        const remBondFirst = monomers[i]['indices']['remBondFirst'];\n        const remBondLast = monomers[i]['indices']['remBondLast'];\n        molfile = molfile.replaceAll('(-\\nM  V30 ', '(')\n            .replaceAll('-\\nM  V30 ', '').replaceAll(' )', ')');\n        const numbers = extractAtomsBondsNumbersV3000(molfile);\n        const coordinates = extractAtomDataV3000(molfile);\n        let indexAtoms = molfile.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        indexAtoms = molfile.indexOf('\\n', indexAtoms);\n        let index = indexAtoms;\n        let indexEnd = indexAtoms;\n        const totalShift = xShift - coordinates.x[first - 1];\n        for (let j = 0; j < numbers.natom; j++) {\n            if (coordinates.atomIndex[j] != remFirst && coordinates.atomIndex[j] != remLast) { //|| i == 0) {\n                //rewrite atom number\n                index = molfile.indexOf('V30', index) + 4;\n                indexEnd = molfile.indexOf(' ', index);\n                let atomNumber = parseInt(molfile.substring(index, indexEnd));\n                atomNumber = (atomNumber > remFirst && atomNumber > remLast) ? atomNumber - 2 :\n                    (atomNumber > remFirst || atomNumber > remLast) ? atomNumber - 1 : atomNumber;\n                atomNumber += natom;\n                molfile = molfile.slice(0, index) + atomNumber + molfile.slice(indexEnd);\n                //rewrite coordinates\n                index = molfile.indexOf(' ', index) + 1;\n                index = molfile.indexOf(' ', index) + 1;\n                indexEnd = molfile.indexOf(' ', index);\n                let coordinate = Math.round(10000 * (parseFloat(molfile.substring(index, indexEnd)) + totalShift)) / 10000;\n                molfile = molfile.slice(0, index) + coordinate + molfile.slice(indexEnd);\n                index = molfile.indexOf(' ', index) + 1;\n                indexEnd = molfile.indexOf(' ', index);\n                coordinate = Math.round(10000 * (parseFloat(molfile.substring(index, indexEnd)))) / 10000;\n                molfile = molfile.slice(0, index) + coordinate + molfile.slice(indexEnd);\n                index = molfile.indexOf('\\n', index) + 1;\n            }\n            else {\n                index = molfile.indexOf('M  V30', index) - 1;\n                indexEnd = molfile.indexOf('\\n', index + 1);\n                molfile = molfile.slice(0, index) + molfile.slice(indexEnd);\n            }\n        }\n        const indexAtomsEnd = molfile.indexOf('M  V30 END ATOM');\n        atomBlock += molfile.substring(indexAtoms + 1, indexAtomsEnd);\n        let indexBonds = molfile.indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n        indexBonds = molfile.indexOf('\\n', indexBonds);\n        index = indexBonds;\n        indexEnd = indexBonds;\n        let bondNumber = 0;\n        for (let j = 0; j < numbers.nbond; j++) {\n            //rewrite bond number\n            index = molfile.indexOf('V30', index) + 4;\n            indexEnd = molfile.indexOf(' ', index);\n            bondNumber = parseInt(molfile.substring(index, indexEnd));\n            if (bondNumber == remBondFirst || bondNumber == remBondLast) {\n                indexEnd = molfile.indexOf('\\n', index) + 1;\n                index -= 7;\n                molfile = molfile.slice(0, index) + molfile.slice(indexEnd);\n                continue;\n            }\n            bondNumber = (bondNumber > remBondFirst && bondNumber > remBondLast) ? bondNumber - 2 :\n                (bondNumber > remBondFirst || bondNumber > remBondLast) ? bondNumber - 1 : bondNumber;\n            bondNumber += nbond;\n            molfile = molfile.slice(0, index) + bondNumber + molfile.slice(indexEnd);\n            //rewrite atom pair in bond\n            index = molfile.indexOf(' ', index) + 1;\n            index = molfile.indexOf(' ', index) + 1;\n            indexEnd = molfile.indexOf(' ', index);\n            let atomNumber = parseInt(molfile.substring(index, indexEnd));\n            atomNumber = (atomNumber > remFirst && atomNumber > remLast) ? atomNumber - 2 :\n                (atomNumber > remFirst || atomNumber > remLast) ? atomNumber - 1 : atomNumber;\n            atomNumber += natom;\n            molfile = molfile.slice(0, index) + atomNumber + molfile.slice(indexEnd);\n            index = molfile.indexOf(' ', index) + 1;\n            indexEnd = Math.min(molfile.indexOf('\\n', index), molfile.indexOf(' ', index));\n            atomNumber = parseInt(molfile.substring(index, indexEnd));\n            atomNumber = (atomNumber > remFirst && atomNumber > remLast) ? atomNumber - 2 :\n                (atomNumber > remFirst || atomNumber > remLast) ? atomNumber - 1 : atomNumber;\n            atomNumber += natom;\n            molfile = molfile.slice(0, index) + atomNumber + molfile.slice(indexEnd);\n            index = molfile.indexOf('\\n', index) + 1;\n        }\n        const indexBondEnd = molfile.indexOf('M  V30 END BOND');\n        bondBlock += molfile.substring(indexBonds + 1, indexBondEnd);\n        //let indexCollection = molfile.indexOf('M  V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections\n        // while (indexCollection != -1) {\n        //   indexCollection += 28;\n        //   const collectionEnd = molfile.indexOf(')', indexCollection);\n        //   const collectionEntries = molfile.substring(indexCollection, collectionEnd).split(' ').slice(1);\n        //   collectionEntries.forEach((e: string) => {\n        //     collection.push(parseInt(e) + natom);\n        //   });\n        //   indexCollection = collectionEnd;\n        //   indexCollection = molfile.indexOf('M  V30 MDLV30/STEABS ATOMS=(', indexCollection);\n        // }\n        natom += numbers.natom - 2;\n        nbond += numbers.nbond - 2;\n        xShift += coordinates.x[last] - coordinates.x[first] + 1;\n        if (i == monomers.length - 1) {\n            natom++;\n            const shift = xShift + 0.2;\n            atomBlock += 'M  V30 ' + natom + ' O ' + shift + ' 0 0.000000 0\\n';\n        }\n        nbond++;\n        if (i == monomers.length - 1) {\n            const rightTerminal = (last > remFirst && last > remLast) ? last + natom - (numbers.natom - 2) - 3 :\n                (last > remFirst || last > remLast) ? last + natom - (numbers.natom - 2) - 2 :\n                    last + natom - (numbers.natom - 2) - 1;\n            bondBlock += 'M  V30 ' + nbond + ' 1 ' + rightTerminal + ' ' + natom + '\\n';\n        }\n        else {\n            const rightTerminal = (last > remFirst && last > remLast) ? last + natom - (numbers.natom - 2) - 2 :\n                (last > remFirst || last > remLast) ? last + natom - (numbers.natom - 2) - 1 :\n                    last + natom - (numbers.natom - 2);\n            const next = monomers[i + 1]['indices'];\n            const nextFirst = next['first'];\n            const nextRemFirst = next['remFirst'];\n            const nextRemLast = next['remLast'];\n            const leftTerminal = (nextFirst > nextRemFirst && nextFirst > nextRemLast) ? nextFirst + natom - 2 :\n                (nextFirst > nextRemFirst || nextFirst > nextRemLast) ? nextFirst + natom - 1 :\n                    nextFirst + natom;\n            bondBlock += 'M  V30 ' + nbond + ' 1 ' + rightTerminal + ' ' + leftTerminal + '\\n';\n        }\n    }\n    // const entries = 4;\n    // const collNumber = Math.ceil(collection.length / entries);\n    // collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\\n';\n    // for (let i = 0; i < collNumber; i++) {\n    //   collectionBlock += 'M  V30 ';\n    //   const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1)*entries : entries;\n    //   for (let j = 0; j < entriesCurrent; j++) {\n    //     collectionBlock += (j + 1 == entriesCurrent) ?\n    //       (i == collNumber - 1 ? collection[entries*i + j] + ')\\n' : collection[entries*i + j] + ' -\\n') :\n    //       collection[entries*i + j] + ' ';\n    //   }\n    // }\n    //generate file\n    macroMolBlock += 'M  V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\\n';\n    macroMolBlock += 'M  V30 BEGIN ATOM\\n';\n    macroMolBlock += atomBlock;\n    macroMolBlock += 'M  V30 END ATOM\\n';\n    macroMolBlock += 'M  V30 BEGIN BOND\\n';\n    macroMolBlock += bondBlock;\n    macroMolBlock += 'M  V30 END BOND\\n';\n    //macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n    //macroMolBlock += collectionBlock;\n    //macroMolBlock += 'M  V30 END COLLECTION\\n';\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\n    return macroMolBlock;\n}\nfunction extractAtomsBondsNumbersV3000(molBlock) {\n    molBlock = molBlock.replaceAll('\\r', ''); //equalize old and new sdf standards\n    let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number\n    let indexEnd = molBlock.indexOf(' ', index);\n    const atomsNumber = parseInt(molBlock.substring(index, indexEnd));\n    index = indexEnd + 1;\n    indexEnd = molBlock.indexOf(' ', index);\n    const bondsNumber = parseInt(molBlock.substring(index, indexEnd));\n    return { natom: atomsNumber, nbond: bondsNumber };\n}\n","import * as C from \"./constants\";\nimport * as DG from 'datagrok-api/dg';\nimport { AminoacidsPalettes } from \"@datagrok-libraries/bio/src/aminoacids\";\nimport { NucleotidesPalettes } from \"@datagrok-libraries/bio/src/nucleotides\";\nimport { UnknownSeqPalettes } from \"@datagrok-libraries/bio/src/unknown\";\nimport { WebLogo } from \"@datagrok-libraries/bio/src/viewers/web-logo\";\nimport * as ui from 'datagrok-api/ui';\nconst lru = new DG.LruCache();\nconst undefinedColor = 'rgb(100,100,100)';\nfunction getPalleteByType(paletteType) {\n    switch (paletteType) {\n        case 'PT':\n            return AminoacidsPalettes.GrokGroups;\n        case 'NT':\n            return NucleotidesPalettes.Chromatogram;\n        // other\n        default:\n            return UnknownSeqPalettes.Color;\n    }\n}\nexport function processSequence(subParts) {\n    const simplified = !subParts.some((amino, index) => amino.length > 1 &&\n        index != 0 &&\n        index != subParts.length - 1);\n    const text = [];\n    const gap = simplified ? '' : ' ';\n    subParts.forEach((amino, index) => {\n        if (index < subParts.length)\n            amino += `${amino ? '' : '-'}${gap}`;\n        text.push(amino);\n    });\n    return [text, simplified];\n}\n/**\n * A function that prints a string aligned to left or centered.\n *\n * @param {number} x x coordinate.\n * @param {number} y y coordinate.\n * @param {number} w Width.\n * @param {number} h Height.\n * @param {CanvasRenderingContext2D} g Canvas rendering context.\n * @param {string} s String to print.\n * @param {string} [color=undefinedColor] String color.\n * @param {number} [pivot=0] Pirvot.\n * @param {boolean} [left=false] Is left aligned.\n * @param {boolean} [hideMod=false] Hide amino acid redidue modifications.\n * @param {number} [transparencyRate=0.0] Transparency rate where 1.0 is fully transparent\n * @return {number} x coordinate to start printing at.\n */\nfunction printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pivot = 0, left = false, hideMod = false, transparencyRate = 1.0, separator = '', last = false) {\n    g.textAlign = 'start';\n    let colorPart = s.substring(0);\n    let grayPart = separator;\n    if (last) {\n        grayPart = '';\n    }\n    const textSize = g.measureText(colorPart + grayPart);\n    const indent = 5;\n    const colorTextSize = g.measureText(colorPart);\n    const dy = (textSize.fontBoundingBoxAscent + textSize.fontBoundingBoxDescent) / 2;\n    function draw(dx1, dx2) {\n        g.fillStyle = color;\n        g.globalAlpha = transparencyRate;\n        g.fillText(colorPart, x + dx1, y + dy);\n        g.fillStyle = '#808080';\n        g.fillText(grayPart, x + dx2, y + dy);\n    }\n    if (left || textSize.width > w) {\n        draw(indent, indent + colorTextSize.width);\n        return x + colorTextSize.width + g.measureText(grayPart).width;\n    }\n    else {\n        const dx = (w - textSize.width) / 2;\n        draw(dx, dx + colorTextSize.width);\n        return x + dx + colorTextSize.width;\n    }\n}\nexport class MacromoleculeSequenceCellRenderer extends DG.GridCellRenderer {\n    get name() { return 'macromoleculeSequence'; }\n    get cellType() { return C.SEM_TYPES.Macro_Molecule; }\n    get defaultHeight() { return 30; }\n    get defaultWidth() { return 230; }\n    /**\n     * Cell renderer function.\n     *\n     * @param {CanvasRenderingContext2D} g Canvas rendering context.\n     * @param {number} x x coordinate on the canvas.\n     * @param {number} y y coordinate on the canvas.\n     * @param {number} w width of the cell.\n     * @param {number} h height of the cell.\n     * @param {DG.GridCell} gridCell Grid cell.\n     * @param {DG.GridCellStyle} cellStyle Cell style.\n     * @memberof AlignedSequenceCellRenderer\n     */\n    render(g, x, y, w, h, gridCell, cellStyle) {\n        var _a, _b;\n        const grid = gridCell.grid;\n        const cell = gridCell.cell;\n        const tag = gridCell.cell.column.getTag(DG.TAGS.UNITS);\n        if (tag === 'HELM') {\n            let host = ui.div([], { style: { width: `${w}px`, height: `${h}px` } });\n            host.setAttribute('dataformat', 'helm');\n            host.setAttribute('data', gridCell.cell.value);\n            gridCell.element = host;\n            //@ts-ignore\n            var canvas = new JSDraw2.Editor(host, { width: w, height: h, skin: \"w8\", viewonly: true });\n            var formula = canvas.getFormula(true);\n            if (!formula) {\n                gridCell.element = ui.divText(gridCell.cell.value, { style: { color: 'red' } });\n            }\n            else {\n                gridCell.element = host;\n                var molWeight = Math.round(canvas.getMolWeight() * 100) / 100;\n                var coef = Math.round(canvas.getExtinctionCoefficient(true) * 100) / 100;\n                var molfile = canvas.getMolfile();\n                var result = formula + ', ' + molWeight + ', ' + coef + ', ' + molfile;\n                lru.set(gridCell.cell.value, result);\n            }\n        }\n        else {\n            const [type, subtype, paletteType] = gridCell.cell.column.getTag(DG.TAGS.UNITS).split(\":\");\n            w = grid ? Math.min(grid.canvas.width - x, w) : g.canvas.width - x;\n            g.save();\n            g.beginPath();\n            g.rect(x, y, w, h);\n            g.clip();\n            g.font = '12px monospace';\n            g.textBaseline = 'top';\n            const s = (_a = cell.value) !== null && _a !== void 0 ? _a : '';\n            //TODO: can this be replaced/merged with splitSequence?\n            const units = gridCell.cell.column.getTag(DG.TAGS.UNITS);\n            const palette = getPalleteByType(paletteType);\n            const separator = (_b = gridCell.cell.column.getTag('separator')) !== null && _b !== void 0 ? _b : '';\n            const splitterFunc = WebLogo.getSplitter(units, gridCell.cell.column.getTag('separator')); // splitter,\n            const subParts = splitterFunc(cell.value);\n            // console.log(subParts);\n            const textSize = g.measureText(subParts.join(''));\n            let x1 = x;\n            let color = undefinedColor;\n            subParts.forEach((amino, index) => {\n                color = palette.get(amino);\n                g.fillStyle = undefinedColor;\n                let last = false;\n                if (index === subParts.length - 1) {\n                    last = true;\n                }\n                x1 = printLeftOrCentered(x1, y, w, h, g, amino, color, 0, true, false, 1.0, separator, last);\n            });\n            g.restore();\n        }\n    }\n}\n","export var COLUMNS_NAMES;\n(function (COLUMNS_NAMES) {\n    COLUMNS_NAMES[\"SPLIT_COL\"] = \"~split\";\n    COLUMNS_NAMES[\"ACTIVITY\"] = \"~activity\";\n    COLUMNS_NAMES[\"ACTIVITY_SCALED\"] = \"activity_scaled\";\n    COLUMNS_NAMES[\"ALIGNED_SEQUENCE\"] = \"~aligned_sequence\";\n    COLUMNS_NAMES[\"AMINO_ACID_RESIDUE\"] = \"AAR\";\n    COLUMNS_NAMES[\"POSITION\"] = \"Pos\";\n    COLUMNS_NAMES[\"P_VALUE\"] = \"pValue\";\n    COLUMNS_NAMES[\"MEAN_DIFFERENCE\"] = \"Mean difference\";\n})(COLUMNS_NAMES || (COLUMNS_NAMES = {}));\nexport var CATEGORIES;\n(function (CATEGORIES) {\n    CATEGORIES[\"OTHER\"] = \"Other\";\n    CATEGORIES[\"ALL\"] = \"All\";\n})(CATEGORIES || (CATEGORIES = {}));\nexport var TAGS;\n(function (TAGS) {\n    TAGS[\"AAR\"] = \"AAR\";\n    TAGS[\"POSITION\"] = \"Pos\";\n    TAGS[\"SEPARATOR\"] = \"monomer-separator\";\n    TAGS[\"SELECTION\"] = \"selection\";\n})(TAGS || (TAGS = {}));\nexport var SEM_TYPES;\n(function (SEM_TYPES) {\n    SEM_TYPES[\"AMINO_ACIDS\"] = \"aminoAcids\";\n    SEM_TYPES[\"ALIGNED_SEQUENCE\"] = \"alignedSequence\";\n    SEM_TYPES[\"ALIGNED_SEQUENCE_DIFFERENCE\"] = \"alignedSequenceDifference\";\n    SEM_TYPES[\"ACTIVITY\"] = \"activity\";\n    SEM_TYPES[\"ACTIVITY_SCALED\"] = \"activityScaled\";\n    SEM_TYPES[\"Macro_Molecule\"] = \"Macromolecule\";\n})(SEM_TYPES || (SEM_TYPES = {}));\nexport const STATS = 'stats';\nexport const EMBEDDING_STATUS = 'embeddingStatus';\nexport const PEPTIDES_ANALYSIS = 'isPeptidesAnalysis';\nexport var FLAGS;\n(function (FLAGS) {\n    FLAGS[\"CELL_CHANGING\"] = \"isCellChanging\";\n})(FLAGS || (FLAGS = {}));\nexport const aarGroups = {\n    'R': 'PC', 'H': 'PC', 'K': 'PC',\n    'D': 'NC', 'E': 'NC',\n    'S': 'U', 'T': 'U', 'N': 'U', 'Q': 'U',\n    'C': 'SC', 'U': 'SC', 'G': 'SC', 'P': 'SC',\n    'A': 'H', 'V': 'H', 'I': 'H', 'L': 'H', 'M': 'H', 'F': 'H', 'Y': 'H', 'W': 'H',\n    '-': '-',\n};\nexport const groupDescription = {\n    'PC': { 'description': 'Positive Amino Acids, with Electrically Charged Side Chains', 'aminoAcids': ['R', 'H', 'K'] },\n    'NC': { 'description': 'Negative Amino Acids, with Electrically Charged Side Chains', 'aminoAcids': ['D', 'E'] },\n    'U': { 'description': 'Amino Acids with Polar Uncharged Side Chains', 'aminoAcids': ['S', 'T', 'N', 'Q'] },\n    'SC': { 'description': 'Special Cases', 'aminoAcids': ['C', 'U', 'G', 'P'] },\n    'H': {\n        'description': 'Amino Acids with Hydrophobic Side Chain',\n        'aminoAcids': ['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'],\n    },\n    '-': { 'description': 'Unknown Amino Acid', 'aminoAcids': ['-'] },\n};\n","import * as ui from 'datagrok-api/ui';\nimport { NotationConverter } from './notation-converter';\n/**\n * Converts notations of a Macromolecule column\n *\n * @param {DG.column} col Column with 'Macromolecule' semantic type\n */\nexport function convert(col) {\n    const converter = new NotationConverter(col);\n    const current = converter.sourceNotation;\n    //TODO: read all notations\n    const notations = [\n        \"FASTA\" /* NOTATION.FASTA */,\n        \"SEPARATOR\" /* NOTATION.SEPARATOR */,\n        \"HELM\" /* NOTATION.HELM */\n    ];\n    const separatorArray = ['-', '.', '/'];\n    const filteredNotations = notations.filter((e) => e !== current);\n    const targetNotationInput = ui.choiceInput('Convert to', filteredNotations[0], filteredNotations);\n    const separatorInput = ui.choiceInput('Choose separator', separatorArray[0], separatorArray);\n    ui.dialog('Convert sequence notation')\n        .add(ui.div([\n        ui.h1('Current notation: ' + current),\n        targetNotationInput.root,\n        // TODO: conditional separator input\n        separatorInput.root\n    ]))\n        .onOK(() => {\n        //TODO: create new converted column\n        const targetNotation = targetNotationInput.value;\n        const separator = separatorInput.value;\n        const newColumn = converter.convert(targetNotation, separator);\n        col.dataFrame.columns.add(newColumn);\n    })\n        .show();\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\n//@ts-ignore\nimport Aioli from '@biowasm/aioli';\nimport { AlignedSequenceEncoder } from '@datagrok-libraries/bio/src/sequence-encoder';\n/**\n * Converts array of sequences into simple fasta string.\n *\n * @param {string[]} sequences Input list of sequences.\n * @return {string} Fasta-formatted string.\n */\nfunction _stringsToFasta(sequences) {\n    return sequences.reduce((a, v, i) => a + `>sample${i + 1}\\n${v}\\n`, '');\n}\n/**\n * Extracts array of sequences from simple fasta string.\n *\n * @param {string} fasta Fasta-formatted string.\n * @return {string[]} Output list of sequences.\n */\nfunction _fastaToStrings(fasta) {\n    return fasta.replace(/>sample\\d+(\\r\\n|\\r|\\n)/g, '').split('\\n');\n}\n/**\n * Runs Aioli environment with kalign tool.\n *\n * @param {DG.Column} srcCol Column with sequences.\n * @param {boolean} isAligned Whether the column is aligned.\n * @return {Promise<DG.Column>} Aligned sequences.\n */\nexport function runKalign(srcCol, isAligned = false) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let sequences = srcCol.toList();\n        if (isAligned)\n            sequences = sequences.map((v, _) => AlignedSequenceEncoder.clean(v).replace(/\\-/g, ''));\n        const fasta = _stringsToFasta(sequences);\n        const CLI = yield new Aioli({\n            tool: 'kalign',\n            version: '3.3.1',\n            reinit: true,\n        });\n        console.log(['fasta.length =', fasta.length]);\n        yield CLI.fs.writeFile('input.fa', fasta);\n        const output = yield CLI.exec('kalign input.fa -f fasta -o result.fasta');\n        console.warn(output);\n        const buf = yield CLI.cat('result.fasta');\n        if (!buf)\n            throw new Error(`kalign output no result`);\n        const aligned = _fastaToStrings(buf).slice(0, sequences.length);\n        const tgtCol = DG.Column.fromStrings(`msa(${srcCol.name})`, aligned);\n        // units\n        const srcUnits = srcCol.getTag(DG.TAGS.UNITS);\n        const tgtUnits = srcUnits.split(':').map((p, i) => i == 1 ? p + '.MSA' : p).join(':');\n        tgtCol.setTag(DG.TAGS.UNITS, tgtUnits);\n        tgtCol.semType = DG.SEMTYPE.MACROMOLECULE;\n        return tgtCol;\n    });\n}\nexport function testMSAEnoughMemory(col) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const sequencesCount = col.length;\n        const delta = sequencesCount / 100;\n        for (let i = delta; i < sequencesCount; i += delta) {\n            try {\n                yield runKalign(DG.Column.fromStrings(col.name, col.toList().slice(0, Math.round(i))));\n                console.log(`runKalign succeeded on ${i}`);\n            }\n            catch (error) {\n                console.log(`runKalign failed on ${i} with '${error}'`);\n            }\n        }\n    });\n}\n","import * as DG from 'datagrok-api/dg';\nimport { WebLogo } from '@datagrok-libraries/bio/src/viewers/web-logo';\n/** Class for handling conversion of notation systems in Macromolecule columns */\nexport class NotationConverter {\n    constructor(col) {\n        this._sourceColumn = col;\n        this._sourceUnits = this._sourceColumn.tags[DG.TAGS.UNITS];\n        this._sourceNotation = this.determineSourceNotation();\n    }\n    get sourceUnits() { return this._sourceUnits; }\n    get sourceColumn() { return this._sourceColumn; }\n    get sourceNotation() { return this._sourceNotation; }\n    isFasta() { return this.sourceNotation === \"FASTA\" /* NOTATION.FASTA */; }\n    isSeparator() { return this.sourceNotation === \"SEPARATOR\" /* NOTATION.SEPARATOR */; }\n    isHelm() { return this.sourceNotation === \"HELM\" /* NOTATION.HELM */; }\n    toFasta(targetNotation) { return targetNotation === \"FASTA\" /* NOTATION.FASTA */; }\n    toSeparator(targetNotation) { return targetNotation === \"SEPARATOR\" /* NOTATION.SEPARATOR */; }\n    toHelm(targetNotation) { return targetNotation === \"HELM\" /* NOTATION.HELM */; }\n    isRna() { return this.sourceUnits.toLowerCase().endsWith('rna'); }\n    isDna() { return this.sourceUnits.toLowerCase().endsWith('dna'); }\n    isPeptide() { return this.sourceUnits.toLowerCase().endsWith('pt'); }\n    /** Associate notation types with the corresponding units */\n    /**\n     * @return {NOTATION}     Notation associated with the units type\n     */\n    determineSourceNotation() {\n        if (this.sourceUnits.toLowerCase().startsWith('fasta'))\n            return \"FASTA\" /* NOTATION.FASTA */;\n        else if (this.sourceUnits.toLowerCase().startsWith('separator'))\n            return \"SEPARATOR\" /* NOTATION.SEPARATOR */;\n        else\n            // TODO: handle possible exceptions\n            return \"HELM\" /* NOTATION.HELM */;\n    }\n    /**\n     * Determine the separator used in SEPARATOR column\n     *\n     * @return {string} The detected separator\n     */\n    determineSeparator() {\n        //   TODO: figure out how to determine the separator efficiently\n        const col = this.sourceColumn;\n        let i = 0;\n        const re = /[^a-z]/;\n        while (i < col.length) {\n            const molecule = col.get(i);\n            const foundSeparator = molecule.toLowerCase().match(re);\n            if (foundSeparator)\n                return foundSeparator[0];\n            i++;\n        }\n        throw new Error('No separators found');\n    }\n    /**\n     * Create a new empty column of the specified notation type and the same\n     * length as sourceColumn\n     *\n     * @param {NOTATION} targetNotation\n     * @return {DG.Column}\n     */\n    getNewColumn(targetNotation) {\n        const col = this.sourceColumn;\n        const len = col.length;\n        const name = targetNotation + '(' + col.name + ')';\n        const newColName = col.dataFrame.columns.getUnusedName(name);\n        // dummy code\n        const newColumn = DG.Column.fromList('string', newColName, new Array(len).fill(''));\n        newColumn.semType = 'Macromolecule';\n        newColumn.setTag(DG.TAGS.UNITS, this.sourceUnits.replace(this.sourceNotation.toLowerCase().toString(), targetNotation.toLowerCase().toString()));\n        // TODO: specify cell renderers for all cases\n        if (this.toFasta(targetNotation)) {\n            newColumn.setTag(DG.TAGS.CELL_RENDERER, 'Macromolecule');\n        }\n        return newColumn;\n    }\n    /**\n     * Convert a Macromolecule column from FASTA to SEPARATOR notation\n     *\n     * @param {string} separator  A specific separator to be used\n     * @param {string} gapSymbol  Gap symbol in FASTA, '-' by default\n     * @return {DG.Column}        A new column in SEPARATOR notation\n     */\n    convertFastaToSeparator(separator, gapSymbol = '-') {\n        // a function splitting FASTA sequence into an array of monomers:\n        const splitterAsFasta = WebLogo.splitterAsFasta;\n        const newColumn = this.getNewColumn(\"SEPARATOR\" /* NOTATION.SEPARATOR */);\n        // assign the values to the newly created empty column\n        newColumn.init((idx) => {\n            const fastaPolymer = this.sourceColumn.get(idx);\n            const fastaMonomersArray = splitterAsFasta(fastaPolymer);\n            for (let i = 0; i < fastaMonomersArray.length; i++) {\n                if (fastaMonomersArray[i] === gapSymbol)\n                    fastaMonomersArray[i] = '';\n            }\n            return fastaMonomersArray.join(separator);\n        });\n        return newColumn;\n    }\n    /**\n     * Convert a Macromolecule column from FASTA to HELM\n     *\n     * @param {string} fastaGapSymbol   Optional fasta gap symbol\n     * @param {string} helmGapSymbol    Optional helm gap symbol\n     * @return {DG.Column}              A new column in HELM notation\n     */\n    convertFastaToHelm(fastaGapSymbol = '-', helmGapSymbol = '*') {\n        // a function splitting FASTA sequence into an array of monomers\n        const splitterAsFasta = WebLogo.splitterAsFasta;\n        const prefix = (this.isDna()) ? 'DNA1{' :\n            (this.isRna()) ? 'RNA1{' :\n                (this.isPeptide()) ? 'PEPTIDE1{' :\n                    'Unknown'; // this case should be handled as exceptional\n        if (prefix === 'Unknown')\n            throw new Error('Neither peptide, nor nucleotide');\n        const postfix = '}$$$';\n        const leftWrapper = (this.isDna()) ? 'D(' :\n            (this.isRna()) ? 'R(' : ''; // no wrapper for peptides\n        const rightWrapper = (this.isDna() || this.isRna()) ? ')P' : ''; // no wrapper for peptides\n        const newColumn = this.getNewColumn(\"HELM\" /* NOTATION.HELM */);\n        // assign the values to the empty column\n        newColumn.init((idx) => {\n            const fastaPolymer = this.sourceColumn.get(idx);\n            const fastaMonomersArray = splitterAsFasta(fastaPolymer);\n            const helmArray = [prefix];\n            let firstIteration = true;\n            for (let i = 0; i < fastaMonomersArray.length; i++) {\n                if (fastaMonomersArray[i] === fastaGapSymbol) {\n                    // TODO: verify the correctness of gap symbols handling\n                    helmArray.push(helmGapSymbol);\n                }\n                else {\n                    const dot = firstIteration ? '' : '.';\n                    const item = [dot, leftWrapper, fastaMonomersArray[i], rightWrapper];\n                    helmArray.push(item.join(''));\n                }\n                firstIteration = false;\n            }\n            helmArray.push(postfix);\n            return helmArray.join('');\n        });\n        return newColumn;\n    }\n    handleSeparatorItemForFasta(idx, separatorItemsArray, separator, gapSymbol, fastaMonomersArray) {\n        const item = separatorItemsArray[idx];\n        if (item.length > 1) {\n            // the case of a multi-character monomer\n            const monomer = '[' + item + ']';\n            fastaMonomersArray.push(monomer);\n        }\n        if (item === separator) {\n            if (idx !== 0 && separatorItemsArray[idx - 1] === separator)\n                fastaMonomersArray.push(gapSymbol);\n        }\n    }\n    convertSeparatorToFasta(separator = null, gapSymbol = '-') {\n        // TODO: implementation\n        // * similarly to fasta2separator, divide string into monomers\n        // * adjacent separators is a gap (symbol to be specified)\n        // * the monomers MUST be single-character onles, otherwise forbid\n        // * NO, they can be multi-characters\n        // conversion\n        // * consider automatic determining the separator\n        // if (separator === null)\n        //   separator = this.determineSeparator();\n        // a function splitting FASTA sequence into an array of monomers\n        //const splitterAsSeparator = WebLogo.getSplitterWithSeparator(separator);\n        const splitter = WebLogo.getSplitterForColumn(this._sourceColumn);\n        const newColumn = this.getNewColumn(\"FASTA\" /* NOTATION.FASTA */);\n        // assign the values to the empty column\n        newColumn.init((idx) => {\n            const separatorPolymer = this.sourceColumn.get(idx);\n            // items can be monomers or separators\n            const separatorItemsArray = splitter(separatorPolymer);\n            const fastaMonomersArray = [];\n            for (let i = 0; i < separatorItemsArray.length; i++) {\n                const item = separatorItemsArray[i];\n                if (item.length === 0) {\n                    fastaMonomersArray.push(gapSymbol);\n                }\n                else if (item.length > 1) {\n                    // the case of a multi-character monomer\n                    const monomer = '[' + item + ']';\n                    fastaMonomersArray.push(monomer);\n                }\n                else {\n                    fastaMonomersArray.push(item);\n                }\n            }\n            return fastaMonomersArray.join('');\n        });\n        return newColumn;\n    }\n    convertSeparatorToHelm(fastaGapSymbol = '-', helmGapSymbol = '*') {\n        // a function splitting FASTA sequence into an array of monomers\n        const splitter = WebLogo.getSplitterForColumn(this._sourceColumn);\n        const prefix = (this.isDna()) ? 'DNA1{' :\n            (this.isRna()) ? 'RNA1{' :\n                (this.isPeptide()) ? 'PEPTIDE1{' :\n                    'Unknown'; // this case should be handled as exceptional\n        if (prefix === 'Unknown')\n            throw new Error('Neither peptide, nor nucleotide');\n        const postfix = '}$$$';\n        const leftWrapper = (this.isDna()) ? 'D(' :\n            (this.isRna()) ? 'R(' : ''; // no wrapper for peptides\n        const rightWrapper = (this.isDna() || this.isRna()) ? ')P' : ''; // no wrapper for peptides\n        const newColumn = this.getNewColumn(\"HELM\" /* NOTATION.HELM */);\n        // assign the values to the empty column\n        newColumn.init((idx) => {\n            const fastaPolymer = this.sourceColumn.get(idx);\n            const fastaMonomersArray = splitter(fastaPolymer);\n            const helmArray = [prefix];\n            let firstIteration = true;\n            for (let i = 0; i < fastaMonomersArray.length; i++) {\n                if (fastaMonomersArray[i] === fastaGapSymbol) {\n                    // TODO: verify the correctness of gap symbols handling\n                    helmArray.push(helmGapSymbol);\n                }\n                else {\n                    const dot = firstIteration ? '' : '.';\n                    const item = [dot, leftWrapper, fastaMonomersArray[i], rightWrapper];\n                    helmArray.push(item.join(''));\n                }\n                firstIteration = false;\n            }\n            helmArray.push(postfix);\n            return helmArray.join('');\n        });\n        return newColumn;\n    }\n    convertHelmToFasta() {\n        // TODO: implementation\n        return this.getNewColumn(\"FASTA\" /* NOTATION.FASTA */);\n    }\n    convertHelmToSeparator() {\n        // TODO: implementatioreturn this.getNewColumn();\n        return this.getNewColumn(\"SEPARATOR\" /* NOTATION.SEPARATOR */);\n    }\n    /** Dispatcher method for notation conversion\n     *\n     * @param {NOTATION} targetNotation   Notation we want to convert to\n     * @param {string | null} tgtSeparator   Possible separator\n     * @return {DG.Column}                Converted column\n     */\n    convert(targetNotation, tgtSeparator = null) {\n        // possible exceptions\n        if (this.sourceNotation === targetNotation)\n            throw new Error('Target notation is invalid');\n        if (this.toSeparator(targetNotation) && tgtSeparator === null)\n            throw new Error('Target separator is not specified');\n        if (this.isFasta() && this.toSeparator(targetNotation) && tgtSeparator !== null)\n            return this.convertFastaToSeparator(tgtSeparator);\n        else if (this.isFasta() && this.toHelm(targetNotation))\n            return this.convertFastaToHelm();\n        else if (this.isSeparator() && this.toFasta(targetNotation))\n            return this.convertSeparatorToFasta(tgtSeparator);\n        else if (this.isSeparator() && this.toHelm(targetNotation))\n            return this.convertSeparatorToHelm();\n        else if (this.isHelm() && this.toFasta(targetNotation))\n            return this.convertHelmToFasta();\n        else\n            return this.convertHelmToSeparator();\n    }\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\nimport { AvailableMetrics } from '@datagrok-libraries/ml/src/typed-metrics';\nexport function sequenceGetSimilarities(col, seq) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const stringArray = col.toList();\n        const distances = new Array(stringArray.length).fill(0.0);\n        for (let i = 0; i < stringArray.length; ++i)\n            distances[i] = getSimilarityFromDistance(AvailableMetrics['String']['Levenshtein'](stringArray[i], seq));\n        return DG.Column.fromList(DG.COLUMN_TYPE.FLOAT, 'distances', distances);\n    });\n}\nexport function drawTooltip(params) {\n    params.tooltips[params.line.id] = ui.divH([]);\n    const columnNames = ui.divV([\n        ui.divText('sequense'),\n        ui.divText(params.activity.name),\n    ]);\n    columnNames.style.fontWeight = 'bold';\n    columnNames.style.display = 'flex';\n    columnNames.style.justifyContent = 'space-between';\n    params.tooltips[params.line.id].append(columnNames);\n    params.line.mols.forEach((mol) => {\n        const seq = ui.divText(params.df.get(params.seqCol.name, mol));\n        const activity = ui.divText(params.df.get(params.activity.name, mol).toFixed(2));\n        activity.style.display = 'flex';\n        activity.style.justifyContent = 'left';\n        activity.style.paddingLeft = '30px';\n        params.tooltips[params.line.id].append(ui.divV([\n            seq,\n            activity,\n        ], { style: { paddingLeft: '5px' } }));\n    });\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\nimport { AvailableMetrics } from '@datagrok-libraries/ml/src/typed-metrics';\nimport { reduceDimensinalityWithNormalization } from '@datagrok-libraries/ml/src/sequence-space';\nexport function sequenceSpace(spaceParams) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let preparedData;\n        if (!(spaceParams.seqCol.tags[DG.TAGS.UNITS] === 'HELM')) {\n            const sep = spaceParams.seqCol.getTag('separator');\n            const sepFinal = sep ? sep === '.' ? '\\\\\\.' : sep : '-';\n            const regex = new RegExp(sepFinal, 'g');\n            if (Object.keys(AvailableMetrics['String']).includes(spaceParams.similarityMetric))\n                preparedData = spaceParams.seqCol.toList().map((v) => v.replace(regex, ''));\n            else\n                preparedData = spaceParams.seqCol.toList().map((v) => v.replace(regex, ''));\n        }\n        else {\n            preparedData = spaceParams.seqCol.toList();\n        }\n        const sequenceSpaceResult = yield reduceDimensinalityWithNormalization(preparedData, spaceParams.methodName, spaceParams.similarityMetric, spaceParams.options);\n        const cols = spaceParams.embedAxesNames.map((name, index) => DG.Column.fromFloat32Array(name, sequenceSpaceResult.embedding[index]));\n        return { distance: sequenceSpaceResult.distance, coordinates: new DG.ColumnList(cols) };\n    });\n}\nexport function getEmbeddingColsNames(df) {\n    const axes = ['Embed_X', 'Embed_Y'];\n    const colNameInd = df.columns.names().filter((it) => it.includes(axes[0])).length + 1;\n    return axes.map((it) => `${it}_${colNameInd}`);\n}\n","import * as DG from 'datagrok-api/dg';\nimport { WebLogo } from '@datagrok-libraries/bio/src/viewers/web-logo';\nimport * as grok from 'datagrok-api/grok';\nexport const HELM_CORE_LIB_FILENAME = '/samples/HELMCoreLibrary.json';\nexport const HELM_CORE_LIB_MONOMER_SYMBOL = 'symbol';\nexport const HELM_CORE_LIB_MOLFILE = 'molfile';\nexport const HELM_CORE_FIELDS = ['symbol', 'molfile', 'rgroups', 'name'];\nexport function getMolfilesFromSeq(col, monomersLibObject) {\n    const units = col.tags[DG.TAGS.UNITS];\n    const sep = col.getTag('separator');\n    const splitterFunc = WebLogo.getSplitter(units, sep);\n    const monomersDict = createMomomersMolDict(monomersLibObject);\n    const molFiles = [];\n    for (let i = 0; i < col.length; ++i) {\n        const monomers = splitterFunc(col.get(i));\n        const molFilesForSeq = [];\n        for (let j = 0; j < monomers.length; ++j) {\n            if (monomers[j]) {\n                if (!monomersDict[monomers[j]]) {\n                    grok.shell.warning(`Monomer ${monomers[j]} is missing in HELM library. Structure cannot be created`);\n                    return null;\n                }\n                molFilesForSeq.push(JSON.parse(JSON.stringify(monomersDict[monomers[j]])));\n            }\n        }\n        molFiles.push(molFilesForSeq);\n    }\n    return molFiles;\n}\nexport function createMomomersMolDict(lib) {\n    const dict = {};\n    lib.forEach((it) => {\n        if (it['polymerType'] === 'PEPTIDE') {\n            const monomerObject = {};\n            HELM_CORE_FIELDS.forEach((field) => {\n                monomerObject[field] = it[field];\n            });\n            dict[it[HELM_CORE_LIB_MONOMER_SYMBOL]] = monomerObject;\n        }\n    });\n    return dict;\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { VdRegionType } from '@datagrok-libraries/bio/src/vd-regions';\nconst vrt = VdRegionType;\n// Positions of regions for numbering schemes\n// http://www.bioinf.org.uk/abs/info.html\n// const imgtRegions: VdRegion[] = [\n//   new VdRegion(vrt.FR, 'FR1', 'Light', 1, '1', '26'),\n//   new VdRegion(vrt.FR, 'FR1', 'Heavy', 1, '1', '26'),\n//\n//   new VdRegion(vrt.CDR, 'CDR1', 'Light', 2, '27', '38'), // 27-32\n//   new VdRegion(vrt.CDR, 'CDR1', 'Heavy', 2, '27', '38'), // 27-32\n//\n//   new VdRegion(vrt.FR, 'FR2', 'Light', 3, '39', '55'),\n//   new VdRegion(vrt.FR, 'FR2', 'Heavy', 3, '39', '55'),\n//\n//   new VdRegion(vrt.CDR, 'CDR2', 'Light', 4, '56', '65'),\n//   new VdRegion(vrt.CDR, 'CDR2', 'Heavy', 4, '56', '65'),\n//\n//   new VdRegion(vrt.FR, 'FR3', 'Light', 5, '66', '104'),\n//   new VdRegion(vrt.FR, 'FR3', 'Heavy', 5, '66', '104'),\n//\n//   new VdRegion(vrt.CDR, 'CDR3', 'Light', 6, '105', '117'),\n//   new VdRegion(vrt.CDR, 'CDR3', 'Heavy', 6, '105', '117'),\n//\n//   new VdRegion(vrt.FR, 'FR4', 'Light', 7, '118', null/*127*/),\n//   new VdRegion(vrt.FR, 'FR4', 'Heavy', 7, '118', null/*128*/),\n// ];\n/** Viewer with tabs based on description of chain regions.\n *  Used to define regions of an immunoglobulin LC.\n */\nexport class VdRegionsViewer extends DG.JsViewer {\n    constructor() {\n        super();\n        // private regionsDf: DG.DataFrame;\n        this.regionsFg = null;\n        // private regionsTV: DG.TableView;\n        this.regionsRoot = null;\n        this.isOpened = false;\n        this.panelNode = null;\n        this.regions = [];\n        // #region -- Handle controls' events --\n        this.resizing = false;\n        // #endregion\n        //#region -- View --\n        this.host = null;\n        this.mainLayout = null;\n        this.logos = [];\n        // To prevent ambiguous numbering scheme in MLB\n        this.regionTypes = this.stringList('regionTypes', [vrt.CDR], { choices: Object.values(vrt).filter((t) => t != vrt.Unknown) });\n        this.chains = this.stringList('chains', ['Heavy', 'Light'], { choices: ['Heavy', 'Light'] });\n        this.sequenceColumnNamePostfix = this.string('sequenceColumnNamePostfix', 'chain sequence');\n    }\n    get df() {\n        return this.dataFrame;\n    }\n    // TODO: .onTableAttached is not calling on dataFrame set, onPropertyChanged  also not calling\n    setDf(value, regions) {\n        return __awaiter(this, void 0, void 0, function* () {\n            console.debug('VdRegionsViewer.setDf()');\n            yield this.destroyView();\n            this.regions = regions;\n            this.dataFrame = value;\n            yield this.buildView();\n        });\n    }\n    init() {\n        return __awaiter(this, void 0, void 0, function* () {\n            //#region regionsDF with filter\n            // this.regionsDf = DG.DataFrame.fromObjects(this.regions);\n            // this.regionsDf.rows.filter((row) => row.name == 'CDR1');\n            // // To available options /\n            // this.regionsFg = (await this.regionsDf.plot.fromType(DG.VIEWER.FILTERS, {\n            //   // columnNames: ['name',],\n            //   showFilterCountsIndication: false,\n            //   showHeader: false,\n            //   showSearchBox: false,\n            //   filters: [\n            //     {type: DG.FILTER_TYPE.CATEGORICAL, column: 'type', label: 'Region name', showHistogram: false},\n            //     {type: DG.FILTER_TYPE.CATEGORICAL, column: 'name', label: 'Region type', showHistogram: false},\n            //   ],\n            //   title: 'Regions filter',\n            //   showTitle: true,\n            //   description: 'Filter for regions of multiple alignment by IMGT nomenclature',\n            //   someProperty: 'Hello',\n            // })) as DG.FilterGroup;\n            //#endregion regionsDF with filter\n            // this.mlbView.dockManager.dock(this.regionsFg.root, DG.DOCK_TYPE.LEFT, rootNode, 'Filter regions', 0.2);\n            this.subs.push(ui.onSizeChanged(this.root).subscribe(this.rootOnSizeChanged.bind(this)));\n            // rxjs.fromEvent(this.root, 'mousemove').subscribe(this.onMouseMoveRoot.bind(this));\n            this.root.addEventListener('mousemove', this.onMouseMoveRoot.bind(this));\n            yield this.buildView();\n        });\n    }\n    onTableAttached() {\n        return __awaiter(this, void 0, void 0, function* () {\n            yield this.init();\n        });\n    }\n    onPropertyChanged(property) {\n        const _super = Object.create(null, {\n            onPropertyChanged: { get: () => super.onPropertyChanged }\n        });\n        return __awaiter(this, void 0, void 0, function* () {\n            _super.onPropertyChanged.call(this, property);\n            if (property) {\n                switch (property.name) {\n                    case 'regionTypes':\n                        break;\n                    case 'chains':\n                        break;\n                    case 'sequenceColumnNamePostfix':\n                        break;\n                }\n            }\n        });\n    }\n    reset() {\n        return __awaiter(this, void 0, void 0, function* () {\n        });\n    }\n    open(mlbView) {\n        return __awaiter(this, void 0, void 0, function* () {\n            if (!this.isOpened) {\n                this.isOpened = true;\n                this.panelNode = mlbView.dockManager.dock(this.root, DG.DOCK_TYPE.TOP, null, 'Regions', 0.2);\n            }\n        });\n    }\n    show(mlbView) {\n        return __awaiter(this, void 0, void 0, function* () {\n        });\n    }\n    rootOnSizeChanged(args) {\n        this.calcSize();\n    }\n    destroyView() {\n        return __awaiter(this, void 0, void 0, function* () {\n            // TODO: Unsubscribe from and remove all view elements\n            console.debug(`VdRegionsViewer.destroyView( mainLayout = ${!this.mainLayout ? 'none' : 'value'} )`);\n            if (this.mainLayout != null) {\n                // this.root.removeChild(this.host);\n                this.mainLayout.remove();\n                this.host.remove();\n                this.host = null;\n                this.mainLayout = null;\n            }\n        });\n    }\n    buildView() {\n        return __awaiter(this, void 0, void 0, function* () {\n            console.debug('VdRegionsViewer.buildView() start');\n            const colNames = Object.assign({}, ...this.chains.map((chain) => ({ [chain]: `${chain} ${this.sequenceColumnNamePostfix}` })));\n            const regionsFiltered = this.regions.filter((r) => this.regionTypes.includes(r.type));\n            const orderList = Array.from(new Set(regionsFiltered.map((r) => r.order))).sort();\n            this.logos = [];\n            for (let orderI = 0; orderI < orderList.length; orderI++) {\n                const regionChains = {};\n                for (const chain of this.chains) {\n                    const region = regionsFiltered\n                        .find((r) => r.order == orderList[orderI] && r.chain == chain);\n                    regionChains[chain] = (yield this.dataFrame.plot.fromType('WebLogo', {\n                        sequenceColumnName: colNames[chain],\n                        startPositionName: region.positionStartName,\n                        endPositionName: region.positionEndName,\n                        fixWidth: true,\n                    }));\n                }\n                // WebLogo creation fires onRootSizeChanged event even before control being added to this.logos\n                this.logos[orderI] = regionChains;\n            }\n            // ui.tableFromMap()\n            // DG.HtmlTable.create()\n            this.mainLayout = ui.table(this.chains, (chain) => {\n                const elements = [\n                    // This is chain label\n                    ...(orderList.length > 0 ? [ui.div(chain, {\n                            style: {\n                                transform: 'rotate(-90deg)',\n                                font: '12px Roboto, Roboto Local, sans-serif',\n                                textAlign: 'center',\n                                width: '16px',\n                                marginTop: '24px',\n                                marginLeft: '6px',\n                            }\n                        })] : []),\n                    // List with controls for regions\n                    ...[...Array(orderList.length).keys()].map((orderI) => {\n                        const wl = this.logos[orderI][chain];\n                        wl.root.style.height = '100%';\n                        const resDiv = ui.div([wl.root] /*`${chain} ${regionsFiltered[rI]}`*/, {\n                            style: {\n                                // height: '100%',\n                                marginTop: '4px',\n                                marginBottom: '4px',\n                            }\n                        });\n                        return resDiv;\n                    })\n                ];\n                return elements;\n            }, ['', ...[...Array(orderList.length).keys()].map((orderI) => regionsFiltered.find((r) => r.order == orderList[orderI] && r.chain == this.chains[0]).name || 'Name')]);\n            this.mainLayout.className = 'mlb-vd-regions-viewer-table2';\n            // this.mainLayout.style.background = '#EEEEFF';\n            // this.mainLayout.style.height = '100%';\n            // this.mainLayout.style.border = '1px solid black';\n            const color = `#ffbb${Math.ceil(Math.random() * 255).toString(16)}`;\n            this.host = ui.box(this.mainLayout, { /*style: {backgroundColor: color}*/});\n            this.root.appendChild(this.host);\n            this.root.style.overflowX = 'auto';\n            this.calcSize();\n            console.debug('VdRegionsViewer.buildView() end');\n        });\n    }\n    calcSize() {\n        const logoHeight = (this.root.clientHeight - 54) / this.chains.length;\n        const maxHeight = Math.min(logoHeight, Math.max(...this.logos.map((wlDict) => Math.max(...Object.values(wlDict).map((wl) => wl.maxHeight)))));\n        for (let orderI = 0; orderI < this.logos.length; orderI++) {\n            for (let chainI = 0; chainI < this.chains.length; chainI++) {\n                const chain = this.chains[chainI];\n                this.logos[orderI][chain].root.style.height = `${maxHeight}px`;\n            }\n        }\n    }\n    //#endregion -- View --\n    onMouseMoveRoot(e) {\n        // ui.tooltip.show('text', e.x + 8, e.y + 8,);\n        // console.log(`onMouseMoveRoot.( x: ${e.x}, y: ${e.y} )`);\n    }\n}\n","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"wu\"] = factory();\n\telse\n\t\troot[\"wu\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\texports: {},\n/******/ \t\t\tid: moduleId,\n/******/ \t\t\tloaded: false\n/******/ \t\t};\n\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.loaded = true;\n\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n\n\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t\"use strict\";\n\n\tvar _toConsumableArray = __webpack_require__(1)[\"default\"];\n\n\tvar _slicedToArray = __webpack_require__(39)[\"default\"];\n\n\tvar _Symbol$iterator = __webpack_require__(52)[\"default\"];\n\n\tvar _getIterator = __webpack_require__(40)[\"default\"];\n\n\tvar _regeneratorRuntime = __webpack_require__(54)[\"default\"];\n\n\tvar _Object$keys = __webpack_require__(80)[\"default\"];\n\n\tvar _Set = __webpack_require__(84)[\"default\"];\n\n\tvar _Promise = __webpack_require__(65)[\"default\"];\n\n\tvar wu = module.exports = function wu(iterable) {\n\t  if (!isIterable(iterable)) {\n\t    throw new Error(\"wu: `\" + iterable + \"` is not iterable!\");\n\t  }\n\t  return new Wu(iterable);\n\t};\n\n\tfunction Wu(iterable) {\n\t  var iterator = getIterator(iterable);\n\t  this.next = iterator.next.bind(iterator);\n\t}\n\twu.prototype = Wu.prototype;\n\n\twu.prototype[_Symbol$iterator] = function () {\n\t  return this;\n\t};\n\n\t/*\n\t * Internal utilities\n\t */\n\n\t// An internal placeholder value.\n\tvar MISSING = {};\n\n\t// Return whether a thing is iterable.\n\tvar isIterable = function isIterable(thing) {\n\t  return thing && typeof thing[_Symbol$iterator] === \"function\";\n\t};\n\n\t// Get the iterator for the thing or throw an error.\n\tvar getIterator = function getIterator(thing) {\n\t  if (isIterable(thing)) {\n\t    return _getIterator(thing);\n\t  }\n\t  throw new TypeError(\"Not iterable: \" + thing);\n\t};\n\n\t// Define a static method on `wu` and set its prototype to the shared\n\t// `Wu.prototype`.\n\tvar staticMethod = function staticMethod(name, fn) {\n\t  fn.prototype = Wu.prototype;\n\t  wu[name] = fn;\n\t};\n\n\t// Define a function that is attached as both a `Wu.prototype` method and a\n\t// curryable static method on `wu` directly that takes an iterable as its last\n\t// parameter.\n\tvar prototypeAndStatic = function prototypeAndStatic(name, fn) {\n\t  var expectedArgs = arguments.length <= 2 || arguments[2] === undefined ? fn.length : arguments[2];\n\t  return (function () {\n\t    fn.prototype = Wu.prototype;\n\t    Wu.prototype[name] = fn;\n\n\t    // +1 for the iterable, which is the `this` value of the function so it\n\t    // isn't reflected by the length property.\n\t    expectedArgs += 1;\n\n\t    wu[name] = wu.curryable(function () {\n\t      var _wu;\n\n\t      for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n\t        args[_key] = arguments[_key];\n\t      }\n\n\t      var iterable = args.pop();\n\t      return (_wu = wu(iterable))[name].apply(_wu, args);\n\t    }, expectedArgs);\n\t  })();\n\t};\n\n\t// A decorator for rewrapping a method's returned iterable in wu to maintain\n\t// chainability.\n\tvar rewrap = function rewrap(fn) {\n\t  return function () {\n\t    for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n\t      args[_key2] = arguments[_key2];\n\t    }\n\n\t    return wu(fn.call.apply(fn, [this].concat(args)));\n\t  };\n\t};\n\n\tvar rewrapStaticMethod = function rewrapStaticMethod(name, fn) {\n\t  return staticMethod(name, rewrap(fn));\n\t};\n\tvar rewrapPrototypeAndStatic = function rewrapPrototypeAndStatic(name, fn, expectedArgs) {\n\t  return prototypeAndStatic(name, rewrap(fn), expectedArgs);\n\t};\n\n\t// Return a wrapped version of `fn` bound with the initial arguments\n\t// `...args`.\n\tfunction curry(fn, args) {\n\t  return function () {\n\t    for (var _len3 = arguments.length, moreArgs = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n\t      moreArgs[_key3] = arguments[_key3];\n\t    }\n\n\t    return fn.call.apply(fn, [this].concat(_toConsumableArray(args), moreArgs));\n\t  };\n\t}\n\n\t/*\n\t * Public utilities\n\t */\n\n\tstaticMethod(\"curryable\", function (fn) {\n\t  var expected = arguments.length <= 1 || arguments[1] === undefined ? fn.length : arguments[1];\n\t  return (function () {\n\t    return function f() {\n\t      for (var _len4 = arguments.length, args = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n\t        args[_key4] = arguments[_key4];\n\t      }\n\n\t      return args.length >= expected ? fn.apply(this, args) : curry(f, args);\n\t    };\n\t  })();\n\t});\n\n\trewrapStaticMethod(\"entries\", _regeneratorRuntime.mark(function callee$0$0(obj) {\n\t  var _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, k;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion = true;\n\t        _didIteratorError = false;\n\t        _iteratorError = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator = _getIterator(_Object$keys(obj));\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion = (_step = _iterator.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        k = _step.value;\n\t        context$1$0.next = 9;\n\t        return [k, obj[k]];\n\n\t      case 9:\n\t        _iteratorNormalCompletion = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError = true;\n\t        _iteratorError = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion && _iterator[\"return\"]) {\n\t          _iterator[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapStaticMethod(\"keys\", _regeneratorRuntime.mark(function callee$0$0(obj) {\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_Object$keys(obj), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"values\", _regeneratorRuntime.mark(function callee$0$0(obj) {\n\t  var _iteratorNormalCompletion2, _didIteratorError2, _iteratorError2, _iterator2, _step2, k;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion2 = true;\n\t        _didIteratorError2 = false;\n\t        _iteratorError2 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator2 = _getIterator(_Object$keys(obj));\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        k = _step2.value;\n\t        context$1$0.next = 9;\n\t        return obj[k];\n\n\t      case 9:\n\t        _iteratorNormalCompletion2 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError2 = true;\n\t        _iteratorError2 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion2 && _iterator2[\"return\"]) {\n\t          _iterator2[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError2) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError2;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\t/*\n\t * Infinite iterators\n\t */\n\n\trewrapPrototypeAndStatic(\"cycle\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var saved, _iteratorNormalCompletion3, _didIteratorError3, _iteratorError3, _iterator3, _step3, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        saved = [];\n\t        _iteratorNormalCompletion3 = true;\n\t        _didIteratorError3 = false;\n\t        _iteratorError3 = undefined;\n\t        context$1$0.prev = 4;\n\t        _iterator3 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        x = _step3.value;\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        saved.push(x);\n\n\t      case 11:\n\t        _iteratorNormalCompletion3 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.next = 20;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.prev = 16;\n\t        context$1$0.t0 = context$1$0[\"catch\"](4);\n\t        _didIteratorError3 = true;\n\t        _iteratorError3 = context$1$0.t0;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.prev = 21;\n\n\t        if (!_iteratorNormalCompletion3 && _iterator3[\"return\"]) {\n\t          _iterator3[\"return\"]();\n\t        }\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\n\t        if (!_didIteratorError3) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        throw _iteratorError3;\n\n\t      case 26:\n\t        return context$1$0.finish(23);\n\n\t      case 27:\n\t        return context$1$0.finish(20);\n\n\t      case 28:\n\t        if (!saved) {\n\t          context$1$0.next = 32;\n\t          break;\n\t        }\n\n\t        return context$1$0.delegateYield(saved, \"t1\", 30);\n\n\t      case 30:\n\t        context$1$0.next = 28;\n\t        break;\n\n\t      case 32:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[4, 16, 20, 28], [21,, 23, 27]]);\n\t}));\n\n\trewrapStaticMethod(\"count\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var start = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\t  var step = arguments.length <= 1 || arguments[1] === undefined ? 1 : arguments[1];\n\t  var n;\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        n = start;\n\n\t      case 1:\n\t        if (false) {\n\t          context$1$0.next = 7;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 4;\n\t        return n;\n\n\t      case 4:\n\t        n += step;\n\t        context$1$0.next = 1;\n\t        break;\n\n\t      case 7:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"repeat\", _regeneratorRuntime.mark(function callee$0$0(thing) {\n\t  var times = arguments.length <= 1 || arguments[1] === undefined ? Infinity : arguments[1];\n\t  var i;\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (!(times === Infinity)) {\n\t          context$1$0.next = 8;\n\t          break;\n\t        }\n\n\t      case 1:\n\t        if (false) {\n\t          context$1$0.next = 6;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 4;\n\t        return thing;\n\n\t      case 4:\n\t        context$1$0.next = 1;\n\t        break;\n\n\t      case 6:\n\t        context$1$0.next = 15;\n\t        break;\n\n\t      case 8:\n\t        i = 0;\n\n\t      case 9:\n\t        if (!(i < times)) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 12;\n\t        return thing;\n\n\t      case 12:\n\t        i++;\n\t        context$1$0.next = 9;\n\t        break;\n\n\t      case 15:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\t/*\n\t * Iterators that terminate once the input sequence has been exhausted\n\t */\n\n\trewrapStaticMethod(\"chain\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var _iteratorNormalCompletion4,\n\t      _didIteratorError4,\n\t      _iteratorError4,\n\t      _len5,\n\t      iterables,\n\t      _key5,\n\t      _iterator4,\n\t      _step4,\n\t      it,\n\t      args$1$0 = arguments;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion4 = true;\n\t        _didIteratorError4 = false;\n\t        _iteratorError4 = undefined;\n\t        context$1$0.prev = 3;\n\n\t        for (_len5 = args$1$0.length, iterables = Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {\n\t          iterables[_key5] = args$1$0[_key5];\n\t        }\n\n\t        _iterator4 = _getIterator(iterables);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        it = _step4.value;\n\t        return context$1$0.delegateYield(it, \"t0\", 9);\n\n\t      case 9:\n\t        _iteratorNormalCompletion4 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t1 = context$1$0[\"catch\"](3);\n\t        _didIteratorError4 = true;\n\t        _iteratorError4 = context$1$0.t1;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion4 && _iterator4[\"return\"]) {\n\t          _iterator4[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError4) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError4;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"chunk\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var n = arguments.length <= 0 || arguments[0] === undefined ? 2 : arguments[0];\n\n\t  var items, index, _iteratorNormalCompletion5, _didIteratorError5, _iteratorError5, _iterator5, _step5, item;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        items = [];\n\t        index = 0;\n\t        _iteratorNormalCompletion5 = true;\n\t        _didIteratorError5 = false;\n\t        _iteratorError5 = undefined;\n\t        context$1$0.prev = 5;\n\t        _iterator5 = _getIterator(this);\n\n\t      case 7:\n\t        if (_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done) {\n\t          context$1$0.next = 18;\n\t          break;\n\t        }\n\n\t        item = _step5.value;\n\n\t        items[index++] = item;\n\n\t        if (!(index === n)) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 13;\n\t        return items;\n\n\t      case 13:\n\t        items = [];\n\t        index = 0;\n\n\t      case 15:\n\t        _iteratorNormalCompletion5 = true;\n\t        context$1$0.next = 7;\n\t        break;\n\n\t      case 18:\n\t        context$1$0.next = 24;\n\t        break;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.t0 = context$1$0[\"catch\"](5);\n\t        _didIteratorError5 = true;\n\t        _iteratorError5 = context$1$0.t0;\n\n\t      case 24:\n\t        context$1$0.prev = 24;\n\t        context$1$0.prev = 25;\n\n\t        if (!_iteratorNormalCompletion5 && _iterator5[\"return\"]) {\n\t          _iterator5[\"return\"]();\n\t        }\n\n\t      case 27:\n\t        context$1$0.prev = 27;\n\n\t        if (!_didIteratorError5) {\n\t          context$1$0.next = 30;\n\t          break;\n\t        }\n\n\t        throw _iteratorError5;\n\n\t      case 30:\n\t        return context$1$0.finish(27);\n\n\t      case 31:\n\t        return context$1$0.finish(24);\n\n\t      case 32:\n\t        if (!index) {\n\t          context$1$0.next = 35;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 35;\n\t        return items;\n\n\t      case 35:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[5, 20, 24, 32], [25,, 27, 31]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"concatMap\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var _iteratorNormalCompletion6, _didIteratorError6, _iteratorError6, _iterator6, _step6, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion6 = true;\n\t        _didIteratorError6 = false;\n\t        _iteratorError6 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator6 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion6 = (_step6 = _iterator6.next()).done) {\n\t          context$1$0.next = 11;\n\t          break;\n\t        }\n\n\t        x = _step6.value;\n\t        return context$1$0.delegateYield(fn(x), \"t0\", 8);\n\n\t      case 8:\n\t        _iteratorNormalCompletion6 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 11:\n\t        context$1$0.next = 17;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.prev = 13;\n\t        context$1$0.t1 = context$1$0[\"catch\"](3);\n\t        _didIteratorError6 = true;\n\t        _iteratorError6 = context$1$0.t1;\n\n\t      case 17:\n\t        context$1$0.prev = 17;\n\t        context$1$0.prev = 18;\n\n\t        if (!_iteratorNormalCompletion6 && _iterator6[\"return\"]) {\n\t          _iterator6[\"return\"]();\n\t        }\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\n\t        if (!_didIteratorError6) {\n\t          context$1$0.next = 23;\n\t          break;\n\t        }\n\n\t        throw _iteratorError6;\n\n\t      case 23:\n\t        return context$1$0.finish(20);\n\n\t      case 24:\n\t        return context$1$0.finish(17);\n\n\t      case 25:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 13, 17, 25], [18,, 20, 24]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"drop\", _regeneratorRuntime.mark(function callee$0$0(n) {\n\t  var i, _iteratorNormalCompletion7, _didIteratorError7, _iteratorError7, _iterator7, _step7, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        i = 0;\n\t        _iteratorNormalCompletion7 = true;\n\t        _didIteratorError7 = false;\n\t        _iteratorError7 = undefined;\n\t        context$1$0.prev = 4;\n\t        _iterator7 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion7 = (_step7 = _iterator7.next()).done) {\n\t          context$1$0.next = 16;\n\t          break;\n\t        }\n\n\t        x = _step7.value;\n\n\t        if (!(i++ < n)) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"continue\", 13);\n\n\t      case 10:\n\t        context$1$0.next = 12;\n\t        return x;\n\n\t      case 12:\n\t        return context$1$0.abrupt(\"break\", 16);\n\n\t      case 13:\n\t        _iteratorNormalCompletion7 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.next = 22;\n\t        break;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.t0 = context$1$0[\"catch\"](4);\n\t        _didIteratorError7 = true;\n\t        _iteratorError7 = context$1$0.t0;\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\t        context$1$0.prev = 23;\n\n\t        if (!_iteratorNormalCompletion7 && _iterator7[\"return\"]) {\n\t          _iterator7[\"return\"]();\n\t        }\n\n\t      case 25:\n\t        context$1$0.prev = 25;\n\n\t        if (!_didIteratorError7) {\n\t          context$1$0.next = 28;\n\t          break;\n\t        }\n\n\t        throw _iteratorError7;\n\n\t      case 28:\n\t        return context$1$0.finish(25);\n\n\t      case 29:\n\t        return context$1$0.finish(22);\n\n\t      case 30:\n\t        return context$1$0.delegateYield(this, \"t1\", 31);\n\n\t      case 31:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[4, 18, 22, 30], [23,, 25, 29]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"dropWhile\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion8, _didIteratorError8, _iteratorError8, _iterator8, _step8, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion8 = true;\n\t        _didIteratorError8 = false;\n\t        _iteratorError8 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator8 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion8 = (_step8 = _iterator8.next()).done) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        x = _step8.value;\n\n\t        if (!fn(x)) {\n\t          context$1$0.next = 9;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"continue\", 12);\n\n\t      case 9:\n\t        context$1$0.next = 11;\n\t        return x;\n\n\t      case 11:\n\t        return context$1$0.abrupt(\"break\", 15);\n\n\t      case 12:\n\t        _iteratorNormalCompletion8 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.next = 21;\n\t        break;\n\n\t      case 17:\n\t        context$1$0.prev = 17;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError8 = true;\n\t        _iteratorError8 = context$1$0.t0;\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\t        context$1$0.prev = 22;\n\n\t        if (!_iteratorNormalCompletion8 && _iterator8[\"return\"]) {\n\t          _iterator8[\"return\"]();\n\t        }\n\n\t      case 24:\n\t        context$1$0.prev = 24;\n\n\t        if (!_didIteratorError8) {\n\t          context$1$0.next = 27;\n\t          break;\n\t        }\n\n\t        throw _iteratorError8;\n\n\t      case 27:\n\t        return context$1$0.finish(24);\n\n\t      case 28:\n\t        return context$1$0.finish(21);\n\n\t      case 29:\n\t        return context$1$0.delegateYield(this, \"t1\", 30);\n\n\t      case 30:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 17, 21, 29], [22,, 24, 28]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"enumerate\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip([this, wu.count()]), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapPrototypeAndStatic(\"filter\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion9, _didIteratorError9, _iteratorError9, _iterator9, _step9, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion9 = true;\n\t        _didIteratorError9 = false;\n\t        _iteratorError9 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator9 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion9 = (_step9 = _iterator9.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step9.value;\n\n\t        if (!fn(x)) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        _iteratorNormalCompletion9 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError9 = true;\n\t        _iteratorError9 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion9 && _iterator9[\"return\"]) {\n\t          _iterator9[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError9) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError9;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"flatten\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var shallow = arguments.length <= 0 || arguments[0] === undefined ? false : arguments[0];\n\n\t  var _iteratorNormalCompletion10, _didIteratorError10, _iteratorError10, _iterator10, _step10, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion10 = true;\n\t        _didIteratorError10 = false;\n\t        _iteratorError10 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator10 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion10 = (_step10 = _iterator10.next()).done) {\n\t          context$1$0.next = 16;\n\t          break;\n\t        }\n\n\t        x = _step10.value;\n\n\t        if (!(typeof x !== \"string\" && isIterable(x))) {\n\t          context$1$0.next = 11;\n\t          break;\n\t        }\n\n\t        return context$1$0.delegateYield(shallow ? x : wu(x).flatten(), \"t0\", 9);\n\n\t      case 9:\n\t        context$1$0.next = 13;\n\t        break;\n\n\t      case 11:\n\t        context$1$0.next = 13;\n\t        return x;\n\n\t      case 13:\n\t        _iteratorNormalCompletion10 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.next = 22;\n\t        break;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.t1 = context$1$0[\"catch\"](3);\n\t        _didIteratorError10 = true;\n\t        _iteratorError10 = context$1$0.t1;\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\t        context$1$0.prev = 23;\n\n\t        if (!_iteratorNormalCompletion10 && _iterator10[\"return\"]) {\n\t          _iterator10[\"return\"]();\n\t        }\n\n\t      case 25:\n\t        context$1$0.prev = 25;\n\n\t        if (!_didIteratorError10) {\n\t          context$1$0.next = 28;\n\t          break;\n\t        }\n\n\t        throw _iteratorError10;\n\n\t      case 28:\n\t        return context$1$0.finish(25);\n\n\t      case 29:\n\t        return context$1$0.finish(22);\n\n\t      case 30:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 18, 22, 30], [23,, 25, 29]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"invoke\", _regeneratorRuntime.mark(function callee$0$0(name) {\n\t  var _iteratorNormalCompletion11,\n\t      _didIteratorError11,\n\t      _iteratorError11,\n\t      _len6,\n\t      args,\n\t      _key6,\n\t      _iterator11,\n\t      _step11,\n\t      x,\n\t      args$1$0 = arguments;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion11 = true;\n\t        _didIteratorError11 = false;\n\t        _iteratorError11 = undefined;\n\t        context$1$0.prev = 3;\n\n\t        for (_len6 = args$1$0.length, args = Array(_len6 > 1 ? _len6 - 1 : 0), _key6 = 1; _key6 < _len6; _key6++) {\n\t          args[_key6 - 1] = args$1$0[_key6];\n\t        }\n\n\t        _iterator11 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion11 = (_step11 = _iterator11.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step11.value;\n\t        context$1$0.next = 10;\n\t        return x[name].apply(x, args);\n\n\t      case 10:\n\t        _iteratorNormalCompletion11 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError11 = true;\n\t        _iteratorError11 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion11 && _iterator11[\"return\"]) {\n\t          _iterator11[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError11) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError11;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"map\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var _iteratorNormalCompletion12, _didIteratorError12, _iteratorError12, _iterator12, _step12, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion12 = true;\n\t        _didIteratorError12 = false;\n\t        _iteratorError12 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator12 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion12 = (_step12 = _iterator12.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        x = _step12.value;\n\t        context$1$0.next = 9;\n\t        return fn(x);\n\n\t      case 9:\n\t        _iteratorNormalCompletion12 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError12 = true;\n\t        _iteratorError12 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion12 && _iterator12[\"return\"]) {\n\t          _iterator12[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError12) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError12;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"pluck\", _regeneratorRuntime.mark(function callee$0$0(name) {\n\t  var _iteratorNormalCompletion13, _didIteratorError13, _iteratorError13, _iterator13, _step13, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion13 = true;\n\t        _didIteratorError13 = false;\n\t        _iteratorError13 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator13 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion13 = (_step13 = _iterator13.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        x = _step13.value;\n\t        context$1$0.next = 9;\n\t        return x[name];\n\n\t      case 9:\n\t        _iteratorNormalCompletion13 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError13 = true;\n\t        _iteratorError13 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion13 && _iterator13[\"return\"]) {\n\t          _iterator13[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError13) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError13;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"reductions\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var initial = arguments.length <= 1 || arguments[1] === undefined ? undefined : arguments[1];\n\n\t  var val, _iteratorNormalCompletion14, _didIteratorError14, _iteratorError14, _iterator14, _step14, x, _iteratorNormalCompletion15, _didIteratorError15, _iteratorError15, _iterator15, _step15;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        val = initial;\n\n\t        if (!(val === undefined)) {\n\t          context$1$0.next = 28;\n\t          break;\n\t        }\n\n\t        _iteratorNormalCompletion14 = true;\n\t        _didIteratorError14 = false;\n\t        _iteratorError14 = undefined;\n\t        context$1$0.prev = 5;\n\t        _iterator14 = _getIterator(this);\n\n\t      case 7:\n\t        if (_iteratorNormalCompletion14 = (_step14 = _iterator14.next()).done) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        x = _step14.value;\n\n\t        val = x;\n\t        return context$1$0.abrupt(\"break\", 14);\n\n\t      case 11:\n\t        _iteratorNormalCompletion14 = true;\n\t        context$1$0.next = 7;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.next = 20;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.prev = 16;\n\t        context$1$0.t0 = context$1$0[\"catch\"](5);\n\t        _didIteratorError14 = true;\n\t        _iteratorError14 = context$1$0.t0;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.prev = 21;\n\n\t        if (!_iteratorNormalCompletion14 && _iterator14[\"return\"]) {\n\t          _iterator14[\"return\"]();\n\t        }\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\n\t        if (!_didIteratorError14) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        throw _iteratorError14;\n\n\t      case 26:\n\t        return context$1$0.finish(23);\n\n\t      case 27:\n\t        return context$1$0.finish(20);\n\n\t      case 28:\n\t        context$1$0.next = 30;\n\t        return val;\n\n\t      case 30:\n\t        _iteratorNormalCompletion15 = true;\n\t        _didIteratorError15 = false;\n\t        _iteratorError15 = undefined;\n\t        context$1$0.prev = 33;\n\t        _iterator15 = _getIterator(this);\n\n\t      case 35:\n\t        if (_iteratorNormalCompletion15 = (_step15 = _iterator15.next()).done) {\n\t          context$1$0.next = 42;\n\t          break;\n\t        }\n\n\t        x = _step15.value;\n\t        context$1$0.next = 39;\n\t        return val = fn(val, x);\n\n\t      case 39:\n\t        _iteratorNormalCompletion15 = true;\n\t        context$1$0.next = 35;\n\t        break;\n\n\t      case 42:\n\t        context$1$0.next = 48;\n\t        break;\n\n\t      case 44:\n\t        context$1$0.prev = 44;\n\t        context$1$0.t1 = context$1$0[\"catch\"](33);\n\t        _didIteratorError15 = true;\n\t        _iteratorError15 = context$1$0.t1;\n\n\t      case 48:\n\t        context$1$0.prev = 48;\n\t        context$1$0.prev = 49;\n\n\t        if (!_iteratorNormalCompletion15 && _iterator15[\"return\"]) {\n\t          _iterator15[\"return\"]();\n\t        }\n\n\t      case 51:\n\t        context$1$0.prev = 51;\n\n\t        if (!_didIteratorError15) {\n\t          context$1$0.next = 54;\n\t          break;\n\t        }\n\n\t        throw _iteratorError15;\n\n\t      case 54:\n\t        return context$1$0.finish(51);\n\n\t      case 55:\n\t        return context$1$0.finish(48);\n\n\t      case 56:\n\t        return context$1$0.abrupt(\"return\", val);\n\n\t      case 57:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[5, 16, 20, 28], [21,, 23, 27], [33, 44, 48, 56], [49,, 51, 55]]);\n\t}), 2);\n\n\trewrapPrototypeAndStatic(\"reject\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion16, _didIteratorError16, _iteratorError16, _iterator16, _step16, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion16 = true;\n\t        _didIteratorError16 = false;\n\t        _iteratorError16 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator16 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion16 = (_step16 = _iterator16.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step16.value;\n\n\t        if (fn(x)) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        _iteratorNormalCompletion16 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError16 = true;\n\t        _iteratorError16 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion16 && _iterator16[\"return\"]) {\n\t          _iterator16[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError16) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError16;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"slice\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var start = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\t  var stop = arguments.length <= 1 || arguments[1] === undefined ? Infinity : arguments[1];\n\n\t  var _iteratorNormalCompletion17, _didIteratorError17, _iteratorError17, _iterator17, _step17, _step17$value, x, i;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (!(stop < start)) {\n\t          context$1$0.next = 2;\n\t          break;\n\t        }\n\n\t        throw new RangeError(\"parameter `stop` (= \" + stop + \") must be >= `start` (= \" + start + \")\");\n\n\t      case 2:\n\t        _iteratorNormalCompletion17 = true;\n\t        _didIteratorError17 = false;\n\t        _iteratorError17 = undefined;\n\t        context$1$0.prev = 5;\n\t        _iterator17 = _getIterator(this.enumerate());\n\n\t      case 7:\n\t        if (_iteratorNormalCompletion17 = (_step17 = _iterator17.next()).done) {\n\t          context$1$0.next = 20;\n\t          break;\n\t        }\n\n\t        _step17$value = _slicedToArray(_step17.value, 2);\n\t        x = _step17$value[0];\n\t        i = _step17$value[1];\n\n\t        if (!(i < start)) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"continue\", 17);\n\n\t      case 13:\n\t        if (!(i >= stop)) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"break\", 20);\n\n\t      case 15:\n\t        context$1$0.next = 17;\n\t        return x;\n\n\t      case 17:\n\t        _iteratorNormalCompletion17 = true;\n\t        context$1$0.next = 7;\n\t        break;\n\n\t      case 20:\n\t        context$1$0.next = 26;\n\t        break;\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\t        context$1$0.t0 = context$1$0[\"catch\"](5);\n\t        _didIteratorError17 = true;\n\t        _iteratorError17 = context$1$0.t0;\n\n\t      case 26:\n\t        context$1$0.prev = 26;\n\t        context$1$0.prev = 27;\n\n\t        if (!_iteratorNormalCompletion17 && _iterator17[\"return\"]) {\n\t          _iterator17[\"return\"]();\n\t        }\n\n\t      case 29:\n\t        context$1$0.prev = 29;\n\n\t        if (!_didIteratorError17) {\n\t          context$1$0.next = 32;\n\t          break;\n\t        }\n\n\t        throw _iteratorError17;\n\n\t      case 32:\n\t        return context$1$0.finish(29);\n\n\t      case 33:\n\t        return context$1$0.finish(26);\n\n\t      case 34:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[5, 22, 26, 34], [27,, 29, 33]]);\n\t}), 2);\n\n\trewrapPrototypeAndStatic(\"spreadMap\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var _iteratorNormalCompletion18, _didIteratorError18, _iteratorError18, _iterator18, _step18, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion18 = true;\n\t        _didIteratorError18 = false;\n\t        _iteratorError18 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator18 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion18 = (_step18 = _iterator18.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        x = _step18.value;\n\t        context$1$0.next = 9;\n\t        return fn.apply(undefined, _toConsumableArray(x));\n\n\t      case 9:\n\t        _iteratorNormalCompletion18 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError18 = true;\n\t        _iteratorError18 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion18 && _iterator18[\"return\"]) {\n\t          _iterator18[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError18) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError18;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"take\", _regeneratorRuntime.mark(function callee$0$0(n) {\n\t  var i, _iteratorNormalCompletion19, _didIteratorError19, _iteratorError19, _iterator19, _step19, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (!(n < 1)) {\n\t          context$1$0.next = 2;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\");\n\n\t      case 2:\n\t        i = 0;\n\t        _iteratorNormalCompletion19 = true;\n\t        _didIteratorError19 = false;\n\t        _iteratorError19 = undefined;\n\t        context$1$0.prev = 6;\n\t        _iterator19 = _getIterator(this);\n\n\t      case 8:\n\t        if (_iteratorNormalCompletion19 = (_step19 = _iterator19.next()).done) {\n\t          context$1$0.next = 17;\n\t          break;\n\t        }\n\n\t        x = _step19.value;\n\t        context$1$0.next = 12;\n\t        return x;\n\n\t      case 12:\n\t        if (!(++i >= n)) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"break\", 17);\n\n\t      case 14:\n\t        _iteratorNormalCompletion19 = true;\n\t        context$1$0.next = 8;\n\t        break;\n\n\t      case 17:\n\t        context$1$0.next = 23;\n\t        break;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.t0 = context$1$0[\"catch\"](6);\n\t        _didIteratorError19 = true;\n\t        _iteratorError19 = context$1$0.t0;\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\t        context$1$0.prev = 24;\n\n\t        if (!_iteratorNormalCompletion19 && _iterator19[\"return\"]) {\n\t          _iterator19[\"return\"]();\n\t        }\n\n\t      case 26:\n\t        context$1$0.prev = 26;\n\n\t        if (!_didIteratorError19) {\n\t          context$1$0.next = 29;\n\t          break;\n\t        }\n\n\t        throw _iteratorError19;\n\n\t      case 29:\n\t        return context$1$0.finish(26);\n\n\t      case 30:\n\t        return context$1$0.finish(23);\n\n\t      case 31:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[6, 19, 23, 31], [24,, 26, 30]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"takeWhile\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion20, _didIteratorError20, _iteratorError20, _iterator20, _step20, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion20 = true;\n\t        _didIteratorError20 = false;\n\t        _iteratorError20 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator20 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion20 = (_step20 = _iterator20.next()).done) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        x = _step20.value;\n\n\t        if (fn(x)) {\n\t          context$1$0.next = 9;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"break\", 14);\n\n\t      case 9:\n\t        context$1$0.next = 11;\n\t        return x;\n\n\t      case 11:\n\t        _iteratorNormalCompletion20 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.next = 20;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.prev = 16;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError20 = true;\n\t        _iteratorError20 = context$1$0.t0;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.prev = 21;\n\n\t        if (!_iteratorNormalCompletion20 && _iterator20[\"return\"]) {\n\t          _iterator20[\"return\"]();\n\t        }\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\n\t        if (!_didIteratorError20) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        throw _iteratorError20;\n\n\t      case 26:\n\t        return context$1$0.finish(23);\n\n\t      case 27:\n\t        return context$1$0.finish(20);\n\n\t      case 28:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 16, 20, 28], [21,, 23, 27]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"tap\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? console.log.bind(console) : arguments[0];\n\n\t  var _iteratorNormalCompletion21, _didIteratorError21, _iteratorError21, _iterator21, _step21, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion21 = true;\n\t        _didIteratorError21 = false;\n\t        _iteratorError21 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator21 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion21 = (_step21 = _iterator21.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step21.value;\n\n\t        fn(x);\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        _iteratorNormalCompletion21 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError21 = true;\n\t        _iteratorError21 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion21 && _iterator21[\"return\"]) {\n\t          _iterator21[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError21) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError21;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"unique\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var seen, _iteratorNormalCompletion22, _didIteratorError22, _iteratorError22, _iterator22, _step22, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        seen = new _Set();\n\t        _iteratorNormalCompletion22 = true;\n\t        _didIteratorError22 = false;\n\t        _iteratorError22 = undefined;\n\t        context$1$0.prev = 4;\n\t        _iterator22 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion22 = (_step22 = _iterator22.next()).done) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        x = _step22.value;\n\n\t        if (seen.has(x)) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 11;\n\t        return x;\n\n\t      case 11:\n\t        seen.add(x);\n\n\t      case 12:\n\t        _iteratorNormalCompletion22 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.next = 21;\n\t        break;\n\n\t      case 17:\n\t        context$1$0.prev = 17;\n\t        context$1$0.t0 = context$1$0[\"catch\"](4);\n\t        _didIteratorError22 = true;\n\t        _iteratorError22 = context$1$0.t0;\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\t        context$1$0.prev = 22;\n\n\t        if (!_iteratorNormalCompletion22 && _iterator22[\"return\"]) {\n\t          _iterator22[\"return\"]();\n\t        }\n\n\t      case 24:\n\t        context$1$0.prev = 24;\n\n\t        if (!_didIteratorError22) {\n\t          context$1$0.next = 27;\n\t          break;\n\t        }\n\n\t        throw _iteratorError22;\n\n\t      case 27:\n\t        return context$1$0.finish(24);\n\n\t      case 28:\n\t        return context$1$0.finish(21);\n\n\t      case 29:\n\t        seen.clear();\n\n\t      case 30:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[4, 17, 21, 29], [22,, 24, 28]]);\n\t}));\n\n\tvar _zip = rewrap(_regeneratorRuntime.mark(function callee$0$0(iterables) {\n\t  var longest = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1];\n\n\t  var iters, numIters, numFinished, finished, zipped, _iteratorNormalCompletion23, _didIteratorError23, _iteratorError23, _iterator23, _step23, it, _it$next, value, done;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (iterables.length) {\n\t          context$1$0.next = 2;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\");\n\n\t      case 2:\n\t        iters = iterables.map(getIterator);\n\t        numIters = iterables.length;\n\t        numFinished = 0;\n\t        finished = false;\n\n\t      case 6:\n\t        if (finished) {\n\t          context$1$0.next = 44;\n\t          break;\n\t        }\n\n\t        zipped = [];\n\t        _iteratorNormalCompletion23 = true;\n\t        _didIteratorError23 = false;\n\t        _iteratorError23 = undefined;\n\t        context$1$0.prev = 11;\n\t        _iterator23 = _getIterator(iters);\n\n\t      case 13:\n\t        if (_iteratorNormalCompletion23 = (_step23 = _iterator23.next()).done) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        it = _step23.value;\n\t        _it$next = it.next();\n\t        value = _it$next.value;\n\t        done = _it$next.done;\n\n\t        if (!done) {\n\t          context$1$0.next = 22;\n\t          break;\n\t        }\n\n\t        if (longest) {\n\t          context$1$0.next = 21;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\");\n\n\t      case 21:\n\t        if (++numFinished == numIters) {\n\t          finished = true;\n\t        }\n\n\t      case 22:\n\t        if (value === undefined) {\n\t          // Leave a hole in the array so that you can distinguish an iterable\n\t          // that's done (via `index in array == false`) from an iterable\n\t          // yielding `undefined`.\n\t          zipped.length++;\n\t        } else {\n\t          zipped.push(value);\n\t        }\n\n\t      case 23:\n\t        _iteratorNormalCompletion23 = true;\n\t        context$1$0.next = 13;\n\t        break;\n\n\t      case 26:\n\t        context$1$0.next = 32;\n\t        break;\n\n\t      case 28:\n\t        context$1$0.prev = 28;\n\t        context$1$0.t0 = context$1$0[\"catch\"](11);\n\t        _didIteratorError23 = true;\n\t        _iteratorError23 = context$1$0.t0;\n\n\t      case 32:\n\t        context$1$0.prev = 32;\n\t        context$1$0.prev = 33;\n\n\t        if (!_iteratorNormalCompletion23 && _iterator23[\"return\"]) {\n\t          _iterator23[\"return\"]();\n\t        }\n\n\t      case 35:\n\t        context$1$0.prev = 35;\n\n\t        if (!_didIteratorError23) {\n\t          context$1$0.next = 38;\n\t          break;\n\t        }\n\n\t        throw _iteratorError23;\n\n\t      case 38:\n\t        return context$1$0.finish(35);\n\n\t      case 39:\n\t        return context$1$0.finish(32);\n\n\t      case 40:\n\t        context$1$0.next = 42;\n\t        return zipped;\n\n\t      case 42:\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 44:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[11, 28, 32, 40], [33,, 35, 39]]);\n\t}));\n\n\trewrapStaticMethod(\"zip\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  for (var _len7 = arguments.length, iterables = Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {\n\t    iterables[_key7] = arguments[_key7];\n\t  }\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip(iterables), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"zipLongest\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  for (var _len8 = arguments.length, iterables = Array(_len8), _key8 = 0; _key8 < _len8; _key8++) {\n\t    iterables[_key8] = arguments[_key8];\n\t  }\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip(iterables, true), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"zipWith\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  for (var _len9 = arguments.length, iterables = Array(_len9 > 1 ? _len9 - 1 : 0), _key9 = 1; _key9 < _len9; _key9++) {\n\t    iterables[_key9 - 1] = arguments[_key9];\n\t  }\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip(iterables).spreadMap(fn), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\t/*\n\t * Functions that force iteration to completion and return a value.\n\t */\n\n\t// The maximum number of milliseconds we will block the main thread at a time\n\t// while in `asyncEach`.\n\twu.MAX_BLOCK = 15;\n\t// The number of milliseconds to yield to the main thread between bursts of\n\t// work.\n\twu.TIMEOUT = 1;\n\n\tprototypeAndStatic(\"asyncEach\", function (fn) {\n\t  var maxBlock = arguments.length <= 1 || arguments[1] === undefined ? wu.MAX_BLOCK : arguments[1];\n\t  var timeout = arguments.length <= 2 || arguments[2] === undefined ? wu.TIMEOUT : arguments[2];\n\n\t  var iter = getIterator(this);\n\n\t  return new _Promise(function (resolve, reject) {\n\t    (function loop() {\n\t      var start = Date.now();\n\n\t      var _iteratorNormalCompletion24 = true;\n\t      var _didIteratorError24 = false;\n\t      var _iteratorError24 = undefined;\n\n\t      try {\n\t        for (var _iterator24 = _getIterator(iter), _step24; !(_iteratorNormalCompletion24 = (_step24 = _iterator24.next()).done); _iteratorNormalCompletion24 = true) {\n\t          var x = _step24.value;\n\n\t          try {\n\t            fn(x);\n\t          } catch (e) {\n\t            reject(e);\n\t            return;\n\t          }\n\n\t          if (Date.now() - start > maxBlock) {\n\t            setTimeout(loop, timeout);\n\t            return;\n\t          }\n\t        }\n\t      } catch (err) {\n\t        _didIteratorError24 = true;\n\t        _iteratorError24 = err;\n\t      } finally {\n\t        try {\n\t          if (!_iteratorNormalCompletion24 && _iterator24[\"return\"]) {\n\t            _iterator24[\"return\"]();\n\t          }\n\t        } finally {\n\t          if (_didIteratorError24) {\n\t            throw _iteratorError24;\n\t          }\n\t        }\n\t      }\n\n\t      resolve();\n\t    })();\n\t  });\n\t}, 3);\n\n\tprototypeAndStatic(\"every\", function () {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\t  var _iteratorNormalCompletion25 = true;\n\t  var _didIteratorError25 = false;\n\t  var _iteratorError25 = undefined;\n\n\t  try {\n\t    for (var _iterator25 = _getIterator(this), _step25; !(_iteratorNormalCompletion25 = (_step25 = _iterator25.next()).done); _iteratorNormalCompletion25 = true) {\n\t      var x = _step25.value;\n\n\t      if (!fn(x)) {\n\t        return false;\n\t      }\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError25 = true;\n\t    _iteratorError25 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion25 && _iterator25[\"return\"]) {\n\t        _iterator25[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError25) {\n\t        throw _iteratorError25;\n\t      }\n\t    }\n\t  }\n\n\t  return true;\n\t}, 1);\n\n\tprototypeAndStatic(\"find\", function (fn) {\n\t  var _iteratorNormalCompletion26 = true;\n\t  var _didIteratorError26 = false;\n\t  var _iteratorError26 = undefined;\n\n\t  try {\n\t    for (var _iterator26 = _getIterator(this), _step26; !(_iteratorNormalCompletion26 = (_step26 = _iterator26.next()).done); _iteratorNormalCompletion26 = true) {\n\t      var x = _step26.value;\n\n\t      if (fn(x)) {\n\t        return x;\n\t      }\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError26 = true;\n\t    _iteratorError26 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion26 && _iterator26[\"return\"]) {\n\t        _iterator26[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError26) {\n\t        throw _iteratorError26;\n\t      }\n\t    }\n\t  }\n\t});\n\n\tprototypeAndStatic(\"forEach\", function (fn) {\n\t  var _iteratorNormalCompletion27 = true;\n\t  var _didIteratorError27 = false;\n\t  var _iteratorError27 = undefined;\n\n\t  try {\n\t    for (var _iterator27 = _getIterator(this), _step27; !(_iteratorNormalCompletion27 = (_step27 = _iterator27.next()).done); _iteratorNormalCompletion27 = true) {\n\t      var x = _step27.value;\n\n\t      fn(x);\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError27 = true;\n\t    _iteratorError27 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion27 && _iterator27[\"return\"]) {\n\t        _iterator27[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError27) {\n\t        throw _iteratorError27;\n\t      }\n\t    }\n\t  }\n\t});\n\n\tprototypeAndStatic(\"has\", function (thing) {\n\t  return this.some(function (x) {\n\t    return x === thing;\n\t  });\n\t});\n\n\tprototypeAndStatic(\"reduce\", function (fn) {\n\t  var initial = arguments.length <= 1 || arguments[1] === undefined ? undefined : arguments[1];\n\n\t  var val = initial;\n\t  if (val === undefined) {\n\t    var _iteratorNormalCompletion28 = true;\n\t    var _didIteratorError28 = false;\n\t    var _iteratorError28 = undefined;\n\n\t    try {\n\t      for (var _iterator28 = _getIterator(this), _step28; !(_iteratorNormalCompletion28 = (_step28 = _iterator28.next()).done); _iteratorNormalCompletion28 = true) {\n\t        var x = _step28.value;\n\n\t        val = x;\n\t        break;\n\t      }\n\t    } catch (err) {\n\t      _didIteratorError28 = true;\n\t      _iteratorError28 = err;\n\t    } finally {\n\t      try {\n\t        if (!_iteratorNormalCompletion28 && _iterator28[\"return\"]) {\n\t          _iterator28[\"return\"]();\n\t        }\n\t      } finally {\n\t        if (_didIteratorError28) {\n\t          throw _iteratorError28;\n\t        }\n\t      }\n\t    }\n\t  }\n\n\t  var _iteratorNormalCompletion29 = true;\n\t  var _didIteratorError29 = false;\n\t  var _iteratorError29 = undefined;\n\n\t  try {\n\t    for (var _iterator29 = _getIterator(this), _step29; !(_iteratorNormalCompletion29 = (_step29 = _iterator29.next()).done); _iteratorNormalCompletion29 = true) {\n\t      var x = _step29.value;\n\n\t      val = fn(val, x);\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError29 = true;\n\t    _iteratorError29 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion29 && _iterator29[\"return\"]) {\n\t        _iterator29[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError29) {\n\t        throw _iteratorError29;\n\t      }\n\t    }\n\t  }\n\n\t  return val;\n\t}, 2);\n\n\tprototypeAndStatic(\"some\", function () {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\t  var _iteratorNormalCompletion30 = true;\n\t  var _didIteratorError30 = false;\n\t  var _iteratorError30 = undefined;\n\n\t  try {\n\t    for (var _iterator30 = _getIterator(this), _step30; !(_iteratorNormalCompletion30 = (_step30 = _iterator30.next()).done); _iteratorNormalCompletion30 = true) {\n\t      var x = _step30.value;\n\n\t      if (fn(x)) {\n\t        return true;\n\t      }\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError30 = true;\n\t    _iteratorError30 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion30 && _iterator30[\"return\"]) {\n\t        _iterator30[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError30) {\n\t        throw _iteratorError30;\n\t      }\n\t    }\n\t  }\n\n\t  return false;\n\t}, 1);\n\n\tprototypeAndStatic(\"toArray\", function () {\n\t  return [].concat(_toConsumableArray(this));\n\t});\n\n\t/*\n\t * Methods that return an array of iterables.\n\t */\n\n\tvar MAX_CACHE = 500;\n\n\tvar _tee = rewrap(_regeneratorRuntime.mark(function callee$0$0(iterator, cache) {\n\t  var items, index, _iterator$next, done, value;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        items = cache.items;\n\t        index = 0;\n\n\t      case 2:\n\t        if (false) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        if (!(index === items.length)) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        _iterator$next = iterator.next();\n\t        done = _iterator$next.done;\n\t        value = _iterator$next.value;\n\n\t        if (!done) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        if (cache.returned === MISSING) {\n\t          cache.returned = value;\n\t        }\n\t        return context$1$0.abrupt(\"break\", 25);\n\n\t      case 10:\n\t        context$1$0.next = 12;\n\t        return items[index++] = value;\n\n\t      case 12:\n\t        context$1$0.next = 23;\n\t        break;\n\n\t      case 14:\n\t        if (!(index === cache.tail)) {\n\t          context$1$0.next = 21;\n\t          break;\n\t        }\n\n\t        value = items[index];\n\n\t        if (index === MAX_CACHE) {\n\t          items = cache.items = items.slice(index);\n\t          index = 0;\n\t          cache.tail = 0;\n\t        } else {\n\t          items[index] = undefined;\n\t          cache.tail = ++index;\n\t        }\n\t        context$1$0.next = 19;\n\t        return value;\n\n\t      case 19:\n\t        context$1$0.next = 23;\n\t        break;\n\n\t      case 21:\n\t        context$1$0.next = 23;\n\t        return items[index++];\n\n\t      case 23:\n\t        context$1$0.next = 2;\n\t        break;\n\n\t      case 25:\n\n\t        if (cache.tail === index) {\n\t          items.length = 0;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\", cache.returned);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\t_tee.prototype = Wu.prototype;\n\n\tprototypeAndStatic(\"tee\", function () {\n\t  var n = arguments.length <= 0 || arguments[0] === undefined ? 2 : arguments[0];\n\n\t  var iterables = new Array(n);\n\t  var cache = { tail: 0, items: [], returned: MISSING };\n\n\t  while (n--) {\n\t    iterables[n] = _tee(this, cache);\n\t  }\n\n\t  return iterables;\n\t}, 1);\n\n\tprototypeAndStatic(\"unzip\", function () {\n\t  var n = arguments.length <= 0 || arguments[0] === undefined ? 2 : arguments[0];\n\n\t  return this.tee(n).map(function (iter, i) {\n\t    return iter.pluck(i);\n\t  });\n\t}, 1);\n\n\t/*\n\t * Number of chambers.\n\t */\n\n\twu.tang = { clan: 36 };\n\n\t// We don't have a cached item for this index, we need to force its\n\t// evaluation.\n\n\t// If we are the last iterator to use a cached value, clean up after\n\t// ourselves.\n\n\t// We have an item in the cache for this index, so yield it.\n\n/***/ },\n/* 1 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t\"use strict\";\n\n\tvar _Array$from = __webpack_require__(2)[\"default\"];\n\n\texports[\"default\"] = function (arr) {\n\t  if (Array.isArray(arr)) {\n\t    for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n\t    return arr2;\n\t  } else {\n\t    return _Array$from(arr);\n\t  }\n\t};\n\n\texports.__esModule = true;\n\n/***/ },\n/* 2 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(3), __esModule: true };\n\n/***/ },\n/* 3 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(4);\n\t__webpack_require__(26);\n\tmodule.exports = __webpack_require__(12).Array.from;\n\n/***/ },\n/* 4 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $at  = __webpack_require__(5)(true);\n\n\t// 21.1.3.27 String.prototype[@@iterator]()\n\t__webpack_require__(8)(String, 'String', function(iterated){\n\t  this._t = String(iterated); // target\n\t  this._i = 0;                // next index\n\t// 21.1.5.2.1 %StringIteratorPrototype%.next()\n\t}, function(){\n\t  var O     = this._t\n\t    , index = this._i\n\t    , point;\n\t  if(index >= O.length)return {value: undefined, done: true};\n\t  point = $at(O, index);\n\t  this._i += point.length;\n\t  return {value: point, done: false};\n\t});\n\n/***/ },\n/* 5 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// true  -> String#at\n\t// false -> String#codePointAt\n\tvar toInteger = __webpack_require__(6)\n\t  , defined   = __webpack_require__(7);\n\tmodule.exports = function(TO_STRING){\n\t  return function(that, pos){\n\t    var s = String(defined(that))\n\t      , i = toInteger(pos)\n\t      , l = s.length\n\t      , a, b;\n\t    if(i < 0 || i >= l)return TO_STRING ? '' : undefined;\n\t    a = s.charCodeAt(i);\n\t    return a < 0xd800 || a > 0xdbff || i + 1 === l\n\t      || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\n\t        ? TO_STRING ? s.charAt(i) : a\n\t        : TO_STRING ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\n\t  };\n\t};\n\n/***/ },\n/* 6 */\n/***/ function(module, exports) {\n\n\t// 7.1.4 ToInteger\n\tvar ceil  = Math.ceil\n\t  , floor = Math.floor;\n\tmodule.exports = function(it){\n\t  return isNaN(it = +it) ? 0 : (it > 0 ? floor : ceil)(it);\n\t};\n\n/***/ },\n/* 7 */\n/***/ function(module, exports) {\n\n\t// 7.2.1 RequireObjectCoercible(argument)\n\tmodule.exports = function(it){\n\t  if(it == undefined)throw TypeError(\"Can't call method on  \" + it);\n\t  return it;\n\t};\n\n/***/ },\n/* 8 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar LIBRARY         = __webpack_require__(9)\n\t  , $def            = __webpack_require__(10)\n\t  , $redef          = __webpack_require__(13)\n\t  , hide            = __webpack_require__(14)\n\t  , has             = __webpack_require__(19)\n\t  , SYMBOL_ITERATOR = __webpack_require__(20)('iterator')\n\t  , Iterators       = __webpack_require__(23)\n\t  , BUGGY           = !([].keys && 'next' in [].keys()) // Safari has buggy iterators w/o `next`\n\t  , FF_ITERATOR     = '@@iterator'\n\t  , KEYS            = 'keys'\n\t  , VALUES          = 'values';\n\tvar returnThis = function(){ return this; };\n\tmodule.exports = function(Base, NAME, Constructor, next, DEFAULT, IS_SET, FORCE){\n\t  __webpack_require__(24)(Constructor, NAME, next);\n\t  var createMethod = function(kind){\n\t    switch(kind){\n\t      case KEYS: return function keys(){ return new Constructor(this, kind); };\n\t      case VALUES: return function values(){ return new Constructor(this, kind); };\n\t    } return function entries(){ return new Constructor(this, kind); };\n\t  };\n\t  var TAG      = NAME + ' Iterator'\n\t    , proto    = Base.prototype\n\t    , _native  = proto[SYMBOL_ITERATOR] || proto[FF_ITERATOR] || DEFAULT && proto[DEFAULT]\n\t    , _default = _native || createMethod(DEFAULT)\n\t    , methods, key;\n\t  // Fix native\n\t  if(_native){\n\t    var IteratorPrototype = __webpack_require__(15).getProto(_default.call(new Base));\n\t    // Set @@toStringTag to native iterators\n\t    __webpack_require__(25)(IteratorPrototype, TAG, true);\n\t    // FF fix\n\t    if(!LIBRARY && has(proto, FF_ITERATOR))hide(IteratorPrototype, SYMBOL_ITERATOR, returnThis);\n\t  }\n\t  // Define iterator\n\t  if(!LIBRARY || FORCE)hide(proto, SYMBOL_ITERATOR, _default);\n\t  // Plug for library\n\t  Iterators[NAME] = _default;\n\t  Iterators[TAG]  = returnThis;\n\t  if(DEFAULT){\n\t    methods = {\n\t      keys:    IS_SET            ? _default : createMethod(KEYS),\n\t      values:  DEFAULT == VALUES ? _default : createMethod(VALUES),\n\t      entries: DEFAULT != VALUES ? _default : createMethod('entries')\n\t    };\n\t    if(FORCE)for(key in methods){\n\t      if(!(key in proto))$redef(proto, key, methods[key]);\n\t    } else $def($def.P + $def.F * BUGGY, NAME, methods);\n\t  }\n\t};\n\n/***/ },\n/* 9 */\n/***/ function(module, exports) {\n\n\tmodule.exports = true;\n\n/***/ },\n/* 10 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar global    = __webpack_require__(11)\n\t  , core      = __webpack_require__(12)\n\t  , PROTOTYPE = 'prototype';\n\tvar ctx = function(fn, that){\n\t  return function(){\n\t    return fn.apply(that, arguments);\n\t  };\n\t};\n\tvar $def = function(type, name, source){\n\t  var key, own, out, exp\n\t    , isGlobal = type & $def.G\n\t    , isProto  = type & $def.P\n\t    , target   = isGlobal ? global : type & $def.S\n\t        ? global[name] : (global[name] || {})[PROTOTYPE]\n\t    , exports  = isGlobal ? core : core[name] || (core[name] = {});\n\t  if(isGlobal)source = name;\n\t  for(key in source){\n\t    // contains in native\n\t    own = !(type & $def.F) && target && key in target;\n\t    if(own && key in exports)continue;\n\t    // export native or passed\n\t    out = own ? target[key] : source[key];\n\t    // prevent global pollution for namespaces\n\t    if(isGlobal && typeof target[key] != 'function')exp = source[key];\n\t    // bind timers to global for call from export context\n\t    else if(type & $def.B && own)exp = ctx(out, global);\n\t    // wrap global constructors for prevent change them in library\n\t    else if(type & $def.W && target[key] == out)!function(C){\n\t      exp = function(param){\n\t        return this instanceof C ? new C(param) : C(param);\n\t      };\n\t      exp[PROTOTYPE] = C[PROTOTYPE];\n\t    }(out);\n\t    else exp = isProto && typeof out == 'function' ? ctx(Function.call, out) : out;\n\t    // export\n\t    exports[key] = exp;\n\t    if(isProto)(exports[PROTOTYPE] || (exports[PROTOTYPE] = {}))[key] = out;\n\t  }\n\t};\n\t// type bitmap\n\t$def.F = 1;  // forced\n\t$def.G = 2;  // global\n\t$def.S = 4;  // static\n\t$def.P = 8;  // proto\n\t$def.B = 16; // bind\n\t$def.W = 32; // wrap\n\tmodule.exports = $def;\n\n/***/ },\n/* 11 */\n/***/ function(module, exports) {\n\n\t// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\n\tvar UNDEFINED = 'undefined';\n\tvar global = module.exports = typeof window != UNDEFINED && window.Math == Math\n\t  ? window : typeof self != UNDEFINED && self.Math == Math ? self : Function('return this')();\n\tif(typeof __g == 'number')__g = global; // eslint-disable-line no-undef\n\n/***/ },\n/* 12 */\n/***/ function(module, exports) {\n\n\tvar core = module.exports = {version: '1.2.0'};\n\tif(typeof __e == 'number')__e = core; // eslint-disable-line no-undef\n\n/***/ },\n/* 13 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(14);\n\n/***/ },\n/* 14 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $          = __webpack_require__(15)\n\t  , createDesc = __webpack_require__(16);\n\tmodule.exports = __webpack_require__(17) ? function(object, key, value){\n\t  return $.setDesc(object, key, createDesc(1, value));\n\t} : function(object, key, value){\n\t  object[key] = value;\n\t  return object;\n\t};\n\n/***/ },\n/* 15 */\n/***/ function(module, exports) {\n\n\tvar $Object = Object;\n\tmodule.exports = {\n\t  create:     $Object.create,\n\t  getProto:   $Object.getPrototypeOf,\n\t  isEnum:     {}.propertyIsEnumerable,\n\t  getDesc:    $Object.getOwnPropertyDescriptor,\n\t  setDesc:    $Object.defineProperty,\n\t  setDescs:   $Object.defineProperties,\n\t  getKeys:    $Object.keys,\n\t  getNames:   $Object.getOwnPropertyNames,\n\t  getSymbols: $Object.getOwnPropertySymbols,\n\t  each:       [].forEach\n\t};\n\n/***/ },\n/* 16 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(bitmap, value){\n\t  return {\n\t    enumerable  : !(bitmap & 1),\n\t    configurable: !(bitmap & 2),\n\t    writable    : !(bitmap & 4),\n\t    value       : value\n\t  };\n\t};\n\n/***/ },\n/* 17 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// Thank's IE8 for his funny defineProperty\n\tmodule.exports = !__webpack_require__(18)(function(){\n\t  return Object.defineProperty({}, 'a', {get: function(){ return 7; }}).a != 7;\n\t});\n\n/***/ },\n/* 18 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(exec){\n\t  try {\n\t    return !!exec();\n\t  } catch(e){\n\t    return true;\n\t  }\n\t};\n\n/***/ },\n/* 19 */\n/***/ function(module, exports) {\n\n\tvar hasOwnProperty = {}.hasOwnProperty;\n\tmodule.exports = function(it, key){\n\t  return hasOwnProperty.call(it, key);\n\t};\n\n/***/ },\n/* 20 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar store  = __webpack_require__(21)('wks')\n\t  , Symbol = __webpack_require__(11).Symbol;\n\tmodule.exports = function(name){\n\t  return store[name] || (store[name] =\n\t    Symbol && Symbol[name] || (Symbol || __webpack_require__(22))('Symbol.' + name));\n\t};\n\n/***/ },\n/* 21 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar global = __webpack_require__(11)\n\t  , SHARED = '__core-js_shared__'\n\t  , store  = global[SHARED] || (global[SHARED] = {});\n\tmodule.exports = function(key){\n\t  return store[key] || (store[key] = {});\n\t};\n\n/***/ },\n/* 22 */\n/***/ function(module, exports) {\n\n\tvar id = 0\n\t  , px = Math.random();\n\tmodule.exports = function(key){\n\t  return 'Symbol('.concat(key === undefined ? '' : key, ')_', (++id + px).toString(36));\n\t};\n\n/***/ },\n/* 23 */\n/***/ function(module, exports) {\n\n\tmodule.exports = {};\n\n/***/ },\n/* 24 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $ = __webpack_require__(15)\n\t  , IteratorPrototype = {};\n\n\t// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\n\t__webpack_require__(14)(IteratorPrototype, __webpack_require__(20)('iterator'), function(){ return this; });\n\n\tmodule.exports = function(Constructor, NAME, next){\n\t  Constructor.prototype = $.create(IteratorPrototype, {next: __webpack_require__(16)(1,next)});\n\t  __webpack_require__(25)(Constructor, NAME + ' Iterator');\n\t};\n\n/***/ },\n/* 25 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar has  = __webpack_require__(19)\n\t  , hide = __webpack_require__(14)\n\t  , TAG  = __webpack_require__(20)('toStringTag');\n\n\tmodule.exports = function(it, tag, stat){\n\t  if(it && !has(it = stat ? it : it.prototype, TAG))hide(it, TAG, tag);\n\t};\n\n/***/ },\n/* 26 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar ctx         = __webpack_require__(27)\n\t  , $def        = __webpack_require__(10)\n\t  , toObject    = __webpack_require__(29)\n\t  , call        = __webpack_require__(30)\n\t  , isArrayIter = __webpack_require__(33)\n\t  , toLength    = __webpack_require__(34)\n\t  , getIterFn   = __webpack_require__(35);\n\t$def($def.S + $def.F * !__webpack_require__(38)(function(iter){ Array.from(iter); }), 'Array', {\n\t  // 22.1.2.1 Array.from(arrayLike, mapfn = undefined, thisArg = undefined)\n\t  from: function from(arrayLike/*, mapfn = undefined, thisArg = undefined*/){\n\t    var O       = toObject(arrayLike)\n\t      , C       = typeof this == 'function' ? this : Array\n\t      , mapfn   = arguments[1]\n\t      , mapping = mapfn !== undefined\n\t      , index   = 0\n\t      , iterFn  = getIterFn(O)\n\t      , length, result, step, iterator;\n\t    if(mapping)mapfn = ctx(mapfn, arguments[2], 2);\n\t    // if object isn't iterable or it's array with default iterator - use simple case\n\t    if(iterFn != undefined && !(C == Array && isArrayIter(iterFn))){\n\t      for(iterator = iterFn.call(O), result = new C; !(step = iterator.next()).done; index++){\n\t        result[index] = mapping ? call(iterator, mapfn, [step.value, index], true) : step.value;\n\t      }\n\t    } else {\n\t      length = toLength(O.length);\n\t      for(result = new C(length); length > index; index++){\n\t        result[index] = mapping ? mapfn(O[index], index) : O[index];\n\t      }\n\t    }\n\t    result.length = index;\n\t    return result;\n\t  }\n\t});\n\n\n/***/ },\n/* 27 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// optional / simple context binding\n\tvar aFunction = __webpack_require__(28);\n\tmodule.exports = function(fn, that, length){\n\t  aFunction(fn);\n\t  if(that === undefined)return fn;\n\t  switch(length){\n\t    case 1: return function(a){\n\t      return fn.call(that, a);\n\t    };\n\t    case 2: return function(a, b){\n\t      return fn.call(that, a, b);\n\t    };\n\t    case 3: return function(a, b, c){\n\t      return fn.call(that, a, b, c);\n\t    };\n\t  }\n\t  return function(/* ...args */){\n\t    return fn.apply(that, arguments);\n\t  };\n\t};\n\n/***/ },\n/* 28 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(it){\n\t  if(typeof it != 'function')throw TypeError(it + ' is not a function!');\n\t  return it;\n\t};\n\n/***/ },\n/* 29 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// 7.1.13 ToObject(argument)\n\tvar defined = __webpack_require__(7);\n\tmodule.exports = function(it){\n\t  return Object(defined(it));\n\t};\n\n/***/ },\n/* 30 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// call something on iterator step with safe closing on error\n\tvar anObject = __webpack_require__(31);\n\tmodule.exports = function(iterator, fn, value, entries){\n\t  try {\n\t    return entries ? fn(anObject(value)[0], value[1]) : fn(value);\n\t  // 7.4.6 IteratorClose(iterator, completion)\n\t  } catch(e){\n\t    var ret = iterator['return'];\n\t    if(ret !== undefined)anObject(ret.call(iterator));\n\t    throw e;\n\t  }\n\t};\n\n/***/ },\n/* 31 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar isObject = __webpack_require__(32);\n\tmodule.exports = function(it){\n\t  if(!isObject(it))throw TypeError(it + ' is not an object!');\n\t  return it;\n\t};\n\n/***/ },\n/* 32 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(it){\n\t  return typeof it === 'object' ? it !== null : typeof it === 'function';\n\t};\n\n/***/ },\n/* 33 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// check on default Array iterator\n\tvar Iterators = __webpack_require__(23)\n\t  , ITERATOR  = __webpack_require__(20)('iterator');\n\tmodule.exports = function(it){\n\t  return (Iterators.Array || Array.prototype[ITERATOR]) === it;\n\t};\n\n/***/ },\n/* 34 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// 7.1.15 ToLength\n\tvar toInteger = __webpack_require__(6)\n\t  , min       = Math.min;\n\tmodule.exports = function(it){\n\t  return it > 0 ? min(toInteger(it), 0x1fffffffffffff) : 0; // pow(2, 53) - 1 == 9007199254740991\n\t};\n\n/***/ },\n/* 35 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar classof   = __webpack_require__(36)\n\t  , ITERATOR  = __webpack_require__(20)('iterator')\n\t  , Iterators = __webpack_require__(23);\n\tmodule.exports = __webpack_require__(12).getIteratorMethod = function(it){\n\t  if(it != undefined)return it[ITERATOR] || it['@@iterator'] || Iterators[classof(it)];\n\t};\n\n/***/ },\n/* 36 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// getting tag from 19.1.3.6 Object.prototype.toString()\n\tvar cof = __webpack_require__(37)\n\t  , TAG = __webpack_require__(20)('toStringTag')\n\t  // ES3 wrong here\n\t  , ARG = cof(function(){ return arguments; }()) == 'Arguments';\n\n\tmodule.exports = function(it){\n\t  var O, T, B;\n\t  return it === undefined ? 'Undefined' : it === null ? 'Null'\n\t    // @@toStringTag case\n\t    : typeof (T = (O = Object(it))[TAG]) == 'string' ? T\n\t    // builtinTag case\n\t    : ARG ? cof(O)\n\t    // ES3 arguments fallback\n\t    : (B = cof(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : B;\n\t};\n\n/***/ },\n/* 37 */\n/***/ function(module, exports) {\n\n\tvar toString = {}.toString;\n\n\tmodule.exports = function(it){\n\t  return toString.call(it).slice(8, -1);\n\t};\n\n/***/ },\n/* 38 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar SYMBOL_ITERATOR = __webpack_require__(20)('iterator')\n\t  , SAFE_CLOSING    = false;\n\ttry {\n\t  var riter = [7][SYMBOL_ITERATOR]();\n\t  riter['return'] = function(){ SAFE_CLOSING = true; };\n\t  Array.from(riter, function(){ throw 2; });\n\t} catch(e){ /* empty */ }\n\tmodule.exports = function(exec){\n\t  if(!SAFE_CLOSING)return false;\n\t  var safe = false;\n\t  try {\n\t    var arr  = [7]\n\t      , iter = arr[SYMBOL_ITERATOR]();\n\t    iter.next = function(){ safe = true; };\n\t    arr[SYMBOL_ITERATOR] = function(){ return iter; };\n\t    exec(arr);\n\t  } catch(e){ /* empty */ }\n\t  return safe;\n\t};\n\n/***/ },\n/* 39 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t\"use strict\";\n\n\tvar _getIterator = __webpack_require__(40)[\"default\"];\n\n\tvar _isIterable = __webpack_require__(49)[\"default\"];\n\n\texports[\"default\"] = (function () {\n\t  function sliceIterator(arr, i) {\n\t    var _arr = [];\n\t    var _n = true;\n\t    var _d = false;\n\t    var _e = undefined;\n\n\t    try {\n\t      for (var _i = _getIterator(arr), _s; !(_n = (_s = _i.next()).done); _n = true) {\n\t        _arr.push(_s.value);\n\n\t        if (i && _arr.length === i) break;\n\t      }\n\t    } catch (err) {\n\t      _d = true;\n\t      _e = err;\n\t    } finally {\n\t      try {\n\t        if (!_n && _i[\"return\"]) _i[\"return\"]();\n\t      } finally {\n\t        if (_d) throw _e;\n\t      }\n\t    }\n\n\t    return _arr;\n\t  }\n\n\t  return function (arr, i) {\n\t    if (Array.isArray(arr)) {\n\t      return arr;\n\t    } else if (_isIterable(Object(arr))) {\n\t      return sliceIterator(arr, i);\n\t    } else {\n\t      throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n\t    }\n\t  };\n\t})();\n\n\texports.__esModule = true;\n\n/***/ },\n/* 40 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(41), __esModule: true };\n\n/***/ },\n/* 41 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(42);\n\t__webpack_require__(4);\n\tmodule.exports = __webpack_require__(48);\n\n/***/ },\n/* 42 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(43);\n\tvar Iterators = __webpack_require__(23);\n\tIterators.NodeList = Iterators.HTMLCollection = Iterators.Array;\n\n/***/ },\n/* 43 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar setUnscope = __webpack_require__(44)\n\t  , step       = __webpack_require__(45)\n\t  , Iterators  = __webpack_require__(23)\n\t  , toIObject  = __webpack_require__(46);\n\n\t// 22.1.3.4 Array.prototype.entries()\n\t// 22.1.3.13 Array.prototype.keys()\n\t// 22.1.3.29 Array.prototype.values()\n\t// 22.1.3.30 Array.prototype[@@iterator]()\n\t__webpack_require__(8)(Array, 'Array', function(iterated, kind){\n\t  this._t = toIObject(iterated); // target\n\t  this._i = 0;                   // next index\n\t  this._k = kind;                // kind\n\t// 22.1.5.2.1 %ArrayIteratorPrototype%.next()\n\t}, function(){\n\t  var O     = this._t\n\t    , kind  = this._k\n\t    , index = this._i++;\n\t  if(!O || index >= O.length){\n\t    this._t = undefined;\n\t    return step(1);\n\t  }\n\t  if(kind == 'keys'  )return step(0, index);\n\t  if(kind == 'values')return step(0, O[index]);\n\t  return step(0, [index, O[index]]);\n\t}, 'values');\n\n\t// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\n\tIterators.Arguments = Iterators.Array;\n\n\tsetUnscope('keys');\n\tsetUnscope('values');\n\tsetUnscope('entries');\n\n/***/ },\n/* 44 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(){ /* empty */ };\n\n/***/ },\n/* 45 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(done, value){\n\t  return {value: value, done: !!done};\n\t};\n\n/***/ },\n/* 46 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// to indexed object, toObject with fallback for non-array-like ES3 strings\r\n\tvar IObject = __webpack_require__(47)\r\n\t  , defined = __webpack_require__(7);\r\n\tmodule.exports = function(it){\r\n\t  return IObject(defined(it));\r\n\t};\n\n/***/ },\n/* 47 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// indexed object, fallback for non-array-like ES3 strings\n\tvar cof = __webpack_require__(37);\n\tmodule.exports = 0 in Object('z') ? Object : function(it){\n\t  return cof(it) == 'String' ? it.split('') : Object(it);\n\t};\n\n/***/ },\n/* 48 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar anObject = __webpack_require__(31)\n\t  , get      = __webpack_require__(35);\n\tmodule.exports = __webpack_require__(12).getIterator = function(it){\n\t  var iterFn = get(it);\n\t  if(typeof iterFn != 'function')throw TypeError(it + ' is not iterable!');\n\t  return anObject(iterFn.call(it));\n\t};\n\n/***/ },\n/* 49 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(50), __esModule: true };\n\n/***/ },\n/* 50 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(42);\n\t__webpack_require__(4);\n\tmodule.exports = __webpack_require__(51);\n\n/***/ },\n/* 51 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar classof   = __webpack_require__(36)\n\t  , ITERATOR  = __webpack_require__(20)('iterator')\n\t  , Iterators = __webpack_require__(23);\n\tmodule.exports = __webpack_require__(12).isIterable = function(it){\n\t  var O = Object(it);\n\t  return ITERATOR in O || '@@iterator' in O || Iterators.hasOwnProperty(classof(O));\n\t};\n\n/***/ },\n/* 52 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(53), __esModule: true };\n\n/***/ },\n/* 53 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(4);\n\t__webpack_require__(42);\n\tmodule.exports = __webpack_require__(20)('iterator');\n\n/***/ },\n/* 54 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(global) {// This method of obtaining a reference to the global object needs to be\n\t// kept identical to the way it is obtained in runtime.js\n\tvar g =\n\t  typeof global === \"object\" ? global :\n\t  typeof window === \"object\" ? window :\n\t  typeof self === \"object\" ? self : this;\n\n\t// Use `getOwnPropertyNames` because not all browsers support calling\n\t// `hasOwnProperty` on the global `self` object in a worker. See #183.\n\tvar hadRuntime = g.regeneratorRuntime &&\n\t  Object.getOwnPropertyNames(g).indexOf(\"regeneratorRuntime\") >= 0;\n\n\t// Save the old regeneratorRuntime in case it needs to be restored later.\n\tvar oldRuntime = hadRuntime && g.regeneratorRuntime;\n\n\t// Force reevalutation of runtime.js.\n\tg.regeneratorRuntime = undefined;\n\n\tmodule.exports = __webpack_require__(55);\n\n\tif (hadRuntime) {\n\t  // Restore the original runtime.\n\t  g.regeneratorRuntime = oldRuntime;\n\t} else {\n\t  // Remove the global property added by runtime.js.\n\t  try {\n\t    delete g.regeneratorRuntime;\n\t  } catch(e) {\n\t    g.regeneratorRuntime = undefined;\n\t  }\n\t}\n\n\tmodule.exports = { \"default\": module.exports, __esModule: true };\n\n\t/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))\n\n/***/ },\n/* 55 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(global, process) {/**\n\t * Copyright (c) 2014, Facebook, Inc.\n\t * All rights reserved.\n\t *\n\t * This source code is licensed under the BSD-style license found in the\n\t * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n\t * additional grant of patent rights can be found in the PATENTS file in\n\t * the same directory.\n\t */\n\n\t\"use strict\";\n\n\tvar _Symbol = __webpack_require__(57)[\"default\"];\n\n\tvar _Symbol$iterator = __webpack_require__(52)[\"default\"];\n\n\tvar _Object$create = __webpack_require__(63)[\"default\"];\n\n\tvar _Promise = __webpack_require__(65)[\"default\"];\n\n\t!(function (global) {\n\t  \"use strict\";\n\n\t  var hasOwn = Object.prototype.hasOwnProperty;\n\t  var undefined; // More compressible than void 0.\n\t  var iteratorSymbol = typeof _Symbol === \"function\" && _Symbol$iterator || \"@@iterator\";\n\n\t  var inModule = typeof module === \"object\";\n\t  var runtime = global.regeneratorRuntime;\n\t  if (runtime) {\n\t    if (inModule) {\n\t      // If regeneratorRuntime is defined globally and we're in a module,\n\t      // make the exports object identical to regeneratorRuntime.\n\t      module.exports = runtime;\n\t    }\n\t    // Don't bother evaluating the rest of this file if the runtime was\n\t    // already defined globally.\n\t    return;\n\t  }\n\n\t  // Define the runtime globally (as expected by generated code) as either\n\t  // module.exports (if we're in a module) or a new, empty object.\n\t  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n\t  function wrap(innerFn, outerFn, self, tryLocsList) {\n\t    // If outerFn provided, then outerFn.prototype instanceof Generator.\n\t    var generator = _Object$create((outerFn || Generator).prototype);\n\n\t    generator._invoke = makeInvokeMethod(innerFn, self || null, new Context(tryLocsList || []));\n\n\t    return generator;\n\t  }\n\t  runtime.wrap = wrap;\n\n\t  // Try/catch helper to minimize deoptimizations. Returns a completion\n\t  // record like context.tryEntries[i].completion. This interface could\n\t  // have been (and was previously) designed to take a closure to be\n\t  // invoked without arguments, but in all the cases we care about we\n\t  // already have an existing method we want to call, so there's no need\n\t  // to create a new function object. We can even get away with assuming\n\t  // the method takes exactly one argument, since that happens to be true\n\t  // in every case, so we don't have to touch the arguments object. The\n\t  // only additional allocation required is the completion record, which\n\t  // has a stable shape and so hopefully should be cheap to allocate.\n\t  function tryCatch(fn, obj, arg) {\n\t    try {\n\t      return { type: \"normal\", arg: fn.call(obj, arg) };\n\t    } catch (err) {\n\t      return { type: \"throw\", arg: err };\n\t    }\n\t  }\n\n\t  var GenStateSuspendedStart = \"suspendedStart\";\n\t  var GenStateSuspendedYield = \"suspendedYield\";\n\t  var GenStateExecuting = \"executing\";\n\t  var GenStateCompleted = \"completed\";\n\n\t  // Returning this object from the innerFn has the same effect as\n\t  // breaking out of the dispatch switch statement.\n\t  var ContinueSentinel = {};\n\n\t  // Dummy constructor functions that we use as the .constructor and\n\t  // .constructor.prototype properties for functions that return Generator\n\t  // objects. For full spec compliance, you may wish to configure your\n\t  // minifier not to mangle the names of these two functions.\n\t  function Generator() {}\n\t  function GeneratorFunction() {}\n\t  function GeneratorFunctionPrototype() {}\n\n\t  var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n\t  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n\t  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n\t  GeneratorFunction.displayName = \"GeneratorFunction\";\n\n\t  // Helper for defining the .next, .throw, and .return methods of the\n\t  // Iterator interface in terms of a single ._invoke method.\n\t  function defineIteratorMethods(prototype) {\n\t    [\"next\", \"throw\", \"return\"].forEach(function (method) {\n\t      prototype[method] = function (arg) {\n\t        return this._invoke(method, arg);\n\t      };\n\t    });\n\t  }\n\n\t  runtime.isGeneratorFunction = function (genFun) {\n\t    var ctor = typeof genFun === \"function\" && genFun.constructor;\n\t    return ctor ? ctor === GeneratorFunction ||\n\t    // For the native GeneratorFunction constructor, the best we can\n\t    // do is to check its .name property.\n\t    (ctor.displayName || ctor.name) === \"GeneratorFunction\" : false;\n\t  };\n\n\t  runtime.mark = function (genFun) {\n\t    genFun.__proto__ = GeneratorFunctionPrototype;\n\t    genFun.prototype = _Object$create(Gp);\n\t    return genFun;\n\t  };\n\n\t  // Within the body of any async function, `await x` is transformed to\n\t  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n\t  // `value instanceof AwaitArgument` to determine if the yielded value is\n\t  // meant to be awaited. Some may consider the name of this method too\n\t  // cutesy, but they are curmudgeons.\n\t  runtime.awrap = function (arg) {\n\t    return new AwaitArgument(arg);\n\t  };\n\n\t  function AwaitArgument(arg) {\n\t    this.arg = arg;\n\t  }\n\n\t  function AsyncIterator(generator) {\n\t    // This invoke function is written in a style that assumes some\n\t    // calling function (or Promise) will handle exceptions.\n\t    function invoke(method, arg) {\n\t      var result = generator[method](arg);\n\t      var value = result.value;\n\t      return value instanceof AwaitArgument ? _Promise.resolve(value.arg).then(invokeNext, invokeThrow) : _Promise.resolve(value).then(function (unwrapped) {\n\t        // When a yielded Promise is resolved, its final value becomes\n\t        // the .value of the Promise<{value,done}> result for the\n\t        // current iteration. If the Promise is rejected, however, the\n\t        // result for this iteration will be rejected with the same\n\t        // reason. Note that rejections of yielded Promises are not\n\t        // thrown back into the generator function, as is the case\n\t        // when an awaited Promise is rejected. This difference in\n\t        // behavior between yield and await is important, because it\n\t        // allows the consumer to decide what to do with the yielded\n\t        // rejection (swallow it and continue, manually .throw it back\n\t        // into the generator, abandon iteration, whatever). With\n\t        // await, by contrast, there is no opportunity to examine the\n\t        // rejection reason outside the generator function, so the\n\t        // only option is to throw it from the await expression, and\n\t        // let the generator function handle the exception.\n\t        result.value = unwrapped;\n\t        return result;\n\t      });\n\t    }\n\n\t    if (typeof process === \"object\" && process.domain) {\n\t      invoke = process.domain.bind(invoke);\n\t    }\n\n\t    var invokeNext = invoke.bind(generator, \"next\");\n\t    var invokeThrow = invoke.bind(generator, \"throw\");\n\t    var invokeReturn = invoke.bind(generator, \"return\");\n\t    var previousPromise;\n\n\t    function enqueue(method, arg) {\n\t      var enqueueResult =\n\t      // If enqueue has been called before, then we want to wait until\n\t      // all previous Promises have been resolved before calling invoke,\n\t      // so that results are always delivered in the correct order. If\n\t      // enqueue has not been called before, then it is important to\n\t      // call invoke immediately, without waiting on a callback to fire,\n\t      // so that the async generator function has the opportunity to do\n\t      // any necessary setup in a predictable way. This predictability\n\t      // is why the Promise constructor synchronously invokes its\n\t      // executor callback, and why async functions synchronously\n\t      // execute code before the first await. Since we implement simple\n\t      // async functions in terms of async generators, it is especially\n\t      // important to get this right, even though it requires care.\n\t      previousPromise ? previousPromise.then(function () {\n\t        return invoke(method, arg);\n\t      }) : new _Promise(function (resolve) {\n\t        resolve(invoke(method, arg));\n\t      });\n\n\t      // Avoid propagating enqueueResult failures to Promises returned by\n\t      // later invocations of the iterator.\n\t      previousPromise = enqueueResult[\"catch\"](function (ignored) {});\n\n\t      return enqueueResult;\n\t    }\n\n\t    // Define the unified helper method that is used to implement .next,\n\t    // .throw, and .return (see defineIteratorMethods).\n\t    this._invoke = enqueue;\n\t  }\n\n\t  defineIteratorMethods(AsyncIterator.prototype);\n\n\t  // Note that simple async functions are implemented on top of\n\t  // AsyncIterator objects; they just return a Promise for the value of\n\t  // the final result produced by the iterator.\n\t  runtime.async = function (innerFn, outerFn, self, tryLocsList) {\n\t    var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList));\n\n\t    return runtime.isGeneratorFunction(outerFn) ? iter // If outerFn is a generator, return the full iterator.\n\t    : iter.next().then(function (result) {\n\t      return result.done ? result.value : iter.next();\n\t    });\n\t  };\n\n\t  function makeInvokeMethod(innerFn, self, context) {\n\t    var state = GenStateSuspendedStart;\n\n\t    return function invoke(method, arg) {\n\t      if (state === GenStateExecuting) {\n\t        throw new Error(\"Generator is already running\");\n\t      }\n\n\t      if (state === GenStateCompleted) {\n\t        if (method === \"throw\") {\n\t          throw arg;\n\t        }\n\n\t        // Be forgiving, per 25.3.3.3.3 of the spec:\n\t        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n\t        return doneResult();\n\t      }\n\n\t      while (true) {\n\t        var delegate = context.delegate;\n\t        if (delegate) {\n\t          if (method === \"return\" || method === \"throw\" && delegate.iterator[method] === undefined) {\n\t            // A return or throw (when the delegate iterator has no throw\n\t            // method) always terminates the yield* loop.\n\t            context.delegate = null;\n\n\t            // If the delegate iterator has a return method, give it a\n\t            // chance to clean up.\n\t            var returnMethod = delegate.iterator[\"return\"];\n\t            if (returnMethod) {\n\t              var record = tryCatch(returnMethod, delegate.iterator, arg);\n\t              if (record.type === \"throw\") {\n\t                // If the return method threw an exception, let that\n\t                // exception prevail over the original return or throw.\n\t                method = \"throw\";\n\t                arg = record.arg;\n\t                continue;\n\t              }\n\t            }\n\n\t            if (method === \"return\") {\n\t              // Continue with the outer return, now that the delegate\n\t              // iterator has been terminated.\n\t              continue;\n\t            }\n\t          }\n\n\t          var record = tryCatch(delegate.iterator[method], delegate.iterator, arg);\n\n\t          if (record.type === \"throw\") {\n\t            context.delegate = null;\n\n\t            // Like returning generator.throw(uncaught), but without the\n\t            // overhead of an extra function call.\n\t            method = \"throw\";\n\t            arg = record.arg;\n\t            continue;\n\t          }\n\n\t          // Delegate generator ran and handled its own exceptions so\n\t          // regardless of what the method was, we continue as if it is\n\t          // \"next\" with an undefined arg.\n\t          method = \"next\";\n\t          arg = undefined;\n\n\t          var info = record.arg;\n\t          if (info.done) {\n\t            context[delegate.resultName] = info.value;\n\t            context.next = delegate.nextLoc;\n\t          } else {\n\t            state = GenStateSuspendedYield;\n\t            return info;\n\t          }\n\n\t          context.delegate = null;\n\t        }\n\n\t        if (method === \"next\") {\n\t          if (state === GenStateSuspendedYield) {\n\t            context.sent = arg;\n\t          } else {\n\t            context.sent = undefined;\n\t          }\n\t        } else if (method === \"throw\") {\n\t          if (state === GenStateSuspendedStart) {\n\t            state = GenStateCompleted;\n\t            throw arg;\n\t          }\n\n\t          if (context.dispatchException(arg)) {\n\t            // If the dispatched exception was caught by a catch block,\n\t            // then let that catch block handle the exception normally.\n\t            method = \"next\";\n\t            arg = undefined;\n\t          }\n\t        } else if (method === \"return\") {\n\t          context.abrupt(\"return\", arg);\n\t        }\n\n\t        state = GenStateExecuting;\n\n\t        var record = tryCatch(innerFn, self, context);\n\t        if (record.type === \"normal\") {\n\t          // If an exception is thrown from innerFn, we leave state ===\n\t          // GenStateExecuting and loop back for another invocation.\n\t          state = context.done ? GenStateCompleted : GenStateSuspendedYield;\n\n\t          var info = {\n\t            value: record.arg,\n\t            done: context.done\n\t          };\n\n\t          if (record.arg === ContinueSentinel) {\n\t            if (context.delegate && method === \"next\") {\n\t              // Deliberately forget the last sent value so that we don't\n\t              // accidentally pass it on to the delegate.\n\t              arg = undefined;\n\t            }\n\t          } else {\n\t            return info;\n\t          }\n\t        } else if (record.type === \"throw\") {\n\t          state = GenStateCompleted;\n\t          // Dispatch the exception by looping back around to the\n\t          // context.dispatchException(arg) call above.\n\t          method = \"throw\";\n\t          arg = record.arg;\n\t        }\n\t      }\n\t    };\n\t  }\n\n\t  // Define Generator.prototype.{next,throw,return} in terms of the\n\t  // unified ._invoke helper method.\n\t  defineIteratorMethods(Gp);\n\n\t  Gp[iteratorSymbol] = function () {\n\t    return this;\n\t  };\n\n\t  Gp.toString = function () {\n\t    return \"[object Generator]\";\n\t  };\n\n\t  function pushTryEntry(locs) {\n\t    var entry = { tryLoc: locs[0] };\n\n\t    if (1 in locs) {\n\t      entry.catchLoc = locs[1];\n\t    }\n\n\t    if (2 in locs) {\n\t      entry.finallyLoc = locs[2];\n\t      entry.afterLoc = locs[3];\n\t    }\n\n\t    this.tryEntries.push(entry);\n\t  }\n\n\t  function resetTryEntry(entry) {\n\t    var record = entry.completion || {};\n\t    record.type = \"normal\";\n\t    delete record.arg;\n\t    entry.completion = record;\n\t  }\n\n\t  function Context(tryLocsList) {\n\t    // The root entry object (effectively a try statement without a catch\n\t    // or a finally block) gives us a place to store values thrown from\n\t    // locations where there is no enclosing try statement.\n\t    this.tryEntries = [{ tryLoc: \"root\" }];\n\t    tryLocsList.forEach(pushTryEntry, this);\n\t    this.reset(true);\n\t  }\n\n\t  runtime.keys = function (object) {\n\t    var keys = [];\n\t    for (var key in object) {\n\t      keys.push(key);\n\t    }\n\t    keys.reverse();\n\n\t    // Rather than returning an object with a next method, we keep\n\t    // things simple and return the next function itself.\n\t    return function next() {\n\t      while (keys.length) {\n\t        var key = keys.pop();\n\t        if (key in object) {\n\t          next.value = key;\n\t          next.done = false;\n\t          return next;\n\t        }\n\t      }\n\n\t      // To avoid creating an additional object, we just hang the .value\n\t      // and .done properties off the next function object itself. This\n\t      // also ensures that the minifier will not anonymize the function.\n\t      next.done = true;\n\t      return next;\n\t    };\n\t  };\n\n\t  function values(iterable) {\n\t    if (iterable) {\n\t      var iteratorMethod = iterable[iteratorSymbol];\n\t      if (iteratorMethod) {\n\t        return iteratorMethod.call(iterable);\n\t      }\n\n\t      if (typeof iterable.next === \"function\") {\n\t        return iterable;\n\t      }\n\n\t      if (!isNaN(iterable.length)) {\n\t        var i = -1,\n\t            next = function next() {\n\t          while (++i < iterable.length) {\n\t            if (hasOwn.call(iterable, i)) {\n\t              next.value = iterable[i];\n\t              next.done = false;\n\t              return next;\n\t            }\n\t          }\n\n\t          next.value = undefined;\n\t          next.done = true;\n\n\t          return next;\n\t        };\n\n\t        return next.next = next;\n\t      }\n\t    }\n\n\t    // Return an iterator with no values.\n\t    return { next: doneResult };\n\t  }\n\t  runtime.values = values;\n\n\t  function doneResult() {\n\t    return { value: undefined, done: true };\n\t  }\n\n\t  Context.prototype = {\n\t    constructor: Context,\n\n\t    reset: function reset(skipTempReset) {\n\t      this.prev = 0;\n\t      this.next = 0;\n\t      this.sent = undefined;\n\t      this.done = false;\n\t      this.delegate = null;\n\n\t      this.tryEntries.forEach(resetTryEntry);\n\n\t      if (!skipTempReset) {\n\t        for (var name in this) {\n\t          // Not sure about the optimal order of these conditions:\n\t          if (name.charAt(0) === \"t\" && hasOwn.call(this, name) && !isNaN(+name.slice(1))) {\n\t            this[name] = undefined;\n\t          }\n\t        }\n\t      }\n\t    },\n\n\t    stop: function stop() {\n\t      this.done = true;\n\n\t      var rootEntry = this.tryEntries[0];\n\t      var rootRecord = rootEntry.completion;\n\t      if (rootRecord.type === \"throw\") {\n\t        throw rootRecord.arg;\n\t      }\n\n\t      return this.rval;\n\t    },\n\n\t    dispatchException: function dispatchException(exception) {\n\t      if (this.done) {\n\t        throw exception;\n\t      }\n\n\t      var context = this;\n\t      function handle(loc, caught) {\n\t        record.type = \"throw\";\n\t        record.arg = exception;\n\t        context.next = loc;\n\t        return !!caught;\n\t      }\n\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        var record = entry.completion;\n\n\t        if (entry.tryLoc === \"root\") {\n\t          // Exception thrown outside of any try block that could handle\n\t          // it, so set the completion value of the entire function to\n\t          // throw the exception.\n\t          return handle(\"end\");\n\t        }\n\n\t        if (entry.tryLoc <= this.prev) {\n\t          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n\t          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n\t          if (hasCatch && hasFinally) {\n\t            if (this.prev < entry.catchLoc) {\n\t              return handle(entry.catchLoc, true);\n\t            } else if (this.prev < entry.finallyLoc) {\n\t              return handle(entry.finallyLoc);\n\t            }\n\t          } else if (hasCatch) {\n\t            if (this.prev < entry.catchLoc) {\n\t              return handle(entry.catchLoc, true);\n\t            }\n\t          } else if (hasFinally) {\n\t            if (this.prev < entry.finallyLoc) {\n\t              return handle(entry.finallyLoc);\n\t            }\n\t          } else {\n\t            throw new Error(\"try statement without catch or finally\");\n\t          }\n\t        }\n\t      }\n\t    },\n\n\t    abrupt: function abrupt(type, arg) {\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n\t          var finallyEntry = entry;\n\t          break;\n\t        }\n\t      }\n\n\t      if (finallyEntry && (type === \"break\" || type === \"continue\") && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc) {\n\t        // Ignore the finally entry if control is not jumping to a\n\t        // location outside the try/catch block.\n\t        finallyEntry = null;\n\t      }\n\n\t      var record = finallyEntry ? finallyEntry.completion : {};\n\t      record.type = type;\n\t      record.arg = arg;\n\n\t      if (finallyEntry) {\n\t        this.next = finallyEntry.finallyLoc;\n\t      } else {\n\t        this.complete(record);\n\t      }\n\n\t      return ContinueSentinel;\n\t    },\n\n\t    complete: function complete(record, afterLoc) {\n\t      if (record.type === \"throw\") {\n\t        throw record.arg;\n\t      }\n\n\t      if (record.type === \"break\" || record.type === \"continue\") {\n\t        this.next = record.arg;\n\t      } else if (record.type === \"return\") {\n\t        this.rval = record.arg;\n\t        this.next = \"end\";\n\t      } else if (record.type === \"normal\" && afterLoc) {\n\t        this.next = afterLoc;\n\t      }\n\t    },\n\n\t    finish: function finish(finallyLoc) {\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        if (entry.finallyLoc === finallyLoc) {\n\t          this.complete(entry.completion, entry.afterLoc);\n\t          resetTryEntry(entry);\n\t          return ContinueSentinel;\n\t        }\n\t      }\n\t    },\n\n\t    \"catch\": function _catch(tryLoc) {\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        if (entry.tryLoc === tryLoc) {\n\t          var record = entry.completion;\n\t          if (record.type === \"throw\") {\n\t            var thrown = record.arg;\n\t            resetTryEntry(entry);\n\t          }\n\t          return thrown;\n\t        }\n\t      }\n\n\t      // The context.catch method must only be called with a location\n\t      // argument that corresponds to a known catch block.\n\t      throw new Error(\"illegal catch attempt\");\n\t    },\n\n\t    delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n\t      this.delegate = {\n\t        iterator: values(iterable),\n\t        resultName: resultName,\n\t        nextLoc: nextLoc\n\t      };\n\n\t      return ContinueSentinel;\n\t    }\n\t  };\n\t})(\n\t// Among the various tricks for obtaining a reference to the global\n\t// object, this seems to be the most reliable technique that does not\n\t// use indirect eval (which violates Content Security Policy).\n\ttypeof global === \"object\" ? global : typeof window === \"object\" ? window : typeof self === \"object\" ? self : undefined);\n\t/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()), __webpack_require__(56)))\n\n/***/ },\n/* 56 */\n/***/ function(module, exports) {\n\n\t// shim for using process in browser\n\n\tvar process = module.exports = {};\n\tvar queue = [];\n\tvar draining = false;\n\tvar currentQueue;\n\tvar queueIndex = -1;\n\n\tfunction cleanUpNextTick() {\n\t    draining = false;\n\t    if (currentQueue.length) {\n\t        queue = currentQueue.concat(queue);\n\t    } else {\n\t        queueIndex = -1;\n\t    }\n\t    if (queue.length) {\n\t        drainQueue();\n\t    }\n\t}\n\n\tfunction drainQueue() {\n\t    if (draining) {\n\t        return;\n\t    }\n\t    var timeout = setTimeout(cleanUpNextTick);\n\t    draining = true;\n\n\t    var len = queue.length;\n\t    while(len) {\n\t        currentQueue = queue;\n\t        queue = [];\n\t        while (++queueIndex < len) {\n\t            if (currentQueue) {\n\t                currentQueue[queueIndex].run();\n\t            }\n\t        }\n\t        queueIndex = -1;\n\t        len = queue.length;\n\t    }\n\t    currentQueue = null;\n\t    draining = false;\n\t    clearTimeout(timeout);\n\t}\n\n\tprocess.nextTick = function (fun) {\n\t    var args = new Array(arguments.length - 1);\n\t    if (arguments.length > 1) {\n\t        for (var i = 1; i < arguments.length; i++) {\n\t            args[i - 1] = arguments[i];\n\t        }\n\t    }\n\t    queue.push(new Item(fun, args));\n\t    if (queue.length === 1 && !draining) {\n\t        setTimeout(drainQueue, 0);\n\t    }\n\t};\n\n\t// v8 likes predictible objects\n\tfunction Item(fun, array) {\n\t    this.fun = fun;\n\t    this.array = array;\n\t}\n\tItem.prototype.run = function () {\n\t    this.fun.apply(null, this.array);\n\t};\n\tprocess.title = 'browser';\n\tprocess.browser = true;\n\tprocess.env = {};\n\tprocess.argv = [];\n\tprocess.version = ''; // empty string to avoid regexp issues\n\tprocess.versions = {};\n\n\tfunction noop() {}\n\n\tprocess.on = noop;\n\tprocess.addListener = noop;\n\tprocess.once = noop;\n\tprocess.off = noop;\n\tprocess.removeListener = noop;\n\tprocess.removeAllListeners = noop;\n\tprocess.emit = noop;\n\n\tprocess.binding = function (name) {\n\t    throw new Error('process.binding is not supported');\n\t};\n\n\tprocess.cwd = function () { return '/' };\n\tprocess.chdir = function (dir) {\n\t    throw new Error('process.chdir is not supported');\n\t};\n\tprocess.umask = function() { return 0; };\n\n\n/***/ },\n/* 57 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(58), __esModule: true };\n\n/***/ },\n/* 58 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(59);\n\tmodule.exports = __webpack_require__(12).Symbol;\n\n/***/ },\n/* 59 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t// ECMAScript 6 symbols shim\n\tvar $              = __webpack_require__(15)\n\t  , global         = __webpack_require__(11)\n\t  , has            = __webpack_require__(19)\n\t  , SUPPORT_DESC   = __webpack_require__(17)\n\t  , $def           = __webpack_require__(10)\n\t  , $redef         = __webpack_require__(13)\n\t  , $fails         = __webpack_require__(18)\n\t  , shared         = __webpack_require__(21)\n\t  , setTag         = __webpack_require__(25)\n\t  , uid            = __webpack_require__(22)\n\t  , wks            = __webpack_require__(20)\n\t  , keyOf          = __webpack_require__(60)\n\t  , $names         = __webpack_require__(61)\n\t  , enumKeys       = __webpack_require__(62)\n\t  , isObject       = __webpack_require__(32)\n\t  , anObject       = __webpack_require__(31)\n\t  , toIObject      = __webpack_require__(46)\n\t  , createDesc     = __webpack_require__(16)\n\t  , getDesc        = $.getDesc\n\t  , setDesc        = $.setDesc\n\t  , _create        = $.create\n\t  , getNames       = $names.get\n\t  , $Symbol        = global.Symbol\n\t  , setter         = false\n\t  , HIDDEN         = wks('_hidden')\n\t  , isEnum         = $.isEnum\n\t  , SymbolRegistry = shared('symbol-registry')\n\t  , AllSymbols     = shared('symbols')\n\t  , useNative      = typeof $Symbol == 'function'\n\t  , ObjectProto    = Object.prototype;\n\n\t// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\n\tvar setSymbolDesc = SUPPORT_DESC && $fails(function(){\n\t  return _create(setDesc({}, 'a', {\n\t    get: function(){ return setDesc(this, 'a', {value: 7}).a; }\n\t  })).a != 7;\n\t}) ? function(it, key, D){\n\t  var protoDesc = getDesc(ObjectProto, key);\n\t  if(protoDesc)delete ObjectProto[key];\n\t  setDesc(it, key, D);\n\t  if(protoDesc && it !== ObjectProto)setDesc(ObjectProto, key, protoDesc);\n\t} : setDesc;\n\n\tvar wrap = function(tag){\n\t  var sym = AllSymbols[tag] = _create($Symbol.prototype);\n\t  sym._k = tag;\n\t  SUPPORT_DESC && setter && setSymbolDesc(ObjectProto, tag, {\n\t    configurable: true,\n\t    set: function(value){\n\t      if(has(this, HIDDEN) && has(this[HIDDEN], tag))this[HIDDEN][tag] = false;\n\t      setSymbolDesc(this, tag, createDesc(1, value));\n\t    }\n\t  });\n\t  return sym;\n\t};\n\n\tvar $defineProperty = function defineProperty(it, key, D){\n\t  if(D && has(AllSymbols, key)){\n\t    if(!D.enumerable){\n\t      if(!has(it, HIDDEN))setDesc(it, HIDDEN, createDesc(1, {}));\n\t      it[HIDDEN][key] = true;\n\t    } else {\n\t      if(has(it, HIDDEN) && it[HIDDEN][key])it[HIDDEN][key] = false;\n\t      D = _create(D, {enumerable: createDesc(0, false)});\n\t    } return setSymbolDesc(it, key, D);\n\t  } return setDesc(it, key, D);\n\t};\n\tvar $defineProperties = function defineProperties(it, P){\n\t  anObject(it);\n\t  var keys = enumKeys(P = toIObject(P))\n\t    , i    = 0\n\t    , l = keys.length\n\t    , key;\n\t  while(l > i)$defineProperty(it, key = keys[i++], P[key]);\n\t  return it;\n\t};\n\tvar $create = function create(it, P){\n\t  return P === undefined ? _create(it) : $defineProperties(_create(it), P);\n\t};\n\tvar $propertyIsEnumerable = function propertyIsEnumerable(key){\n\t  var E = isEnum.call(this, key);\n\t  return E || !has(this, key) || !has(AllSymbols, key) || has(this, HIDDEN) && this[HIDDEN][key]\n\t    ? E : true;\n\t};\n\tvar $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(it, key){\n\t  var D = getDesc(it = toIObject(it), key);\n\t  if(D && has(AllSymbols, key) && !(has(it, HIDDEN) && it[HIDDEN][key]))D.enumerable = true;\n\t  return D;\n\t};\n\tvar $getOwnPropertyNames = function getOwnPropertyNames(it){\n\t  var names  = getNames(toIObject(it))\n\t    , result = []\n\t    , i      = 0\n\t    , key;\n\t  while(names.length > i)if(!has(AllSymbols, key = names[i++]) && key != HIDDEN)result.push(key);\n\t  return result;\n\t};\n\tvar $getOwnPropertySymbols = function getOwnPropertySymbols(it){\n\t  var names  = getNames(toIObject(it))\n\t    , result = []\n\t    , i      = 0\n\t    , key;\n\t  while(names.length > i)if(has(AllSymbols, key = names[i++]))result.push(AllSymbols[key]);\n\t  return result;\n\t};\n\n\t// 19.4.1.1 Symbol([description])\n\tif(!useNative){\n\t  $Symbol = function Symbol(){\n\t    if(this instanceof $Symbol)throw TypeError('Symbol is not a constructor');\n\t    return wrap(uid(arguments[0]));\n\t  };\n\t  $redef($Symbol.prototype, 'toString', function toString(){\n\t    return this._k;\n\t  });\n\n\t  $.create     = $create;\n\t  $.isEnum     = $propertyIsEnumerable;\n\t  $.getDesc    = $getOwnPropertyDescriptor;\n\t  $.setDesc    = $defineProperty;\n\t  $.setDescs   = $defineProperties;\n\t  $.getNames   = $names.get = $getOwnPropertyNames;\n\t  $.getSymbols = $getOwnPropertySymbols;\n\n\t  if(SUPPORT_DESC && !__webpack_require__(9)){\n\t    $redef(ObjectProto, 'propertyIsEnumerable', $propertyIsEnumerable, true);\n\t  }\n\t}\n\n\t// MS Edge converts symbol values to JSON as {}\n\tif(!useNative || $fails(function(){\n\t  return JSON.stringify([$Symbol()]) != '[null]';\n\t}))$redef($Symbol.prototype, 'toJSON', function toJSON(){\n\t  if(useNative && isObject(this))return this;\n\t});\n\n\tvar symbolStatics = {\n\t  // 19.4.2.1 Symbol.for(key)\n\t  'for': function(key){\n\t    return has(SymbolRegistry, key += '')\n\t      ? SymbolRegistry[key]\n\t      : SymbolRegistry[key] = $Symbol(key);\n\t  },\n\t  // 19.4.2.5 Symbol.keyFor(sym)\n\t  keyFor: function keyFor(key){\n\t    return keyOf(SymbolRegistry, key);\n\t  },\n\t  useSetter: function(){ setter = true; },\n\t  useSimple: function(){ setter = false; }\n\t};\n\t// 19.4.2.2 Symbol.hasInstance\n\t// 19.4.2.3 Symbol.isConcatSpreadable\n\t// 19.4.2.4 Symbol.iterator\n\t// 19.4.2.6 Symbol.match\n\t// 19.4.2.8 Symbol.replace\n\t// 19.4.2.9 Symbol.search\n\t// 19.4.2.10 Symbol.species\n\t// 19.4.2.11 Symbol.split\n\t// 19.4.2.12 Symbol.toPrimitive\n\t// 19.4.2.13 Symbol.toStringTag\n\t// 19.4.2.14 Symbol.unscopables\n\t$.each.call((\n\t    'hasInstance,isConcatSpreadable,iterator,match,replace,search,' +\n\t    'species,split,toPrimitive,toStringTag,unscopables'\n\t  ).split(','), function(it){\n\t    var sym = wks(it);\n\t    symbolStatics[it] = useNative ? sym : wrap(sym);\n\t  }\n\t);\n\n\tsetter = true;\n\n\t$def($def.G + $def.W, {Symbol: $Symbol});\n\n\t$def($def.S, 'Symbol', symbolStatics);\n\n\t$def($def.S + $def.F * !useNative, 'Object', {\n\t  // 19.1.2.2 Object.create(O [, Properties])\n\t  create: $create,\n\t  // 19.1.2.4 Object.defineProperty(O, P, Attributes)\n\t  defineProperty: $defineProperty,\n\t  // 19.1.2.3 Object.defineProperties(O, Properties)\n\t  defineProperties: $defineProperties,\n\t  // 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\n\t  getOwnPropertyDescriptor: $getOwnPropertyDescriptor,\n\t  // 19.1.2.7 Object.getOwnPropertyNames(O)\n\t  getOwnPropertyNames: $getOwnPropertyNames,\n\t  // 19.1.2.8 Object.getOwnPropertySymbols(O)\n\t  getOwnPropertySymbols: $getOwnPropertySymbols\n\t});\n\n\t// 19.4.3.5 Symbol.prototype[@@toStringTag]\n\tsetTag($Symbol, 'Symbol');\n\t// 20.2.1.9 Math[@@toStringTag]\n\tsetTag(Math, 'Math', true);\n\t// 24.3.3 JSON[@@toStringTag]\n\tsetTag(global.JSON, 'JSON', true);\n\n/***/ },\n/* 60 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $         = __webpack_require__(15)\n\t  , toIObject = __webpack_require__(46);\n\tmodule.exports = function(object, el){\n\t  var O      = toIObject(object)\n\t    , keys   = $.getKeys(O)\n\t    , length = keys.length\n\t    , index  = 0\n\t    , key;\n\t  while(length > index)if(O[key = keys[index++]] === el)return key;\n\t};\n\n/***/ },\n/* 61 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\n\tvar toString  = {}.toString\n\t  , toIObject = __webpack_require__(46)\n\t  , getNames  = __webpack_require__(15).getNames;\n\n\tvar windowNames = typeof window == 'object' && Object.getOwnPropertyNames\n\t  ? Object.getOwnPropertyNames(window) : [];\n\n\tvar getWindowNames = function(it){\n\t  try {\n\t    return getNames(it);\n\t  } catch(e){\n\t    return windowNames.slice();\n\t  }\n\t};\n\n\tmodule.exports.get = function getOwnPropertyNames(it){\n\t  if(windowNames && toString.call(it) == '[object Window]')return getWindowNames(it);\n\t  return getNames(toIObject(it));\n\t};\n\n/***/ },\n/* 62 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// all enumerable object keys, includes symbols\n\tvar $ = __webpack_require__(15);\n\tmodule.exports = function(it){\n\t  var keys       = $.getKeys(it)\n\t    , getSymbols = $.getSymbols;\n\t  if(getSymbols){\n\t    var symbols = getSymbols(it)\n\t      , isEnum  = $.isEnum\n\t      , i       = 0\n\t      , key;\n\t    while(symbols.length > i)if(isEnum.call(it, key = symbols[i++]))keys.push(key);\n\t  }\n\t  return keys;\n\t};\n\n/***/ },\n/* 63 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(64), __esModule: true };\n\n/***/ },\n/* 64 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $ = __webpack_require__(15);\n\tmodule.exports = function create(P, D){\n\t  return $.create(P, D);\n\t};\n\n/***/ },\n/* 65 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(66), __esModule: true };\n\n/***/ },\n/* 66 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(67);\n\t__webpack_require__(4);\n\t__webpack_require__(42);\n\t__webpack_require__(68);\n\tmodule.exports = __webpack_require__(12).Promise;\n\n/***/ },\n/* 67 */\n/***/ function(module, exports) {\n\n\t\n\n/***/ },\n/* 68 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $          = __webpack_require__(15)\n\t  , LIBRARY    = __webpack_require__(9)\n\t  , global     = __webpack_require__(11)\n\t  , ctx        = __webpack_require__(27)\n\t  , classof    = __webpack_require__(36)\n\t  , $def       = __webpack_require__(10)\n\t  , isObject   = __webpack_require__(32)\n\t  , anObject   = __webpack_require__(31)\n\t  , aFunction  = __webpack_require__(28)\n\t  , strictNew  = __webpack_require__(69)\n\t  , forOf      = __webpack_require__(70)\n\t  , setProto   = __webpack_require__(71).set\n\t  , same       = __webpack_require__(72)\n\t  , species    = __webpack_require__(73)\n\t  , SPECIES    = __webpack_require__(20)('species')\n\t  , RECORD     = __webpack_require__(22)('record')\n\t  , asap       = __webpack_require__(74)\n\t  , PROMISE    = 'Promise'\n\t  , process    = global.process\n\t  , isNode     = classof(process) == 'process'\n\t  , P          = global[PROMISE]\n\t  , Wrapper;\n\n\tvar testResolve = function(sub){\n\t  var test = new P(function(){});\n\t  if(sub)test.constructor = Object;\n\t  return P.resolve(test) === test;\n\t};\n\n\tvar useNative = function(){\n\t  var works = false;\n\t  function P2(x){\n\t    var self = new P(x);\n\t    setProto(self, P2.prototype);\n\t    return self;\n\t  }\n\t  try {\n\t    works = P && P.resolve && testResolve();\n\t    setProto(P2, P);\n\t    P2.prototype = $.create(P.prototype, {constructor: {value: P2}});\n\t    // actual Firefox has broken subclass support, test that\n\t    if(!(P2.resolve(5).then(function(){}) instanceof P2)){\n\t      works = false;\n\t    }\n\t    // actual V8 bug, https://code.google.com/p/v8/issues/detail?id=4162\n\t    if(works && __webpack_require__(17)){\n\t      var thenableThenGotten = false;\n\t      P.resolve($.setDesc({}, 'then', {\n\t        get: function(){ thenableThenGotten = true; }\n\t      }));\n\t      works = thenableThenGotten;\n\t    }\n\t  } catch(e){ works = false; }\n\t  return works;\n\t}();\n\n\t// helpers\n\tvar isPromise = function(it){\n\t  return isObject(it) && (useNative ? classof(it) == 'Promise' : RECORD in it);\n\t};\n\tvar sameConstructor = function(a, b){\n\t  // library wrapper special case\n\t  if(LIBRARY && a === P && b === Wrapper)return true;\n\t  return same(a, b);\n\t};\n\tvar getConstructor = function(C){\n\t  var S = anObject(C)[SPECIES];\n\t  return S != undefined ? S : C;\n\t};\n\tvar isThenable = function(it){\n\t  var then;\n\t  return isObject(it) && typeof (then = it.then) == 'function' ? then : false;\n\t};\n\tvar notify = function(record, isReject){\n\t  if(record.n)return;\n\t  record.n = true;\n\t  var chain = record.c;\n\t  asap(function(){\n\t    var value = record.v\n\t      , ok    = record.s == 1\n\t      , i     = 0;\n\t    var run = function(react){\n\t      var cb = ok ? react.ok : react.fail\n\t        , ret, then;\n\t      try {\n\t        if(cb){\n\t          if(!ok)record.h = true;\n\t          ret = cb === true ? value : cb(value);\n\t          if(ret === react.P){\n\t            react.rej(TypeError('Promise-chain cycle'));\n\t          } else if(then = isThenable(ret)){\n\t            then.call(ret, react.res, react.rej);\n\t          } else react.res(ret);\n\t        } else react.rej(value);\n\t      } catch(err){\n\t        react.rej(err);\n\t      }\n\t    };\n\t    while(chain.length > i)run(chain[i++]); // variable length - can't use forEach\n\t    chain.length = 0;\n\t    record.n = false;\n\t    if(isReject)setTimeout(function(){\n\t      var promise = record.p\n\t        , handler, console;\n\t      if(isUnhandled(promise)){\n\t        if(isNode){\n\t          process.emit('unhandledRejection', value, promise);\n\t        } else if(handler = global.onunhandledrejection){\n\t          handler({promise: promise, reason: value});\n\t        } else if((console = global.console) && console.error){\n\t          console.error('Unhandled promise rejection', value);\n\t        }\n\t      } record.a = undefined;\n\t    }, 1);\n\t  });\n\t};\n\tvar isUnhandled = function(promise){\n\t  var record = promise[RECORD]\n\t    , chain  = record.a || record.c\n\t    , i      = 0\n\t    , react;\n\t  if(record.h)return false;\n\t  while(chain.length > i){\n\t    react = chain[i++];\n\t    if(react.fail || !isUnhandled(react.P))return false;\n\t  } return true;\n\t};\n\tvar $reject = function(value){\n\t  var record = this;\n\t  if(record.d)return;\n\t  record.d = true;\n\t  record = record.r || record; // unwrap\n\t  record.v = value;\n\t  record.s = 2;\n\t  record.a = record.c.slice();\n\t  notify(record, true);\n\t};\n\tvar $resolve = function(value){\n\t  var record = this\n\t    , then;\n\t  if(record.d)return;\n\t  record.d = true;\n\t  record = record.r || record; // unwrap\n\t  try {\n\t    if(then = isThenable(value)){\n\t      asap(function(){\n\t        var wrapper = {r: record, d: false}; // wrap\n\t        try {\n\t          then.call(value, ctx($resolve, wrapper, 1), ctx($reject, wrapper, 1));\n\t        } catch(e){\n\t          $reject.call(wrapper, e);\n\t        }\n\t      });\n\t    } else {\n\t      record.v = value;\n\t      record.s = 1;\n\t      notify(record, false);\n\t    }\n\t  } catch(e){\n\t    $reject.call({r: record, d: false}, e); // wrap\n\t  }\n\t};\n\n\t// constructor polyfill\n\tif(!useNative){\n\t  // 25.4.3.1 Promise(executor)\n\t  P = function Promise(executor){\n\t    aFunction(executor);\n\t    var record = {\n\t      p: strictNew(this, P, PROMISE),         // <- promise\n\t      c: [],                                  // <- awaiting reactions\n\t      a: undefined,                           // <- checked in isUnhandled reactions\n\t      s: 0,                                   // <- state\n\t      d: false,                               // <- done\n\t      v: undefined,                           // <- value\n\t      h: false,                               // <- handled rejection\n\t      n: false                                // <- notify\n\t    };\n\t    this[RECORD] = record;\n\t    try {\n\t      executor(ctx($resolve, record, 1), ctx($reject, record, 1));\n\t    } catch(err){\n\t      $reject.call(record, err);\n\t    }\n\t  };\n\t  __webpack_require__(79)(P.prototype, {\n\t    // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\n\t    then: function then(onFulfilled, onRejected){\n\t      var S = anObject(anObject(this).constructor)[SPECIES];\n\t      var react = {\n\t        ok:   typeof onFulfilled == 'function' ? onFulfilled : true,\n\t        fail: typeof onRejected == 'function'  ? onRejected  : false\n\t      };\n\t      var promise = react.P = new (S != undefined ? S : P)(function(res, rej){\n\t        react.res = res;\n\t        react.rej = rej;\n\t      });\n\t      aFunction(react.res);\n\t      aFunction(react.rej);\n\t      var record = this[RECORD];\n\t      record.c.push(react);\n\t      if(record.a)record.a.push(react);\n\t      if(record.s)notify(record, false);\n\t      return promise;\n\t    },\n\t    // 25.4.5.1 Promise.prototype.catch(onRejected)\n\t    'catch': function(onRejected){\n\t      return this.then(undefined, onRejected);\n\t    }\n\t  });\n\t}\n\n\t// export\n\t$def($def.G + $def.W + $def.F * !useNative, {Promise: P});\n\t__webpack_require__(25)(P, PROMISE);\n\tspecies(P);\n\tspecies(Wrapper = __webpack_require__(12)[PROMISE]);\n\n\t// statics\n\t$def($def.S + $def.F * !useNative, PROMISE, {\n\t  // 25.4.4.5 Promise.reject(r)\n\t  reject: function reject(r){\n\t    return new this(function(res, rej){ rej(r); });\n\t  }\n\t});\n\t$def($def.S + $def.F * (!useNative || testResolve(true)), PROMISE, {\n\t  // 25.4.4.6 Promise.resolve(x)\n\t  resolve: function resolve(x){\n\t    return isPromise(x) && sameConstructor(x.constructor, this)\n\t      ? x : new this(function(res){ res(x); });\n\t  }\n\t});\n\t$def($def.S + $def.F * !(useNative && __webpack_require__(38)(function(iter){\n\t  P.all(iter)['catch'](function(){});\n\t})), PROMISE, {\n\t  // 25.4.4.1 Promise.all(iterable)\n\t  all: function all(iterable){\n\t    var C      = getConstructor(this)\n\t      , values = [];\n\t    return new C(function(res, rej){\n\t      forOf(iterable, false, values.push, values);\n\t      var remaining = values.length\n\t        , results   = Array(remaining);\n\t      if(remaining)$.each.call(values, function(promise, index){\n\t        C.resolve(promise).then(function(value){\n\t          results[index] = value;\n\t          --remaining || res(results);\n\t        }, rej);\n\t      });\n\t      else res(results);\n\t    });\n\t  },\n\t  // 25.4.4.4 Promise.race(iterable)\n\t  race: function race(iterable){\n\t    var C = getConstructor(this);\n\t    return new C(function(res, rej){\n\t      forOf(iterable, false, function(promise){\n\t        C.resolve(promise).then(res, rej);\n\t      });\n\t    });\n\t  }\n\t});\n\n/***/ },\n/* 69 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(it, Constructor, name){\n\t  if(!(it instanceof Constructor))throw TypeError(name + \": use the 'new' operator!\");\n\t  return it;\n\t};\n\n/***/ },\n/* 70 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar ctx         = __webpack_require__(27)\n\t  , call        = __webpack_require__(30)\n\t  , isArrayIter = __webpack_require__(33)\n\t  , anObject    = __webpack_require__(31)\n\t  , toLength    = __webpack_require__(34)\n\t  , getIterFn   = __webpack_require__(35);\n\tmodule.exports = function(iterable, entries, fn, that){\n\t  var iterFn = getIterFn(iterable)\n\t    , f      = ctx(fn, that, entries ? 2 : 1)\n\t    , index  = 0\n\t    , length, step, iterator;\n\t  if(typeof iterFn != 'function')throw TypeError(iterable + ' is not iterable!');\n\t  // fast case for arrays with default iterator\n\t  if(isArrayIter(iterFn))for(length = toLength(iterable.length); length > index; index++){\n\t    entries ? f(anObject(step = iterable[index])[0], step[1]) : f(iterable[index]);\n\t  } else for(iterator = iterFn.call(iterable); !(step = iterator.next()).done; ){\n\t    call(iterator, f, step.value, entries);\n\t  }\n\t};\n\n/***/ },\n/* 71 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// Works with __proto__ only. Old v8 can't work with null proto objects.\n\t/* eslint-disable no-proto */\n\tvar getDesc  = __webpack_require__(15).getDesc\n\t  , isObject = __webpack_require__(32)\n\t  , anObject = __webpack_require__(31);\n\tvar check = function(O, proto){\n\t  anObject(O);\n\t  if(!isObject(proto) && proto !== null)throw TypeError(proto + \": can't set as prototype!\");\n\t};\n\tmodule.exports = {\n\t  set: Object.setPrototypeOf || ('__proto__' in {} ? // eslint-disable-line no-proto\n\t    function(test, buggy, set){\n\t      try {\n\t        set = __webpack_require__(27)(Function.call, getDesc(Object.prototype, '__proto__').set, 2);\n\t        set(test, []);\n\t        buggy = !(test instanceof Array);\n\t      } catch(e){ buggy = true; }\n\t      return function setPrototypeOf(O, proto){\n\t        check(O, proto);\n\t        if(buggy)O.__proto__ = proto;\n\t        else set(O, proto);\n\t        return O;\n\t      };\n\t    }({}, false) : undefined),\n\t  check: check\n\t};\n\n/***/ },\n/* 72 */\n/***/ function(module, exports) {\n\n\tmodule.exports = Object.is || function is(x, y){\n\t  return x === y ? x !== 0 || 1 / x === 1 / y : x != x && y != y;\n\t};\n\n/***/ },\n/* 73 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $       = __webpack_require__(15)\n\t  , SPECIES = __webpack_require__(20)('species');\n\tmodule.exports = function(C){\n\t  if(__webpack_require__(17) && !(SPECIES in C))$.setDesc(C, SPECIES, {\n\t    configurable: true,\n\t    get: function(){ return this; }\n\t  });\n\t};\n\n/***/ },\n/* 74 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar global    = __webpack_require__(11)\r\n\t  , macrotask = __webpack_require__(75).set\r\n\t  , Observer  = global.MutationObserver || global.WebKitMutationObserver\r\n\t  , process   = global.process\r\n\t  , isNode    = __webpack_require__(37)(process) == 'process'\r\n\t  , head, last, notify;\r\n\r\n\tvar flush = function(){\r\n\t  var parent, domain;\r\n\t  if(isNode && (parent = process.domain)){\r\n\t    process.domain = null;\r\n\t    parent.exit();\r\n\t  }\r\n\t  while(head){\r\n\t    domain = head.domain;\r\n\t    if(domain)domain.enter();\r\n\t    head.fn.call(); // <- currently we use it only for Promise - try / catch not required\r\n\t    if(domain)domain.exit();\r\n\t    head = head.next;\r\n\t  } last = undefined;\r\n\t  if(parent)parent.enter();\r\n\t}\r\n\r\n\t// Node.js\r\n\tif(isNode){\r\n\t  notify = function(){\r\n\t    process.nextTick(flush);\r\n\t  };\r\n\t// browsers with MutationObserver\r\n\t} else if(Observer){\r\n\t  var toggle = 1\r\n\t    , node   = document.createTextNode('');\r\n\t  new Observer(flush).observe(node, {characterData: true}); // eslint-disable-line no-new\r\n\t  notify = function(){\r\n\t    node.data = toggle = -toggle;\r\n\t  };\r\n\t// for other environments - macrotask based on:\r\n\t// - setImmediate\r\n\t// - MessageChannel\r\n\t// - window.postMessag\r\n\t// - onreadystatechange\r\n\t// - setTimeout\r\n\t} else {\r\n\t  notify = function(){\r\n\t    // strange IE + webpack dev server bug - use .call(global)\r\n\t    macrotask.call(global, flush);\r\n\t  };\r\n\t}\r\n\r\n\tmodule.exports = function asap(fn){\r\n\t  var task = {fn: fn, next: undefined, domain: isNode && process.domain};\r\n\t  if(last)last.next = task;\r\n\t  if(!head){\r\n\t    head = task;\r\n\t    notify();\r\n\t  } last = task;\r\n\t};\n\n/***/ },\n/* 75 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar ctx                = __webpack_require__(27)\n\t  , invoke             = __webpack_require__(76)\n\t  , html               = __webpack_require__(77)\n\t  , cel                = __webpack_require__(78)\n\t  , global             = __webpack_require__(11)\n\t  , process            = global.process\n\t  , setTask            = global.setImmediate\n\t  , clearTask          = global.clearImmediate\n\t  , MessageChannel     = global.MessageChannel\n\t  , counter            = 0\n\t  , queue              = {}\n\t  , ONREADYSTATECHANGE = 'onreadystatechange'\n\t  , defer, channel, port;\n\tvar run = function(){\n\t  var id = +this;\n\t  if(queue.hasOwnProperty(id)){\n\t    var fn = queue[id];\n\t    delete queue[id];\n\t    fn();\n\t  }\n\t};\n\tvar listner = function(event){\n\t  run.call(event.data);\n\t};\n\t// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\n\tif(!setTask || !clearTask){\n\t  setTask = function setImmediate(fn){\n\t    var args = [], i = 1;\n\t    while(arguments.length > i)args.push(arguments[i++]);\n\t    queue[++counter] = function(){\n\t      invoke(typeof fn == 'function' ? fn : Function(fn), args);\n\t    };\n\t    defer(counter);\n\t    return counter;\n\t  };\n\t  clearTask = function clearImmediate(id){\n\t    delete queue[id];\n\t  };\n\t  // Node.js 0.8-\n\t  if(__webpack_require__(37)(process) == 'process'){\n\t    defer = function(id){\n\t      process.nextTick(ctx(run, id, 1));\n\t    };\n\t  // Browsers with MessageChannel, includes WebWorkers\n\t  } else if(MessageChannel){\n\t    channel = new MessageChannel;\n\t    port    = channel.port2;\n\t    channel.port1.onmessage = listner;\n\t    defer = ctx(port.postMessage, port, 1);\n\t  // Browsers with postMessage, skip WebWorkers\n\t  // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n\t  } else if(global.addEventListener && typeof postMessage == 'function' && !global.importScript){\n\t    defer = function(id){\n\t      global.postMessage(id + '', '*');\n\t    };\n\t    global.addEventListener('message', listner, false);\n\t  // IE8-\n\t  } else if(ONREADYSTATECHANGE in cel('script')){\n\t    defer = function(id){\n\t      html.appendChild(cel('script'))[ONREADYSTATECHANGE] = function(){\n\t        html.removeChild(this);\n\t        run.call(id);\n\t      };\n\t    };\n\t  // Rest old browsers\n\t  } else {\n\t    defer = function(id){\n\t      setTimeout(ctx(run, id, 1), 0);\n\t    };\n\t  }\n\t}\n\tmodule.exports = {\n\t  set:   setTask,\n\t  clear: clearTask\n\t};\n\n/***/ },\n/* 76 */\n/***/ function(module, exports) {\n\n\t// fast apply, http://jsperf.lnkit.com/fast-apply/5\n\tmodule.exports = function(fn, args, that){\n\t  var un = that === undefined;\n\t  switch(args.length){\n\t    case 0: return un ? fn()\n\t                      : fn.call(that);\n\t    case 1: return un ? fn(args[0])\n\t                      : fn.call(that, args[0]);\n\t    case 2: return un ? fn(args[0], args[1])\n\t                      : fn.call(that, args[0], args[1]);\n\t    case 3: return un ? fn(args[0], args[1], args[2])\n\t                      : fn.call(that, args[0], args[1], args[2]);\n\t    case 4: return un ? fn(args[0], args[1], args[2], args[3])\n\t                      : fn.call(that, args[0], args[1], args[2], args[3]);\n\t  } return              fn.apply(that, args);\n\t};\n\n/***/ },\n/* 77 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(11).document && document.documentElement;\n\n/***/ },\n/* 78 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar isObject = __webpack_require__(32)\n\t  , document = __webpack_require__(11).document\n\t  // in old IE typeof document.createElement is 'object'\n\t  , is = isObject(document) && isObject(document.createElement);\n\tmodule.exports = function(it){\n\t  return is ? document.createElement(it) : {};\n\t};\n\n/***/ },\n/* 79 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $redef = __webpack_require__(13);\n\tmodule.exports = function(target, src){\n\t  for(var key in src)$redef(target, key, src[key]);\n\t  return target;\n\t};\n\n/***/ },\n/* 80 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(81), __esModule: true };\n\n/***/ },\n/* 81 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(82);\n\tmodule.exports = __webpack_require__(12).Object.keys;\n\n/***/ },\n/* 82 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// 19.1.2.14 Object.keys(O)\n\tvar toObject = __webpack_require__(29);\n\n\t__webpack_require__(83)('keys', function($keys){\n\t  return function keys(it){\n\t    return $keys(toObject(it));\n\t  };\n\t});\n\n/***/ },\n/* 83 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// most Object methods by ES6 should accept primitives\n\tmodule.exports = function(KEY, exec){\n\t  var $def = __webpack_require__(10)\n\t    , fn   = (__webpack_require__(12).Object || {})[KEY] || Object[KEY]\n\t    , exp  = {};\n\t  exp[KEY] = exec(fn);\n\t  $def($def.S + $def.F * __webpack_require__(18)(function(){ fn(1); }), 'Object', exp);\n\t};\n\n/***/ },\n/* 84 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(85), __esModule: true };\n\n/***/ },\n/* 85 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(67);\n\t__webpack_require__(4);\n\t__webpack_require__(42);\n\t__webpack_require__(86);\n\t__webpack_require__(89);\n\tmodule.exports = __webpack_require__(12).Set;\n\n/***/ },\n/* 86 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar strong = __webpack_require__(87);\n\n\t// 23.2 Set Objects\n\t__webpack_require__(88)('Set', function(get){\n\t  return function Set(){ return get(this, arguments[0]); };\n\t}, {\n\t  // 23.2.3.1 Set.prototype.add(value)\n\t  add: function add(value){\n\t    return strong.def(this, value = value === 0 ? 0 : value, value);\n\t  }\n\t}, strong);\n\n/***/ },\n/* 87 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $            = __webpack_require__(15)\n\t  , hide         = __webpack_require__(14)\n\t  , ctx          = __webpack_require__(27)\n\t  , species      = __webpack_require__(73)\n\t  , strictNew    = __webpack_require__(69)\n\t  , defined      = __webpack_require__(7)\n\t  , forOf        = __webpack_require__(70)\n\t  , step         = __webpack_require__(45)\n\t  , ID           = __webpack_require__(22)('id')\n\t  , $has         = __webpack_require__(19)\n\t  , isObject     = __webpack_require__(32)\n\t  , isExtensible = Object.isExtensible || isObject\n\t  , SUPPORT_DESC = __webpack_require__(17)\n\t  , SIZE         = SUPPORT_DESC ? '_s' : 'size'\n\t  , id           = 0;\n\n\tvar fastKey = function(it, create){\n\t  // return primitive with prefix\n\t  if(!isObject(it))return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;\n\t  if(!$has(it, ID)){\n\t    // can't set id to frozen object\n\t    if(!isExtensible(it))return 'F';\n\t    // not necessary to add id\n\t    if(!create)return 'E';\n\t    // add missing object id\n\t    hide(it, ID, ++id);\n\t  // return object id with prefix\n\t  } return 'O' + it[ID];\n\t};\n\n\tvar getEntry = function(that, key){\n\t  // fast case\n\t  var index = fastKey(key), entry;\n\t  if(index !== 'F')return that._i[index];\n\t  // frozen object case\n\t  for(entry = that._f; entry; entry = entry.n){\n\t    if(entry.k == key)return entry;\n\t  }\n\t};\n\n\tmodule.exports = {\n\t  getConstructor: function(wrapper, NAME, IS_MAP, ADDER){\n\t    var C = wrapper(function(that, iterable){\n\t      strictNew(that, C, NAME);\n\t      that._i = $.create(null); // index\n\t      that._f = undefined;      // first entry\n\t      that._l = undefined;      // last entry\n\t      that[SIZE] = 0;           // size\n\t      if(iterable != undefined)forOf(iterable, IS_MAP, that[ADDER], that);\n\t    });\n\t    __webpack_require__(79)(C.prototype, {\n\t      // 23.1.3.1 Map.prototype.clear()\n\t      // 23.2.3.2 Set.prototype.clear()\n\t      clear: function clear(){\n\t        for(var that = this, data = that._i, entry = that._f; entry; entry = entry.n){\n\t          entry.r = true;\n\t          if(entry.p)entry.p = entry.p.n = undefined;\n\t          delete data[entry.i];\n\t        }\n\t        that._f = that._l = undefined;\n\t        that[SIZE] = 0;\n\t      },\n\t      // 23.1.3.3 Map.prototype.delete(key)\n\t      // 23.2.3.4 Set.prototype.delete(value)\n\t      'delete': function(key){\n\t        var that  = this\n\t          , entry = getEntry(that, key);\n\t        if(entry){\n\t          var next = entry.n\n\t            , prev = entry.p;\n\t          delete that._i[entry.i];\n\t          entry.r = true;\n\t          if(prev)prev.n = next;\n\t          if(next)next.p = prev;\n\t          if(that._f == entry)that._f = next;\n\t          if(that._l == entry)that._l = prev;\n\t          that[SIZE]--;\n\t        } return !!entry;\n\t      },\n\t      // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\n\t      // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\n\t      forEach: function forEach(callbackfn /*, that = undefined */){\n\t        var f = ctx(callbackfn, arguments[1], 3)\n\t          , entry;\n\t        while(entry = entry ? entry.n : this._f){\n\t          f(entry.v, entry.k, this);\n\t          // revert to the last existing entry\n\t          while(entry && entry.r)entry = entry.p;\n\t        }\n\t      },\n\t      // 23.1.3.7 Map.prototype.has(key)\n\t      // 23.2.3.7 Set.prototype.has(value)\n\t      has: function has(key){\n\t        return !!getEntry(this, key);\n\t      }\n\t    });\n\t    if(SUPPORT_DESC)$.setDesc(C.prototype, 'size', {\n\t      get: function(){\n\t        return defined(this[SIZE]);\n\t      }\n\t    });\n\t    return C;\n\t  },\n\t  def: function(that, key, value){\n\t    var entry = getEntry(that, key)\n\t      , prev, index;\n\t    // change existing entry\n\t    if(entry){\n\t      entry.v = value;\n\t    // create new entry\n\t    } else {\n\t      that._l = entry = {\n\t        i: index = fastKey(key, true), // <- index\n\t        k: key,                        // <- key\n\t        v: value,                      // <- value\n\t        p: prev = that._l,             // <- previous entry\n\t        n: undefined,                  // <- next entry\n\t        r: false                       // <- removed\n\t      };\n\t      if(!that._f)that._f = entry;\n\t      if(prev)prev.n = entry;\n\t      that[SIZE]++;\n\t      // add to index\n\t      if(index !== 'F')that._i[index] = entry;\n\t    } return that;\n\t  },\n\t  getEntry: getEntry,\n\t  setStrong: function(C, NAME, IS_MAP){\n\t    // add .keys, .values, .entries, [@@iterator]\n\t    // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11\n\t    __webpack_require__(8)(C, NAME, function(iterated, kind){\n\t      this._t = iterated;  // target\n\t      this._k = kind;      // kind\n\t      this._l = undefined; // previous\n\t    }, function(){\n\t      var that  = this\n\t        , kind  = that._k\n\t        , entry = that._l;\n\t      // revert to the last existing entry\n\t      while(entry && entry.r)entry = entry.p;\n\t      // get next entry\n\t      if(!that._t || !(that._l = entry = entry ? entry.n : that._t._f)){\n\t        // or finish the iteration\n\t        that._t = undefined;\n\t        return step(1);\n\t      }\n\t      // return step by kind\n\t      if(kind == 'keys'  )return step(0, entry.k);\n\t      if(kind == 'values')return step(0, entry.v);\n\t      return step(0, [entry.k, entry.v]);\n\t    }, IS_MAP ? 'entries' : 'values' , !IS_MAP, true);\n\n\t    // add [@@species], 23.1.2.2, 23.2.2.2\n\t    species(C);\n\t    species(__webpack_require__(12)[NAME]); // for wrapper\n\t  }\n\t};\n\n/***/ },\n/* 88 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $          = __webpack_require__(15)\n\t  , $def       = __webpack_require__(10)\n\t  , hide       = __webpack_require__(14)\n\t  , forOf      = __webpack_require__(70)\n\t  , strictNew  = __webpack_require__(69);\n\n\tmodule.exports = function(NAME, wrapper, methods, common, IS_MAP, IS_WEAK){\n\t  var Base  = __webpack_require__(11)[NAME]\n\t    , C     = Base\n\t    , ADDER = IS_MAP ? 'set' : 'add'\n\t    , proto = C && C.prototype\n\t    , O     = {};\n\t  if(!__webpack_require__(17) || typeof C != 'function'\n\t    || !(IS_WEAK || proto.forEach && !__webpack_require__(18)(function(){ new C().entries().next(); }))\n\t  ){\n\t    // create collection constructor\n\t    C = common.getConstructor(wrapper, NAME, IS_MAP, ADDER);\n\t    __webpack_require__(79)(C.prototype, methods);\n\t  } else {\n\t    C = wrapper(function(target, iterable){\n\t      strictNew(target, C, NAME);\n\t      target._c = new Base;\n\t      if(iterable != undefined)forOf(iterable, IS_MAP, target[ADDER], target);\n\t    });\n\t    $.each.call('add,clear,delete,forEach,get,has,set,keys,values,entries'.split(','),function(KEY){\n\t      var chain = KEY == 'add' || KEY == 'set';\n\t      if(KEY in proto && !(IS_WEAK && KEY == 'clear'))hide(C.prototype, KEY, function(a, b){\n\t        var result = this._c[KEY](a === 0 ? 0 : a, b);\n\t        return chain ? this : result;\n\t      });\n\t    });\n\t    if('size' in proto)$.setDesc(C.prototype, 'size', {\n\t      get: function(){\n\t        return this._c.size;\n\t      }\n\t    });\n\t  }\n\n\t  __webpack_require__(25)(C, NAME);\n\n\t  O[NAME] = C;\n\t  $def($def.G + $def.W + $def.F, O);\n\n\t  if(!IS_WEAK)common.setStrong(C, NAME, IS_MAP);\n\n\t  return C;\n\t};\n\n/***/ },\n/* 89 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// https://github.com/DavidBruant/Map-Set.prototype.toJSON\n\tvar $def  = __webpack_require__(10);\n\n\t$def($def.P, 'Set', {toJSON: __webpack_require__(90)('Set')});\n\n/***/ },\n/* 90 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// https://github.com/DavidBruant/Map-Set.prototype.toJSON\n\tvar forOf   = __webpack_require__(70)\n\t  , classof = __webpack_require__(36);\n\tmodule.exports = function(NAME){\n\t  return function toJSON(){\n\t    if(classof(this) != NAME)throw TypeError(NAME + \"#toJSON isn't generic\");\n\t    var arr = [];\n\t    forOf(this, false, arr.push, arr);\n\t    return arr;\n\t  };\n\t};\n\n/***/ }\n/******/ ])\n});\n;","module.exports = DG;","module.exports = grok;","module.exports = rxjs;","module.exports = ui;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + chunkId + \".js\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) scriptUrl = scripts[scripts.length - 1].src\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = document.baseURI || self.location.href;\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t\"package\": 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// no jsonp function","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\n/* Do not change these import lines to match external modules in webpack configuration */\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nexport const _package = new DG.Package();\nimport { WebLogo } from '@datagrok-libraries/bio/src/viewers/web-logo';\nimport { VdRegionsViewer } from './viewers/vd-regions-viewer';\nimport { runKalign } from './utils/multiple-sequence-alignment';\nimport { SequenceAlignment } from './seq_align';\nimport { convert } from './utils/convert';\nimport { getEmbeddingColsNames, sequenceSpace } from './utils/sequence-space';\nimport { getActivityCliffs } from '@datagrok-libraries/ml/src/viewers/activity-cliffs';\nimport { sequenceGetSimilarities, drawTooltip } from './utils/sequence-activity-cliffs';\nimport { getMolfilesFromSeq, HELM_CORE_LIB_FILENAME } from './utils/utils';\nimport { getMacroMol } from './utils/atomic-works';\nimport { MacromoleculeSequenceCellRenderer } from './utils/cell-renderer';\n//tags: init\nexport function initBio() {\n    return __awaiter(this, void 0, void 0, function* () {\n        // apparently HELMWebEditor requires dojo to be initialized first\n        return new Promise((resolve, reject) => {\n            // @ts-ignore\n            dojo.ready(function () { resolve(null); });\n        });\n    });\n}\n//name: macromoleculeSequenceCellRenderer\n//tags: cellRenderer\n//meta.cellType: Macromolecule\n//output: grid_cell_renderer result\nexport function macromoleculeSequenceCellRenderer() {\n    return new MacromoleculeSequenceCellRenderer();\n}\nfunction checkInputColumn(col, name, allowedNotations = [], allowedAlphabets = []) {\n    const units = col.getTag(DG.TAGS.UNITS);\n    if (col.semType !== DG.SEMTYPE.MACROMOLECULE) {\n        grok.shell.warning(name + ' analysis is allowed for Macromolecules semantic type');\n        return false;\n    }\n    else if ((allowedAlphabets.length > 0 &&\n        !allowedAlphabets.some((a) => units.toUpperCase().endsWith(a.toUpperCase()))) ||\n        (allowedNotations.length > 0 &&\n            !allowedNotations.some((n) => units.toUpperCase().startsWith(n.toUpperCase())))) {\n        const notationAdd = allowedNotations.length == 0 ? 'any notation' :\n            (`notation${allowedNotations.length > 1 ? 's' : ''} ${allowedNotations.map((n) => `\"${n}\"`).join(', ')} `);\n        const alphabetAdd = allowedNotations.length == 0 ? 'any alphabet' :\n            (`alphabet${allowedAlphabets.length > 1 ? 's' : ''} ${allowedAlphabets.map((a) => `\"${a}\"`).join(', ')}.`);\n        grok.shell.warning(name + ' analysis is allowed for Macromolecules with ' + notationAdd + ' and ' + alphabetAdd);\n        return false;\n    }\n    return true;\n}\n//name: sequenceAlignment\n//input: string alignType {choices: ['Local alignment', 'Global alignment']}\n// eslint-disable-next-line max-len\n//input: string alignTable {choices: ['AUTO', 'NUCLEOTIDES', 'BLOSUM45', 'BLOSUM50','BLOSUM62','BLOSUM80','BLOSUM90','PAM30','PAM70','PAM250','SCHNEIDER','TRANS']}\n//input: double gap\n//input: string seq1\n//input: string seq2\n//output: object res\nexport function sequenceAlignment(alignType, alignTable, gap, seq1, seq2) {\n    const toAlign = new SequenceAlignment(seq1, seq2, gap, alignTable);\n    const res = alignType == 'Local alignment' ? toAlign.smithWaterman() : toAlign.needlemanWunch();\n    return res;\n}\n//name: WebLogo\n//description: WebLogo viewer\n//tags: viewer, panel\n//output: viewer result\nexport function webLogoViewer() {\n    return new WebLogo();\n}\n//name: VdRegions\n//description: V-Domain regions viewer\n//tags: viewer, panel\n//output: viewer result\nexport function vdRegionViewer() {\n    return new VdRegionsViewer();\n}\n//top-menu: Bio | Sequence Activity Cliffs...\n//name: Sequence Activity Cliffs\n//description: detect activity cliffs\n//input: dataframe table [Input data table]\n//input: column macroMolecule {semType: Macromolecule}\n//input: column activities\n//input: double similarity = 80 [Similarity cutoff]\n//input: string methodName { choices:[\"UMAP\", \"t-SNE\", \"SPE\"] }\nexport function activityCliffs(df, macroMolecule, activities, similarity, methodName) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!checkInputColumn(macroMolecule, 'Activity Cliffs'))\n            return;\n        const axesNames = getEmbeddingColsNames(df);\n        const options = {\n            'SPE': { cycles: 2000, lambda: 1.0, dlambda: 0.0005 },\n        };\n        const units = macroMolecule.tags[DG.TAGS.UNITS];\n        yield getActivityCliffs(df, macroMolecule, axesNames, 'Activity cliffs', activities, similarity, 'Levenshtein', methodName, DG.SEMTYPE.MACROMOLECULE, units, sequenceSpace, sequenceGetSimilarities, drawTooltip, options[methodName]);\n    });\n}\n//top-menu: Bio | Sequence Space...\n//name: Sequence Space\n//input: dataframe table\n//input: column macroMolecule { semType: Macromolecule }\n//input: string methodName { choices:[\"UMAP\", \"t-SNE\", \"SPE\"] }\n//input: string similarityMetric { choices:[\"Levenshtein\", \"Tanimoto\"] }\n//input: bool plotEmbeddings = true\nexport function sequenceSpaceTopMenu(table, macroMolecule, methodName, similarityMetric = 'Levenshtein', plotEmbeddings) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!checkInputColumn(macroMolecule, 'Activity Cliffs'))\n            return;\n        const embedColsNames = getEmbeddingColsNames(table);\n        const chemSpaceParams = {\n            seqCol: macroMolecule,\n            methodName: methodName,\n            similarityMetric: similarityMetric,\n            embedAxesNames: embedColsNames\n        };\n        const sequenceSpaceRes = yield sequenceSpace(chemSpaceParams);\n        const embeddings = sequenceSpaceRes.coordinates;\n        for (const col of embeddings)\n            table.columns.add(col);\n        if (plotEmbeddings) {\n            for (const v of grok.shell.views) {\n                if (v.name === table.name)\n                    v.scatterPlot({ x: embedColsNames[0], y: embedColsNames[1], title: 'Sequence space' });\n            }\n        }\n    });\n}\n;\n//top-menu: Bio | To Atomic Level...\n//name: To Atomic Level\n//description: returns molfiles for each monomer from HELM library\n//input: dataframe df [Input data table]\n//input: column macroMolecule {semType: Macromolecule}\nexport function toAtomicLevel(df, macroMolecule) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (DG.Func.find({ package: 'Chem', name: 'getRdKitModule' }).length === 0) {\n            grok.shell.warning('Transformation to atomic level requires package \"Chem\" installed.');\n            return;\n        }\n        if (!checkInputColumn(macroMolecule, 'To Atomic Level'))\n            return;\n        const monomersLibFile = yield _package.files.readAsText(HELM_CORE_LIB_FILENAME);\n        const monomersLibObject = JSON.parse(monomersLibFile);\n        const atomicCodes = getMolfilesFromSeq(macroMolecule, monomersLibObject);\n        const result = yield getMacroMol(atomicCodes);\n        const col = DG.Column.fromStrings('regenerated', result);\n        col.semType = DG.SEMTYPE.MOLECULE;\n        col.tags[DG.TAGS.UNITS] = 'molblock';\n        df.columns.add(col);\n    });\n}\n//top-menu: Bio | MSA...\n//name: MSA\n//input: dataframe table\n//input: column sequence { semType: Macromolecule }\n//output: column result\nexport function multipleSequenceAlignmentAny(table, col) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!checkInputColumn(col, 'MSA', ['fasta'], ['DNA', 'RNA', 'PT']))\n            return null;\n        const msaCol = yield runKalign(col, false);\n        table.columns.add(msaCol);\n        // This call is required to enable cell renderer activation\n        yield grok.data.detectSemanticTypes(table);\n        // const tv: DG.TableView = grok.shell.tv;\n        // tv.grid.invalidate();\n        return msaCol;\n    });\n}\n//name: Composition Analysis\n//top-menu: Bio | Composition Analysis\n//output: viewer result\nexport function compositionAnalysis() {\n    return __awaiter(this, void 0, void 0, function* () {\n        // Higher priority for columns with MSA data to show with WebLogo.\n        const tv = grok.shell.tv;\n        const df = tv.dataFrame;\n        const col = WebLogo.pickUpSeqCol2(df);\n        if (!col) {\n            grok.shell.error('Current table does not contain sequences');\n            return;\n        }\n        if (!checkInputColumn(col, 'Composition'))\n            return;\n        const allowedNotations = ['fasta', 'separator'];\n        const units = col.getTag(DG.TAGS.UNITS);\n        if (!allowedNotations.some((n) => units.toUpperCase().startsWith(n.toUpperCase()))) {\n            grok.shell.warning('Composition analysis is allowed for ' +\n                `notation${allowedNotations.length > 1 ? 's' : ''} ${allowedNotations.map((n) => `\"${n}\"`).join(', ')}.`);\n            return;\n        }\n        tv.addViewer('WebLogo', { sequenceColumnName: col.name });\n    });\n}\n// helper function for importFasta\nfunction parseMacromolecule(fileContent, startOfSequence, endOfSequence) {\n    const seq = fileContent.slice(startOfSequence, endOfSequence);\n    const seqArray = seq.split(/\\s/);\n    return seqArray.join('');\n}\n//name: importFasta\n//description: Opens FASTA file\n//tags: file-handler\n//meta.ext: fasta, fna, ffn, faa, frn, fa, fst\n//input: string fileContent\n//output: list tables\nexport function importFasta(fileContent) {\n    const regex = /^>(.*)$/gm; // match lines starting with >\n    const descriptionsArray = [];\n    const sequencesArray = [];\n    let startOfSequence = 0;\n    let match; // match.index is the beginning of the matched line\n    while (match = regex.exec(fileContent)) {\n        const description = fileContent.substring(match.index + 1, regex.lastIndex);\n        descriptionsArray.push(description);\n        if (startOfSequence !== 0)\n            sequencesArray.push(parseMacromolecule(fileContent, startOfSequence, match.index));\n        startOfSequence = regex.lastIndex + 1;\n    }\n    sequencesArray.push(parseMacromolecule(fileContent, startOfSequence, -1));\n    const descriptionsArrayCol = DG.Column.fromStrings('description', descriptionsArray);\n    const sequenceCol = DG.Column.fromStrings('sequence', sequencesArray);\n    sequenceCol.semType = 'Macromolecule';\n    const stats = WebLogo.getStats(sequenceCol, 5, WebLogo.splitterAsFasta);\n    const seqType = stats.sameLength ? 'SEQ.MSA' : 'SEQ';\n    const PeptideFastaAlphabet = new Set([\n        'G', 'L', 'Y', 'S', 'E', 'Q', 'D', 'N', 'F', 'A',\n        'K', 'R', 'H', 'C', 'V', 'P', 'W', 'I', 'M', 'T',\n    ]);\n    const DnaFastaAlphabet = new Set(['A', 'C', 'G', 'T']);\n    const RnaFastaAlphabet = new Set(['A', 'C', 'G', 'U']);\n    //const SmilesRawAlphabet = new Set([\n    //  'O', 'C', 'c', 'N', 'S', 'F', '(', ')',\n    //  '1', '2', '3', '4', '5', '6', '7',\n    //  '+', '-', '@', '[', ']', '/', '\\\\', '#', '=']);\n    const alphabetCandidates = [\n        ['PT', PeptideFastaAlphabet],\n        ['DNA', DnaFastaAlphabet],\n        ['RNA', RnaFastaAlphabet],\n    ];\n    //const alphabetCandidates: [string, Set<string>][] = [\n    //  ['NT', new Set(Object.keys(Nucleotides.Names))],\n    //  ['PT', new Set(Object.keys(Aminoacids.Names))],\n    //];\n    // Calculate likelihoods for alphabet_candidates\n    const alphabetCandidatesSim = alphabetCandidates.map((c) => WebLogo.getAlphabetSimilarity(stats.freq, c[1]));\n    const maxCos = Math.max(...alphabetCandidatesSim);\n    const alphabet = maxCos > 0.65 ? alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][0] : 'UN';\n    sequenceCol.semType = DG.SEMTYPE.MACROMOLECULE;\n    const units = `fasta:${seqType}:${alphabet}`;\n    sequenceCol.setTag(DG.TAGS.UNITS, units);\n    return [DG.DataFrame.fromColumns([\n            descriptionsArrayCol,\n            sequenceCol,\n        ])];\n}\n//name: Bio | Convert\n//friendly-name: Bio | Convert\n//tags: panel, bio\n//input: column col {semType: Macromolecule}\nexport function convertPanel(col) {\n    convert(col);\n}\n"],"names":[],"sourceRoot":""}
10865
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package.js","mappings":";;;;;;;;;;AAAA;AACA,EAAE,KAA4D;AAC9D,EAAE,CACmD;AACrD,CAAC,sBAAsB;;AAEvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,eAAe;AACjC;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,OAAO;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA,6BAA6B;AAC7B;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,iBAAiB,kBAAkB,UAAU;AAC/D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,eAAe;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA,uBAAuB;AACvB,WAAW;AACX;AACA;AACA,2DAA2D,gBAAgB,IAAI;AAC/E;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8DAA8D;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf,WAAW;AACX,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qBAAqB;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,yCAAyC,IAAI;AAC7C,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,aAAa,SAAS,YAAY;AAClD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+EAA+E;AAC/E;;AAEA,+FAA+F,6BAA6B;AAC5H;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iCAAiC;AACjC;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA,yDAAyD,WAAW;AACpE,6DAA6D,WAAW;AACxE;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,gCAAgC;;AAE9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,uEAAuE;AACvE;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC;AACD;;;;;;;;;;;;;;;;;;ACrdgD;AACzC,iCAAiC,yDAAc;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yDAAyD,OAAO;AAChE;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,gBAAgB,kBAAkB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,yBAAyB;AAC9E,qDAAqD,yBAAyB;AAC9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;ACjOK;AACzC,kCAAkC,yDAAc;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;AC1BpC;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;AC3C8B;AACzE;AACA;AACA;AACA;AACA;AACA,QAAQ,uFAAM,+CAA+C,KAAK;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC;AACzC,YAAY,uFAAM,0CAA0C,YAAY,4BAA4B,IAAI;AACxG;AACA;AACA;AACA,6CAA6C;AAC7C,YAAY,uFAAM,gDAAgD,YAAY,6BAA6B,IAAI;AAC/G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB,kBAAkB,UAAU;AAC5B;AACA;AACA;AACA;AACA;AACA,wBAAwB,YAAY;AACpC;AACA,YAAY,uFAAM,uCAAuC,KAAK,uBAAuB,SAAS;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,UAAU;AAC3B,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA;AACA,wBAAwB,kBAAkB;AAC1C;AACA,YAAY,uFAAM,uCAAuC,KAAK,qBAAqB,MAAM;AACzF;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;AC1JpC;AACP;AACA;AACA;AACA;AACA,wBAAwB,cAAc;AACtC;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACgD;AACzC;AACP;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA,+CAA+C,uEAA4B;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,iCAAiC,yDAAc;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;AC7C3C;AACO;AACP;AACA;AACA;AACA;AACA,CAAC,oCAAoC;AACrC;AACA;AACA;AACO;AACP;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC7B3C,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACA;AAClB;AACS;AAC4C;AACwB;AAClC;AACG;AAClB;AAChD;AACA;AACA,eAAe,kDAAQ;AACvB;AACA,oEAA0B;AAC1B;AACA;AACO;AACP;AACA;AACA,0BAA0B,iDAAO;AACjC;AACA;AACO;AACP,iBAAiB;AACjB,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACO,sBAAsB,qDAAW;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,iDAAiD;AAC5D;AACA,WAAW,mDAAmD;AAC9D;AACA,WAAW,mDAAmD;AAC9D;AACA;AACA;AACA;AACA;AACA,8EAA8E,sCAAsC;AACpH,kFAAkF,sCAAsC;AACxH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,gDAAM;AACjC;AACA,0BAA0B,mDAAS;AACnC;AACA,wBAAwB,gDAAM;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB,+BAA+B,2CAAc;AAC7C;AACA;AACA;AACA;AACA;AACA,oBAAoB,iEAAuB;AAC3C;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA,aAAa;AACb,+BAA+B,2CAAc;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb,+BAA+B,0DAAgB;AAC/C;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,2BAA2B,sBAAsB,gBAAgB,uBAAuB;AACxF,6BAA6B,kBAAkB,kBAAkB,oBAAoB;AACrF;AACA,iBAAiB,cAAc,KAAK,UAAU,UAAU,0BAA0B,WAAW,aAAa;AAC1G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,uDAAa;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0DAA0D,SAAS;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,eAAe,MAAM;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B,SAAS;AACT;AACA;AACA,0CAA0C,cAAc,iCAAiC,cAAc;AACvG;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,0CAA0C,cAAc;AACxD,SAAS;AACT;AACA;AACA;AACA,sBAAsB;AACtB,SAAS;AACT;AACA,oCAAoC,iCAAiC;AACrE,0CAA0C,cAAc,iCAAiC,cAAc;AACvG;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,cAAc;AACxD,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,oBAAoB;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,cAAc,2BAA2B,UAAU;AACvF;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,oCAAoC,iDAAO;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8EAA8E,oBAAoB;AAClG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oBAAoB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,EAAE,gCAAgC,2BAA2B;AAC1G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,MAAM;AAC3C;AACA,iDAAiD,OAAO;AACxD;AACA;AACA,mDAAmD,aAAa;AAChE;AACA;AACA;AACA,+DAA+D,MAAM;AACrE,wCAAwC,OAAO;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yDAAyD,cAAc;AACvE;AACA,yDAAyD,uBAAuB;AAChF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,uBAAuB;AAChE,yCAAyC,uBAAuB;AAChE,yCAAyC,uBAAuB;AAChE,yCAAyC,uBAAuB;AAChE;AACA,2CAA2C,mBAAmB;AAC9D,2CAA2C,yBAAyB;AACpE;AACA;AACA,eAAe,WAAW;AAC1B,eAAe,SAAS;AACxB,gBAAgB,YAAY;AAC5B;AACA;AACA;AACA;AACA,iBAAiB,4EAAmC;AACpD,sBAAsB,sEAA6B;AACnD;AACA,iBAAiB,8EAAoC;AACrD,sBAAsB,0EAAgC;AACtD;AACA;AACA;AACA;AACA,iCAAiC,2DAAiB,IAAI,0EAAgC;AACtF,iCAAiC,yDAAgB,IAAI,sEAA6B;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,8DAAwB;AAC1C;AACA;AACA,mEAAmE,kBAAkB;AACrF,eAAe,WAAW;AAC1B,eAAe,QAAQ;AACvB,eAAe,cAAc;AAC7B,iBAAiB,aAAa,wBAAwB;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,mFAAM;AAChC,8BAA8B,mFAAM;AACpC,oBAAoB,iGAAgB,sBAAsB,6FAAY,UAAU,6FAAY;AAC5F;AACA;AACA;AACA;AACA,kBAAkB,cAAc;AAChC,mBAAmB,WAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,kEAAwB;AAC/E;AACA,qCAAqC,uDAAa;AAClD;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,eAAe,KAAK;AACpB,gBAAgB,UAAU;AAC1B;AACA;AACA,oBAAoB,yCAAE;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,EAAE;AACrD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,eAAe,QAAQ;AACvB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,OAAO;AACvD;AACA;AACA;AACA,4BAA4B,kEAAwB;AACpD,yDAAyD,kEAAwB,CAAC;AAClF,iCAAiC,uDAAa;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;AChpB3C,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC4E;AACyB;AAC9F;AACP;AACA,8CAA8C,kHAAiC,GAAG,yCAAyC;AAC3H,wFAAwF,0FAAS;AACjG;AACA,KAAK;AACL;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;AClBD;AACY;AAC6B;AACU;AACtF;AACP;AACA,6BAA6B,uGAA0B;AACvD,KAAK;AACL;AACA,uBAAuB,yDAAW;AAClC,wBAAwB,gEAAW;AACnC,KAAK;AACL;AACA,oBAAoB,sGAA2B;AAC/C,gBAAgB,kGAAuB;AACvC,sBAAsB,wGAA6B;AACnD,0BAA0B,+GAAiC;AAC3D,kBAAkB,oGAAyB;AAC3C,sBAAsB,wGAA6B;AACnD,yBAAyB,8GAAgC;AACzD,0BAA0B,+GAAiC;AAC3D,kBAAkB,oGAAyB;AAC3C,iBAAiB,mGAAwB;AACzC,KAAK;AACL;AACO;AACP;AACA;AACA;AACA;AACA;AACA,CAAC,IAAI;AACE;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA,eAAe,QAAQ;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,gBAAgB;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,oBAAoB;AACnC,gBAAgB,UAAU;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;AC7E3C,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC0C;AACJ;AACA;AACuD;AAC7F;AACA;AACO;AACP;AACA;AACA;AACA;AACA,gBAAgB,wBAAwB;AACxC;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,sBAAsB,kEAAwB,EAAE,4DAAkB;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,cAAc;AACtC,4BAA4B,kBAAkB;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,4DAAkB,mBAAmB,sDAAsD;AAChH;AACA,qBAAqB,iEAAuB;AAC5C,kCAAkC,+DAAqB;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT,+BAA+B,mDAAS,IAAI,2BAA2B;AACvE,iCAAiC,mDAAS,GAAG,0BAA0B;AACvE;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,qBAAM;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,yDAAe;AACnC;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,2CAA2C;AACvE;AACA,iBAAiB;AACjB;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,kBAAkB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,MAAM,GAAG,QAAQ;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,eAAe;AACnC;AACA;AACA,qBAAqB,0DAA0D;AAC/E;AACA,oBAAoB,6DAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,uDAAa;AAC3C,8BAA8B,uDAAa;AAC3C;AACA;AACA,aAAa;AACb;AACO;AACP;AACA,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACO;AACP,oBAAoB,aAAa;AACjC;AACA,4BAA4B,SAAS;AACrC,+BAA+B,2GAAyB;AACxD,oBAAoB,oEAA0B;AAC9C;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;ACvRpC;AACP;AACA,0CAA0C,4KAA2C;AACrF;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,8BAA8B,QAAQ,uBAAuB;AAC7D,sBAAsB,0CAA0C;AAChE;AACA,KAAK;AACL;AACA,2CAA2C;;;;;;;;;;;;;;;;ACd3C;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACpBN;AAC9B;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,kDAAS;AAC7B;AACA,oBAAoB,YAAY;AAChC;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;;;;;;;;ACpL3C;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA,2CAA2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACpCE;AACK;AAClD;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,QAAQ;AACnB,YAAY;AACZ;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,aAAa;AACzB;AACA;AACA;AACA,2DAA2D,sDAAM;AACjE;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACO;AACP;AACA,4BAA4B,sDAAM;AAClC;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA,sBAAsB,sDAAM;AAC5B,oBAAoB,cAAc;AAClC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACA;AACA,oBAAoB,cAAc;AAClC;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACA;AACA,sBAAsB,sDAAM;AAC5B,oBAAoB,cAAc;AAClC;AACA;AACA;AACO;AACP;AACA,oBAAoB,cAAc;AAClC;AACA;AACA;AACO;AACP;AACA;AACA;AACA,oBAAoB,eAAe;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA,oBAAoB,gBAAgB;AACpC,wBAAwB,gBAAgB;AACxC,2BAA2B,oDAAW;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB,WAAW,gBAAgB;AAC3B,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA,oBAAoB,YAAY;AAChC,4BAA4B,YAAY;AACxC;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,gBAAgB;AAClD;AACP;AACA;AACA,oBAAoB,YAAY;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU,OAAO;AACjB,UAAU,SAAS;AACnB,WAAW,UAAU;AACrB;AACO;AACP;AACA,oCAAoC;AACpC,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,oCAAoC;AAC/C;AACA,aAAa,UAAU;AACvB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,kDAAS;AAC7B;AACA,oBAAoB,YAAY;AAChC;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACO;AACP;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB,YAAY;AACZ;AACO;AACP;AACA;AACA;AACA,2CAA2C;;;;;;;;;;;ACxO9B;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,OAAO;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,WAAW;AAC7B;AACA;AACA;AACA;AACA,SAAS,eAAe;AACxB;AACA;AACA;AACA;AACA,wBAAwB,SAAS;AACjC;AACA;AACA;AACA,oBAAoB,OAAO;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,SAAS;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,SAAS;AAC/B;AACA;AACA;AACA,kBAAkB,OAAO;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,SAAS;AAC/B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB,gBAAgB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;;;;;;;;;;;AClJa;AACb;AACA,8CAA6C,EAAE,aAAa,EAAC;AAC7D,mBAAmB,GAAG,YAAY;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,UAAU;AAC9B,8CAA8C,qCAAqC;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,UAAU;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;;;;;;;;;;;;;;;;;ACtFnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB;AACxB,yBAAyB;AACzB,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,eAAe;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,eAAe;AACvC;AACA,4BAA4B,eAAe;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA,4BAA4B,mBAAmB;AAC/C;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC,4BAA4B,gBAAgB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA,4BAA4B,mBAAmB;AAC/C;AACA;AACA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC,4BAA4B,gBAAgB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;AChfA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AAC0C;AACnC;AACP;AACA;AACA,kCAAkC,6DAAmB;AACrD,wBAAwB,qBAAqB;AAC7C,4BAA4B,wBAAwB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA,2DAA2D;AAC3D;AACA;AACA,wBAAwB,WAAW;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,uDAAuD;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,qBAAqB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D;AAC/D;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C,+FAA+F;AAC/F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D;AAC/D;AACA;AACA;AACA;AACA,wBAAwB,mBAAmB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iFAAiF;AACjF;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA,yBAAyB,oBAAoB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;;;;;;;;;;;;;;;;;;;;;;;;;ACrUiC;AACK;AACsC;AACE;AACL;AACF;AACjC;AACtC,gBAAgB,qDAAW;AAC3B;AACA;AACA;AACA;AACA,mBAAmB,iGAA6B;AAChD;AACA,mBAAmB,qGAAgC;AACnD;AACA,mBAAmB,qGAAgC;AACnD;AACA,mBAAmB,qGAAgC;AACnD;AACA;AACA,mBAAmB,yFAAwB;AAC3C;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,iBAAiB,EAAE,IAAI;AAC/C;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,0BAA0B;AACrC,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,SAAS;AACpB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,SAAS;AACpB,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,gDAAgD,6DAAmB;AAC1E,iBAAiB;AACjB,qBAAqB,OAAO,gEAA0B;AACtD,0BAA0B;AAC1B,yBAAyB;AACzB;AACA;AACA;AACA,eAAe,0BAA0B;AACzC,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,aAAa;AAC5B,eAAe,kBAAkB;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,uDAAa;AAC7D;AACA,yBAAyB,gDAAM,OAAO,SAAS,UAAU,EAAE,gBAAgB,EAAE,OAAO;AACpF;AACA;AACA;AACA;AACA,sDAAsD,iDAAiD;AACvG;AACA;AACA,mCAAmC,oDAAU,wBAAwB,SAAS,gBAAgB;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6EAA6E,uDAAa;AAC1F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,uDAAa;AACnE;AACA;AACA,iCAAiC,6FAAmB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;AC3JO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,sCAAsC;AAChC;AACP;AACA;AACA;AACA,CAAC,gCAAgC;AAC1B;AACP;AACA;AACA;AACA;AACA;AACA,CAAC,oBAAoB;AACd;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,8BAA8B;AACxB;AACA;AACA;AACA;AACP;AACA;AACA,CAAC,sBAAsB;AAChB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,YAAY,6GAA6G;AACzH,YAAY,wGAAwG;AACpH,WAAW,mGAAmG;AAC9G,YAAY,oEAAoE;AAChF;AACA;AACA;AACA,KAAK;AACL,WAAW,0DAA0D;AACrE;;;;;;;;;;;;;;;;;;;ACzDsC;AACmB;AACzD;AACA;AACA;AACA,WAAW,WAAW;AACtB;AACO;AACP,0BAA0B,kEAAiB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,wDAAc;AAC9C,2BAA2B,wDAAc;AACzC,IAAI,mDAAS;AACb,aAAa,gDAAM;AACnB,QAAQ,+CAAK;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;;;;;;;;;;;;;;;;;;;;;ACnCA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACtC;AACmC;AACmD;AACtF;AACA;AACA;AACA,WAAW,UAAU;AACrB,YAAY,QAAQ;AACpB;AACA;AACA,uDAAuD,MAAM,IAAI,EAAE;AACnE;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,UAAU;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,WAAW;AACtB,WAAW,SAAS;AACpB,YAAY,oBAAoB;AAChC;AACO;AACP;AACA;AACA;AACA,gDAAgD,sGAA4B;AAC5E;AACA,8BAA8B,uDAAK;AACnC;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,+DAAqB,QAAQ,YAAY;AAChE;AACA,uCAAuC,uDAAa;AACpD;AACA,sBAAsB,uDAAa;AACnC,yBAAyB,kEAAwB;AACjD;AACA,KAAK;AACL;AACO;AACP;AACA;AACA;AACA,4BAA4B,oBAAoB;AAChD;AACA,gCAAgC,+DAAqB;AACrD,sDAAsD,EAAE;AACxD;AACA;AACA,mDAAmD,GAAG,QAAQ,MAAM;AACpE;AACA;AACA,KAAK;AACL;;;;;;;;;;;;;;;;;;;AChFsC;AACiC;AACvE;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,uDAAa;AAC3D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB;AACxB,yBAAyB;AACzB,2BAA2B;AAC3B,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB,oBAAoB;AACpB,eAAe;AACf,8BAA8B;AAC9B,kCAAkC;AAClC,6BAA6B;AAC7B,cAAc;AACd,cAAc;AACd,kBAAkB;AAClB;AACA;AACA,gBAAgB,cAAc;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,UAAU;AACzB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,4DAAkB;AAC5C,4BAA4B,kEAAwB;AACpD,yBAAyB,uDAAa;AACtC;AACA;AACA,6BAA6B,+DAAqB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,gBAAgB,kBAAkB;AAClC;AACA;AACA;AACA,gCAAgC,iGAAuB;AACvD;AACA;AACA;AACA;AACA;AACA,4BAA4B,+BAA+B;AAC3D;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,sGAA4B;AACrD,8CAA8C;AAC9C,mCAAmC;AACnC,+CAA+C;AAC/C,+BAA+B;AAC/B;AACA;AACA,0BAA0B;AAC1B;AACA,wCAAwC;AACxC,yEAAyE;AACzE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,gCAAgC;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,sGAA4B;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,gCAAgC;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,UAAU;AACzB,eAAe,eAAe;AAC9B,gBAAgB,0BAA0B;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;AC5NA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACA;AACuD;AACjB;AACrE;AACP;AACA;AACA;AACA,wBAAwB,wBAAwB;AAChD,2BAA2B,2GAAyB,CAAC,yGAAyC;AAC9F,eAAe,4DAAkB,CAAC,8DAAoB;AACtD,KAAK;AACL;AACO;AACP,sCAAsC,iDAAO;AAC7C,wBAAwB,iDAAO;AAC/B,QAAQ,oDAAU;AAClB,QAAQ,oDAAU;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oDAAU;AAC9B,yBAAyB,oDAAU;AACnC;AACA;AACA;AACA,+CAA+C,iDAAO;AACtD;AACA;AACA,aAAa,SAAS,sBAAsB;AAC5C,KAAK;AACL;;;;;;;;;;;;;;;;;;;;;AC3CA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACsC;AACqB;AAC1F;AACP;AACA;AACA,sCAAsC,uDAAa;AACnD;AACA;AACA;AACA,4BAA4B,6FAA0B;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,+GAAoC;AAC9E,qEAAqE,oEAA0B;AAC/F,iBAAiB,yDAAyD,uDAAa;AACvF,KAAK;AACL;AACO;AACP;AACA;AACA,+BAA+B,GAAG,GAAG,WAAW;AAChD;;;;;;;;;;;;;;;;;;;;;;;;;;ACpCsC;AACiC;AAC7B;AACnC;AACA;AACA;AACA;AACA;AACP,2BAA2B,uDAAa;AACxC;AACA,yBAAyB,6FAAmB;AAC5C;AACA;AACA,oBAAoB,gBAAgB;AACpC;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA,oBAAoB,4DAAkB,YAAY,aAAa;AAC/D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,KAAK;AACL;AACA;;;;;;;;;;;;;;;;;;;;;ACzCA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACsC;AACA;AACgC;AACtE,YAAY,gFAAY;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,8BAA8B,qDAAW;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uEAAuE,6DAA6D;AACpI,sEAAsE,6BAA6B;AACnG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,6FAA6F;AACjH,oBAAoB,6FAA6F;AACjH;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA,2BAA2B,0DAAgB;AAC3C;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,iCAAiC;AACjC,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,qEAAqE,0DAAgB;AACrF;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uEAAuE,qCAAqC;AAC5G;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,6CAA6C,mCAAmC,YAAY,OAAO,EAAE,+BAA+B,GAAG;AACvI;AACA;AACA;AACA,iCAAiC,2BAA2B;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,kDAAQ;AACtC;AACA;AACA,gDAAgD,gDAAM;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA,uCAAuC,gDAAM,gBAAgB,OAAO,EAAE,oBAAoB;AAC1F;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA,qBAAqB;AACrB;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,kCAAkC,4CAA4C;AAC9E,wBAAwB,gDAAM,oBAAoB,UAAU,uBAAuB,GAAG;AACtF;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,6BAA6B,4BAA4B;AACzD,iCAAiC,6BAA6B;AAC9D;AACA,iEAAiE,UAAU;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,IAAI,OAAO,KAAK;AAC/D;AACA;;;;;;;;;;;AC9OA;AACA,IAAI,IAAyD;AAC7D;AACA,MAAM,EAKmB;AACzB,CAAC;AACD,qCAAqC;AACrC;AACA;;AAEA;AACA,mBAAmB,8BAAmB;;AAEtC;AACA;AACA;;AAEA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;;AAEA;AACA,0EAA0E,8BAAmB;;AAE7F;AACA;;AAEA;AACA;AACA;;;AAGA;AACA,UAAU,8BAAmB;;AAE7B;AACA,UAAU,8BAAmB;;AAE7B;AACA,UAAU,8BAAmB;;AAE7B;AACA,iBAAiB,8BAAmB;AACpC,UAAU;AACV;AACA;AACA;AACA,gCAAgC,+BAAmB;;AAEnD;;AAEA,0BAA0B,+BAAmB;;AAE7C,sBAAsB,+BAAmB;;AAEzC,wBAAwB,+BAAmB;;AAE3C,oBAAoB,+BAAmB;;AAEvC,2BAA2B,+BAAmB;;AAE9C,oBAAoB,+BAAmB;;AAEvC,YAAY,+BAAmB;;AAE/B,gBAAgB,+BAAmB;;AAEnC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,uEAAuE,aAAa;AACpF;AACA;;AAEA;AACA;AACA,MAAM;AACN,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,wEAAwE,eAAe;AACvF;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,0EAA0E,eAAe;AACzF;AACA;;AAEA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,KAAK,EAAE,EAGV;;AAEV;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,KAAK,EAAE,EAGV;;AAEV;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,2FAA2F,eAAe;AAC1G;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA,2EAA2E,eAAe;AAC1F;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA,2EAA2E,eAAe;AAC1F;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA,+FAA+F,eAAe;AAC9G;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,6DAA6D,sEAAsE;AACnI;;AAEA;AACA;AACA,aAAa;AACb;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;;AAEA;AACA,MAAM;AACN,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;AACA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,2DAA2D,sEAAsE;AACjI;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;;AAEA;AACA,yDAAyD,sEAAsE;AAC/H;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;AACA,EAAE;;AAEF;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,KAAK,EAAE,EAGV;;AAEV;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ,EAAE;AACF;;AAEA;AACA;;AAEA;AACA,iBAAiB;;AAEjB;AACA;AACA;;AAEA;AACA,EAAE;;AAEF;AACA;;AAEA;AACA;AACA,IAAI;AACJ,EAAE;;AAEF;AACA;AACA;;AAEA,aAAa;;AAEb;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;;AAEA,mBAAmB,gCAAmB;;AAEtC;AACA;AACA,+CAA+C,gBAAgB;;AAE/D;AACA,KAAK;AACL;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,oBAAoB,WAAW,gCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,CAAC,gCAAmB;AACpB,CAAC,gCAAmB;AACpB,kBAAkB,gCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;AACA,YAAY,gCAAmB;;AAE/B;AACA,CAAC,gCAAmB;AACpB,+BAA+B;AAC/B,+BAA+B;AAC/B;AACA,EAAE;AACF;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA,WAAW;AACX,EAAE;;AAEF,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;AACA;AACA,iBAAiB,gCAAmB;AACpC,iBAAiB,gCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD;AACA,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C,uBAAuB,gCAAmB;AAC1C;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA,GAAG,gCAAmB;AACtB;AACA;AACA,0CAA0C;AAC1C,8CAA8C;AAC9C,OAAO,2BAA2B;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,gCAAmB;AAChD;AACA,KAAK,gCAAmB;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,iBAAiB,gCAAmB;AACpC,iBAAiB,gCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C,kEAAkE;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;A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AACA;AACA;;AAEA,oBAAoB;;AAEpB,6BAA6B,6BAA6B,cAAc;;AAExE,OAAO;AACP;AACA,gCAAgC,gCAAmB;;AAEnD,wDAAwD;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,eAAe,gCAAmB;;AAElC,wBAAwB,gCAAmB;;AAE3C,sBAAsB,gCAAmB;;AAEzC,gBAAgB,gCAAmB;;AAEnC;AACA;;AAEA;AACA,kBAAkB;AAClB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB,OAAO;AACP,gBAAgB;AAChB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,WAAW;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA,QAAQ;;AAER;AACA;AACA,qEAAqE;;AAErE;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,6BAA6B;AAC7B;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,mBAAmB;AACrD;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,mBAAmB;;AAEnB;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,0BAA0B,gBAAgB;AAC1C;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,cAAc;AACd;AACA;;AAEA;AACA,cAAc;AACd;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,MAAM;;AAEN;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,QAAQ;AACxD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA,gDAAgD,QAAQ;AACxD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA,MAAM;;AAEN;AACA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,MAAM;;AAEN;AACA,gDAAgD,QAAQ;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA,gDAAgD,QAAQ;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;;AAEN;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA,6BAA6B,6BAA6B,cAAc,KAAK,gCAAmB;;AAEhG,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yBAAyB,sBAAsB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,6BAA6B;AAC7B;AACA;AACA;AACA,8BAA8B;;;AAG9B,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA;AACA,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC,sBAAsB,iCAAmB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,4BAA4B;AAC5B,sBAAsB,2BAA2B,SAAS;AAC1D,IAAI;AACJ,EAAE;AACF;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA,+DAA+D;AAC/D;AACA,OAAO;AACP;AACA,uBAAuB,iCAAiC;AACxD,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,uBAAuB,iCAAmB;AAC1C;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ,0BAA0B,gBAAgB;AAC1C,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,wBAAwB,gBAAgB;;AAExC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,iBAAiB,iCAAmB;AACpC,iBAAiB,iCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,mBAAmB;AACnB,iBAAiB,iCAAmB;AACpC,iBAAiB,iCAAmB;;AAEpC;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,SAAS,iCAAmB;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,SAAS,iCAAmB;AAC5B;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C,cAAc,WAAW;AACpE;AACA,yCAAyC;AACzC;AACA;AACA;AACA,iBAAiB,iCAAmB;AACpC;AACA,6BAA6B;AAC7B,0BAA0B;AAC1B,QAAQ;AACR;AACA;AACA,KAAK,UAAU;AACf;AACA,EAAE;;AAEF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,aAAa;AACb,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,oBAAoB,gCAAgC;AACpD,WAAW;AACX;AACA;AACA,SAAS;AACT,MAAM;AACN,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC;AAChC;AACA;AACA;AACA,wBAAwB,sBAAsB;AAC9C;AACA;AACA,WAAW;AACX;AACA;AACA,QAAQ;AACR,OAAO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL,mBAAmB,oBAAoB,MAAM;AAC7C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG,iCAAmB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA,8CAA8C,WAAW;AACzD,CAAC,iCAAmB;AACpB;AACA,mBAAmB,iCAAmB;;AAEtC;AACA;AACA;AACA;AACA,yCAAyC,SAAS;AAClD;AACA,EAAE;AACF;AACA;AACA;AACA;AACA,qCAAqC,SAAS;AAC9C;AACA,EAAE;AACF,uCAAuC,iCAAmB;AAC1D,oCAAoC;AACpC,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV,QAAQ;AACR;AACA,MAAM;AACN,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,MAAM;AACN;AACA,EAAE;;AAEF,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC,mBAAmB,iCAAmB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kEAAkE,gBAAgB;AAClF;AACA,KAAK,2CAA2C,gCAAgC;AAChF;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA;AACA,gBAAgB,iCAAmB;AACnC,gBAAgB,iCAAmB;AACnC,gBAAgB,iCAAmB;AACnC;AACA;AACA;AACA;AACA;AACA,oDAAoD;AACpD;AACA;AACA,eAAe,iCAAmB;AAClC;AACA;AACA,SAAS,UAAU;AACnB;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,GAAG;AACT;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,eAAe,iCAAmB;AAClC,eAAe,iCAAmB;AAClC;AACA,MAAM,iCAAmB;AACzB;AACA,sBAAsB;AACtB,IAAI;AACJ;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,iBAAiB,iCAAmB;AACpC,iBAAiB,iCAAmB;AACpC;AACA;AACA,iBAAiB,iCAAmB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,sCAAsC,oBAAoB,GAAG;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C,0BAA0B,iCAAmB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,iCAAmB;AACzB;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,gBAAgB,iCAAmB;AACnC,gBAAgB,iCAAmB;AACnC;AACA;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,cAAc,iCAAmB;AACjC;AACA;AACA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,gBAAgB,iCAAmB;;AAEnC,CAAC,iCAAmB;AACpB;AACA;AACA;AACA,EAAE;;AAEF,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA;AACA,cAAc,iCAAmB;AACjC,eAAe,iCAAmB,iBAAiB;AACnD;AACA;AACA,0BAA0B,iCAAmB,iBAAiB,QAAQ;AACtE;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,oBAAoB,WAAW,iCAAmB;;AAElD,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,CAAC,iCAAmB;AACpB,kBAAkB,iCAAmB;;AAErC,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,cAAc,iCAAmB;;AAEjC;AACA,CAAC,iCAAmB;AACpB,0BAA0B;AAC1B,EAAE;AACF;AACA;AACA;AACA;AACA,EAAE;;AAEF,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC,oBAAoB,iCAAmB;AACvC;AACA,oBAAoB,iCAAmB;AACvC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA,wBAAwB,OAAO;AAC/B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;AACjC;AACA,MAAM;AACN,KAAK,iCAAmB;AACxB;AACA;AACA;AACA,+DAA+D,OAAO;AACtE;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,IAAI;AACJ;AACA;AACA;AACA;AACA,KAAK,iCAAmB;AACxB,4BAA4B;AAC5B,4BAA4B;AAC5B,4BAA4B;AAC5B,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA;AACA,aAAa,iCAAmB,aAAa;AAC7C;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;AACrC,kBAAkB,iCAAmB;;AAErC;AACA,eAAe,iCAAmB;AAClC;AACA;AACA;AACA;AACA,OAAO,iCAAmB;AAC1B,uCAAuC,iCAAmB,iBAAiB,2BAA2B;AACtG;AACA;AACA;AACA,KAAK,iCAAmB;AACxB,KAAK;AACL;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;;AAEA,GAAG,iCAAmB;;AAEtB;AACA;;AAEA;;AAEA;AACA;;AAEA,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,aAAa,iCAAmB;;AAEhC,sBAAsB,QAAQ,iCAAmB,YAAY;;AAE7D,OAAO;AACP;AACA,gCAAgC,iCAAmB;;AAEnD;AACA,eAAe,iCAAmB;AAClC,eAAe,iCAAmB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;AACD;;;;;;;;;;;ACnrKA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;UAEA;UACA;;;;;WCzBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;WACA;WACA;WACA;WACA;;;;;WCJA;WACA;WACA;WACA;WACA,GAAG;WACH;WACA;WACA,CAAC;;;;;WCPD;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;WCNA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;;;;;WCfA;;WAEA;WACA;WACA;WACA;WACA;WACA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACrBA,iBAAiB,SAAI,IAAI,SAAI;AAC7B,4BAA4B,+DAA+D,iBAAiB;AAC5G;AACA,oCAAoC,MAAM,+BAA+B,YAAY;AACrF,mCAAmC,MAAM,mCAAmC,YAAY;AACxF,gCAAgC;AAChC;AACA,KAAK;AACL;AACA;AAC0C;AACJ;AAC/B,qBAAqB,oDAAU;AACiC;AACT;AACE;AAChB;AACN;AACoC;AACS;AACC;AACb;AACxB;AACuB;AAC1E;AACO;AACP;AACA;AACA;AACA;AACA,qCAAqC,gBAAgB;AACrD,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACO;AACP,eAAe,oFAAiC;AAChD;AACA;AACA,6BAA6B,uDAAa;AAC1C,wBAAwB,kEAAwB;AAChD,QAAQ,4DAAkB;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,wCAAwC,EAAE,gCAAgC,EAAE,gBAAgB;AACpH;AACA,wBAAwB,wCAAwC,EAAE,gCAAgC,EAAE,eAAe;AACnH,QAAQ,4DAAkB;AAC1B;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA,4BAA4B;AAC5B;AACA;AACA;AACA;AACO;AACP,wBAAwB,yDAAiB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,eAAe,iFAAO;AACtB;AACA;AACA;AACA;AACA;AACO;AACP,eAAe,uEAAe;AAC9B;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA,6BAA6B;AACtB;AACP;AACA;AACA;AACA,0BAA0B,4EAAqB;AAC/C;AACA,qBAAqB,4CAA4C;AACjE;AACA,yCAAyC,uDAAa;AACtD,cAAc,qGAAiB,qGAAqG,kEAAwB,SAAS,gEAAa,EAAE,oFAAuB,EAAE,wEAAW;AACxN,KAAK;AACL;AACA;AACA;AACA;AACA,gCAAgC;AAChC,6BAA6B;AAC7B,mCAAmC;AACnC;AACO;AACP;AACA;AACA;AACA,+BAA+B,4EAAqB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,oEAAa;AACpD;AACA;AACA;AACA;AACA,4BAA4B,0DAAgB;AAC5C;AACA,oCAAoC,qEAAqE;AACzG;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AACxB;AACP;AACA,YAAY,sDAAY,GAAG,yCAAyC;AACpE,YAAY,4DAAkB;AAC9B;AACA;AACA;AACA;AACA;AACA,yBAAyB,+DAAqB;AAC9C;AACA;AACA;AACA;AACA;AACA,oBAAoB,8DAAoB;AACxC,kBAAkB,iEAAuB;AACzC;AACA,YAAY,+DAAqB;AACjC;AACA,YAAY,sDAAY;AACxB,SAAS;AACT,gEAAgE,iEAAsB;AACtF;AACA,4BAA4B,iEAAkB;AAC9C,6BAA6B,iEAAW;AACxC,oBAAoB,+DAAqB;AACzC,sBAAsB,6DAAmB;AACzC,iBAAiB,uDAAa;AAC9B;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACO;AACP;AACA;AACA;AACA,6BAA6B,6EAAS;AACtC;AACA;AACA,cAAc,uEAA6B;AAC3C;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACO;AACP;AACA;AACA,mBAAmB,uDAAa;AAChC;AACA,oBAAoB,+FAAqB;AACzC;AACA,YAAY,0DAAgB;AAC5B;AACA;AACA;AACA;AACA;AACA,iCAAiC,uDAAa;AAC9C;AACA,YAAY,4DAAkB;AAC9B,2BAA2B,wCAAwC,EAAE,gCAAgC,EAAE,eAAe;AACtH;AACA;AACA,kCAAkC,8BAA8B;AAChE,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,+BAA+B;AAC/B;AACA;AACA;AACA,eAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,+DAAqB;AACtD,wBAAwB,+DAAqB;AAC7C;AACA,kBAAkB,0FAAgB,iBAAiB,iGAAuB;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gEAAgE,uGAA6B;AAC7F;AACA;AACA,0BAA0B,kEAAwB;AAClD,2BAA2B,QAAQ,GAAG,SAAS;AAC/C,uBAAuB,uDAAa;AACpC,YAAY,kEAAwB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACd;AACP,IAAI,uDAAO;AACX","sources":["webpack://bio/./node_modules/@biowasm/aioli/dist/aioli.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/aminoacids.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/nucleotides.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/seq-palettes.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/sequence-encoder.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/unknown.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/vd-regions.js","webpack://bio/./node_modules/@datagrok-libraries/bio/src/viewers/web-logo.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/sequence-space.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/typed-metrics.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/viewers/activity-cliffs.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/workers/dimensionality-reducing-worker-creator.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/random.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/similarity-metrics.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/type-declarations.js","webpack://bio/./node_modules/@datagrok-libraries/utils/src/vector-operations.js","webpack://bio/./node_modules/fastest-levenshtein/index.js","webpack://bio/./node_modules/jaro-winkler-typescript/lib/index.js","webpack://bio/./src/seq_align.ts","webpack://bio/./src/utils/atomic-works.ts","webpack://bio/./src/utils/cell-renderer.ts","webpack://bio/./src/utils/constants.ts","webpack://bio/./src/utils/convert.ts","webpack://bio/./src/utils/multiple-sequence-alignment.ts","webpack://bio/./src/utils/notation-converter.ts","webpack://bio/./src/utils/sequence-activity-cliffs.ts","webpack://bio/./src/utils/sequence-space.ts","webpack://bio/./src/utils/utils.ts","webpack://bio/./src/viewers/vd-regions-viewer.ts","webpack://bio/./node_modules/wu/dist/wu.js","webpack://bio/external var \"DG\"","webpack://bio/external var \"grok\"","webpack://bio/external var \"rxjs\"","webpack://bio/external var \"ui\"","webpack://bio/webpack/bootstrap","webpack://bio/webpack/runtime/compat get default export","webpack://bio/webpack/runtime/define property getters","webpack://bio/webpack/runtime/get javascript chunk filename","webpack://bio/webpack/runtime/global","webpack://bio/webpack/runtime/hasOwnProperty shorthand","webpack://bio/webpack/runtime/make namespace object","webpack://bio/webpack/runtime/publicPath","webpack://bio/webpack/runtime/jsonp chunk loading","webpack://bio/./src/package.ts"],"sourcesContent":["(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n  typeof define === 'function' && define.amd ? define(factory) :\n  (global = global || self, global.Aioli = factory());\n}(this, (function () { 'use strict';\n\n  var name = \"@biowasm/aioli\";\n  var version = \"2.4.0-rc2\";\n  var description = \"A framework for building WebAssembly-based genomics tools\";\n  var browser = \"dist/aioli.js\";\n  var worker = \"dist/aioli.worker.js\";\n  var main = \"aioli.js\";\n  var repository = {\n  \ttype: \"git\",\n  \turl: \"git+https://github.com/biowasm/aioli.git\"\n  };\n  var author = \"Robert Aboukhalil\";\n  var license = \"MIT\";\n  var dependencies = {\n  \tcomlink: \"^4.3.1\",\n  \t\"wasm-feature-detect\": \"^1.2.11\"\n  };\n  var devDependencies = {\n  \t\"@rollup/plugin-commonjs\": \"^11.0.1\",\n  \t\"@rollup/plugin-json\": \"^4.1.0\",\n  \t\"@rollup/plugin-node-resolve\": \"^7.0.0\",\n  \tcypress: \"^8.0.0\",\n  \trollup: \"^1.29.0\",\n  \t\"rollup-plugin-terser\": \"^7.0.2\"\n  };\n  var scripts = {\n  \tbuild: \"rollup -c\",\n  \tdev: \"rollup -c -w\",\n  \ttest: \"cypress run\",\n  \t\"test-open\": \"cypress open\"\n  };\n  var files = [\n  \t\"dist\"\n  ];\n  var pkg = {\n  \tname: name,\n  \tversion: version,\n  \tdescription: description,\n  \tbrowser: browser,\n  \tworker: worker,\n  \tmain: main,\n  \trepository: repository,\n  \tauthor: author,\n  \tlicense: license,\n  \tdependencies: dependencies,\n  \tdevDependencies: devDependencies,\n  \tscripts: scripts,\n  \tfiles: files\n  };\n\n  /**\r\n   * Copyright 2019 Google Inc. All Rights Reserved.\r\n   * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n   * you may not use this file except in compliance with the License.\r\n   * You may obtain a copy of the License at\r\n   *     http://www.apache.org/licenses/LICENSE-2.0\r\n   * Unless required by applicable law or agreed to in writing, software\r\n   * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n   * See the License for the specific language governing permissions and\r\n   * limitations under the License.\r\n   */\r\n  const proxyMarker = Symbol(\"Comlink.proxy\");\r\n  const createEndpoint = Symbol(\"Comlink.endpoint\");\r\n  const releaseProxy = Symbol(\"Comlink.releaseProxy\");\r\n  const throwMarker = Symbol(\"Comlink.thrown\");\r\n  const isObject = (val) => (typeof val === \"object\" && val !== null) || typeof val === \"function\";\r\n  /**\r\n   * Internal transfer handle to handle objects marked to proxy.\r\n   */\r\n  const proxyTransferHandler = {\r\n      canHandle: (val) => isObject(val) && val[proxyMarker],\r\n      serialize(obj) {\r\n          const { port1, port2 } = new MessageChannel();\r\n          expose(obj, port1);\r\n          return [port2, [port2]];\r\n      },\r\n      deserialize(port) {\r\n          port.start();\r\n          return wrap(port);\r\n      },\r\n  };\r\n  /**\r\n   * Internal transfer handler to handle thrown exceptions.\r\n   */\r\n  const throwTransferHandler = {\r\n      canHandle: (value) => isObject(value) && throwMarker in value,\r\n      serialize({ value }) {\r\n          let serialized;\r\n          if (value instanceof Error) {\r\n              serialized = {\r\n                  isError: true,\r\n                  value: {\r\n                      message: value.message,\r\n                      name: value.name,\r\n                      stack: value.stack,\r\n                  },\r\n              };\r\n          }\r\n          else {\r\n              serialized = { isError: false, value };\r\n          }\r\n          return [serialized, []];\r\n      },\r\n      deserialize(serialized) {\r\n          if (serialized.isError) {\r\n              throw Object.assign(new Error(serialized.value.message), serialized.value);\r\n          }\r\n          throw serialized.value;\r\n      },\r\n  };\r\n  /**\r\n   * Allows customizing the serialization of certain values.\r\n   */\r\n  const transferHandlers = new Map([\r\n      [\"proxy\", proxyTransferHandler],\r\n      [\"throw\", throwTransferHandler],\r\n  ]);\r\n  function expose(obj, ep = self) {\r\n      ep.addEventListener(\"message\", function callback(ev) {\r\n          if (!ev || !ev.data) {\r\n              return;\r\n          }\r\n          const { id, type, path } = Object.assign({ path: [] }, ev.data);\r\n          const argumentList = (ev.data.argumentList || []).map(fromWireValue);\r\n          let returnValue;\r\n          try {\r\n              const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);\r\n              const rawValue = path.reduce((obj, prop) => obj[prop], obj);\r\n              switch (type) {\r\n                  case \"GET\" /* GET */:\r\n                      {\r\n                          returnValue = rawValue;\r\n                      }\r\n                      break;\r\n                  case \"SET\" /* SET */:\r\n                      {\r\n                          parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);\r\n                          returnValue = true;\r\n                      }\r\n                      break;\r\n                  case \"APPLY\" /* APPLY */:\r\n                      {\r\n                          returnValue = rawValue.apply(parent, argumentList);\r\n                      }\r\n                      break;\r\n                  case \"CONSTRUCT\" /* CONSTRUCT */:\r\n                      {\r\n                          const value = new rawValue(...argumentList);\r\n                          returnValue = proxy(value);\r\n                      }\r\n                      break;\r\n                  case \"ENDPOINT\" /* ENDPOINT */:\r\n                      {\r\n                          const { port1, port2 } = new MessageChannel();\r\n                          expose(obj, port2);\r\n                          returnValue = transfer(port1, [port1]);\r\n                      }\r\n                      break;\r\n                  case \"RELEASE\" /* RELEASE */:\r\n                      {\r\n                          returnValue = undefined;\r\n                      }\r\n                      break;\r\n                  default:\r\n                      return;\r\n              }\r\n          }\r\n          catch (value) {\r\n              returnValue = { value, [throwMarker]: 0 };\r\n          }\r\n          Promise.resolve(returnValue)\r\n              .catch((value) => {\r\n              return { value, [throwMarker]: 0 };\r\n          })\r\n              .then((returnValue) => {\r\n              const [wireValue, transferables] = toWireValue(returnValue);\r\n              ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);\r\n              if (type === \"RELEASE\" /* RELEASE */) {\r\n                  // detach and deactive after sending release response above.\r\n                  ep.removeEventListener(\"message\", callback);\r\n                  closeEndPoint(ep);\r\n              }\r\n          });\r\n      });\r\n      if (ep.start) {\r\n          ep.start();\r\n      }\r\n  }\r\n  function isMessagePort(endpoint) {\r\n      return endpoint.constructor.name === \"MessagePort\";\r\n  }\r\n  function closeEndPoint(endpoint) {\r\n      if (isMessagePort(endpoint))\r\n          endpoint.close();\r\n  }\r\n  function wrap(ep, target) {\r\n      return createProxy(ep, [], target);\r\n  }\r\n  function throwIfProxyReleased(isReleased) {\r\n      if (isReleased) {\r\n          throw new Error(\"Proxy has been released and is not useable\");\r\n      }\r\n  }\r\n  function createProxy(ep, path = [], target = function () { }) {\r\n      let isProxyReleased = false;\r\n      const proxy = new Proxy(target, {\r\n          get(_target, prop) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              if (prop === releaseProxy) {\r\n                  return () => {\r\n                      return requestResponseMessage(ep, {\r\n                          type: \"RELEASE\" /* RELEASE */,\r\n                          path: path.map((p) => p.toString()),\r\n                      }).then(() => {\r\n                          closeEndPoint(ep);\r\n                          isProxyReleased = true;\r\n                      });\r\n                  };\r\n              }\r\n              if (prop === \"then\") {\r\n                  if (path.length === 0) {\r\n                      return { then: () => proxy };\r\n                  }\r\n                  const r = requestResponseMessage(ep, {\r\n                      type: \"GET\" /* GET */,\r\n                      path: path.map((p) => p.toString()),\r\n                  }).then(fromWireValue);\r\n                  return r.then.bind(r);\r\n              }\r\n              return createProxy(ep, [...path, prop]);\r\n          },\r\n          set(_target, prop, rawValue) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              // FIXME: ES6 Proxy Handler `set` methods are supposed to return a\r\n              // boolean. To show good will, we return true asynchronously ¯\\_(ツ)_/¯\r\n              const [value, transferables] = toWireValue(rawValue);\r\n              return requestResponseMessage(ep, {\r\n                  type: \"SET\" /* SET */,\r\n                  path: [...path, prop].map((p) => p.toString()),\r\n                  value,\r\n              }, transferables).then(fromWireValue);\r\n          },\r\n          apply(_target, _thisArg, rawArgumentList) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              const last = path[path.length - 1];\r\n              if (last === createEndpoint) {\r\n                  return requestResponseMessage(ep, {\r\n                      type: \"ENDPOINT\" /* ENDPOINT */,\r\n                  }).then(fromWireValue);\r\n              }\r\n              // We just pretend that `bind()` didn’t happen.\r\n              if (last === \"bind\") {\r\n                  return createProxy(ep, path.slice(0, -1));\r\n              }\r\n              const [argumentList, transferables] = processArguments(rawArgumentList);\r\n              return requestResponseMessage(ep, {\r\n                  type: \"APPLY\" /* APPLY */,\r\n                  path: path.map((p) => p.toString()),\r\n                  argumentList,\r\n              }, transferables).then(fromWireValue);\r\n          },\r\n          construct(_target, rawArgumentList) {\r\n              throwIfProxyReleased(isProxyReleased);\r\n              const [argumentList, transferables] = processArguments(rawArgumentList);\r\n              return requestResponseMessage(ep, {\r\n                  type: \"CONSTRUCT\" /* CONSTRUCT */,\r\n                  path: path.map((p) => p.toString()),\r\n                  argumentList,\r\n              }, transferables).then(fromWireValue);\r\n          },\r\n      });\r\n      return proxy;\r\n  }\r\n  function myFlat(arr) {\r\n      return Array.prototype.concat.apply([], arr);\r\n  }\r\n  function processArguments(argumentList) {\r\n      const processed = argumentList.map(toWireValue);\r\n      return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];\r\n  }\r\n  const transferCache = new WeakMap();\r\n  function transfer(obj, transfers) {\r\n      transferCache.set(obj, transfers);\r\n      return obj;\r\n  }\r\n  function proxy(obj) {\r\n      return Object.assign(obj, { [proxyMarker]: true });\r\n  }\r\n  function toWireValue(value) {\r\n      for (const [name, handler] of transferHandlers) {\r\n          if (handler.canHandle(value)) {\r\n              const [serializedValue, transferables] = handler.serialize(value);\r\n              return [\r\n                  {\r\n                      type: \"HANDLER\" /* HANDLER */,\r\n                      name,\r\n                      value: serializedValue,\r\n                  },\r\n                  transferables,\r\n              ];\r\n          }\r\n      }\r\n      return [\r\n          {\r\n              type: \"RAW\" /* RAW */,\r\n              value,\r\n          },\r\n          transferCache.get(value) || [],\r\n      ];\r\n  }\r\n  function fromWireValue(value) {\r\n      switch (value.type) {\r\n          case \"HANDLER\" /* HANDLER */:\r\n              return transferHandlers.get(value.name).deserialize(value.value);\r\n          case \"RAW\" /* RAW */:\r\n              return value.value;\r\n      }\r\n  }\r\n  function requestResponseMessage(ep, msg, transfers) {\r\n      return new Promise((resolve) => {\r\n          const id = generateUUID();\r\n          ep.addEventListener(\"message\", function l(ev) {\r\n              if (!ev.data || !ev.data.id || ev.data.id !== id) {\r\n                  return;\r\n              }\r\n              ep.removeEventListener(\"message\", l);\r\n              resolve(ev.data);\r\n          });\r\n          if (ep.start) {\r\n              ep.start();\r\n          }\r\n          ep.postMessage(Object.assign({ id }, msg), transfers);\r\n      });\r\n  }\r\n  function generateUUID() {\r\n      return new Array(4)\r\n          .fill(0)\r\n          .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))\r\n          .join(\"-\");\r\n  }\n  //# sourceMappingURL=comlink.mjs.map\n\n  // Constants\n  const URL_CDN_ROOT = \"https://cdn.biowasm.com/v2\";\n  const CONFIG_DEFAULTS = {\n  \t// Biowasm CDN URLs\n  \turlCDN: URL_CDN_ROOT,\n  \t// Get the Worker code corresponding to the current Aioli version\n  \turlAioli: `${URL_CDN_ROOT}/aioli/${pkg.version}/aioli.worker.js`,\n  \t// Where we can find the base biowasm module (only modify this for local development)\n  \turlBaseModule: null,\n\n  \t// Folder to use for mounting the shared filesystem\n  \tdirShared: \"/shared\",\n  \t// Folder to use for mounting File/Blob objects to the virtual file system\n  \tdirMounted: \"/mnt\",\n  \t// Folder to use for symlinks (basically, we make a symlink to each file mounted on WORKERFS\n  \t// so that operations like \"samtools index\" don't crash due to the read-only nature of WORKERS).\n  \t// Also mount URLs lazily in that folder.\n  \tdirData: \"/data\",\n  \t// Interleave stdout/stderr. If set to false, `.exec()` returns an object { \"stdout\": <text>, \"stderr\": <text> }\n  \tprintInterleaved: true,\n\n  \t// Callback function to run whenever we receive a message from the WebWorker with payload { type: \"biowasm\", value: ... }.\n  \t// See <https://github.com/biowasm/biowasm/tree/main/tools/bhtsne> for an example of how this can be used to send regular updates\n  \t// back to the main thread before callMain() is done running.\n  \tcallback: null,\n\n  \t// Debugging\n  \tdebug: false,\n  \tenv: \"prd\"\n  };\n\n  // Class: 1 object = 1 worker; user can decide if they want tools running in separate threads or all of them in one\n  class Aioli\n  {\n  \tconstructor(tools, config={})\n  \t{\n  \t\tif(tools == null)\n  \t\t\tthrow \"Expecting array of tools as input to Aioli constructor.\";\n\n  \t\t// Parse user input\n  \t\tif(!Array.isArray(tools))\n  \t\t\ttools = [ tools ];\n  \t\t// Overwrite default config if specified\n  \t\tconfig = Object.assign({}, CONFIG_DEFAULTS, config);\n  \t\t// For convenience, support \"<tool>/<version>\" or \"<tool>/<program>/<version>\" instead of object config\n  \t\ttools = tools.map(this._parseTool);\n  \t\t// If testing with different environment e.g. cdn-stg.biowasm.com\n  \t\tif(config.env != \"prd\") {\n  \t\t\tconfig.urlCDN = config.urlCDN.replace(\"cdn\", `cdn-${config.env}`);\n  \t\t\tconfig.urlAioli = config.urlAioli.replace(\"cdn\", `cdn-${config.env}`);\n  \t\t}\n\n  \t\t// Add biowasm base module to list of tools to initialize (need this for the shared virtual filesystem)\n  \t\ttools = [{\n  \t\t\ttool: \"base\",\n  \t\t\tversion: pkg.version,\n  \t\t\turlPrefix: config.urlBaseModule\n  \t\t}, ...tools];\n\n  \t\t// Set state\n  \t\tthis.tools = tools;\n  \t\tthis.config = config;\n\n  \t\t// Handle callback (delete it because we can't send a function to the WebWorker)\n  \t\tif(this.config.callback != null)\n  \t\t\tthis.callback = this.config.callback;\n  \t\tdelete this.config.callback;\n\n  \t\treturn this.init();\n  \t}\n\n  \t// Initialize the WebWorker and the WebAssembly modules within it\n  \tasync init() {\n  \t\t// Note: We can only create a WebWorker using a URL that has the same origin as the app running it, i.e. we\n  \t\t// can't do `new Worker(\"https://cdn.biowasm.com/v2/...\")`, so instead we need to fetch the contents of that\n  \t\t// URL first, and then create the WebWorker. See <https://stackoverflow.com/a/60015898>.\n  \t\tconst moduleJS = await (await fetch(this.config.urlAioli)).text();\n  \t\tconst moduleBlob = new Blob([moduleJS], { type: \"application/javascript\" });\n\n  \t\t// Create the WebWorker\n  \t\tconst worker = new Worker(URL.createObjectURL(moduleBlob));\n  \t\t// Listen for \"biowasm\" messages from the WebWorker\n  \t\tif(this.callback)\n  \t\t\tworker.onmessage = e => {\n  \t\t\t\tif(e.data.type == \"biowasm\")\n  \t\t\t\t\tthis.callback(e.data.value);\n  \t\t\t};\n\n  \t\tconst aioli = wrap(worker);\n  \t\taioli.tools = this.tools;\n  \t\taioli.config = this.config;\n\n  \t\t// Initialize the tools inside the WebWorker\n  \t\tawait aioli.init();\n\n  \t\treturn aioli;\n  \t}\n\n  \t// Parse \"<tool>/<version>\" and \"<tool>/<program>/<version>\" into { \"tool\": <tool>, \"program\": <program>, \"version\": <version> }\n  \t_parseTool(tool)\n  \t{\n  \t\t// If not a string, leave it as is\n  \t\tif(typeof tool !== \"string\")\n  \t\t\treturn tool;\n\n  \t\t// Support \"<tool>/<version>\" and \"<tool>/<program>/<version>\"\n  \t\tconst toolSplit = tool.split(\"/\");\n  \t\tif(toolSplit.length != 2 && toolSplit.length != 3)\n  \t\t\tthrow \"Expecting '<tool>/<version>' or '<tool>/<program>/<version>'\";\n\n  \t\treturn {\n  \t\t\ttool: toolSplit[0],\n  \t\t\tprogram: toolSplit.length == 3 ? toolSplit[1] : toolSplit[0],\n  \t\t\tversion: toolSplit[toolSplit.length - 1]\n  \t\t};\n  \t}\n  }\n\n  return Aioli;\n\n})));\n//# sourceMappingURL=aioli.js.map\n","import { SeqPaletteBase } from './seq-palettes';\nexport class AminoacidsPalettes extends SeqPaletteBase {\n    static get Lesk() {\n        if (this.lesk === void 0) {\n            this.lesk = this.makePalette([\n                [['G', 'A', 'S', 'T'], 'orange'],\n                [['C', 'V', 'I', 'L', 'P', 'F', 'Y', 'M', 'W'], 'all_green'],\n                [['N', 'Q', 'H'], 'magenta'],\n                [['D', 'E'], 'red'],\n                [['K', 'R'], 'all_blue'],\n            ], false, AminoacidsPalettes);\n        }\n        return this.lesk;\n    }\n    static get GrokGroups() {\n        if (this.grokGroups === void 0) {\n            this.grokGroups = this.makePalette([\n                [['C', 'U'], 'yellow'],\n                [['G', 'P'], 'red'],\n                [['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'], 'all_green'],\n                [['R', 'H', 'K'], 'light_blue'],\n                [['D', 'E'], 'dark_blue'],\n                [['S', 'T', 'N', 'Q'], 'orange'],\n            ], false, AminoacidsPalettes);\n        }\n        return this.grokGroups;\n    }\n    static get RasMol() {\n        if (this.rasMol === void 0) {\n            this.rasMol = new AminoacidsPalettes({\n                // http://acces.ens-lyon.fr/biotic/rastop/help/colour.htm\n                'D': '#E60A0A',\n                'E': '#E60A0A',\n                'C': '#E6E600',\n                'M': '#E6E600',\n                'K': '#145AFF',\n                'R': '#145AFF',\n                'S': '#FA9600',\n                'T': '#FA9600',\n                'F': '#3232AA',\n                'Y': '#3232AA',\n                'N': '#00DCDC',\n                'Q': '#00DCDC',\n                'G': '#EBEBEB',\n                'L': '#0F820F',\n                'V': '#0F820F',\n                'I': '#0F820F',\n                'A': '#C8C8C8',\n                'W': '#B45AB4',\n                'H': '#8282D2',\n                'P': '#DC9682',\n                'others': '#BEA06E',\n            });\n        }\n        return this.rasMol;\n    }\n}\nexport class Aminoacids {\n    static getPalette(scheme = 'grok') {\n        switch (scheme) {\n            case 'grok':\n                return AminoacidsPalettes.GrokGroups;\n            case 'lesk':\n                return AminoacidsPalettes.Lesk;\n            default:\n                throw new Error(`ChemPalette: scheme \\`${scheme}\\` does not exist`);\n        }\n    }\n    /**\n     * Returns divided amino acid with its content in the bracket, if the content is number, then its omitted\n     *\n     * @param {string} c raw amino\n     * @return {[string, string]} outer and inner content\n     */\n    static getInnerOuter(c) {\n        let isInner = 0;\n        let inner = '';\n        let outer = '';\n        for (const char of c) {\n            if (char == '(')\n                isInner++;\n            else if (char == ')')\n                isInner--;\n            else if (isInner)\n                inner += char;\n            else\n                outer += char;\n        }\n        return !isNaN(parseInt(inner)) ? [outer, ''] : [outer, inner];\n    }\n    static getColorAAPivot(monomer = '', scheme = 'grok') {\n        var _a, _b, _c;\n        //const chemPaletteInstance = AAPalettes.GrokGroups();\n        const chemPaletteInstance = this.getPalette(scheme);\n        let [outerMonomer, innerMonomer] = this.getInnerOuter(monomer);\n        outerMonomer = (outerMonomer.length > 6 ? `${outerMonomer.slice(0, 3)}...` : outerMonomer);\n        innerMonomer = (innerMonomer.length > 6 ? `${innerMonomer.slice(0, 3)}...` : innerMonomer);\n        if (monomer.length == 1 || monomer[1] == '(') {\n            const amino = (_a = monomer[0]) === null || _a === void 0 ? void 0 : _a.toUpperCase();\n            return amino in chemPaletteInstance ?\n                [chemPaletteInstance.get(amino), amino, innerMonomer, 1] :\n                [this.undefinedColor, outerMonomer, innerMonomer, 1];\n        }\n        if (monomer[0] == 'd' && monomer[1] in chemPaletteInstance) {\n            if (monomer.length == 2 || monomer[2] == '(') {\n                const amino = (_b = monomer[1]) === null || _b === void 0 ? void 0 : _b.toUpperCase();\n                return amino in chemPaletteInstance ?\n                    [chemPaletteInstance.get(amino), amino, innerMonomer, 2] :\n                    [this.undefinedColor, outerMonomer, innerMonomer, 2];\n            }\n        }\n        if (monomer.substring(0, 3) in this.AAFullNames) {\n            if (monomer.length == 3 || monomer[3] == '(') {\n                const amino = this.AAFullNames[monomer.substring(0, 3)];\n                return amino in chemPaletteInstance ?\n                    [chemPaletteInstance.get(amino), amino, innerMonomer, 3] :\n                    [this.undefinedColor, outerMonomer, innerMonomer, 3];\n            }\n        }\n        if (((_c = monomer[0]) === null || _c === void 0 ? void 0 : _c.toLowerCase()) == monomer[0]) {\n            if (monomer.substring(1, 3) in this.AAFullNames) {\n                if (monomer.length == 4 || monomer[4] == '(') {\n                    const amino = this.AAFullNames[monomer.substring(1, 3)];\n                    return amino in chemPaletteInstance ?\n                        [chemPaletteInstance.get(amino), amino, innerMonomer, 4] :\n                        [this.undefinedColor, outerMonomer, innerMonomer, 4];\n                }\n            }\n        }\n        return [this.undefinedColor, outerMonomer, innerMonomer, 0];\n    }\n}\nAminoacids.SemType = 'Aminoacids';\nAminoacids.SemTypeMultipleAlignment = 'AminoacidsMultipleAlignment';\nAminoacids.undefinedColor = 'rgb(100,100,100)';\nAminoacids.Names = {\n    'G': 'Glycine',\n    'L': 'Leucine',\n    'Y': 'Tyrosine',\n    'S': 'Serine',\n    'E': 'Glutamic acid',\n    'Q': 'Glutamine',\n    'D': 'Aspartic acid',\n    'N': 'Asparagine',\n    'F': 'Phenylalanine',\n    'A': 'Alanine',\n    'K': 'Lysine',\n    'R': 'Arginine',\n    'H': 'Histidine',\n    'C': 'Cysteine',\n    'V': 'Valine',\n    'P': 'Proline',\n    'W': 'Tryptophan',\n    'I': 'Isoleucine',\n    'M': 'Methionine',\n    'T': 'Threonine',\n};\nAminoacids.AASmiles = {\n    'G': 'NCC(=O)O',\n    'L': 'N[C@H](CC(C)C)C(=O)O',\n    'Y': 'NC(CC1=CC=C(O)C=C1)C(=O)O',\n    'S': 'NC(CO)C(=O)O',\n    'E': 'N[C@@H](CCC(O)=O)C(=O)O',\n    'Q': 'N[C@@H](CCC(N)=O)C(=O)O',\n    'D': 'N[C@@H](CC(O)=O)C(=O)O',\n    'N': 'N[C@@H](CC(N)=O)C(=O)O',\n    'F': 'NC(CC1=CC=CC=C1)C(=O)O',\n    'A': 'N[C@H](C)C(=O)O',\n    'K': 'NC(CCCCN)C(=O)O',\n    'R': 'N[C@H](CCCNC(=N)C)C(=O)O',\n    'H': 'NC(CC1=CN=C[N]1)C(=O)O',\n    'C': 'N[C@@H](CS)C(=O)O',\n    'V': 'NC(C(C)C)C(=O)O',\n    'P': 'N(CCC1)C1C(=O)O',\n    'W': 'N[C@@H](Cc1c2ccccc2n([H])c1)C(=O)O',\n    'I': 'N[C@H]([C@H](C)CC)C(=O)O',\n    'M': 'NC(CCSC)C(=O)O',\n    'T': 'NC(C(O)C)C(=O)O',\n};\nAminoacids.AASmilesTruncated = {\n    'G': '*C*',\n    'L': 'CC(C)C[C@H](*)*',\n    'Y': 'C1=CC(=CC=C1CC(*)*)O',\n    'S': 'OCC(*)C*',\n    'E': '*[C@@H](CCC(O)=O)*',\n    'Q': '*N[C@@H](CCC(N)=O)*',\n    'D': '*[C@@H](CC(O)=O)*',\n    'N': '*[C@@H](CC(N)=O)*',\n    'F': 'C1=CC=C(C=C1)CC(*)*',\n    'A': 'C[C@H](*)*',\n    'K': 'C(CCN)CC(*)*',\n    'R': '*[C@H](CCCNC(=N)C)*',\n    'H': 'C1=C(NC=N1)CC(*)*',\n    'C': 'C([C@@H](*)*)S',\n    'V': 'CC(C)C(*)*',\n    'P': 'C1CCN(*)C1*',\n    'W': '*[C@@H](Cc1c2ccccc2n([H])c1)*',\n    'I': 'CC[C@H](C)[C@H](*)*',\n    'M': 'CSCCC(*)*',\n    'T': 'CC(O)C(*)*',\n};\n/** TODO: Full?\n */\nAminoacids.AAFullNames = {\n    'Ala': 'A',\n    'Arg': 'R',\n    'Asn': 'N',\n    'Asp': 'D',\n    'Cys': 'C',\n    'Gln': 'Q',\n    'Glu': 'E',\n    'Gly': 'G',\n    'His': 'H',\n    'Ile': 'I',\n    'Leu': 'L',\n    'Lys': 'K',\n    'Met': 'M',\n    'Phe': 'F',\n    'Pro': 'P',\n    'Ser': 'S',\n    'Thr': 'T',\n    'Trp': 'W',\n    'Tyr': 'Y',\n    'Val': 'V',\n};\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aminoacids.js","sourceRoot":"","sources":["aminoacids.ts"],"names":[],"mappings":"AAKA,OAAO,EAAa,cAAc,EAAC,MAAM,gBAAgB,CAAC;AAE1D,MAAM,OAAO,kBAAmB,SAAQ,cAAc;IAG7C,MAAM,KAAK,IAAI;QACpB,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,EAAE;YACxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC;gBAC3B,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,QAAQ,CAAC;gBAChC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,WAAW,CAAC;gBAC5D,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,SAAS,CAAC;gBAC5B,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,KAAK,CAAC;gBACnB,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,UAAU,CAAC;aACzB,EAAE,KAAK,EAAE,kBAAkB,CAAC,CAAC;SAC/B;QACD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAIM,MAAM,KAAK,UAAU;QAC1B,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,CAAC,EAAE;YAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC;gBACjC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,QAAQ,CAAC;gBACtB,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,KAAK,CAAC;gBACnB,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,WAAW,CAAC;gBACvD,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,YAAY,CAAC;gBAC/B,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,WAAW,CAAC;gBACzB,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,QAAQ,CAAC;aACjC,EAAE,KAAK,EAAE,kBAAkB,CAAC,CAAC;SAC/B;QACD,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAIM,MAAM,KAAK,MAAM;QACtB,IAAI,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,EAAE;YAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,kBAAkB,CAAC;gBACnC,yDAAyD;gBACzD,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,GAAG,EAAE,SAAS;gBACd,QAAQ,EAAE,SAAS;aACpB,CAAC,CAAC;SACJ;QACD,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF;AAED,MAAM,OAAO,UAAU;IAqGd,MAAM,CAAC,UAAU,CAAC,SAAiB,MAAM;QAC9C,QAAQ,MAAM,EAAE;YAChB,KAAK,MAAM;gBACT,OAAO,kBAAkB,CAAC,UAAU,CAAC;YACvC,KAAK,MAAM;gBACT,OAAO,kBAAkB,CAAC,IAAI,CAAC;YACjC;gBACE,MAAM,IAAI,KAAK,CAAC,yBAAyB,MAAM,mBAAmB,CAAC,CAAC;SACrE;IACH,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,aAAa,CAAC,CAAS;QACnC,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,IAAI,KAAK,GAAG,EAAE,CAAC;QACf,IAAI,KAAK,GAAG,EAAE,CAAC;QAEf,KAAK,MAAM,IAAI,IAAI,CAAC,EAAE;YACpB,IAAI,IAAI,IAAI,GAAG;gBACb,OAAO,EAAE,CAAC;iBACP,IAAI,IAAI,IAAI,GAAG;gBAClB,OAAO,EAAE,CAAC;iBACP,IAAI,OAAO;gBACd,KAAK,IAAI,IAAI,CAAC;;gBAEd,KAAK,IAAI,IAAI,CAAC;SACjB;QAED,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAChE,CAAC;IAEM,MAAM,CAAC,eAAe,CAAC,UAAkB,EAAE,EAAE,SAAiB,MAAM;;QACzE,sDAAsD;QACtD,MAAM,mBAAmB,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACpD,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC/D,YAAY,GAAG,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;QAC3F,YAAY,GAAG,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;QAE3F,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;YAC5C,MAAM,KAAK,GAAG,MAAA,OAAO,CAAC,CAAC,CAAC,0CAAE,WAAW,EAAG,CAAC;YACzC,OAAO,KAAK,IAAI,mBAAmB,CAAC,CAAC;gBACnC,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;gBAC1D,CAAC,IAAI,CAAC,cAAc,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;SACxD;QAED,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,OAAO,CAAC,CAAC,CAAE,IAAI,mBAAmB,EAAE;YAC3D,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;gBAC5C,MAAM,KAAK,GAAG,MAAA,OAAO,CAAC,CAAC,CAAC,0CAAE,WAAW,EAAG,CAAC;gBACzC,OAAO,KAAK,IAAI,mBAAmB,CAAC,CAAC;oBACnC,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;oBAC1D,CAAC,IAAI,CAAC,cAAc,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;aACxD;SACF;QAED,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE;YAC/C,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;gBAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;gBACxD,OAAO,KAAK,IAAI,mBAAmB,CAAC,CAAC;oBACnC,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;oBAC1D,CAAC,IAAI,CAAC,cAAc,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;aACxD;SACF;QAED,IAAI,CAAA,MAAA,OAAO,CAAC,CAAC,CAAC,0CAAE,WAAW,EAAE,KAAI,OAAO,CAAC,CAAC,CAAC,EAAE;YAC3C,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE;gBAC/C,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;oBAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;oBACxD,OAAO,KAAK,IAAI,mBAAmB,CAAC,CAAC;wBACnC,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;wBAC1D,CAAC,IAAI,CAAC,cAAc,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;iBACxD;aACF;SACF;QAED,OAAO,CAAC,IAAI,CAAC,cAAc,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;IAC9D,CAAC;;AApLe,kBAAO,GAAW,YAAY,CAAC;AAE/B,mCAAwB,GAAW,6BAA6B,CAAC;AAE1E,yBAAc,GAAG,kBAAkB,CAAC;AAE7B,gBAAK,GAAqB;IACtC,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,UAAU;IACf,GAAG,EAAE,QAAQ;IACb,GAAG,EAAE,eAAe;IACpB,GAAG,EAAE,WAAW;IAChB,GAAG,EAAE,eAAe;IACpB,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,eAAe;IACpB,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,QAAQ;IACb,GAAG,EAAE,UAAU;IACf,GAAG,EAAE,WAAW;IAChB,GAAG,EAAE,UAAU;IACf,GAAG,EAAE,QAAQ;IACb,GAAG,EAAE,SAAS;IACd,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,WAAW;CACjB,CAAC;AAEY,mBAAQ,GAAqB;IACzC,GAAG,EAAE,UAAU;IACf,GAAG,EAAE,sBAAsB;IAC3B,GAAG,EAAE,2BAA2B;IAChC,GAAG,EAAE,cAAc;IACnB,GAAG,EAAE,yBAAyB;IAC9B,GAAG,EAAE,yBAAyB;IAC9B,GAAG,EAAE,wBAAwB;IAC7B,GAAG,EAAE,wBAAwB;IAC7B,GAAG,EAAE,wBAAwB;IAC7B,GAAG,EAAE,iBAAiB;IACtB,GAAG,EAAE,iBAAiB;IACtB,GAAG,EAAE,0BAA0B;IAC/B,GAAG,EAAE,wBAAwB;IAC7B,GAAG,EAAE,mBAAmB;IACxB,GAAG,EAAE,iBAAiB;IACtB,GAAG,EAAE,iBAAiB;IACtB,GAAG,EAAE,oCAAoC;IACzC,GAAG,EAAE,0BAA0B;IAC/B,GAAG,EAAE,gBAAgB;IACrB,GAAG,EAAE,iBAAiB;CACvB,CAAC;AAEY,4BAAiB,GAAqB;IAClD,GAAG,EAAE,KAAK;IACV,GAAG,EAAE,iBAAiB;IACtB,GAAG,EAAE,sBAAsB;IAC3B,GAAG,EAAE,UAAU;IACf,GAAG,EAAE,oBAAoB;IACzB,GAAG,EAAE,qBAAqB;IAC1B,GAAG,EAAE,mBAAmB;IACxB,GAAG,EAAE,mBAAmB;IACxB,GAAG,EAAE,qBAAqB;IAC1B,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,cAAc;IACnB,GAAG,EAAE,qBAAqB;IAC1B,GAAG,EAAE,mBAAmB;IACxB,GAAG,EAAE,gBAAgB;IACrB,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,aAAa;IAClB,GAAG,EAAE,+BAA+B;IACpC,GAAG,EAAE,qBAAqB;IAC1B,GAAG,EAAE,WAAW;IAChB,GAAG,EAAE,YAAY;CAClB,CAAC;AAEF;GACG;AACW,sBAAW,GAAqB;IAC5C,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;IACV,KAAK,EAAE,GAAG;CACX,CAAC","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n\nimport {StringDictionary} from '@datagrok-libraries/utils/src/type-declarations';\nimport {SeqPalette, SeqPaletteBase} from './seq-palettes';\n\nexport class AminoacidsPalettes extends SeqPaletteBase {\n  private static lesk: SeqPalette;\n\n  public static get Lesk(): SeqPalette {\n    if (this.lesk === void 0) {\n      this.lesk = this.makePalette([\n        [['G', 'A', 'S', 'T'], 'orange'],\n        [['C', 'V', 'I', 'L', 'P', 'F', 'Y', 'M', 'W'], 'all_green'],\n        [['N', 'Q', 'H'], 'magenta'],\n        [['D', 'E'], 'red'],\n        [['K', 'R'], 'all_blue'],\n      ], false, AminoacidsPalettes);\n    }\n    return this.lesk;\n  }\n\n  private static grokGroups: SeqPalette;\n\n  public static get GrokGroups(): SeqPalette {\n    if (this.grokGroups === void 0) {\n      this.grokGroups = this.makePalette([\n        [['C', 'U'], 'yellow'],\n        [['G', 'P'], 'red'],\n        [['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'], 'all_green'],\n        [['R', 'H', 'K'], 'light_blue'],\n        [['D', 'E'], 'dark_blue'],\n        [['S', 'T', 'N', 'Q'], 'orange'],\n      ], false, AminoacidsPalettes);\n    }\n    return this.grokGroups;\n  }\n\n  private static rasMol: SeqPalette;\n\n  public static get RasMol(): SeqPalette {\n    if (this.rasMol === void 0) {\n      this.rasMol = new AminoacidsPalettes({\n        // http://acces.ens-lyon.fr/biotic/rastop/help/colour.htm\n        'D': '#E60A0A', // asp, aspartic acid, asp\n        'E': '#E60A0A', // glu, glutamic acid\n        'C': '#E6E600', // cys, cysteine\n        'M': '#E6E600', // met, methionine\n        'K': '#145AFF', // lys, lysine\n        'R': '#145AFF', // arg, arginine\n        'S': '#FA9600', // ser, serine\n        'T': '#FA9600', // thr, threonine\n        'F': '#3232AA', // phe, phenylalanine\n        'Y': '#3232AA', // tyr, tyrosine\n        'N': '#00DCDC', // asn, asparagine\n        'Q': '#00DCDC', // gln, glutamine\n        'G': '#EBEBEB', // gly, glycine\n        'L': '#0F820F', // leu, leucine\n        'V': '#0F820F', // val, valine\n        'I': '#0F820F', // ile, isoleucine\n        'A': '#C8C8C8', // ala, alanine\n        'W': '#B45AB4', // trp, tryptophan\n        'H': '#8282D2', // his, histidine\n        'P': '#DC9682', // pro, proline\n        'others': '#BEA06E',\n      });\n    }\n    return this.rasMol;\n  }\n}\n\nexport class Aminoacids {\n  static readonly SemType: string = 'Aminoacids';\n\n  static readonly SemTypeMultipleAlignment: string = 'AminoacidsMultipleAlignment';\n\n  static undefinedColor = 'rgb(100,100,100)';\n\n  public static Names: StringDictionary = {\n    'G': 'Glycine',\n    'L': 'Leucine',\n    'Y': 'Tyrosine',\n    'S': 'Serine',\n    'E': 'Glutamic acid',\n    'Q': 'Glutamine',\n    'D': 'Aspartic acid',\n    'N': 'Asparagine',\n    'F': 'Phenylalanine',\n    'A': 'Alanine',\n    'K': 'Lysine',\n    'R': 'Arginine',\n    'H': 'Histidine',\n    'C': 'Cysteine',\n    'V': 'Valine',\n    'P': 'Proline',\n    'W': 'Tryptophan',\n    'I': 'Isoleucine',\n    'M': 'Methionine',\n    'T': 'Threonine',\n  };\n\n  public static AASmiles: StringDictionary = {\n    'G': 'NCC(=O)O',\n    'L': 'N[C@H](CC(C)C)C(=O)O',\n    'Y': 'NC(CC1=CC=C(O)C=C1)C(=O)O',\n    'S': 'NC(CO)C(=O)O',\n    'E': 'N[C@@H](CCC(O)=O)C(=O)O',\n    'Q': 'N[C@@H](CCC(N)=O)C(=O)O',\n    'D': 'N[C@@H](CC(O)=O)C(=O)O',\n    'N': 'N[C@@H](CC(N)=O)C(=O)O',\n    'F': 'NC(CC1=CC=CC=C1)C(=O)O',\n    'A': 'N[C@H](C)C(=O)O',\n    'K': 'NC(CCCCN)C(=O)O',\n    'R': 'N[C@H](CCCNC(=N)C)C(=O)O',\n    'H': 'NC(CC1=CN=C[N]1)C(=O)O',\n    'C': 'N[C@@H](CS)C(=O)O',\n    'V': 'NC(C(C)C)C(=O)O',\n    'P': 'N(CCC1)C1C(=O)O',\n    'W': 'N[C@@H](Cc1c2ccccc2n([H])c1)C(=O)O',\n    'I': 'N[C@H]([C@H](C)CC)C(=O)O',\n    'M': 'NC(CCSC)C(=O)O',\n    'T': 'NC(C(O)C)C(=O)O',\n  };\n\n  public static AASmilesTruncated: StringDictionary = {\n    'G': '*C*',\n    'L': 'CC(C)C[C@H](*)*',\n    'Y': 'C1=CC(=CC=C1CC(*)*)O',\n    'S': 'OCC(*)C*',\n    'E': '*[C@@H](CCC(O)=O)*',\n    'Q': '*N[C@@H](CCC(N)=O)*',\n    'D': '*[C@@H](CC(O)=O)*',\n    'N': '*[C@@H](CC(N)=O)*',\n    'F': 'C1=CC=C(C=C1)CC(*)*',\n    'A': 'C[C@H](*)*',\n    'K': 'C(CCN)CC(*)*',\n    'R': '*[C@H](CCCNC(=N)C)*',\n    'H': 'C1=C(NC=N1)CC(*)*',\n    'C': 'C([C@@H](*)*)S',\n    'V': 'CC(C)C(*)*',\n    'P': 'C1CCN(*)C1*',\n    'W': '*[C@@H](Cc1c2ccccc2n([H])c1)*',\n    'I': 'CC[C@H](C)[C@H](*)*',\n    'M': 'CSCCC(*)*',\n    'T': 'CC(O)C(*)*',\n  };\n\n  /** TODO: Full?\n   */\n  public static AAFullNames: StringDictionary = {\n    'Ala': 'A',\n    'Arg': 'R',\n    'Asn': 'N',\n    'Asp': 'D',\n    'Cys': 'C',\n    'Gln': 'Q',\n    'Glu': 'E',\n    'Gly': 'G',\n    'His': 'H',\n    'Ile': 'I',\n    'Leu': 'L',\n    'Lys': 'K',\n    'Met': 'M',\n    'Phe': 'F',\n    'Pro': 'P',\n    'Ser': 'S',\n    'Thr': 'T',\n    'Trp': 'W',\n    'Tyr': 'Y',\n    'Val': 'V',\n  };\n\n  public static getPalette(scheme: string = 'grok'): SeqPalette {\n    switch (scheme) {\n    case 'grok':\n      return AminoacidsPalettes.GrokGroups;\n    case 'lesk':\n      return AminoacidsPalettes.Lesk;\n    default:\n      throw new Error(`ChemPalette: scheme \\`${scheme}\\` does not exist`);\n    }\n  }\n\n  /**\n   * Returns divided amino acid with its content in the bracket, if the content is number, then its omitted\n   *\n   * @param {string} c raw amino\n   * @return {[string, string]} outer and inner content\n   */\n  public static getInnerOuter(c: string): [string, string] {\n    let isInner = 0;\n    let inner = '';\n    let outer = '';\n\n    for (const char of c) {\n      if (char == '(')\n        isInner++;\n      else if (char == ')')\n        isInner--;\n      else if (isInner)\n        inner += char;\n      else\n        outer += char;\n    }\n\n    return !isNaN(parseInt(inner)) ? [outer, ''] : [outer, inner];\n  }\n\n  public static getColorAAPivot(monomer: string = '', scheme: 'grok' = 'grok'): [string, string, string, number] {\n    //const chemPaletteInstance = AAPalettes.GrokGroups();\n    const chemPaletteInstance = this.getPalette(scheme);\n    let [outerMonomer, innerMonomer] = this.getInnerOuter(monomer);\n    outerMonomer = (outerMonomer.length > 6 ? `${outerMonomer.slice(0, 3)}...` : outerMonomer);\n    innerMonomer = (innerMonomer.length > 6 ? `${innerMonomer.slice(0, 3)}...` : innerMonomer);\n\n    if (monomer.length == 1 || monomer[1] == '(') {\n      const amino = monomer[0]?.toUpperCase()!;\n      return amino in chemPaletteInstance ?\n        [chemPaletteInstance.get(amino), amino, innerMonomer, 1] :\n        [this.undefinedColor, outerMonomer, innerMonomer, 1];\n    }\n\n    if (monomer[0] == 'd' && monomer[1]! in chemPaletteInstance) {\n      if (monomer.length == 2 || monomer[2] == '(') {\n        const amino = monomer[1]?.toUpperCase()!;\n        return amino in chemPaletteInstance ?\n          [chemPaletteInstance.get(amino), amino, innerMonomer, 2] :\n          [this.undefinedColor, outerMonomer, innerMonomer, 2];\n      }\n    }\n\n    if (monomer.substring(0, 3) in this.AAFullNames) {\n      if (monomer.length == 3 || monomer[3] == '(') {\n        const amino = this.AAFullNames[monomer.substring(0, 3)];\n        return amino in chemPaletteInstance ?\n          [chemPaletteInstance.get(amino), amino, innerMonomer, 3] :\n          [this.undefinedColor, outerMonomer, innerMonomer, 3];\n      }\n    }\n\n    if (monomer[0]?.toLowerCase() == monomer[0]) {\n      if (monomer.substring(1, 3) in this.AAFullNames) {\n        if (monomer.length == 4 || monomer[4] == '(') {\n          const amino = this.AAFullNames[monomer.substring(1, 3)];\n          return amino in chemPaletteInstance ?\n            [chemPaletteInstance.get(amino), amino, innerMonomer, 4] :\n            [this.undefinedColor, outerMonomer, innerMonomer, 4];\n        }\n      }\n    }\n\n    return [this.undefinedColor, outerMonomer, innerMonomer, 0];\n  }\n}\n"]}","import { SeqPaletteBase } from './seq-palettes';\nexport class NucleotidesPalettes extends SeqPaletteBase {\n    static get Chromatogram() {\n        if (this.chromatogram === void 0) {\n            this.chromatogram = new NucleotidesPalettes({\n                'A': 'green',\n                'C': 'blue',\n                'G': 'black',\n                'T': 'red', 'U': 'red',\n                'others': 'gray',\n            });\n        }\n        return this.chromatogram;\n    }\n}\nexport class Nucleotides {\n}\nNucleotides.SemType = 'Nucleotides';\nNucleotides.SemTypeMultipleAlignment = 'NucleotidesMultipleAlignment';\nNucleotides.Names = {\n    'A': 'Adenine',\n    'C': 'Cytosine',\n    'G': 'Guanine',\n    'T': 'Thymine',\n    'U': 'Uracil',\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVjbGVvdGlkZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJudWNsZW90aWRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxPQUFPLEVBQWEsY0FBYyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFMUQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGNBQWM7SUFHOUMsTUFBTSxLQUFLLFlBQVk7UUFDNUIsSUFBSSxJQUFJLENBQUMsWUFBWSxLQUFLLEtBQUssQ0FBQyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxtQkFBbUIsQ0FBQztnQkFDMUMsR0FBRyxFQUFFLE9BQU87Z0JBQ1osR0FBRyxFQUFFLE1BQU07Z0JBQ1gsR0FBRyxFQUFFLE9BQU87Z0JBQ1osR0FBRyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsS0FBSztnQkFDdEIsUUFBUSxFQUFFLE1BQU07YUFDakIsQ0FBQyxDQUFDO1NBQ0o7UUFDRCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLFdBQVc7O0FBQ04sbUJBQU8sR0FBVyxhQUFhLENBQUM7QUFFaEMsb0NBQXdCLEdBQVcsOEJBQThCLENBQUM7QUFFcEUsaUJBQUssR0FBcUI7SUFDdEMsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsVUFBVTtJQUNmLEdBQUcsRUFBRSxTQUFTO0lBQ2QsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsUUFBUTtDQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBncm9rIGZyb20gJ2RhdGFncm9rLWFwaS9ncm9rJztcbmltcG9ydCAqIGFzIHVpIGZyb20gJ2RhdGFncm9rLWFwaS91aSc7XG5pbXBvcnQgKiBhcyBERyBmcm9tICdkYXRhZ3Jvay1hcGkvZGcnO1xuXG5pbXBvcnQge1N0cmluZ0RpY3Rpb25hcnl9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3R5cGUtZGVjbGFyYXRpb25zJztcbmltcG9ydCB7U2VxUGFsZXR0ZSwgU2VxUGFsZXR0ZUJhc2V9IGZyb20gJy4vc2VxLXBhbGV0dGVzJztcblxuZXhwb3J0IGNsYXNzIE51Y2xlb3RpZGVzUGFsZXR0ZXMgZXh0ZW5kcyBTZXFQYWxldHRlQmFzZSB7XG4gIHByaXZhdGUgc3RhdGljIGNocm9tYXRvZ3JhbTogU2VxUGFsZXR0ZTtcblxuICBwdWJsaWMgc3RhdGljIGdldCBDaHJvbWF0b2dyYW0oKTogU2VxUGFsZXR0ZSB7XG4gICAgaWYgKHRoaXMuY2hyb21hdG9ncmFtID09PSB2b2lkIDApIHtcbiAgICAgIHRoaXMuY2hyb21hdG9ncmFtID0gbmV3IE51Y2xlb3RpZGVzUGFsZXR0ZXMoe1xuICAgICAgICAnQSc6ICdncmVlbicsXG4gICAgICAgICdDJzogJ2JsdWUnLFxuICAgICAgICAnRyc6ICdibGFjaycsIC8vIG9yYW5nZSA/XG4gICAgICAgICdUJzogJ3JlZCcsICdVJzogJ3JlZCcsXG4gICAgICAgICdvdGhlcnMnOiAnZ3JheScsXG4gICAgICB9KTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuY2hyb21hdG9ncmFtO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBOdWNsZW90aWRlcyB7XG4gIHN0YXRpYyByZWFkb25seSBTZW1UeXBlOiBzdHJpbmcgPSAnTnVjbGVvdGlkZXMnO1xuXG4gIHN0YXRpYyByZWFkb25seSBTZW1UeXBlTXVsdGlwbGVBbGlnbm1lbnQ6IHN0cmluZyA9ICdOdWNsZW90aWRlc011bHRpcGxlQWxpZ25tZW50JztcblxuICBwdWJsaWMgc3RhdGljIE5hbWVzOiBTdHJpbmdEaWN0aW9uYXJ5ID0ge1xuICAgICdBJzogJ0FkZW5pbmUnLFxuICAgICdDJzogJ0N5dG9zaW5lJyxcbiAgICAnRyc6ICdHdWFuaW5lJyxcbiAgICAnVCc6ICdUaHltaW5lJyxcbiAgICAnVSc6ICdVcmFjaWwnLFxuICB9O1xufVxuIl19","export class SeqPaletteBase {\n    constructor(palette) {\n        this._palette = palette;\n    }\n    static makePalette(dt, simplified = false, PaletteType = SeqPaletteBase) {\n        const palette = {};\n        dt.forEach((cp) => {\n            const objList = cp[0];\n            const colour = cp[1];\n            objList.forEach((obj, ind) => {\n                palette[obj] = this.colourPalette[colour][simplified ? 0 : ind];\n            });\n        });\n        return new PaletteType(palette);\n    }\n    get(m) {\n        return this._palette[m];\n    }\n}\nSeqPaletteBase.undefinedColor = 'rgb(100,100,100)';\n/** Palette with shades of primary colors */\nSeqPaletteBase.colourPalette = {\n    'orange': ['rgb(255,187,120)', 'rgb(245,167,100)', 'rgb(235,137,70)', 'rgb(205, 111, 71)'],\n    'all_green': ['rgb(44,160,44)', 'rgb(74,160,74)', 'rgb(23,103,57)', 'rgb(30,110,96)', 'rgb(60,131,95)',\n        'rgb(24,110,79)', 'rgb(152,223,138)', 'rgb(182, 223, 138)', 'rgb(152, 193, 138)'],\n    'all_blue': ['rgb(31,119,180)', 'rgb(23,190,207)', 'rgb(122, 102, 189)', 'rgb(158,218,229)', 'rgb(141, 124, 217)',\n        'rgb(31, 120, 150)'],\n    'magenta': ['rgb(162,106,192)', 'rgb(197,165,224)', 'rgb(208,113,218)'],\n    'red': ['rgb(214,39,40)', 'rgb(255,152,150)'],\n    'st_blue': ['rgb(23,190,207)', 'rgb(158,218,229)', 'rgb(31,119,180)'],\n    'dark_blue': ['rgb(31,119,180)', 'rgb(31, 120, 150)'],\n    'light_blue': ['rgb(23,190,207)', 'rgb(158,218,229)', 'rgb(108, 218, 229)', 'rgb(23,190,227)'],\n    'lilac_blue': ['rgb(124,102,211)', 'rgb(149,134,217)', 'rgb(97, 81, 150)'],\n    'dark_green': ['rgb(23,103,57)', 'rgb(30,110,96)', 'rgb(60,131,95)', 'rgb(24,110,79)'],\n    'green': ['rgb(44,160,44)', 'rgb(74,160,74)'],\n    'light_green': ['rgb(152,223,138)', 'rgb(182, 223, 138)', 'rgb(152, 193, 138)'],\n    'st_green': ['rgb(44,160,44)', 'rgb(152,223,138)', 'rgb(39, 174, 96)', 'rgb(74,160,74)'],\n    'pink': ['rgb(247,182,210)'],\n    'brown': ['rgb(140,86,75)', 'rgb(102, 62, 54)'],\n    'gray': ['rgb(127,127,127)', 'rgb(199,199,199)', 'rgb(196,156,148)', 'rgb(222, 222, 180)'],\n    'yellow': ['rgb(188,189,34)'],\n    'white': ['rgb(230,230,230)'],\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VxLXBhbGV0dGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2VxLXBhbGV0dGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCQSxNQUFNLE9BQU8sY0FBYztJQTJDekIsWUFBWSxPQUFnQztRQUMxQyxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztJQUMxQixDQUFDO0lBbEJTLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBd0IsRUFDbkQsVUFBVSxHQUFHLEtBQUssRUFBRSxjQUFxQyxjQUFjO1FBRXZFLE1BQU0sT0FBTyxHQUE4QixFQUFFLENBQUM7UUFDOUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFO1lBQ2hCLE1BQU0sT0FBTyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0QixNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDckIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRTtnQkFDM0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2xFLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFRTSxHQUFHLENBQUMsQ0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUIsQ0FBQzs7QUFoRGEsNkJBQWMsR0FBRyxrQkFBa0IsQ0FBQztBQUVsRCw0Q0FBNEM7QUFDOUIsNEJBQWEsR0FBZ0M7SUFDekQsUUFBUSxFQUFFLENBQUMsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUUsbUJBQW1CLENBQUM7SUFDMUYsV0FBVyxFQUFFLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCO1FBQ3BHLGdCQUFnQixFQUFFLGtCQUFrQixFQUFFLG9CQUFvQixFQUFFLG9CQUFvQixDQUFDO0lBQ25GLFVBQVUsRUFBRSxDQUFDLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLG9CQUFvQixFQUFFLGtCQUFrQixFQUFFLG9CQUFvQjtRQUMvRyxtQkFBbUIsQ0FBQztJQUN0QixTQUFTLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsQ0FBQztJQUN2RSxLQUFLLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxrQkFBa0IsQ0FBQztJQUM3QyxTQUFTLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxpQkFBaUIsQ0FBQztJQUNyRSxXQUFXLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxtQkFBbUIsQ0FBQztJQUNyRCxZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxpQkFBaUIsQ0FBQztJQUM5RixZQUFZLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsQ0FBQztJQUMxRSxZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsQ0FBQztJQUN0RixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxnQkFBZ0IsQ0FBQztJQUM3QyxhQUFhLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxvQkFBb0IsQ0FBQztJQUMvRSxVQUFVLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsQ0FBQztJQUN4RixNQUFNLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztJQUM1QixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxrQkFBa0IsQ0FBQztJQUMvQyxNQUFNLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsQ0FBQztJQUMxRixRQUFRLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztJQUM3QixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztDQUM5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZ3JvayBmcm9tICdkYXRhZ3Jvay1hcGkvZ3Jvayc7XG5pbXBvcnQgKiBhcyB1aSBmcm9tICdkYXRhZ3Jvay1hcGkvdWknO1xuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcblxuZXhwb3J0IGludGVyZmFjZSBTZXFQYWxldHRlIHtcbiAgLy8gVGhlcmUgYXJlIHRvbyBtdWNoIHByb2JsZW0gd2l0aCBpbmRleGVyIHByb3BlcnR5IGluIHR5cGVzY3JpcHQuXG4gIC8vIC8qKlxuICAvLyAgKiBAcGFyYW0ge3N0cmluZ30gbSBNb25vbWVyIGNoYXJhY3RlclxuICAvLyAgKiBAcmV0dXJuIHtzdHJpbmd9IENvbG9yXG4gIC8vICAqL1xuICAvLyBbbTogc3RyaW5nXTogc3RyaW5nO1xuICAvKiogTW9ub21lciBjb2xvclxuICAgKiBAcGFyYW0ge3N0cmluZ30gbSBNb25vbWVyXG4gICAqL1xuICBnZXQobTogc3RyaW5nKTogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgU2VxUGFsZXR0ZUJhc2UgaW1wbGVtZW50cyBTZXFQYWxldHRlIHtcbiAgcHVibGljIHN0YXRpYyB1bmRlZmluZWRDb2xvciA9ICdyZ2IoMTAwLDEwMCwxMDApJztcblxuICAvKiogUGFsZXR0ZSB3aXRoIHNoYWRlcyBvZiBwcmltYXJ5IGNvbG9ycyAqL1xuICBwdWJsaWMgc3RhdGljIGNvbG91clBhbGV0dGU6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nW10gfSA9IHtcbiAgICAnb3JhbmdlJzogWydyZ2IoMjU1LDE4NywxMjApJywgJ3JnYigyNDUsMTY3LDEwMCknLCAncmdiKDIzNSwxMzcsNzApJywgJ3JnYigyMDUsIDExMSwgNzEpJ10sXG4gICAgJ2FsbF9ncmVlbic6IFsncmdiKDQ0LDE2MCw0NCknLCAncmdiKDc0LDE2MCw3NCknLCAncmdiKDIzLDEwMyw1NyknLCAncmdiKDMwLDExMCw5NiknLCAncmdiKDYwLDEzMSw5NSknLFxuICAgICAgJ3JnYigyNCwxMTAsNzkpJywgJ3JnYigxNTIsMjIzLDEzOCknLCAncmdiKDE4MiwgMjIzLCAxMzgpJywgJ3JnYigxNTIsIDE5MywgMTM4KSddLFxuICAgICdhbGxfYmx1ZSc6IFsncmdiKDMxLDExOSwxODApJywgJ3JnYigyMywxOTAsMjA3KScsICdyZ2IoMTIyLCAxMDIsIDE4OSknLCAncmdiKDE1OCwyMTgsMjI5KScsICdyZ2IoMTQxLCAxMjQsIDIxNyknLFxuICAgICAgJ3JnYigzMSwgMTIwLCAxNTApJ10sXG4gICAgJ21hZ2VudGEnOiBbJ3JnYigxNjIsMTA2LDE5MiknLCAncmdiKDE5NywxNjUsMjI0KScsICdyZ2IoMjA4LDExMywyMTgpJ10sXG4gICAgJ3JlZCc6IFsncmdiKDIxNCwzOSw0MCknLCAncmdiKDI1NSwxNTIsMTUwKSddLFxuICAgICdzdF9ibHVlJzogWydyZ2IoMjMsMTkwLDIwNyknLCAncmdiKDE1OCwyMTgsMjI5KScsICdyZ2IoMzEsMTE5LDE4MCknXSxcbiAgICAnZGFya19ibHVlJzogWydyZ2IoMzEsMTE5LDE4MCknLCAncmdiKDMxLCAxMjAsIDE1MCknXSxcbiAgICAnbGlnaHRfYmx1ZSc6IFsncmdiKDIzLDE5MCwyMDcpJywgJ3JnYigxNTgsMjE4LDIyOSknLCAncmdiKDEwOCwgMjE4LCAyMjkpJywgJ3JnYigyMywxOTAsMjI3KSddLFxuICAgICdsaWxhY19ibHVlJzogWydyZ2IoMTI0LDEwMiwyMTEpJywgJ3JnYigxNDksMTM0LDIxNyknLCAncmdiKDk3LCA4MSwgMTUwKSddLFxuICAgICdkYXJrX2dyZWVuJzogWydyZ2IoMjMsMTAzLDU3KScsICdyZ2IoMzAsMTEwLDk2KScsICdyZ2IoNjAsMTMxLDk1KScsICdyZ2IoMjQsMTEwLDc5KSddLFxuICAgICdncmVlbic6IFsncmdiKDQ0LDE2MCw0NCknLCAncmdiKDc0LDE2MCw3NCknXSxcbiAgICAnbGlnaHRfZ3JlZW4nOiBbJ3JnYigxNTIsMjIzLDEzOCknLCAncmdiKDE4MiwgMjIzLCAxMzgpJywgJ3JnYigxNTIsIDE5MywgMTM4KSddLFxuICAgICdzdF9ncmVlbic6IFsncmdiKDQ0LDE2MCw0NCknLCAncmdiKDE1MiwyMjMsMTM4KScsICdyZ2IoMzksIDE3NCwgOTYpJywgJ3JnYig3NCwxNjAsNzQpJ10sXG4gICAgJ3BpbmsnOiBbJ3JnYigyNDcsMTgyLDIxMCknXSxcbiAgICAnYnJvd24nOiBbJ3JnYigxNDAsODYsNzUpJywgJ3JnYigxMDIsIDYyLCA1NCknXSxcbiAgICAnZ3JheSc6IFsncmdiKDEyNywxMjcsMTI3KScsICdyZ2IoMTk5LDE5OSwxOTkpJywgJ3JnYigxOTYsMTU2LDE0OCknLCAncmdiKDIyMiwgMjIyLCAxODApJ10sXG4gICAgJ3llbGxvdyc6IFsncmdiKDE4OCwxODksMzQpJ10sXG4gICAgJ3doaXRlJzogWydyZ2IoMjMwLDIzMCwyMzApJ10sXG4gIH07XG5cbiAgcHJvdGVjdGVkIHN0YXRpYyBtYWtlUGFsZXR0ZShkdDogW3N0cmluZ1tdLCBzdHJpbmddW10sXG4gICAgc2ltcGxpZmllZCA9IGZhbHNlLCBQYWxldHRlVHlwZTogdHlwZW9mIFNlcVBhbGV0dGVCYXNlID0gU2VxUGFsZXR0ZUJhc2VcbiAgKSB7XG4gICAgY29uc3QgcGFsZXR0ZTogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSA9IHt9O1xuICAgIGR0LmZvckVhY2goKGNwKSA9PiB7XG4gICAgICBjb25zdCBvYmpMaXN0ID0gY3BbMF07XG4gICAgICBjb25zdCBjb2xvdXIgPSBjcFsxXTtcbiAgICAgIG9iakxpc3QuZm9yRWFjaCgob2JqLCBpbmQpID0+IHtcbiAgICAgICAgcGFsZXR0ZVtvYmpdID0gdGhpcy5jb2xvdXJQYWxldHRlW2NvbG91cl1bc2ltcGxpZmllZCA/IDAgOiBpbmRdO1xuICAgICAgfSk7XG4gICAgfSk7XG4gICAgcmV0dXJuIG5ldyBQYWxldHRlVHlwZShwYWxldHRlKTtcbiAgfVxuXG4gIHByaXZhdGUgcmVhZG9ubHkgX3BhbGV0dGU6IHsgW206IHN0cmluZ106IHN0cmluZyB9O1xuXG4gIGNvbnN0cnVjdG9yKHBhbGV0dGU6IHsgW206IHN0cmluZ106IHN0cmluZyB9KSB7XG4gICAgdGhpcy5fcGFsZXR0ZSA9IHBhbGV0dGU7XG4gIH1cblxuICBwdWJsaWMgZ2V0KG06IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3BhbGV0dGVbbV07XG4gIH1cbn1cbiJdfQ==","import { assert } from '@datagrok-libraries/utils/src/vector-operations';\nclass SideChainScales {\n    static getAvailableScales() {\n        return Object.entries(this.scales).map(([k, _]) => k);\n    }\n    static getScale(name) {\n        assert(!(this.scales[name] === undefined), `Scale '${name}' was not found.`);\n        return this.scales[name];\n    }\n}\nSideChainScales.scales = {\n    // Wimley-White interfacial hydrophobicity scale\n    'WimleyWhite': {\n        '-': 0,\n        'A': 0.17,\n        'C': -0.24,\n        'D': -0.07,\n        'E': -0.01,\n        'F': -1.13,\n        'G': 0.01,\n        'H': 0.17,\n        'I': -0.31,\n        'K': 0.99,\n        'L': -0.56,\n        'M': -0.23,\n        'N': 0.42,\n        'P': 0.45,\n        'Q': 0.58,\n        'R': 0.81,\n        'S': 0.13,\n        'T': 0.14,\n        'V': 0.07,\n        'W': -1.85,\n        'Y': -0.94,\n    },\n    'categorial': {\n        '-': 0,\n        'A': 1,\n        'C': 2,\n        'D': 3,\n        'E': 4,\n        'F': 5,\n        'G': 6,\n        'H': 7,\n        'I': 8,\n        'K': 9,\n        'L': 10,\n        'M': 11,\n        'N': 12,\n        'P': 13,\n        'Q': 14,\n        'R': 15,\n        'S': 16,\n        'T': 17,\n        'V': 18,\n        'W': 19,\n        'Y': 20,\n    },\n};\n/**\n * Class to categorial encode/decode aligned amino acid residues sequence.\n *\n * @export\n * @class AlignedSequenceEncoder\n */\nexport class AlignedSequenceEncoder {\n    constructor(scale = 'categorial') {\n        this.aa2num = SideChainScales.getScale(scale);\n        this.num2aa = {};\n        Object.entries(this.aa2num).forEach(([k, v]) => (this.num2aa[v] = k));\n    }\n    /**\n       * Truncate NH2 and -COOH terminals of the given sequence.\n       *\n       * @static\n       * @param {string} seq The sequence provided.\n       * @return {string} Truncated sequence.\n       * @memberof AlignedSequenceEncoder\n       */\n    static _truncateSequence(seq) {\n        let start = 0;\n        let end = seq.length;\n        const termina = ['NH2', 'COOH'];\n        if (seq.startsWith(termina[0])) {\n            const l = termina[0].length; // Cut only 'NH2' without following '-'.\n            assert(seq[l] == '-', `Wrong sequence format: ${termina[0]} without following '-' in '${seq}'.`);\n            start = l;\n        }\n        if (seq.endsWith(termina[1])) {\n            const l = termina[1].length + 1; // Cut both 'COOH' and precending '-'.\n            assert(seq[end - l] == '-', `Wrong sequence format: ${termina[1]} without '-' precending in '${seq}'.`);\n            end -= l;\n        }\n        return seq.substring(start, end);\n    }\n    /**\n       * Cuts auxiliary defises before a residue.\n       *\n       * @static\n       * @param {string} seq The sequence to process.\n       * @return {string} Processed sequence.\n       * @memberof AlignedSequenceEncoder\n       */\n    static _dropDefises(seq) {\n        return seq.replace(/(-)([^-]+)/g, '$2');\n    }\n    /**\n       * Performs truncation and cutting auxiliary defises.\n       *\n       * @static\n       * @param {string} sequence The sequence work under process.\n       * @return {string} Result of cleaning.\n       * @memberof AlignedSequenceEncoder\n       */\n    static clean(sequence) {\n        return AlignedSequenceEncoder._dropDefises(AlignedSequenceEncoder._truncateSequence(sequence));\n    }\n    /**\n       * Categorial encode of the sequence provided.\n       *\n       * @param {string} sequence The sequence.\n       * @return {number[]} Encoded vector.\n       * @memberof AlignedSequenceEncoder\n       */\n    encode(sequence) {\n        const nItems = sequence.length;\n        const values = new Array(nItems).fill(0);\n        for (let i = 0; i < nItems; ++i) {\n            const char = sequence[i];\n            assert(char in this.aa2num, `Unknown char '${char}' found in sequence '${sequence}'`);\n            values[i] = this.encodeLettter(char);\n        }\n        return values;\n    }\n    encodeLettter(letter) {\n        return this.aa2num[letter];\n    }\n    /**\n       * Decode the encoded vector into the sequence back.\n       *\n       * @param {number[]} value The vector encoded.\n       * @return {string} Decoded sequence.\n       * @memberof AlignedSequenceEncoder\n       */\n    decode(value) {\n        let s = '';\n        for (let i = 0; i < value.length; ++i) {\n            const code = value[i];\n            assert(code in this.num2aa, `Unknown code '${code}' found in vector '${value}'`);\n            s += this.num2aa[code];\n        }\n        return s;\n    }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sequence-encoder.js","sourceRoot":"","sources":["sequence-encoder.ts"],"names":[],"mappings":"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","sourcesContent":["import {assert} from '@datagrok-libraries/utils/src/vector-operations';\n\ntype SideChainScale = {[name: string]: number};\ntype SideChainScaleCollection = {[name: string]: SideChainScale};\n\nclass SideChainScales {\n  static scales: SideChainScaleCollection = {\n    // Wimley-White interfacial hydrophobicity scale\n    'WimleyWhite': {\n      '-': 0,\n      'A': 0.17,\n      'C': -0.24,\n      'D': -0.07, // Asp-: 1.23\n      'E': -0.01, // Glu-: 2.02\n      'F': -1.13, //\n      'G': 0.01,\n      'H': 0.17, // His+: 0.96\n      'I': -0.31,\n      'K': 0.99, // Lys+\n      'L': -0.56,\n      'M': -0.23,\n      'N': 0.42,\n      'P': 0.45,\n      'Q': 0.58,\n      'R': 0.81, // Arg+\n      'S': 0.13,\n      'T': 0.14,\n      'V': 0.07,\n      'W': -1.85,\n      'Y': -0.94,\n    },\n    'categorial': {\n      '-': 0,\n      'A': 1,\n      'C': 2,\n      'D': 3,\n      'E': 4,\n      'F': 5,\n      'G': 6,\n      'H': 7,\n      'I': 8,\n      'K': 9,\n      'L': 10,\n      'M': 11,\n      'N': 12,\n      'P': 13,\n      'Q': 14,\n      'R': 15,\n      'S': 16,\n      'T': 17,\n      'V': 18,\n      'W': 19,\n      'Y': 20,\n    },\n  };\n\n  static getAvailableScales(): string[] {\n    return Object.entries(this.scales).map(([k, _]) => k);\n  }\n\n  static getScale(name: string): SideChainScale {\n    assert(!(this.scales[name] === undefined), `Scale '${name}' was not found.`);\n    return this.scales[name];\n  }\n}\n\n/**\n * Class to categorial encode/decode aligned amino acid residues sequence.\n *\n * @export\n * @class AlignedSequenceEncoder\n */\nexport class AlignedSequenceEncoder {\n  protected aa2num: SideChainScale;\n  protected num2aa: {[code: number]: string};\n\n  constructor(scale: string = 'categorial') {\n    this.aa2num = SideChainScales.getScale(scale);\n    this.num2aa = {};\n    Object.entries(this.aa2num).forEach(([k, v]) => (this.num2aa[v] = k));\n  }\n\n  /**\n     * Truncate NH2 and -COOH terminals of the given sequence.\n     *\n     * @static\n     * @param {string} seq The sequence provided.\n     * @return {string} Truncated sequence.\n     * @memberof AlignedSequenceEncoder\n     */\n  static _truncateSequence(seq: string): string {\n    let start = 0;\n    let end = seq.length;\n    const termina = ['NH2', 'COOH'];\n\n    if (seq.startsWith(termina[0])) {\n      const l = termina[0].length; // Cut only 'NH2' without following '-'.\n      assert(seq[l] == '-', `Wrong sequence format: ${termina[0]} without following '-' in '${seq}'.`);\n      start = l;\n    }\n    if (seq.endsWith(termina[1])) {\n      const l = termina[1].length+1; // Cut both 'COOH' and precending '-'.\n      assert(seq[end-l] == '-', `Wrong sequence format: ${termina[1]} without '-' precending in '${seq}'.`);\n      end -= l;\n    }\n    return seq.substring(start, end);\n  }\n\n  /**\n     * Cuts auxiliary defises before a residue.\n     *\n     * @static\n     * @param {string} seq The sequence to process.\n     * @return {string} Processed sequence.\n     * @memberof AlignedSequenceEncoder\n     */\n  static _dropDefises(seq: string): string {\n    return seq.replace(/(-)([^-]+)/g, '$2');\n  }\n\n  /**\n     * Performs truncation and cutting auxiliary defises.\n     *\n     * @static\n     * @param {string} sequence The sequence work under process.\n     * @return {string} Result of cleaning.\n     * @memberof AlignedSequenceEncoder\n     */\n  static clean(sequence: string): string {\n    return AlignedSequenceEncoder._dropDefises(AlignedSequenceEncoder._truncateSequence(sequence));\n  }\n\n  /**\n     * Categorial encode of the sequence provided.\n     *\n     * @param {string} sequence The sequence.\n     * @return {number[]} Encoded vector.\n     * @memberof AlignedSequenceEncoder\n     */\n  public encode(sequence: string): number[] {\n    const nItems = sequence.length;\n    const values = new Array(nItems).fill(0);\n\n    for (let i = 0; i < nItems; ++i) {\n      const char = sequence[i];\n\n      assert(char in this.aa2num, `Unknown char '${char}' found in sequence '${sequence}'`);\n\n      values[i] = this.encodeLettter(char);\n    }\n    return values;\n  }\n\n  public encodeLettter(letter: string): number {\n    return this.aa2num[letter];\n  }\n\n  /**\n     * Decode the encoded vector into the sequence back.\n     *\n     * @param {number[]} value The vector encoded.\n     * @return {string} Decoded sequence.\n     * @memberof AlignedSequenceEncoder\n     */\n  public decode(value: number[]): string {\n    let s: string = '';\n\n    for (let i = 0; i < value.length; ++i) {\n      const code = value[i];\n\n      assert(code in this.num2aa, `Unknown code '${code}' found in vector '${value}'`);\n\n      s += this.num2aa[code];\n    }\n    return s;\n  }\n}\n"]}","export class StringUtils {\n    static hashCode(s) {\n        let hash = 0;\n        if (s.length === 0)\n            return hash;\n        for (let i = 0; i < s.length; i++) {\n            const chr = s.charCodeAt(i);\n            hash = ((hash << 5) - hash) + chr;\n            hash |= 0; // Convert to 32bit integer\n        }\n        return hash;\n    }\n}\nimport { SeqPaletteBase } from './seq-palettes';\nexport class UnknownSeqPalette {\n}\nexport class GrayAllPalette extends UnknownSeqPalette {\n    get(m) {\n        return '#666666';\n    }\n}\nexport class UnknownColorPalette extends UnknownSeqPalette {\n    static buildPalette() {\n        const res = [].concat(...Object.values(SeqPaletteBase.colourPalette));\n        return res;\n    }\n    get(m) {\n        const hash = StringUtils.hashCode(m);\n        const pI = hash % UnknownColorPalette.palette.length;\n        return UnknownColorPalette.palette[pI];\n    }\n}\nUnknownColorPalette.palette = UnknownColorPalette.buildPalette();\nexport class UnknownSeqPalettes extends SeqPaletteBase {\n    static get Gray() {\n        if (this.gray === void 0)\n            this.gray = new GrayAllPalette();\n        return this.gray;\n    }\n    static get Color() {\n        if (this.color === void 0)\n            this.color = new UnknownColorPalette();\n        return this.color;\n    }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5rbm93bi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVua25vd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsTUFBTSxPQUFPLFdBQVc7SUFDZixNQUFNLENBQUMsUUFBUSxDQUFDLENBQVM7UUFDOUIsSUFBSSxJQUFJLEdBQVcsQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDO1lBQ2hCLE9BQU8sSUFBSSxDQUFDO1FBQ2QsS0FBSyxJQUFJLENBQUMsR0FBVyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDekMsTUFBTSxHQUFHLEdBQVcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNwQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxHQUFHLENBQUM7WUFDbEMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLDJCQUEyQjtTQUN2QztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztDQUNGO0FBRUQsT0FBTyxFQUFhLGNBQWMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRTFELE1BQU0sT0FBZ0IsaUJBQWlCO0NBRXRDO0FBRUQsTUFBTSxPQUFPLGNBQWUsU0FBUSxpQkFBaUI7SUFDNUMsR0FBRyxDQUFDLENBQVM7UUFDbEIsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztDQUNGO0FBR0QsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGlCQUFpQjtJQUdoRCxNQUFNLENBQUMsWUFBWTtRQUN6QixNQUFNLEdBQUcsR0FBSSxFQUFlLENBQUMsTUFBTSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztRQUNwRixPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFFTSxHQUFHLENBQUMsQ0FBUztRQUNsQixNQUFNLElBQUksR0FBVyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzdDLE1BQU0sRUFBRSxHQUFHLElBQUksR0FBRyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDO1FBQ3JELE9BQU8sbUJBQW1CLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7O0FBWGEsMkJBQU8sR0FBYSxtQkFBbUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztBQWN2RSxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsY0FBYztJQUc3QyxNQUFNLEtBQUssSUFBSTtRQUNwQixJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssS0FBSyxDQUFDO1lBQ3RCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxjQUFjLEVBQUUsQ0FBQztRQUNuQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUlNLE1BQU0sS0FBSyxLQUFLO1FBQ3JCLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxLQUFLLENBQUM7WUFDdkIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLG1CQUFtQixFQUFFLENBQUM7UUFDekMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGdyb2sgZnJvbSAnZGF0YWdyb2stYXBpL2dyb2snO1xuaW1wb3J0ICogYXMgdWkgZnJvbSAnZGF0YWdyb2stYXBpL3VpJztcbmltcG9ydCAqIGFzIERHIGZyb20gJ2RhdGFncm9rLWFwaS9kZyc7XG5cbmV4cG9ydCBjbGFzcyBTdHJpbmdVdGlscyB7XG4gIHB1YmxpYyBzdGF0aWMgaGFzaENvZGUoczogc3RyaW5nKTogbnVtYmVyIHtcbiAgICBsZXQgaGFzaDogbnVtYmVyID0gMDtcbiAgICBpZiAocy5sZW5ndGggPT09IDApXG4gICAgICByZXR1cm4gaGFzaDtcbiAgICBmb3IgKGxldCBpOiBudW1iZXIgPSAwOyBpIDwgcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgY2hyOiBudW1iZXIgPSBzLmNoYXJDb2RlQXQoaSk7XG4gICAgICBoYXNoID0gKChoYXNoIDw8IDUpIC0gaGFzaCkgKyBjaHI7XG4gICAgICBoYXNoIHw9IDA7IC8vIENvbnZlcnQgdG8gMzJiaXQgaW50ZWdlclxuICAgIH1cbiAgICByZXR1cm4gaGFzaDtcbiAgfVxufVxuXG5pbXBvcnQge1NlcVBhbGV0dGUsIFNlcVBhbGV0dGVCYXNlfSBmcm9tICcuL3NlcS1wYWxldHRlcyc7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBVbmtub3duU2VxUGFsZXR0ZSBpbXBsZW1lbnRzIFNlcVBhbGV0dGUge1xuICBwdWJsaWMgYWJzdHJhY3QgZ2V0KG06IHN0cmluZyk6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIEdyYXlBbGxQYWxldHRlIGV4dGVuZHMgVW5rbm93blNlcVBhbGV0dGUge1xuICBwdWJsaWMgZ2V0KG06IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuICcjNjY2NjY2JztcbiAgfVxufVxuXG5cbmV4cG9ydCBjbGFzcyBVbmtub3duQ29sb3JQYWxldHRlIGV4dGVuZHMgVW5rbm93blNlcVBhbGV0dGUge1xuICBwdWJsaWMgc3RhdGljIHBhbGV0dGU6IHN0cmluZ1tdID0gVW5rbm93bkNvbG9yUGFsZXR0ZS5idWlsZFBhbGV0dGUoKTtcblxuICBwcml2YXRlIHN0YXRpYyBidWlsZFBhbGV0dGUoKTogc3RyaW5nW10ge1xuICAgIGNvbnN0IHJlcyA9IChbXSBhcyBzdHJpbmdbXSkuY29uY2F0KC4uLk9iamVjdC52YWx1ZXMoU2VxUGFsZXR0ZUJhc2UuY29sb3VyUGFsZXR0ZSkpO1xuICAgIHJldHVybiByZXM7XG4gIH1cblxuICBwdWJsaWMgZ2V0KG06IHN0cmluZyk6IHN0cmluZyB7XG4gICAgY29uc3QgaGFzaDogbnVtYmVyID0gU3RyaW5nVXRpbHMuaGFzaENvZGUobSk7XG4gICAgY29uc3QgcEkgPSBoYXNoICUgVW5rbm93bkNvbG9yUGFsZXR0ZS5wYWxldHRlLmxlbmd0aDtcbiAgICByZXR1cm4gVW5rbm93bkNvbG9yUGFsZXR0ZS5wYWxldHRlW3BJXTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgVW5rbm93blNlcVBhbGV0dGVzIGV4dGVuZHMgU2VxUGFsZXR0ZUJhc2Uge1xuICBwcml2YXRlIHN0YXRpYyBncmF5OiBTZXFQYWxldHRlO1xuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IEdyYXkoKTogU2VxUGFsZXR0ZSB7XG4gICAgaWYgKHRoaXMuZ3JheSA9PT0gdm9pZCAwKVxuICAgICAgdGhpcy5ncmF5ID0gbmV3IEdyYXlBbGxQYWxldHRlKCk7XG4gICAgcmV0dXJuIHRoaXMuZ3JheTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIGNvbG9yOiBTZXFQYWxldHRlO1xuXG4gIHB1YmxpYyBzdGF0aWMgZ2V0IENvbG9yKCk6IFNlcVBhbGV0dGUge1xuICAgIGlmICh0aGlzLmNvbG9yID09PSB2b2lkIDApXG4gICAgICB0aGlzLmNvbG9yID0gbmV3IFVua25vd25Db2xvclBhbGV0dGUoKTtcbiAgICByZXR1cm4gdGhpcy5jb2xvcjtcbiAgfVxufVxuIl19","// Data structures for V-Domain regions of antibodies\nexport var VdRegionType;\n(function (VdRegionType) {\n    VdRegionType[\"Unknown\"] = \"unknown\";\n    VdRegionType[\"FR\"] = \"framework\";\n    VdRegionType[\"CDR\"] = \"cdr\";\n})(VdRegionType || (VdRegionType = {}));\n/** Describes V-DOMAIN (IG and TR) region (of multiple alignment)\n * https://www.imgt.org/IMGTScientificChart/Numbering/IMGTIGVLsuperfamily.html\n */\nexport class VdRegion {\n    /**\n     * start and position are strings because they correspond to position names as column names in ANARCI output\n     * @param {VdRegionType} type  Type of the region\n     * @param {string} name  Name of the region\n     * @param {string} chain\n     * @param {string} order\n     * @param {string} positionStartName  Region start position (inclusive)\n     * @param {string} positionEndName  Region end position (inclusive)\n     */\n    constructor(type, name, chain, order, positionStartName, positionEndName) {\n        this.type = type;\n        this.name = name;\n        this.chain = chain;\n        this.order = order;\n        this.positionStartName = positionStartName;\n        this.positionEndName = positionEndName;\n    }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmQtcmVnaW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInZkLXJlZ2lvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEscURBQXFEO0FBRXJELE1BQU0sQ0FBTixJQUFZLFlBSVg7QUFKRCxXQUFZLFlBQVk7SUFDdEIsbUNBQW1CLENBQUE7SUFDbkIsZ0NBQWdCLENBQUE7SUFDaEIsMkJBQVcsQ0FBQTtBQUNiLENBQUMsRUFKVyxZQUFZLEtBQVosWUFBWSxRQUl2QjtBQUVEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLFFBQVE7SUFRbkI7Ozs7Ozs7O09BUUc7SUFDSCxZQUFZLElBQWtCLEVBQUUsSUFBWSxFQUFFLEtBQWEsRUFBRSxLQUFhLEVBQ3hFLGlCQUF5QixFQUFFLGVBQXVCO1FBQ2xELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxpQkFBaUIsQ0FBQztRQUMzQyxJQUFJLENBQUMsZUFBZSxHQUFHLGVBQWUsQ0FBQztJQUN6QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBEYXRhIHN0cnVjdHVyZXMgZm9yIFYtRG9tYWluIHJlZ2lvbnMgb2YgYW50aWJvZGllc1xuXG5leHBvcnQgZW51bSBWZFJlZ2lvblR5cGUge1xuICBVbmtub3duID0gJ3Vua25vd24nLFxuICBGUiA9ICdmcmFtZXdvcmsnLFxuICBDRFIgPSAnY2RyJyxcbn1cblxuLyoqIERlc2NyaWJlcyBWLURPTUFJTiAoSUcgYW5kIFRSKSByZWdpb24gKG9mIG11bHRpcGxlIGFsaWdubWVudClcbiAqIGh0dHBzOi8vd3d3LmltZ3Qub3JnL0lNR1RTY2llbnRpZmljQ2hhcnQvTnVtYmVyaW5nL0lNR1RJR1ZMc3VwZXJmYW1pbHkuaHRtbFxuICovXG5leHBvcnQgY2xhc3MgVmRSZWdpb24ge1xuICB0eXBlOiBWZFJlZ2lvblR5cGU7XG4gIG5hbWU6IHN0cmluZztcbiAgY2hhaW46IHN0cmluZztcbiAgb3JkZXI6IG51bWJlcjtcbiAgcG9zaXRpb25TdGFydE5hbWU6IHN0cmluZztcbiAgcG9zaXRpb25FbmROYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIHN0YXJ0IGFuZCBwb3NpdGlvbiBhcmUgc3RyaW5ncyBiZWNhdXNlIHRoZXkgY29ycmVzcG9uZCB0byBwb3NpdGlvbiBuYW1lcyBhcyBjb2x1bW4gbmFtZXMgaW4gQU5BUkNJIG91dHB1dFxuICAgKiBAcGFyYW0ge1ZkUmVnaW9uVHlwZX0gdHlwZSAgVHlwZSBvZiB0aGUgcmVnaW9uXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBuYW1lICBOYW1lIG9mIHRoZSByZWdpb25cbiAgICogQHBhcmFtIHtzdHJpbmd9IGNoYWluXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBvcmRlclxuICAgKiBAcGFyYW0ge3N0cmluZ30gcG9zaXRpb25TdGFydE5hbWUgIFJlZ2lvbiBzdGFydCBwb3NpdGlvbiAoaW5jbHVzaXZlKVxuICAgKiBAcGFyYW0ge3N0cmluZ30gcG9zaXRpb25FbmROYW1lICBSZWdpb24gZW5kIHBvc2l0aW9uIChpbmNsdXNpdmUpXG4gICAqL1xuICBjb25zdHJ1Y3Rvcih0eXBlOiBWZFJlZ2lvblR5cGUsIG5hbWU6IHN0cmluZywgY2hhaW46IHN0cmluZywgb3JkZXI6IG51bWJlcixcbiAgICBwb3NpdGlvblN0YXJ0TmFtZTogc3RyaW5nLCBwb3NpdGlvbkVuZE5hbWU6IHN0cmluZykge1xuICAgIHRoaXMudHlwZSA9IHR5cGU7XG4gICAgdGhpcy5uYW1lID0gbmFtZTtcbiAgICB0aGlzLmNoYWluID0gY2hhaW47XG4gICAgdGhpcy5vcmRlciA9IG9yZGVyO1xuICAgIHRoaXMucG9zaXRpb25TdGFydE5hbWUgPSBwb3NpdGlvblN0YXJ0TmFtZTtcbiAgICB0aGlzLnBvc2l0aW9uRW5kTmFtZSA9IHBvc2l0aW9uRW5kTmFtZTtcbiAgfVxufVxuIl19","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport wu from 'wu';\nimport * as rxjs from 'rxjs';\nimport { Vector } from '@datagrok-libraries/utils/src/type-declarations';\nimport { vectorLength, vectorDotProduct } from '@datagrok-libraries/utils/src/vector-operations';\nimport { Aminoacids, AminoacidsPalettes } from '../aminoacids';\nimport { Nucleotides, NucleotidesPalettes } from '../nucleotides';\nimport { UnknownSeqPalettes } from '../unknown';\nHTMLCanvasElement.prototype.getCursorPosition = function (event) {\n    const rect = this.getBoundingClientRect();\n    return new DG.Point(event.clientX - rect.left, event.clientY - rect.top);\n};\nDG.Rect.prototype.contains = function (x, y) {\n    return this.left <= x && x <= this.right && this.top <= y && y <= this.bottom;\n};\nexport class PositionMonomerInfo {\n    constructor() {\n        this.count = 0;\n        this.bounds = new DG.Rect(0, 0, 0, 0);\n    }\n}\nexport class PositionInfo {\n    /** freq = {}, rowCount = 0\n     * @param {string} name Name of position ('111A', '111.1', etc)\n     */\n    constructor(name) {\n        this.name = name;\n        this.freq = {};\n        this.rowCount = 0;\n    }\n}\nexport class WebLogo extends DG.JsViewer {\n    constructor() {\n        super();\n        this.viewerId = -1;\n        this.initialized = false;\n        // private readonly colorScheme: ColorScheme = ColorSchemes[NucleotidesWebLogo.residuesSet];\n        this.cp = null;\n        this.axisHeight = 12;\n        this.seqCol = null;\n        this.splitter = null;\n        // private maxLength: number = 100;\n        this.positions = [];\n        this.rowsMasked = 0;\n        this.rowsNull = 0;\n        this.positionNames = [];\n        this.startPosition = -1;\n        this.endPosition = -1;\n        this.viewSubs = [];\n        this.viewerId = WebLogo.viewerCount;\n        WebLogo.viewerCount += 1;\n        this.textBaseline = 'top';\n        this._positionWidth = this.positionWidth = this.float('positionWidth', 16 /*,\n          {editor: 'slider', min: 4, max: 64, postfix: 'px'}*/);\n        this.minHeight = this.float('minHeight', 50 /*,\n          {editor: 'slider', min: 25, max: 250, postfix: 'px'}*/);\n        this.maxHeight = this.float('maxHeight', 100 /*,\n          {editor: 'slider', min: 25, max: 500, postfix: 'px'}*/);\n        this.considerNullSequences = this.bool('considerNullSequences', false);\n        this.sequenceColumnName = this.string('sequenceColumnName', null);\n        this.startPositionName = this.string('startPositionName', null);\n        this.endPositionName = this.string('endPositionName', null);\n        this.fixWidth = this.bool('fixWidth', false);\n        this.verticalAlignment = this.string('verticalAlignment', 'middle', { choices: ['top', 'middle', 'bottom'] });\n        this.horizontalAlignment = this.string('horizontalAlignment', 'center', { choices: ['left', 'center', 'right'] });\n        this.fitArea = this.bool('fitArea', true);\n        this.shrinkEmptyTail = this.bool('shrinkEmptyTail', true);\n        this.skipEmptyPositions = this.bool('skipEmptyPositions', false);\n    }\n    /** For startPosition equals to endPosition Length is 1 */\n    get Length() {\n        return this.startPosition <= this.endPosition ? this.endPosition - this.startPosition + 1 : 0;\n    }\n    init() {\n        return __awaiter(this, void 0, void 0, function* () {\n            if (this.initialized) {\n                console.error('WebLogo second initialization!');\n                return;\n            }\n            this.initialized = true;\n            this.helpUrl = '/help/visualize/viewers/web-logo.md';\n            this.msgHost = ui.div('No message');\n            this.msgHost.style.display = 'none';\n            this.canvas = ui.canvas();\n            this.canvas.style.width = '100%';\n            this.host = ui.div([this.msgHost, this.canvas]);\n            // this.slider = ui.rangeSlider(0, 20, 2, 5);\n            // this.slider.root.style.width = '100%';\n            // this.slider.root.style.height = '12px';\n            const getMonomer = (p) => {\n                const jPos = Math.floor(p.x / this._positionWidth);\n                const position = this.positions[jPos];\n                if (position === void 0)\n                    return [jPos, null, null];\n                const monomer = Object.keys(position.freq)\n                    .find((m) => position.freq[m].bounds.contains(p.x, p.y));\n                if (monomer === undefined)\n                    return [jPos, null, null];\n                return [jPos, monomer, position.freq[monomer]];\n            };\n            // this.subs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mouseover').subscribe((e: MouseEvent) => {\n            // }));\n            this.viewSubs.push(rxjs.fromEvent(this.canvas, 'mousemove').subscribe((e) => {\n                if (!this.canvas)\n                    return;\n                const args = e;\n                const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n                if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n                    ui.tooltip.showRowGroup(this.dataFrame, (iRow) => {\n                        const seq = this.seqCol.get(iRow);\n                        const seqM = seq ? this.splitter(seq)[this.startPosition + jPos] : null;\n                        return seqM === monomer && this.dataFrame.filter.get(iRow);\n                    }, args.x + 16, args.y + 16);\n                }\n                else {\n                    ui.tooltip.hide();\n                }\n            }));\n            this.viewSubs.push(rxjs.fromEvent(this.canvas, 'mousedown').subscribe((e) => {\n                if (!this.canvas || e.button != 0)\n                    return;\n                const args = e;\n                const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n                // prevents deselect all rows if we miss monomer bounds\n                if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n                    this.dataFrame.selection.init((iRow) => {\n                        const seq = this.seqCol.get(iRow);\n                        const seqM = seq ? this.splitter(seq)[this.startPosition + jPos] : null;\n                        return seqM === monomer && this.dataFrame.filter.get(iRow);\n                    });\n                }\n            }));\n            this.viewSubs.push(ui.onSizeChanged(this.root).subscribe(this.rootOnSizeChanged.bind(this)));\n            this.root.append(this.host);\n            // this.root.appendChild(this.slider.root);\n            this.render(true);\n        });\n    }\n    rootOnSizeChanged(args) {\n        this.render(true);\n        // console.debug(`WebLogo.onRootSizeChanged() ` +\n        //   `root.width=${this.root.clientWidth}, root.height=${this.root.clientHeight}, ` +\n        //   `canvas.width=${this.canvas.width}, canvas.height=${this.canvas.height} .`);\n    }\n    /** Assigns {@link seqCol} and {@link cp} based on {@link sequenceColumnName} and calls {@link render}().\n     */\n    updateSeqCol() {\n        if (this.dataFrame) {\n            this.seqCol = this.sequenceColumnName ? this.dataFrame.col(this.sequenceColumnName) : null;\n            if (this.seqCol == null) {\n                this.seqCol = WebLogo.pickUpSeqCol2(this.dataFrame);\n                this.sequenceColumnName = this.seqCol ? this.seqCol.name : null;\n            }\n            if (this.seqCol) {\n                const units = this.seqCol.getTag(DG.TAGS.UNITS);\n                const separator = this.seqCol.getTag('separator');\n                this.splitter = WebLogo.getSplitter(units, separator);\n                this.updatePositions();\n                this.cp = WebLogo.pickUpPalette(this.seqCol);\n            }\n            else {\n                this.splitter = null;\n                this.positionNames = [];\n                this.startPosition = -1;\n                this.endPosition = -1;\n                this.cp = null;\n            }\n        }\n        this.render();\n    }\n    updatePositions() {\n        if (!this.seqCol)\n            return;\n        let categories;\n        if (this.shrinkEmptyTail) {\n            const indices = this.dataFrame.filter.getSelectedIndexes();\n            categories = Array.from(new Set(Array.from(Array(indices.length).keys()).map((i) => this.seqCol.get(indices[i]))));\n        }\n        else {\n            categories = this.seqCol.categories;\n        }\n        const maxLength = categories.length > 0 ? Math.max(...categories.map((s) => s !== null ? this.splitter(s).length : 0)) : 0;\n        // Get position names from data column tag 'positionNames'\n        const positionNamesTxt = this.seqCol.getTag('positionNames');\n        // Fallback if 'positionNames' tag is not provided\n        this.positionNames = positionNamesTxt ? positionNamesTxt.split(', ').map((n) => n.trim()) :\n            [...Array(maxLength).keys()].map((jPos) => `${jPos + 1}`);\n        this.startPosition = (this.startPositionName && this.positionNames &&\n            this.positionNames.includes(this.startPositionName)) ?\n            this.positionNames.indexOf(this.startPositionName) : 0;\n        this.endPosition = (this.endPositionName && this.positionNames &&\n            this.positionNames.includes(this.endPositionName)) ?\n            this.positionNames.indexOf(this.endPositionName) : (maxLength - 1);\n    }\n    onPropertyChanged(property) {\n        // console.debug(`WebLogo.onPropertyChanged( ${property.name} = '' })`);\n        super.onPropertyChanged(property);\n        switch (property.name) {\n            case 'considerNullSequences':\n                this.render(true);\n                break;\n            case 'sequenceColumnName':\n                this.updateSeqCol();\n                break;\n            case 'startPositionName':\n                this.updateSeqCol();\n                break;\n            case 'endPositionName':\n                this.updateSeqCol();\n                break;\n            case 'positionWidth':\n                this._positionWidth = this.positionWidth;\n                this.render(true);\n                break;\n            case 'minHeight':\n                this.render(true);\n                break;\n            case 'maxHeight':\n                this.render(true);\n                break;\n            case 'fixWidth':\n                this.render(true);\n                break;\n            case 'verticalAlignment':\n                this.render(true);\n                break;\n            case 'horizontalAlignment':\n                this.render(true);\n                break;\n            case 'fitArea':\n                this.render(true);\n                break;\n            case 'shrinkEmptyTail':\n                this.updatePositions();\n                this.render(true);\n                break;\n        }\n    }\n    onTableAttached() {\n        const _super = Object.create(null, {\n            onTableAttached: { get: () => super.onTableAttached }\n        });\n        return __awaiter(this, void 0, void 0, function* () {\n            const dataFrameTxt = this.dataFrame ? 'data' : 'null';\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n            _super.onTableAttached.call(this);\n            this.updateSeqCol();\n            if (this.dataFrame !== void 0) {\n                this.subs.push(this.dataFrame.selection.onChanged.subscribe((_) => this.render()));\n                this.subs.push(this.dataFrame.filter.onChanged.subscribe((_) => {\n                    this.updatePositions();\n                    this.render();\n                }));\n            }\n            yield this.init();\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n        });\n    }\n    detach() {\n        const _super = Object.create(null, {\n            detach: { get: () => super.detach }\n        });\n        return __awaiter(this, void 0, void 0, function* () {\n            const dataFrameTxt = `${this.dataFrame ? 'data' : 'null'}`;\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n            _super.detach.call(this);\n            this.viewSubs.forEach((sub) => sub.unsubscribe());\n            this.host.remove();\n            this.canvas = undefined;\n            this.msgHost = undefined;\n            this.host = undefined;\n            this.initialized = false;\n            console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n        });\n    }\n    _nullSequence(fillerResidue = 'X') {\n        if (this.considerNullSequences)\n            return new Array(this.Length).fill(fillerResidue).join('');\n        return '';\n    }\n    _calculate() {\n        if (!this.canvas || !this.host || !this.seqCol || !this.dataFrame)\n            return;\n        this.calcSize();\n        this.positions = new Array(this.Length);\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            const posName = this.positionNames[this.startPosition + jPos];\n            this.positions[jPos] = new PositionInfo(posName);\n        }\n        // 2022-05-05 askalkin instructed to show WebLogo based on filter (not selection)\n        const indices = this.dataFrame.filter.getSelectedIndexes();\n        // const indices = this.dataFrame.selection.trueCount > 0 ? this.dataFrame.selection.getSelectedIndexes() :\n        //   this.dataFrame.filter.getSelectedIndexes();\n        this.rowsMasked = indices.length;\n        this.rowsNull = 0;\n        for (const i of indices) {\n            let s = (this.seqCol.get(i));\n            if (!s) {\n                s = this._nullSequence();\n                ++this.rowsNull;\n            }\n            const seqM = this.splitter(s);\n            for (let jPos = 0; jPos < this.Length; jPos++) {\n                const pmInfo = this.positions[jPos].freq;\n                const m = seqM[this.startPosition + jPos] || '-';\n                if (!(m in pmInfo))\n                    pmInfo[m] = new PositionMonomerInfo();\n                pmInfo[m].count++;\n            }\n        }\n        //#region Polish freq counts\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            // delete this.positions[jPos].freq['-'];\n            this.positions[jPos].rowCount = 0;\n            for (const m in this.positions[jPos].freq)\n                this.positions[jPos].rowCount += this.positions[jPos].freq[m].count;\n        }\n        //#endregion\n        const r = window.devicePixelRatio;\n        const maxHeight = this.canvas.height - this.axisHeight * r;\n        // console.debug(`WebLogo<${this.viewerId}>._calculate() maxHeight=${maxHeight}.`);\n        //#region Calculate screen\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            const freq = this.positions[jPos].freq;\n            const rowCount = this.positions[jPos].rowCount;\n            let y = this.axisHeight;\n            const entries = Object.entries(freq).sort((a, b) => {\n                if (a[0] !== '-' && b[0] !== '-')\n                    return b[1].count - a[1].count;\n                else if (a[0] === '-' && b[0] === '-')\n                    return 0;\n                else if (a[0] === '-')\n                    return -1;\n                else /* (b[0] === '-') */\n                    return +1;\n            });\n            for (const entry of entries) {\n                const pmInfo = entry[1];\n                // const m: string = entry[0];\n                const h = maxHeight * pmInfo.count / rowCount;\n                pmInfo.bounds = new DG.Rect(jPos * this._positionWidth, y, this._positionWidth, h);\n                y += h;\n            }\n        }\n        //#endregion\n    }\n    // reflect changes made to filter/selection\n    render(recalc = true) {\n        var _a;\n        if (this.msgHost) {\n            if (this.seqCol && !this.cp) {\n                this.msgHost.innerText = `Unknown palette (column semType: '${this.seqCol.semType}').`;\n                this.msgHost.style.display = '';\n            }\n            else {\n                this.msgHost.style.display = 'none';\n            }\n        }\n        if (!this.canvas || !this.seqCol || !this.dataFrame || !this.cp)\n            return;\n        const g = this.canvas.getContext('2d');\n        if (!g)\n            return;\n        if (recalc)\n            this._calculate();\n        g.resetTransform();\n        g.fillStyle = 'white';\n        g.fillRect(0, 0, this.canvas.width, this.canvas.height);\n        g.textBaseline = this.textBaseline;\n        // Prevents division by zero on Length = 0\n        if (this.startPosition === -1 || this.endPosition === -1)\n            return;\n        //#region Plot positionNames\n        g.resetTransform();\n        g.fillStyle = 'black';\n        g.textAlign = 'center';\n        g.font = '10px Roboto, Roboto Local, sans-serif';\n        const posNameMaxWidth = Math.max(...this.positions.map((pos) => g.measureText(pos.name).width));\n        const hScale = posNameMaxWidth < (this._positionWidth - 2) ? 1 : (this._positionWidth - 2) / posNameMaxWidth;\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            const pos = this.positions[jPos];\n            g.resetTransform();\n            g.setTransform(hScale, 0, 0, 1, jPos * this._positionWidth + this._positionWidth / 2, 0);\n            g.fillText(pos.name, 0, 0);\n        }\n        //#endregion Plot positionNames\n        for (let jPos = 0; jPos < this.Length; jPos++) {\n            for (const [monomer, pmInfo] of Object.entries(this.positions[jPos].freq)) {\n                if (monomer !== '-') {\n                    const b = pmInfo.bounds;\n                    const fontStyle = '16px Roboto, Roboto Local, sans-serif';\n                    // Hacks to scale uppercase characters to target rectangle\n                    const uppercaseLetterAscent = 0.25;\n                    const uppercaseLetterHeight = 12.2;\n                    g.resetTransform();\n                    g.strokeStyle = 'lightgray';\n                    g.lineWidth = 1;\n                    g.rect(b.left, b.top, b.width, b.height);\n                    g.fillStyle = (_a = this.cp.get(monomer)) !== null && _a !== void 0 ? _a : this.cp.get('other');\n                    g.textAlign = 'left';\n                    g.font = fontStyle;\n                    //g.fillRect(b.left, b.top, b.width, b.height);\n                    const mTm = g.measureText(monomer);\n                    // if (mM.actualBoundingBoxAscent != 0)\n                    //   console.debug(`m: ${m}, mM.actualBoundingBoxAscent: ${mM.actualBoundingBoxAscent}`);\n                    g.setTransform(b.width / mTm.width, 0, 0, b.height / uppercaseLetterHeight, b.left, b.top);\n                    g.fillText(monomer, 0, -uppercaseLetterAscent);\n                }\n            }\n        }\n    }\n    calcSize() {\n        if (!this.canvas || !this.host)\n            return;\n        let width = this.Length * this.positionWidth;\n        let height = Math.min(this.maxHeight, Math.max(this.minHeight, this.root.clientHeight));\n        if (this.fitArea) {\n            const xScale = this.root.clientHeight / height;\n            const yScale = this.root.clientWidth / width;\n            const scale = Math.max(1, Math.min(xScale, yScale));\n            width = width * scale;\n            height = height * scale;\n            this._positionWidth = this.positionWidth * scale;\n        }\n        const r = window.devicePixelRatio;\n        this.canvas.width = width * r;\n        this.canvas.style.width = `${width}px`;\n        // const canvasHeight: number = width > this.root.clientWidth ? height - 8 : height;\n        this.host.style.setProperty('height', `${height}px`);\n        const canvasHeight = this.host.clientHeight;\n        this.canvas.height = canvasHeight * r;\n        this.canvas.style.setProperty('height', `${canvasHeight}px`);\n        // Adjust host and root width\n        if (this.fixWidth) {\n            // full width for canvas host and root\n            this.root.style.width = this.host.style.width = `${width}px`;\n            this.root.style.height = `${height}px`;\n            this.host.style.setProperty('overflow', 'hidden', 'important');\n        }\n        else {\n            // allow scroll canvas in root\n            this.root.style.width = this.host.style.width = '100%';\n            this.host.style.overflowX = 'auto!important';\n            this.host.style.setProperty('overflow', null);\n            this.host.style.setProperty('text-align', this.horizontalAlignment);\n            // vertical alignment\n            let hostTopMargin = 0;\n            switch (this.verticalAlignment) {\n                case 'top':\n                    hostTopMargin = 0;\n                    break;\n                case 'middle':\n                    hostTopMargin = Math.max(0, (this.root.clientHeight - height) / 2);\n                    break;\n                case 'bottom':\n                    hostTopMargin = Math.max(0, this.root.clientHeight - height);\n                    break;\n            }\n            this.host.style.setProperty('margin-top', `${hostTopMargin}px`, 'important');\n            if (this.root.clientHeight < height) {\n                this.host.style.setProperty('height', `${this.root.clientHeight}px`);\n                this.host.style.setProperty('overflow-y', null);\n            }\n            else {\n                this.host.style.setProperty('overflow-y', 'hidden', 'important');\n            }\n        }\n        // console.debug(\n        //   `this.root.style.height = ${this.root.style.height}\\n` +\n        //   `this.root.clientHeight = ${this.root.clientHeight}\\n` +\n        //   `this.host.style.height = ${this.host.style.height}\\n` +\n        //   `this.host.clientHeight = ${this.host.clientHeight}\\n` +\n        //   '\\n' +\n        //   `this.canvas.height       = ${this.canvas.height}\\n` +\n        //   `this.canvas.style.height = ${this.canvas.style.height}`);\n    }\n    /**\n     * @param {DG.Column} seqCol Column to look for a palette\n     * @param {number}  minLength minimum length of sequence to detect palette (empty strings are allowed)\n     * @return {SeqPalette} Palette corresponding to the alphabet of the sequences in the column\n     */\n    static pickUpPalette(seqCol, minLength = 5) {\n        let res = null;\n        switch (seqCol.semType) {\n            case Aminoacids.SemTypeMultipleAlignment:\n                res = AminoacidsPalettes.GrokGroups;\n                break;\n            case Nucleotides.SemTypeMultipleAlignment:\n                res = NucleotidesPalettes.Chromatogram;\n                break;\n        }\n        const stats = WebLogo.getStats(seqCol, minLength, WebLogo.splitterAsFasta);\n        const alphabetCandidates = [\n            [new Set(Object.keys(Nucleotides.Names)), NucleotidesPalettes.Chromatogram],\n            [new Set(Object.keys(Aminoacids.Names)), AminoacidsPalettes.GrokGroups],\n        ];\n        // Calculate likelihoods for alphabet_candidates\n        const alphabetCandidatesSim = alphabetCandidates\n            .map((c) => WebLogo.getAlphabetSimilarity(stats.freq, c[0]));\n        const maxCos = Math.max(...alphabetCandidatesSim);\n        if (maxCos > 0.65)\n            res = alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][1];\n        else\n            res = UnknownSeqPalettes.Color;\n        return res;\n    }\n    /** Stats of sequences with specified splitter func, returns { freq, sameLength }.\n     * @param {DG.Column} seqCol\n     * @param {number} minLength\n     * @param {SplitterFunc} splitter\n     * @return { SeqColStats }, sameLength: boolean } stats of column sequences\n     */\n    static getStats(seqCol, minLength, splitter) {\n        const freq = {};\n        let sameLength = true;\n        let firstLength = null;\n        for (const seq of seqCol.categories) {\n            const mSeq = splitter(seq);\n            if (firstLength == null)\n                firstLength = mSeq.length;\n            else if (mSeq.length !== firstLength)\n                sameLength = false;\n            if (mSeq.length > minLength) {\n                for (const m of mSeq) {\n                    if (!(m in freq))\n                        freq[m] = 0;\n                    freq[m] += 1;\n                }\n            }\n        }\n        return { freq: freq, sameLength: sameLength };\n    }\n    static getAlphabetSimilarity(freq, alphabet, gapSymbol = '-') {\n        const keys = new Set([...new Set(Object.keys(freq)), ...alphabet]);\n        keys.delete(gapSymbol);\n        const freqA = [];\n        const alphabetA = [];\n        for (const m of keys) {\n            freqA.push(m in freq ? freq[m] : 0);\n            alphabetA.push(alphabet.has(m) ? 1 : 0);\n        }\n        /* There were a few ideas: chi-squared, pearson correlation (variance?), scalar product */\n        const freqV = new Vector(freqA);\n        const alphabetV = new Vector(alphabetA);\n        const cos = vectorDotProduct(freqV, alphabetV) / (vectorLength(freqV) * vectorLength(alphabetV));\n        return cos;\n    }\n    // /** First try to find column with semType 'alignedSequence'.\n    //  * Next look for column with data alphabet corresponding to any of the known palettes.\n    //  * @param {DG.DataFrame} dataFrame\n    //  * @return {DG.Column} The column we were looking for or null\n    //  */\n    // private pickUpSeqCol(dataFrame: DG.DataFrame): DG.Column | null {\n    //   let res: DG.Column | null = dataFrame.columns.bySemType('alignedSequence');\n    //   if (res == null) {\n    //     for (const col of dataFrame.columns) {\n    //       const cp = WebLogo.pickUpPalette(col as DG.Column, 5);\n    //       if (cp !== null && !(cp instanceof UnknownSeqPalette)) {\n    //         res = col;\n    //         break;\n    //       }\n    //     }\n    //   }\n    //   return res;\n    // }\n    static pickUpSeqCol2(df) {\n        var _a;\n        const semTypeColList = df.columns.bySemTypeAll(DG.SEMTYPE.MACROMOLECULE);\n        let resCol = (_a = semTypeColList.find((col) => {\n            const units = col.getTag(DG.TAGS.UNITS);\n            return units ? units.indexOf('MSA') !== -1 : false;\n        })) !== null && _a !== void 0 ? _a : null;\n        if (!resCol && semTypeColList.length > 0)\n            resCol = semTypeColList[0];\n        return resCol;\n    }\n    /** Split sequence for single character monomers, square brackets multichar monomer names or gap symbol.\n     * @param {any} seq object with sequence\n     * @return {string[]} array of monomers\n     */\n    static splitterAsFasta(seq) {\n        const res = wu(seq.toString().matchAll(WebLogo.monomerRe))\n            .map((ma) => {\n            let mRes;\n            const m = ma[0];\n            if (m.length > 1) {\n                if (m in WebLogo.aaSynonyms) {\n                    mRes = WebLogo.aaSynonyms[m];\n                }\n                else {\n                    mRes = '';\n                    console.debug(`Long monomer '${m}' has not a short synonym.`);\n                }\n            }\n            else {\n                mRes = m;\n            }\n            return mRes;\n        }).toArray();\n        return res;\n    }\n    /** Gets method to split sequence by separator\n     * @param {string} separator\n     * @return {SplitterFunc}\n     */\n    static getSplitterWithSeparator(separator) {\n        return (seq) => {\n            return seq.split(separator);\n        };\n    }\n    /** Get splitter method to split sequences to monomers\n     * @param {string} units\n     * @param {string} separator\n     * @return {SplitterFunc}\n     */\n    static getSplitter(units, separator) {\n        if (units.toLowerCase().startsWith('fasta'))\n            return WebLogo.splitterAsFasta;\n        else if (units.toLowerCase().startsWith('separator'))\n            return WebLogo.getSplitterWithSeparator(separator);\n        /*\n        else if (units.toLowerCase().startsWith('helm'))\n          return WebLogo.splitterAsHelm;\n        /**/\n        else\n            throw new Error(`Unexpected units ${units} .`);\n        // TODO: Splitter for HELM\n    }\n    static getSplitterForColumn(col) {\n        if (col.semType !== DG.SEMTYPE.MACROMOLECULE)\n            throw new Error(`Get splitter for semType \"${DG.SEMTYPE.MACROMOLECULE}\" only.`);\n        const units = col.getTag(DG.TAGS.UNITS);\n        const separator = col.getTag('separator');\n        return WebLogo.getSplitter(units, separator);\n    }\n}\nWebLogo.residuesSet = 'nucleotides';\nWebLogo.viewerCount = -1;\nWebLogo.monomerRe = /\\[(\\w+)\\]|(\\w)|(-)/g;\n/** Only some of the synonyms. These were obtained from the clustered oligopeptide dataset. */\nWebLogo.aaSynonyms = {\n    '[MeNle]': 'L',\n    '[MeA]': 'A',\n    '[MeG]': 'G',\n    '[MeF]': 'F',\n};\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web-logo.js","sourceRoot":"","sources":["web-logo.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\n\nimport wu from 'wu';\nimport * as rxjs from 'rxjs';\n\nimport {Vector} from '@datagrok-libraries/utils/src/type-declarations';\nimport {vectorLength, vectorDotProduct} from '@datagrok-libraries/utils/src/vector-operations';\nimport {Aminoacids, AminoacidsPalettes} from '../aminoacids';\nimport {Nucleotides, NucleotidesPalettes} from '../nucleotides';\nimport {UnknownSeqPalette, UnknownSeqPalettes} from '../unknown';\nimport {SeqPalette} from '../seq-palettes';\nimport {Subscription} from 'rxjs';\n\ndeclare module 'datagrok-api/src/grid' {\n  interface Rect {\n    contains(x: number, y: number): boolean;\n  }\n}\n\ndeclare global {\n  interface HTMLCanvasElement {\n    getCursorPosition(event: MouseEvent): DG.Point;\n  }\n}\n\nexport type MonomerFreqs = { [m: string]: number };\nexport type SeqColStats = { freq: MonomerFreqs, sameLength: boolean }\nexport type SplitterFunc = (seq: string) => string[];\n\nHTMLCanvasElement.prototype.getCursorPosition = function(event: MouseEvent): DG.Point {\n  const rect = this.getBoundingClientRect();\n  return new DG.Point(event.clientX - rect.left, event.clientY - rect.top);\n};\n\nDG.Rect.prototype.contains = function(x: number, y: number): boolean {\n  return this.left <= x && x <= this.right && this.top <= y && y <= this.bottom;\n};\n\nexport class PositionMonomerInfo {\n  /** Sequences count with monomer in position\n   */\n  count: number;\n\n  /** Remember screen coords rect\n   */\n  bounds: DG.Rect;\n\n  constructor() {\n    this.count = 0;\n    this.bounds = new DG.Rect(0, 0, 0, 0);\n  }\n}\n\nexport class PositionInfo {\n  public readonly name: string;\n  freq: { [m: string]: PositionMonomerInfo };\n  rowCount: number;\n\n  /** freq = {}, rowCount = 0\n   * @param {string} name Name of position ('111A', '111.1', etc)\n   */\n  constructor(name: string) {\n    this.name = name;\n    this.freq = {};\n    this.rowCount = 0;\n  }\n}\n\nexport class WebLogo extends DG.JsViewer {\n  public static residuesSet = 'nucleotides';\n  private static viewerCount: number = -1;\n\n  private viewerId: number = -1;\n  private initialized: boolean = false;\n\n  // private readonly colorScheme: ColorScheme = ColorSchemes[NucleotidesWebLogo.residuesSet];\n  protected cp: SeqPalette | null = null;\n\n  private host?: HTMLDivElement;\n  private msgHost?: HTMLElement;\n  private canvas?: HTMLCanvasElement;\n  private slider?: DG.RangeSlider;\n  private textBaseline: CanvasTextBaseline;\n\n  private axisHeight: number = 12;\n\n  private seqCol: DG.Column<string> | null = null;\n  private splitter: SplitterFunc | null = null;\n  // private maxLength: number = 100;\n  private positions: PositionInfo[] = [];\n\n  private rowsMasked: number = 0;\n  private rowsNull: number = 0;\n\n  // Viewer's properties (likely they should be public so that they can be set outside)\n  private _positionWidth: number;\n  public positionWidth: number;\n  public minHeight: number;\n  public maxHeight: number;\n  public considerNullSequences: boolean;\n  public sequenceColumnName: string | null;\n  public startPositionName: string | null;\n  public endPositionName: string | null;\n  public fixWidth: boolean;\n  public verticalAlignment: string | null;\n  public horizontalAlignment: string | null;\n  public fitArea: boolean;\n  public shrinkEmptyTail: boolean;\n  public skipEmptyPositions: boolean;\n\n  private positionNames: string[] = [];\n\n  private startPosition: number = -1;\n\n  private endPosition: number = -1;\n\n  /** For startPosition equals to endPosition Length is 1 */\n  private get Length(): number {\n    return this.startPosition <= this.endPosition ? this.endPosition - this.startPosition + 1 : 0;\n  }\n\n  private viewSubs: Subscription[] = [];\n\n  constructor() {\n    super();\n\n    this.viewerId = WebLogo.viewerCount;\n    WebLogo.viewerCount += 1;\n\n    this.textBaseline = 'top';\n\n    this._positionWidth = this.positionWidth = this.float('positionWidth', 16/*,\n      {editor: 'slider', min: 4, max: 64, postfix: 'px'}*/);\n    this.minHeight = this.float('minHeight', 50/*,\n      {editor: 'slider', min: 25, max: 250, postfix: 'px'}*/);\n    this.maxHeight = this.float('maxHeight', 100/*,\n      {editor: 'slider', min: 25, max: 500, postfix: 'px'}*/);\n\n    this.considerNullSequences = this.bool('considerNullSequences', false);\n    this.sequenceColumnName = this.string('sequenceColumnName', null);\n\n    this.startPositionName = this.string('startPositionName', null);\n    this.endPositionName = this.string('endPositionName', null);\n\n    this.fixWidth = this.bool('fixWidth', false);\n\n    this.verticalAlignment = this.string('verticalAlignment', 'middle',\n      {choices: ['top', 'middle', 'bottom']});\n    this.horizontalAlignment = this.string('horizontalAlignment', 'center',\n      {choices: ['left', 'center', 'right']});\n    this.fitArea = this.bool('fitArea', true);\n    this.shrinkEmptyTail = this.bool('shrinkEmptyTail', true);\n    this.skipEmptyPositions = this.bool('skipEmptyPositions', false);\n  }\n\n  private async init(): Promise<void> {\n    if (this.initialized) {\n      console.error('WebLogo second initialization!');\n      return;\n    }\n\n    this.initialized = true;\n    this.helpUrl = '/help/visualize/viewers/web-logo.md';\n\n    this.msgHost = ui.div('No message');\n    this.msgHost.style.display = 'none';\n\n    this.canvas = ui.canvas();\n    this.canvas.style.width = '100%';\n\n    this.host = ui.div([this.msgHost, this.canvas]);\n\n    // this.slider = ui.rangeSlider(0, 20, 2, 5);\n    // this.slider.root.style.width = '100%';\n    // this.slider.root.style.height = '12px';\n\n    const getMonomer = (p: DG.Point): [number, string | null, PositionMonomerInfo | null] => {\n      const jPos = Math.floor(p.x / this._positionWidth);\n      const position = this.positions[jPos];\n\n      if (position === void 0)\n        return [jPos, null, null];\n\n      const monomer: string | undefined = Object.keys(position.freq)\n        .find((m) => position.freq[m].bounds.contains(p.x, p.y));\n      if (monomer === undefined)\n        return [jPos, null, null];\n\n      return [jPos, monomer, position.freq[monomer]];\n    };\n\n\n    // this.subs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mouseover').subscribe((e: MouseEvent) => {\n    // }));\n\n    this.viewSubs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mousemove').subscribe((e: MouseEvent) => {\n      if (!this.canvas)\n        return;\n\n      const args = e as MouseEvent;\n      const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n\n      if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n        ui.tooltip.showRowGroup(this.dataFrame, (iRow) => {\n          const seq = this.seqCol!.get(iRow);\n          const seqM = seq ? this.splitter!(seq)[this.startPosition + jPos] : null;\n          return seqM === monomer && this.dataFrame.filter.get(iRow);\n        }, args.x + 16, args.y + 16);\n      } else {\n        ui.tooltip.hide();\n      }\n    }));\n\n    this.viewSubs.push(rxjs.fromEvent<MouseEvent>(this.canvas, 'mousedown').subscribe((e: MouseEvent) => {\n      if (!this.canvas || e.button != 0)\n        return;\n\n      const args = e as MouseEvent;\n      const [jPos, monomer] = getMonomer(this.canvas.getCursorPosition(args));\n\n      // prevents deselect all rows if we miss monomer bounds\n      if (this.dataFrame && this.seqCol && this.splitter && monomer) {\n        this.dataFrame.selection.init((iRow) => {\n          const seq = this.seqCol!.get(iRow);\n          const seqM = seq ? this.splitter!(seq)[this.startPosition + jPos] : null;\n          return seqM === monomer && this.dataFrame.filter.get(iRow);\n        });\n      }\n    }));\n\n    this.viewSubs.push(ui.onSizeChanged(this.root).subscribe(this.rootOnSizeChanged.bind(this)));\n\n    this.root.append(this.host);\n    // this.root.appendChild(this.slider.root);\n\n    this.render(true);\n  }\n\n  private rootOnSizeChanged(args: any) {\n    this.render(true);\n\n    // console.debug(`WebLogo.onRootSizeChanged() ` +\n    //   `root.width=${this.root.clientWidth}, root.height=${this.root.clientHeight}, ` +\n    //   `canvas.width=${this.canvas.width}, canvas.height=${this.canvas.height} .`);\n  }\n\n  /** Assigns {@link seqCol} and {@link cp} based on {@link sequenceColumnName} and calls {@link render}().\n   */\n  private updateSeqCol(): void {\n    if (this.dataFrame) {\n      this.seqCol = this.sequenceColumnName ? this.dataFrame.col(this.sequenceColumnName) : null;\n      if (this.seqCol == null) {\n        this.seqCol = WebLogo.pickUpSeqCol2(this.dataFrame);\n        this.sequenceColumnName = this.seqCol ? this.seqCol.name : null;\n      }\n      if (this.seqCol) {\n        const units: string = this.seqCol!.getTag(DG.TAGS.UNITS);\n        const separator: string = this.seqCol!.getTag('separator');\n        this.splitter = WebLogo.getSplitter(units, separator);\n\n        this.updatePositions();\n        this.cp = WebLogo.pickUpPalette(this.seqCol);\n      } else {\n        this.splitter = null;\n        this.positionNames = [];\n        this.startPosition = -1;\n        this.endPosition = -1;\n        this.cp = null;\n      }\n    }\n    this.render();\n  }\n\n  private updatePositions(): void {\n    if (!this.seqCol)\n      return;\n\n    let categories: (string | null) [];\n    if (this.shrinkEmptyTail) {\n      const indices: Int32Array = this.dataFrame.filter.getSelectedIndexes();\n      categories = Array.from(new Set(\n        Array.from(Array(indices.length).keys()).map((i: number) => this.seqCol!.get(indices[i]))));\n    } else {\n      categories = this.seqCol.categories;\n    }\n    const maxLength = categories.length > 0 ? Math.max(...categories.map(\n      (s) => s !== null ? this.splitter!(s).length : 0)) : 0;\n\n    // Get position names from data column tag 'positionNames'\n    const positionNamesTxt = this.seqCol.getTag('positionNames');\n    // Fallback if 'positionNames' tag is not provided\n    this.positionNames = positionNamesTxt ? positionNamesTxt.split(', ').map((n) => n.trim()) :\n      [...Array(maxLength).keys()].map((jPos) => `${jPos + 1}`);\n\n    this.startPosition = (this.startPositionName && this.positionNames &&\n      this.positionNames.includes(this.startPositionName)) ?\n      this.positionNames.indexOf(this.startPositionName) : 0;\n    this.endPosition = (this.endPositionName && this.positionNames &&\n      this.positionNames.includes(this.endPositionName)) ?\n      this.positionNames.indexOf(this.endPositionName) : (maxLength - 1);\n  }\n\n  public override onPropertyChanged(property: DG.Property): void {\n    // console.debug(`WebLogo.onPropertyChanged( ${property.name} = '' })`);\n    super.onPropertyChanged(property);\n\n    switch (property.name) {\n    case 'considerNullSequences':\n      this.render(true);\n      break;\n    case 'sequenceColumnName':\n      this.updateSeqCol();\n      break;\n    case 'startPositionName':\n      this.updateSeqCol();\n      break;\n    case 'endPositionName':\n      this.updateSeqCol();\n      break;\n    case 'positionWidth':\n      this._positionWidth = this.positionWidth;\n      this.render(true);\n      break;\n    case 'minHeight':\n      this.render(true);\n      break;\n    case 'maxHeight':\n      this.render(true);\n      break;\n    case 'fixWidth':\n      this.render(true);\n      break;\n    case 'verticalAlignment':\n      this.render(true);\n      break;\n    case 'horizontalAlignment':\n      this.render(true);\n      break;\n    case 'fitArea':\n      this.render(true);\n      break;\n    case 'shrinkEmptyTail':\n      this.updatePositions();\n      this.render(true);\n      break;\n    }\n  }\n\n  public override async onTableAttached() {\n    const dataFrameTxt: string = this.dataFrame ? 'data' : 'null';\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n    super.onTableAttached();\n\n    this.updateSeqCol();\n\n    if (this.dataFrame !== void 0) {\n      this.subs.push(this.dataFrame.selection.onChanged.subscribe((_) => this.render()));\n      this.subs.push(this.dataFrame.filter.onChanged.subscribe((_) => {\n        this.updatePositions();\n        this.render();\n      }));\n    }\n\n    await this.init();\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n  }\n\n  public override async detach() {\n    const dataFrameTxt = `${this.dataFrame ? 'data' : 'null'}`;\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached( dataFrame = ${dataFrameTxt} ) start`);\n    super.detach();\n\n    this.viewSubs.forEach((sub) => sub.unsubscribe());\n    this.host!.remove();\n    this.canvas = undefined;\n    this.msgHost = undefined;\n    this.host = undefined;\n\n    this.initialized = false;\n    console.debug(`bio: WebLogo<${this.viewerId}>.onTableAttached() end`);\n  }\n\n  protected _nullSequence(fillerResidue = 'X'): string {\n    if (this.considerNullSequences)\n      return new Array(this.Length).fill(fillerResidue).join('');\n\n    return '';\n  }\n\n  protected _calculate() {\n    if (!this.canvas || !this.host || !this.seqCol || !this.dataFrame)\n      return;\n\n    this.calcSize();\n\n    this.positions = new Array(this.Length);\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      const posName: string = this.positionNames[this.startPosition + jPos];\n      this.positions[jPos] = new PositionInfo(posName);\n    }\n\n    // 2022-05-05 askalkin instructed to show WebLogo based on filter (not selection)\n    const indices = this.dataFrame.filter.getSelectedIndexes();\n    // const indices = this.dataFrame.selection.trueCount > 0 ? this.dataFrame.selection.getSelectedIndexes() :\n    //   this.dataFrame.filter.getSelectedIndexes();\n\n    this.rowsMasked = indices.length;\n    this.rowsNull = 0;\n\n    for (const i of indices) {\n      let s: string = <string>(this.seqCol.get(i));\n\n      if (!s) {\n        s = this._nullSequence();\n        ++this.rowsNull;\n      }\n\n      const seqM: string[] = this.splitter!(s);\n      for (let jPos = 0; jPos < this.Length; jPos++) {\n        const pmInfo = this.positions[jPos].freq;\n        const m: string = seqM[this.startPosition + jPos] || '-';\n        if (!(m in pmInfo))\n          pmInfo[m] = new PositionMonomerInfo();\n        pmInfo[m].count++;\n      }\n    }\n\n    //#region Polish freq counts\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      // delete this.positions[jPos].freq['-'];\n\n      this.positions[jPos].rowCount = 0;\n      for (const m in this.positions[jPos].freq)\n        this.positions[jPos].rowCount += this.positions[jPos].freq[m].count;\n    }\n    //#endregion\n\n    const r = window.devicePixelRatio;\n    const maxHeight = this.canvas.height - this.axisHeight * r;\n    // console.debug(`WebLogo<${this.viewerId}>._calculate() maxHeight=${maxHeight}.`);\n\n    //#region Calculate screen\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      const freq: { [c: string]: PositionMonomerInfo } = this.positions[jPos].freq;\n      const rowCount = this.positions[jPos].rowCount;\n\n      let y: number = this.axisHeight;\n\n      const entries = Object.entries(freq).sort((a, b) => {\n        if (a[0] !== '-' && b[0] !== '-')\n          return b[1].count - a[1].count;\n        else if (a[0] === '-' && b[0] === '-')\n          return 0;\n        else if (a[0] === '-')\n          return -1;\n        else /* (b[0] === '-') */\n          return +1;\n      });\n      for (const entry of entries) {\n        const pmInfo: PositionMonomerInfo = entry[1];\n        // const m: string = entry[0];\n        const h: number = maxHeight * pmInfo.count / rowCount;\n\n        pmInfo.bounds = new DG.Rect(jPos * this._positionWidth, y, this._positionWidth, h);\n        y += h;\n      }\n    }\n    //#endregion\n  }\n\n  // reflect changes made to filter/selection\n  render(recalc = true) {\n    if (this.msgHost) {\n      if (this.seqCol && !this.cp) {\n        this.msgHost!.innerText = `Unknown palette (column semType: '${this.seqCol.semType}').`;\n        this.msgHost!.style.display = '';\n      } else {\n        this.msgHost!.style.display = 'none';\n      }\n    }\n\n    if (!this.canvas || !this.seqCol || !this.dataFrame || !this.cp)\n      return;\n\n    const g = this.canvas.getContext('2d');\n    if (!g) return;\n\n    if (recalc)\n      this._calculate();\n\n    g.resetTransform();\n    g.fillStyle = 'white';\n    g.fillRect(0, 0, this.canvas.width, this.canvas.height);\n    g.textBaseline = this.textBaseline;\n\n    // Prevents division by zero on Length = 0\n    if (this.startPosition === -1 || this.endPosition === -1)\n      return;\n\n    //#region Plot positionNames\n    g.resetTransform();\n    g.fillStyle = 'black';\n    g.textAlign = 'center';\n    g.font = '10px Roboto, Roboto Local, sans-serif';\n    const posNameMaxWidth = Math.max(...this.positions.map((pos) => g.measureText(pos.name).width));\n    const hScale = posNameMaxWidth < (this._positionWidth - 2) ? 1 : (this._positionWidth - 2) / posNameMaxWidth;\n\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      const pos: PositionInfo = this.positions[jPos];\n      g.resetTransform();\n      g.setTransform(\n        hScale, 0, 0, 1,\n        jPos * this._positionWidth + this._positionWidth / 2, 0);\n      g.fillText(pos.name, 0, 0);\n    }\n    //#endregion Plot positionNames\n\n    for (let jPos = 0; jPos < this.Length; jPos++) {\n      for (const [monomer, pmInfo] of Object.entries(this.positions[jPos].freq)) {\n        if (monomer !== '-') {\n          const b = pmInfo.bounds;\n\n          const fontStyle = '16px Roboto, Roboto Local, sans-serif';\n          // Hacks to scale uppercase characters to target rectangle\n          const uppercaseLetterAscent = 0.25;\n          const uppercaseLetterHeight = 12.2;\n\n          g.resetTransform();\n          g.strokeStyle = 'lightgray';\n          g.lineWidth = 1;\n          g.rect(b.left, b.top, b.width, b.height);\n          g.fillStyle = this.cp.get(monomer) ?? this.cp.get('other');\n          g.textAlign = 'left';\n          g.font = fontStyle;\n          //g.fillRect(b.left, b.top, b.width, b.height);\n          const mTm: TextMetrics = g.measureText(monomer);\n\n          // if (mM.actualBoundingBoxAscent != 0)\n          //   console.debug(`m: ${m}, mM.actualBoundingBoxAscent: ${mM.actualBoundingBoxAscent}`);\n\n          g.setTransform(\n            b.width / mTm.width, 0, 0, b.height / uppercaseLetterHeight,\n            b.left, b.top);\n          g.fillText(monomer, 0, -uppercaseLetterAscent);\n        }\n      }\n    }\n  }\n\n  private calcSize() {\n    if (!this.canvas || !this.host)\n      return;\n\n    let width: number = this.Length * this.positionWidth;\n    let height = Math.min(this.maxHeight, Math.max(this.minHeight, this.root.clientHeight));\n\n    if (this.fitArea) {\n      const xScale: number = this.root.clientHeight / height;\n      const yScale: number = this.root.clientWidth / width;\n      const scale = Math.max(1, Math.min(xScale, yScale));\n      width = width * scale;\n      height = height * scale;\n      this._positionWidth = this.positionWidth * scale;\n    }\n\n    const r = window.devicePixelRatio;\n    this.canvas.width = width * r;\n    this.canvas.style.width = `${width}px`;\n\n    // const canvasHeight: number = width > this.root.clientWidth ? height - 8 : height;\n    this.host.style.setProperty('height', `${height}px`);\n    const canvasHeight: number = this.host.clientHeight;\n    this.canvas.height = canvasHeight * r;\n    this.canvas.style.setProperty('height', `${canvasHeight}px`);\n\n    // Adjust host and root width\n    if (this.fixWidth) {\n      // full width for canvas host and root\n      this.root.style.width = this.host.style.width = `${width}px`;\n      this.root.style.height = `${height}px`;\n      this.host.style.setProperty('overflow', 'hidden', 'important');\n    } else {\n      // allow scroll canvas in root\n      this.root.style.width = this.host.style.width = '100%';\n      this.host.style.overflowX = 'auto!important';\n      this.host.style.setProperty('overflow', null);\n\n      this.host.style.setProperty('text-align', this.horizontalAlignment);\n\n      // vertical alignment\n      let hostTopMargin = 0;\n      switch (this.verticalAlignment) {\n      case 'top':\n        hostTopMargin = 0;\n        break;\n      case 'middle':\n        hostTopMargin = Math.max(0, (this.root.clientHeight - height) / 2);\n        break;\n      case 'bottom':\n        hostTopMargin = Math.max(0, this.root.clientHeight - height);\n        break;\n      }\n      this.host.style.setProperty('margin-top', `${hostTopMargin}px`, 'important');\n\n      if (this.root.clientHeight < height) {\n        this.host.style.setProperty('height', `${this.root.clientHeight}px`);\n        this.host.style.setProperty('overflow-y', null);\n      } else {\n        this.host.style.setProperty('overflow-y', 'hidden', 'important');\n      }\n    }\n\n    // console.debug(\n    //   `this.root.style.height = ${this.root.style.height}\\n` +\n    //   `this.root.clientHeight = ${this.root.clientHeight}\\n` +\n    //   `this.host.style.height = ${this.host.style.height}\\n` +\n    //   `this.host.clientHeight = ${this.host.clientHeight}\\n` +\n    //   '\\n' +\n    //   `this.canvas.height       = ${this.canvas.height}\\n` +\n    //   `this.canvas.style.height = ${this.canvas.style.height}`);\n  }\n\n  /**\n   * @param {DG.Column} seqCol Column to look for a palette\n   * @param {number}  minLength minimum length of sequence to detect palette (empty strings are allowed)\n   * @return {SeqPalette} Palette corresponding to the alphabet of the sequences in the column\n   */\n  public static pickUpPalette(seqCol: DG.Column, minLength: number = 5): SeqPalette {\n    let res: SeqPalette | null = null;\n    switch (seqCol.semType) {\n    case Aminoacids.SemTypeMultipleAlignment:\n      res = AminoacidsPalettes.GrokGroups;\n      break;\n    case Nucleotides.SemTypeMultipleAlignment:\n      res = NucleotidesPalettes.Chromatogram;\n      break;\n    }\n    const stats: SeqColStats = WebLogo.getStats(seqCol, minLength, WebLogo.splitterAsFasta);\n\n    const alphabetCandidates: [Set<string>, SeqPalette][] = [\n      [new Set(Object.keys(Nucleotides.Names)), NucleotidesPalettes.Chromatogram],\n      [new Set(Object.keys(Aminoacids.Names)), AminoacidsPalettes.GrokGroups],\n    ];\n    // Calculate likelihoods for alphabet_candidates\n    const alphabetCandidatesSim: number[] = alphabetCandidates\n      .map((c) => WebLogo.getAlphabetSimilarity(stats.freq, c[0]));\n    const maxCos = Math.max(...alphabetCandidatesSim);\n    if (maxCos > 0.65)\n      res = alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][1];\n    else\n      res = UnknownSeqPalettes.Color;\n\n    return res;\n  }\n\n  /** Stats of sequences with specified splitter func, returns { freq, sameLength }.\n   * @param {DG.Column} seqCol\n   * @param {number} minLength\n   * @param {SplitterFunc} splitter\n   * @return { SeqColStats }, sameLength: boolean } stats of column sequences\n   */\n  static getStats(seqCol: DG.Column, minLength: number, splitter: SplitterFunc): SeqColStats {\n    const freq: { [m: string]: number } = {};\n    let sameLength = true;\n    let firstLength = null;\n\n    for (const seq of seqCol.categories) {\n      const mSeq = splitter(seq);\n\n      if (firstLength == null)\n        firstLength = mSeq.length;\n      else if (mSeq.length !== firstLength)\n        sameLength = false;\n\n      if (mSeq.length > minLength) {\n        for (const m of mSeq) {\n          if (!(m in freq))\n            freq[m] = 0;\n          freq[m] += 1;\n        }\n      }\n    }\n    return {freq: freq, sameLength: sameLength};\n  }\n\n  public static getAlphabetSimilarity(freq: MonomerFreqs, alphabet: Set<string>, gapSymbol: string = '-'): number {\n    const keys = new Set<string>([...new Set(Object.keys(freq)), ...alphabet]);\n    keys.delete(gapSymbol);\n\n    const freqA: number[] = [];\n    const alphabetA: number[] = [];\n    for (const m of keys) {\n      freqA.push(m in freq ? freq[m] : 0);\n      alphabetA.push(alphabet.has(m) ? 1 : 0);\n    }\n    /* There were a few ideas: chi-squared, pearson correlation (variance?), scalar product */\n    const freqV: Vector = new Vector(freqA);\n    const alphabetV: Vector = new Vector(alphabetA);\n    const cos: number = vectorDotProduct(freqV, alphabetV) / (vectorLength(freqV) * vectorLength(alphabetV));\n    return cos;\n  }\n\n  // /** First try to find column with semType 'alignedSequence'.\n  //  * Next look for column with data alphabet corresponding to any of the known palettes.\n  //  * @param {DG.DataFrame} dataFrame\n  //  * @return {DG.Column} The column we were looking for or null\n  //  */\n  // private pickUpSeqCol(dataFrame: DG.DataFrame): DG.Column | null {\n  //   let res: DG.Column | null = dataFrame.columns.bySemType('alignedSequence');\n  //   if (res == null) {\n  //     for (const col of dataFrame.columns) {\n  //       const cp = WebLogo.pickUpPalette(col as DG.Column, 5);\n  //       if (cp !== null && !(cp instanceof UnknownSeqPalette)) {\n  //         res = col;\n  //         break;\n  //       }\n  //     }\n  //   }\n  //   return res;\n  // }\n\n  public static pickUpSeqCol2(df: DG.DataFrame): DG.Column | null {\n    const semTypeColList = df.columns.bySemTypeAll(DG.SEMTYPE.MACROMOLECULE);\n    let resCol: DG.Column | null = semTypeColList.find((col) => {\n      const units = col.getTag(DG.TAGS.UNITS);\n      return units ? units.indexOf('MSA') !== -1 : false;\n    }) ?? null;\n    if (!resCol && semTypeColList.length > 0)\n      resCol = semTypeColList[0];\n    return resCol;\n  }\n\n  private static monomerRe = /\\[(\\w+)\\]|(\\w)|(-)/g;\n\n  /** Split sequence for single character monomers, square brackets multichar monomer names or gap symbol.\n   * @param {any} seq object with sequence\n   * @return {string[]} array of monomers\n   */\n  public static splitterAsFasta(seq: any): string[] {\n    const res: string[] = wu<RegExpMatchArray>(seq.toString().matchAll(WebLogo.monomerRe))\n      .map((ma: RegExpMatchArray) => {\n        let mRes: string;\n        const m: string = ma[0];\n        if (m.length > 1) {\n          if (m in WebLogo.aaSynonyms) {\n            mRes = WebLogo.aaSynonyms[m];\n          } else {\n            mRes = '';\n            console.debug(`Long monomer '${m}' has not a short synonym.`);\n          }\n        } else {\n          mRes = m;\n        }\n        return mRes;\n      }).toArray();\n\n    return res;\n  }\n\n  /** Gets method to split sequence by separator\n   * @param {string} separator\n   * @return {SplitterFunc}\n   */\n  public static getSplitterWithSeparator(separator: string): SplitterFunc {\n    return (seq: string) => {\n      return seq.split(separator);\n    };\n  }\n\n  /** Get splitter method to split sequences to monomers\n   * @param {string} units\n   * @param {string} separator\n   * @return {SplitterFunc}\n   */\n  public static getSplitter(units: string, separator: string): SplitterFunc {\n    if (units.toLowerCase().startsWith('fasta'))\n      return WebLogo.splitterAsFasta;\n    else if (units.toLowerCase().startsWith('separator'))\n      return WebLogo.getSplitterWithSeparator(separator);\n    /*\n    else if (units.toLowerCase().startsWith('helm'))\n      return WebLogo.splitterAsHelm;\n    /**/\n    else\n      throw new Error(`Unexpected units ${units} .`);\n\n    // TODO: Splitter for HELM\n  }\n\n  public static getSplitterForColumn(col: DG.Column): SplitterFunc {\n    if (col.semType !== DG.SEMTYPE.MACROMOLECULE)\n      throw new Error(`Get splitter for semType \"${DG.SEMTYPE.MACROMOLECULE}\" only.`);\n\n    const units = col.getTag(DG.TAGS.UNITS);\n    const separator = col.getTag('separator');\n    return WebLogo.getSplitter(units, separator);\n  }\n\n  /** Only some of the synonyms. These were obtained from the clustered oligopeptide dataset. */\n  private static aaSynonyms: { [name: string]: string } = {\n    '[MeNle]': 'L', // Nle - norleucine\n    '[MeA]': 'A',\n    '[MeG]': 'G',\n    '[MeF]': 'F',\n  };\n}\n"]}","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport { normalize } from '@datagrok-libraries/utils/src/vector-operations';\nimport { createDimensinalityReducingWorker } from './workers/dimensionality-reducing-worker-creator';\nexport function reduceDimensinalityWithNormalization(dataCol, methodName, similarityMetric, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const dimensionalityReduceRes = yield createDimensinalityReducingWorker({ data: dataCol, metric: similarityMetric }, methodName, options);\n        dimensionalityReduceRes.embedding = dimensionalityReduceRes.embedding.map(it => normalize(it));\n        return dimensionalityReduceRes;\n    });\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VxdWVuY2Utc3BhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzZXF1ZW5jZS1zcGFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFFQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saURBQWlELENBQUM7QUFHNUUsT0FBTyxFQUFFLGlDQUFpQyxFQUErQixNQUFNLGtEQUFrRCxDQUFDO0FBR2xJLE1BQU0sVUFBZ0Isb0NBQW9DLENBQ3RELE9BQXFDLEVBQ3JDLFVBQWtCLEVBQ2xCLGdCQUE2RCxFQUM3RCxPQUFhOztRQUViLE1BQU0sdUJBQXVCLEdBQ3pCLE1BQU0saUNBQWlDLENBQ25DLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsZ0JBQWdCLEVBQWdCLEVBQ3pELFVBQVUsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUU3Qix1QkFBdUIsQ0FBQyxTQUFTLEdBQUcsdUJBQXVCLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQy9GLE9BQU8sdUJBQXVCLENBQUM7SUFDbkMsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJpdEFycmF5IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL2JpdC1hcnJheSc7XG5pbXBvcnQgeyBNYXRyaXgsIFZlY3RvciB9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3R5cGUtZGVjbGFyYXRpb25zJztcbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3ZlY3Rvci1vcGVyYXRpb25zJztcbmltcG9ydCAqIGFzIERHIGZyb20gJ2RhdGFncm9rLWFwaS9kZyc7XG5pbXBvcnQgeyBCaXRBcnJheU1ldHJpY3MsIFN0cmluZ01ldHJpY3MsIFZhbGlkVHlwZXMsIFZlY3Rvck1ldHJpY3MgfSBmcm9tICcuL3R5cGVkLW1ldHJpY3MnO1xuaW1wb3J0IHsgY3JlYXRlRGltZW5zaW5hbGl0eVJlZHVjaW5nV29ya2VyLCBJUmVkdWNlRGltZW5zaW9uYWxpdHlSZXN1bHQgfSBmcm9tICcuL3dvcmtlcnMvZGltZW5zaW9uYWxpdHktcmVkdWNpbmctd29ya2VyLWNyZWF0b3InO1xuXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiByZWR1Y2VEaW1lbnNpbmFsaXR5V2l0aE5vcm1hbGl6YXRpb24oXG4gICAgZGF0YUNvbDogQml0QXJyYXlbXXxWZWN0b3JbXXxzdHJpbmdbXSwgXG4gICAgbWV0aG9kTmFtZTogc3RyaW5nLCBcbiAgICBzaW1pbGFyaXR5TWV0cmljOiBCaXRBcnJheU1ldHJpY3N8VmVjdG9yTWV0cmljc3xTdHJpbmdNZXRyaWNzLFxuICAgIG9wdGlvbnM/OiBhbnkpOiBQcm9taXNlPElSZWR1Y2VEaW1lbnNpb25hbGl0eVJlc3VsdD4ge1xuXG4gICAgY29uc3QgZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXM6IElSZWR1Y2VEaW1lbnNpb25hbGl0eVJlc3VsdCA9XG4gICAgICAgIGF3YWl0IGNyZWF0ZURpbWVuc2luYWxpdHlSZWR1Y2luZ1dvcmtlcihcbiAgICAgICAgICAgIHsgZGF0YTogZGF0YUNvbCwgbWV0cmljOiBzaW1pbGFyaXR5TWV0cmljIH0gYXMgVmFsaWRUeXBlcyxcbiAgICAgICAgICAgIG1ldGhvZE5hbWUsIG9wdGlvbnMpO1xuXG4gICAgZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXMuZW1iZWRkaW5nID0gZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXMuZW1iZWRkaW5nLm1hcChpdCA9PiBub3JtYWxpemUoaXQpKTtcbiAgICByZXR1cm4gZGltZW5zaW9uYWxpdHlSZWR1Y2VSZXM7XG59Il19","import * as fl from 'fastest-levenshtein';\nimport { jaroWinkler } from 'jaro-winkler-typescript';\nimport { distanceMetrics } from '@datagrok-libraries/utils/src/similarity-metrics';\nimport { calculateEuclideanDistance } from '@datagrok-libraries/utils/src/vector-operations';\nexport const AvailableMetrics = {\n    'Vector': {\n        'EuclideanDistance': calculateEuclideanDistance,\n    },\n    'String': {\n        'Levenshtein': fl.distance,\n        'Jaro-Winkler': jaroWinkler,\n    },\n    'BitArray': {\n        'Tanimoto': distanceMetrics['Tanimoto'],\n        'Dice': distanceMetrics['Dice'],\n        'Asymmetric': distanceMetrics['Asymmetric'],\n        'Braun-Blanquet': distanceMetrics['Braun-Blanquet'],\n        'Cosine': distanceMetrics['Cosine'],\n        'Kulczynski': distanceMetrics['Kulczynski'],\n        'Mc-Connaughey': distanceMetrics['Mc-Connaughey'],\n        'Rogot-Goldberg': distanceMetrics['Rogot-Goldberg'],\n        'Russel': distanceMetrics['Russel'],\n        'Sokal': distanceMetrics['Sokal'],\n    },\n};\nexport const MetricToDataType = Object.keys(AvailableMetrics)\n    .reduce((ret, key) => {\n    for (const val of Object.keys(AvailableMetrics[key])) {\n        ret[val] = key;\n    }\n    return ret;\n}, {});\nexport function isStringMetric(name) {\n    return MetricToDataType[name] == 'String';\n}\nexport function isBitArrayMetric(name) {\n    return MetricToDataType[name] == 'BitArray';\n}\nexport function isVectorMetric(name) {\n    return MetricToDataType[name] == 'Vector';\n}\n/** Unified class implementing different string measures. */\nexport class Measure {\n    /**\n     * Creates an instance of Measure with .\n     * @param {string} method Method to calculate distance between strings.\n     * @memberof Measurer\n     */\n    constructor(method) {\n        this.method = method;\n        this.dataType = MetricToDataType[method];\n    }\n    /**\n     * Returns custom string distance function specified.\n     * @return {DistanceMetric} Callback of the measure chosen.\n     * @memberof Measurer\n     */\n    getMeasure() {\n        const dict = AvailableMetrics;\n        return dict[this.dataType][this.method];\n    }\n    /**\n     * Returns custom string distance by the given data type.\n     * @param {AvailableDataTypes} dataType Metric's data type\n     * @return {string[]} Metric names which expects the given data type\n     * @memberof Measurer\n     */\n    static getMetricByDataType(dataType) {\n        return Object.keys(AvailableMetrics[dataType]);\n    }\n    /** Returns metric names available.\n     * @memberof Measurer\n    */\n    static get availableMeasures() {\n        return Object.keys(AvailableMetrics);\n    }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZWQtbWV0cmljcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInR5cGVkLW1ldHJpY3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMxQyxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFFcEQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLGtEQUFrRCxDQUFDO0FBQ2pGLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBSTNGLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHO0lBQzlCLFFBQVEsRUFBRTtRQUNSLG1CQUFtQixFQUFFLDBCQUEwQjtLQUNoRDtJQUNELFFBQVEsRUFBRTtRQUNSLGFBQWEsRUFBRSxFQUFFLENBQUMsUUFBUTtRQUMxQixjQUFjLEVBQUUsV0FBVztLQUM1QjtJQUNELFVBQVUsRUFBRTtRQUNWLFVBQVUsRUFBRSxlQUFlLENBQUMsVUFBVSxDQUFDO1FBQ3ZDLE1BQU0sRUFBRSxlQUFlLENBQUMsTUFBTSxDQUFDO1FBQy9CLFlBQVksRUFBRSxlQUFlLENBQUMsWUFBWSxDQUFDO1FBQzNDLGdCQUFnQixFQUFFLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQztRQUNuRCxRQUFRLEVBQUUsZUFBZSxDQUFDLFFBQVEsQ0FBQztRQUNuQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFlBQVksQ0FBQztRQUMzQyxlQUFlLEVBQUUsZUFBZSxDQUFDLGVBQWUsQ0FBQztRQUNqRCxnQkFBZ0IsRUFBRSxlQUFlLENBQUMsZ0JBQWdCLENBQUM7UUFDbkQsUUFBUSxFQUFFLGVBQWUsQ0FBQyxRQUFRLENBQUM7UUFDbkMsT0FBTyxFQUFFLGVBQWUsQ0FBQyxPQUFPLENBQUM7S0FDbEM7Q0FDRixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQXFCLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7S0FDNUUsTUFBTSxDQUFDLENBQUMsR0FBcUIsRUFBRSxHQUFHLEVBQUUsRUFBRTtJQUNyQyxLQUFLLE1BQU0sR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBeUIsQ0FBQyxDQUFDLEVBQUU7UUFDMUUsR0FBRyxDQUFDLEdBQXlCLENBQUMsR0FBRyxHQUFHLENBQUM7S0FDdEM7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztBQVdULE1BQU0sVUFBVSxjQUFjLENBQUMsSUFBa0I7SUFDL0MsT0FBTyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxRQUFRLENBQUM7QUFDNUMsQ0FBQztBQUVELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxJQUFrQjtJQUNqRCxPQUFPLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLFVBQVUsQ0FBQztBQUM5QyxDQUFDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FBQyxJQUFrQjtJQUMvQyxPQUFPLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLFFBQVEsQ0FBQztBQUM1QyxDQUFDO0FBRUQsNERBQTREO0FBQzVELE1BQU0sT0FBTyxPQUFPO0lBSWxCOzs7O09BSUc7SUFDSCxZQUFZLE1BQW9CO1FBQzlCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxDQUF1QixDQUFDO0lBQ2pFLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksVUFBVTtRQUNmLE1BQU0sSUFBSSxHQUFzRCxnQkFBZ0IsQ0FBQztRQUNqRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxRQUE0QjtRQUM1RCxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQ7O01BRUU7SUFDRixNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZsIGZyb20gJ2Zhc3Rlc3QtbGV2ZW5zaHRlaW4nO1xuaW1wb3J0IHtqYXJvV2lua2xlcn0gZnJvbSAnamFyby13aW5rbGVyLXR5cGVzY3JpcHQnO1xuaW1wb3J0IHtEaXN0YW5jZU1ldHJpY30gZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvdHlwZS1kZWNsYXJhdGlvbnMnO1xuaW1wb3J0IHtkaXN0YW5jZU1ldHJpY3N9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3NpbWlsYXJpdHktbWV0cmljcyc7XG5pbXBvcnQge2NhbGN1bGF0ZUV1Y2xpZGVhbkRpc3RhbmNlfSBmcm9tICdAZGF0YWdyb2stbGlicmFyaWVzL3V0aWxzL3NyYy92ZWN0b3Itb3BlcmF0aW9ucyc7XG5pbXBvcnQgQml0QXJyYXkgZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvYml0LWFycmF5JztcbmltcG9ydCB7VmVjdG9yLCBTdHJpbmdEaWN0aW9uYXJ5fSBmcm9tICdAZGF0YWdyb2stbGlicmFyaWVzL3V0aWxzL3NyYy90eXBlLWRlY2xhcmF0aW9ucyc7XG5cbmV4cG9ydCBjb25zdCBBdmFpbGFibGVNZXRyaWNzID0ge1xuICAnVmVjdG9yJzoge1xuICAgICdFdWNsaWRlYW5EaXN0YW5jZSc6IGNhbGN1bGF0ZUV1Y2xpZGVhbkRpc3RhbmNlLFxuICB9LFxuICAnU3RyaW5nJzoge1xuICAgICdMZXZlbnNodGVpbic6IGZsLmRpc3RhbmNlLFxuICAgICdKYXJvLVdpbmtsZXInOiBqYXJvV2lua2xlcixcbiAgfSxcbiAgJ0JpdEFycmF5Jzoge1xuICAgICdUYW5pbW90byc6IGRpc3RhbmNlTWV0cmljc1snVGFuaW1vdG8nXSxcbiAgICAnRGljZSc6IGRpc3RhbmNlTWV0cmljc1snRGljZSddLFxuICAgICdBc3ltbWV0cmljJzogZGlzdGFuY2VNZXRyaWNzWydBc3ltbWV0cmljJ10sXG4gICAgJ0JyYXVuLUJsYW5xdWV0JzogZGlzdGFuY2VNZXRyaWNzWydCcmF1bi1CbGFucXVldCddLFxuICAgICdDb3NpbmUnOiBkaXN0YW5jZU1ldHJpY3NbJ0Nvc2luZSddLFxuICAgICdLdWxjenluc2tpJzogZGlzdGFuY2VNZXRyaWNzWydLdWxjenluc2tpJ10sXG4gICAgJ01jLUNvbm5hdWdoZXknOiBkaXN0YW5jZU1ldHJpY3NbJ01jLUNvbm5hdWdoZXknXSxcbiAgICAnUm9nb3QtR29sZGJlcmcnOiBkaXN0YW5jZU1ldHJpY3NbJ1JvZ290LUdvbGRiZXJnJ10sXG4gICAgJ1J1c3NlbCc6IGRpc3RhbmNlTWV0cmljc1snUnVzc2VsJ10sXG4gICAgJ1Nva2FsJzogZGlzdGFuY2VNZXRyaWNzWydTb2thbCddLFxuICB9LFxufTtcblxuZXhwb3J0IGNvbnN0IE1ldHJpY1RvRGF0YVR5cGU6IFN0cmluZ0RpY3Rpb25hcnkgPSBPYmplY3Qua2V5cyhBdmFpbGFibGVNZXRyaWNzKVxuICAucmVkdWNlKChyZXQ6IFN0cmluZ0RpY3Rpb25hcnksIGtleSkgPT4ge1xuICAgIGZvciAoY29uc3QgdmFsIG9mIE9iamVjdC5rZXlzKEF2YWlsYWJsZU1ldHJpY3Nba2V5IGFzIEF2YWlsYWJsZURhdGFUeXBlc10pKSB7XG4gICAgICByZXRbdmFsIGFzIEF2YWlsYWJsZURhdGFUeXBlc10gPSBrZXk7XG4gICAgfVxuICAgIHJldHVybiByZXQ7XG4gIH0sIHt9KTtcblxuZXhwb3J0IHR5cGUgQXZhaWxhYmxlRGF0YVR5cGVzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3M7XG5leHBvcnQgdHlwZSBTdHJpbmdNZXRyaWNzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3NbJ1N0cmluZyddO1xuZXhwb3J0IHR5cGUgQml0QXJyYXlNZXRyaWNzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3NbJ0JpdEFycmF5J107XG5leHBvcnQgdHlwZSBWZWN0b3JNZXRyaWNzID0ga2V5b2YgdHlwZW9mIEF2YWlsYWJsZU1ldHJpY3NbJ1ZlY3RvciddO1xuZXhwb3J0IHR5cGUgS25vd25NZXRyaWNzID0gU3RyaW5nTWV0cmljcyB8IEJpdEFycmF5TWV0cmljcyB8IFZlY3Rvck1ldHJpY3M7XG5cbmV4cG9ydCB0eXBlIFZhbGlkVHlwZXMgPSB7ZGF0YTogc3RyaW5nW10sIG1ldHJpYzogU3RyaW5nTWV0cmljc30gfCB7ZGF0YTogVmVjdG9yW10sIG1ldHJpYzogVmVjdG9yTWV0cmljc30gfFxuICAgICAgICAgICAgICAgICAgICAgICAgIHtkYXRhOiBCaXRBcnJheVtdLCBtZXRyaWM6IEJpdEFycmF5TWV0cmljc307XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1N0cmluZ01ldHJpYyhuYW1lOiBLbm93bk1ldHJpY3MpIHtcbiAgcmV0dXJuIE1ldHJpY1RvRGF0YVR5cGVbbmFtZV0gPT0gJ1N0cmluZyc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0JpdEFycmF5TWV0cmljKG5hbWU6IEtub3duTWV0cmljcykge1xuICByZXR1cm4gTWV0cmljVG9EYXRhVHlwZVtuYW1lXSA9PSAnQml0QXJyYXknO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNWZWN0b3JNZXRyaWMobmFtZTogS25vd25NZXRyaWNzKSB7XG4gIHJldHVybiBNZXRyaWNUb0RhdGFUeXBlW25hbWVdID09ICdWZWN0b3InO1xufVxuXG4vKiogVW5pZmllZCBjbGFzcyBpbXBsZW1lbnRpbmcgZGlmZmVyZW50IHN0cmluZyBtZWFzdXJlcy4gKi9cbmV4cG9ydCBjbGFzcyBNZWFzdXJlIHtcbiAgcHJvdGVjdGVkIG1ldGhvZDogS25vd25NZXRyaWNzO1xuICBwcm90ZWN0ZWQgZGF0YVR5cGU6IEF2YWlsYWJsZURhdGFUeXBlcztcblxuICAvKipcbiAgICogQ3JlYXRlcyBhbiBpbnN0YW5jZSBvZiBNZWFzdXJlIHdpdGggLlxuICAgKiBAcGFyYW0ge3N0cmluZ30gbWV0aG9kIE1ldGhvZCB0byBjYWxjdWxhdGUgZGlzdGFuY2UgYmV0d2VlbiBzdHJpbmdzLlxuICAgKiBAbWVtYmVyb2YgTWVhc3VyZXJcbiAgICovXG4gIGNvbnN0cnVjdG9yKG1ldGhvZDogS25vd25NZXRyaWNzKSB7XG4gICAgdGhpcy5tZXRob2QgPSBtZXRob2Q7XG4gICAgdGhpcy5kYXRhVHlwZSA9IE1ldHJpY1RvRGF0YVR5cGVbbWV0aG9kXSBhcyBBdmFpbGFibGVEYXRhVHlwZXM7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBjdXN0b20gc3RyaW5nIGRpc3RhbmNlIGZ1bmN0aW9uIHNwZWNpZmllZC5cbiAgICogQHJldHVybiB7RGlzdGFuY2VNZXRyaWN9IENhbGxiYWNrIG9mIHRoZSBtZWFzdXJlIGNob3Nlbi5cbiAgICogQG1lbWJlcm9mIE1lYXN1cmVyXG4gICAqL1xuICBwdWJsaWMgZ2V0TWVhc3VyZSgpOiBEaXN0YW5jZU1ldHJpYyB7XG4gICAgY29uc3QgZGljdDoge1trZXk6IHN0cmluZ106IHtba2V5Mjogc3RyaW5nXTogRGlzdGFuY2VNZXRyaWN9fSA9IEF2YWlsYWJsZU1ldHJpY3M7XG4gICAgcmV0dXJuIGRpY3RbdGhpcy5kYXRhVHlwZV1bdGhpcy5tZXRob2RdO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgY3VzdG9tIHN0cmluZyBkaXN0YW5jZSBieSB0aGUgZ2l2ZW4gZGF0YSB0eXBlLlxuICAgKiBAcGFyYW0ge0F2YWlsYWJsZURhdGFUeXBlc30gZGF0YVR5cGUgTWV0cmljJ3MgZGF0YSB0eXBlXG4gICAqIEByZXR1cm4ge3N0cmluZ1tdfSBNZXRyaWMgbmFtZXMgd2hpY2ggZXhwZWN0cyB0aGUgZ2l2ZW4gZGF0YSB0eXBlXG4gICAqIEBtZW1iZXJvZiBNZWFzdXJlclxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBnZXRNZXRyaWNCeURhdGFUeXBlKGRhdGFUeXBlOiBBdmFpbGFibGVEYXRhVHlwZXMpOiBzdHJpbmdbXSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKEF2YWlsYWJsZU1ldHJpY3NbZGF0YVR5cGVdKTtcbiAgfVxuXG4gIC8qKiBSZXR1cm5zIG1ldHJpYyBuYW1lcyBhdmFpbGFibGUuXG4gICAqIEBtZW1iZXJvZiBNZWFzdXJlclxuICAqL1xuICBzdGF0aWMgZ2V0IGF2YWlsYWJsZU1lYXN1cmVzKCk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXMoQXZhaWxhYmxlTWV0cmljcyk7XG4gIH1cbn1cbiJdfQ==","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\nlet zoom = false;\n// Searches for activity cliffs in a chemical dataset by selected cutoff\nexport function getActivityCliffs(df, seqCol, axesNames, scatterTitle, activities, similarity, similarityMetric, methodName, semType, units, seqSpaceFunc, simFunc, tooltipDrawFunc, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const automaticSimilarityLimit = false;\n        const MIN_SIMILARITY = 80;\n        const initialSimilarityLimit = automaticSimilarityLimit ? MIN_SIMILARITY : similarity / 100;\n        const { distance, coordinates } = yield seqSpaceFunc({\n            seqCol: seqCol,\n            methodName: methodName,\n            similarityMetric: similarityMetric,\n            embedAxesNames: axesNames,\n            options: options\n        });\n        for (const col of coordinates)\n            df.columns.add(col);\n        const dfSeq = DG.DataFrame.fromColumns([DG.Column.fromList('string', 'seq', seqCol.toList())]);\n        const dim = seqCol.length;\n        const simArr = Array(dim - 1);\n        if (!distance)\n            yield getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc);\n        else\n            getSimilaritiesMarixFromDistances(dim, distance, simArr);\n        const optSimilarityLimit = initialSimilarityLimit;\n        const simVals = [];\n        const saliVals = [];\n        const n1 = [];\n        const n2 = [];\n        for (let i = 0; i != dim - 1; ++i) {\n            for (let j = 0; j != dim - 1 - i; ++j) {\n                const sim = simArr[i].get(j);\n                if (sim >= optSimilarityLimit) {\n                    n1.push(i);\n                    n2.push(i + j + 1);\n                    simVals.push(sim);\n                    const diff = Math.abs(activities.get(i) - activities.get(i + j + 1));\n                    if (sim != 1)\n                        saliVals.push(diff / (1 - sim));\n                    else\n                        saliVals.push(Infinity);\n                }\n            }\n        }\n        const saliValsWithoutInfinity = saliVals.filter(it => it !== Infinity);\n        const saliMin = Math.min(...saliValsWithoutInfinity);\n        const saliMax = Math.max(...saliValsWithoutInfinity);\n        const saliOpacityCoef = 0.8 / (saliMax - saliMin);\n        const neighboursCount = new Array(dim).fill(0);\n        const similarityCount = new Array(dim).fill(0);\n        const saliCount = new Array(dim).fill(0);\n        for (let i = 0; i != n1.length; ++i) {\n            neighboursCount[n1[i]] += 1;\n            neighboursCount[n2[i]] += 1;\n            similarityCount[n1[i]] += simVals[i];\n            similarityCount[n2[i]] += simVals[i];\n            if (saliVals[i] != Infinity) {\n                if (activities.get(n1[i]) > activities.get(n2[i]))\n                    saliCount[n1[i]] += saliVals[i];\n                else\n                    saliCount[n2[i]] += saliVals[i];\n            }\n        }\n        const sali = DG.Column.fromList('double', `sali_${axesNames[0].substring(axesNames[0].lastIndexOf('_'))}`, saliCount);\n        df.columns.add(sali);\n        const view = grok.shell.getTableView(df.name);\n        const sp = view.addViewer(DG.Viewer.scatterPlot(df, {\n            xColumnName: axesNames[0],\n            yColumnName: axesNames[1],\n            size: sali.name,\n            color: activities.name,\n            showXSelector: false,\n            showYSelector: false,\n            showSizeSelector: false,\n            showColorSelector: false,\n            markerMinSize: 5,\n            markerMaxSize: 25,\n            title: scatterTitle\n        }));\n        const canvas = sp.getInfo()['canvas'];\n        const linesRes = createLines(n1, n2, seqCol, activities, saliVals, semType, units);\n        const tooltips = {};\n        linesRes.linesDf.onCurrentCellChanged.subscribe(() => {\n            const currentMolIdx = linesRes.linesDf.currentCol && linesRes.linesDf.currentCol.name === '2_seq' ? 1 : 0;\n            sp.dataFrame.currentRowIdx =\n                linesRes.linesDf.currentRowIdx !== -1 ? linesRes.lines[linesRes.linesDf.currentRowIdx].mols[currentMolIdx] : -1;\n            sp.dataFrame.selection.set(0, !linesRes.lines[0].selected);\n            sp.dataFrame.selection.set(0, linesRes.lines[0].selected);\n            linesDfGrid.invalidate();\n        });\n        linesRes.linesDf.onSelectionChanged.subscribe((_) => {\n            if (linesRes.linesDf.mouseOverRowIdx !== -1) {\n                const line = linesRes.lines[linesRes.linesDf.mouseOverRowIdx];\n                line.selected = !line.selected;\n                if (!line.selected)\n                    df.selection.setAll(false);\n            }\n            linesRes.lines.forEach((l) => {\n                if (l.selected)\n                    l.mols.forEach((m) => df.selection.set(m, true));\n            });\n            linesDfGrid.invalidate();\n        });\n        const linesDfGrid = linesRes.linesDf.plot.grid().sort(['act_diff'], [false]);\n        linesDfGrid.onCellClick.subscribe(() => {\n            zoom = true;\n        });\n        const listCliffsLink = ui.button(`${linesRes.linesDf.rowCount} cliffs`, () => {\n            const cliffsDialog = ui.dialog({ title: 'Activity cliffs' })\n                .add(linesDfGrid.root)\n                .show();\n            cliffsDialog.root.id = 'cliffs_dialog';\n        });\n        listCliffsLink.style.position = 'absolute';\n        listCliffsLink.style.top = '10px';\n        listCliffsLink.style.right = '10px';\n        sp.root.append(listCliffsLink);\n        let timer;\n        canvas.addEventListener('mousemove', function (event) {\n            clearTimeout(timer);\n            timer = global.setTimeout(function () {\n                const line = checkCursorOnLine(event, canvas, linesRes.lines);\n                if (line && df.mouseOverRowIdx === -1) {\n                    if (!tooltips[line.id]) {\n                        const drawTooltipParams = {\n                            tooltips: tooltips,\n                            line: line,\n                            df: df,\n                            seqCol: seqCol,\n                            activity: activities,\n                            x: event.clientX,\n                            y: event.clientY\n                        };\n                        tooltipDrawFunc(drawTooltipParams);\n                    }\n                    ui.tooltip.show(tooltips[line.id], event.clientX, event.clientY);\n                }\n            }, 1000);\n        });\n        canvas.addEventListener('mousedown', function (event) {\n            const line = checkCursorOnLine(event, canvas, linesRes.lines);\n            if (line && df.mouseOverRowIdx === -1) {\n                if (event.ctrlKey) {\n                    line.selected = !line.selected;\n                    linesRes.linesDf.selection.set(line.id, line.selected);\n                    if (!line.selected)\n                        df.selection.setAll(false);\n                    linesRes.lines.forEach((l) => {\n                        if (l.selected)\n                            l.mols.forEach((m) => df.selection.set(m, true));\n                    });\n                }\n                else {\n                    if (linesRes.linesDf.currentRowIdx !== line.id) {\n                        linesRes.linesDf.currentRowIdx = line.id;\n                        df.currentRowIdx = line.mols[0];\n                        df.selection.set(0, !linesRes.lines[0].selected);\n                        df.selection.set(0, linesRes.lines[0].selected);\n                    }\n                }\n            }\n        });\n        sp.onEvent('d4-before-draw-scene')\n            .subscribe((_) => {\n            const lines = renderLines(sp, axesNames[0], axesNames[1], linesRes, saliVals, saliOpacityCoef, saliMin);\n            if (zoom) {\n                const currentLine = lines[linesRes.linesDf.currentRowIdx];\n                setTimeout(() => {\n                    const { zoomLeft, zoomRight, zoomTop, zoomBottom } = getZoomCoordinates(sp.viewport.width, sp.viewport.height, sp.dataFrame.get(axesNames[0], currentLine.mols[0]), sp.dataFrame.get(axesNames[1], currentLine.mols[0]), sp.dataFrame.get(axesNames[0], currentLine.mols[1]), sp.dataFrame.get(axesNames[1], currentLine.mols[1]));\n                    sp.zoom(zoomLeft, zoomTop, zoomRight, zoomBottom);\n                }, 300);\n                zoom = false;\n            }\n        });\n        sp.addProperty('similarityLimit', 'double', optSimilarityLimit);\n        return sp;\n    });\n}\nfunction getZoomCoordinates(W0, H0, x1, y1, x2, y2) {\n    const W1 = Math.abs(x1 - x2);\n    const H1 = Math.abs(y1 - y2);\n    const scaleW = W0 / W1;\n    const scaleH = H0 / H1;\n    const scale = Math.min(scaleW, scaleH);\n    const W2 = (W0 / scale) * 5;\n    const H2 = (H0 / scale) * 5;\n    const left = x1 < x2 ? x1 : x2;\n    const top = y1 > y2 ? y1 : y2;\n    const zoomLeft = (left + W1 / 2) - W2 / 2;\n    const zoomRight = zoomLeft + W2;\n    const zoomTop = (top - H1 / 2) + H2 / 2;\n    const zoomBottom = zoomTop - H2;\n    return { zoomLeft: zoomLeft, zoomRight: zoomRight, zoomTop: zoomTop, zoomBottom: zoomBottom };\n}\nfunction checkCursorOnLine(event, canvas, lines) {\n    const rect = canvas.getBoundingClientRect();\n    const x = event.clientX - rect.left;\n    const y = event.clientY - rect.top;\n    for (const line of lines) {\n        const dist = Math.abs(Math.hypot(line.a[0] - x, line.a[1] - y) +\n            Math.hypot(line.b[0] - x, line.b[1] - y) - Math.hypot(line.a[0] - line.b[0], line.a[1] - line.b[1]));\n        if (dist < 2)\n            return line;\n    }\n    return null;\n}\nfunction renderLines(sp, xAxis, yAxis, linesRes, saliVals, saliOpacityCoef, saliMin) {\n    const lines = linesRes.lines;\n    const canvas = sp.getInfo()['canvas'];\n    const ctx = canvas.getContext('2d');\n    const x = sp.dataFrame.columns.byName(xAxis);\n    const y = sp.dataFrame.columns.byName(yAxis);\n    for (let i = 0; i < lines.length; i++) {\n        const pointFrom = sp.worldToScreen(x.get(lines[i].mols[0]), y.get(lines[i].mols[0]));\n        const pointTo = sp.worldToScreen(x.get(lines[i].mols[1]), y.get(lines[i].mols[1]));\n        lines[i].a = [pointFrom.x, pointFrom.y];\n        lines[i].b = [pointTo.x, pointTo.y];\n        const line = new Path2D();\n        line.moveTo(lines[i].a[0], lines[i].a[1]);\n        const color = lines[i].selected ? '255,255,0' : '0,128,0';\n        const opacity = saliVals[i] === Infinity ? 1 : 0.2 + (saliVals[i] - saliMin) * saliOpacityCoef;\n        ctx.strokeStyle = `rgba(${color},${opacity})`;\n        ctx.lineWidth = lines[i].id === linesRes.linesDf.currentRowIdx ? 3 : 1;\n        line.lineTo(lines[i].b[0], lines[i].b[1]);\n        ctx.stroke(line);\n    }\n    return lines;\n}\nfunction createLines(n1, n2, seq, activities, saliVals, semType, units) {\n    const lines = [];\n    for (let i = 0; i < n1.length; i++) {\n        const num1 = n1[i];\n        const num2 = n2[i];\n        lines.push({ id: i, mols: [num1, num2], selected: false, a: [], b: [] });\n    }\n    const linesDf = DG.DataFrame.create(lines.length);\n    linesDf.columns.addNewString('1_seq').init((i) => seq.get(lines[i].mols[0]));\n    linesDf.columns.addNewString('2_seq').init((i) => seq.get(lines[i].mols[1]));\n    linesDf.columns.addNewFloat('act_diff')\n        .init((i) => Math.abs(activities.get(lines[i].mols[0]) - activities.get(lines[i].mols[1])));\n    linesDf.columns.addNewInt('line_index').init((i) => i);\n    linesDf.columns.addNewFloat('sali').init((i) => saliVals[i]);\n    linesDf.col('1_seq').tags[DG.TAGS.UNITS] = units;\n    linesDf.col('2_seq').tags[DG.TAGS.UNITS] = units;\n    linesDf.col('1_seq').semType = semType;\n    linesDf.col('2_seq').semType = semType;\n    return { lines, linesDf };\n}\nexport function getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc) {\n    return __awaiter(this, void 0, void 0, function* () {\n        for (let i = 0; i != dim - 1; ++i) {\n            const mol = seqCol.get(i);\n            dfSeq.rows.removeAt(0, 1, false);\n            simArr[i] = (yield simFunc(dfSeq.col('seq'), mol));\n        }\n        return simArr;\n    });\n}\nexport function getSimilaritiesMarixFromDistances(dim, distances, simArr) {\n    for (let i = 0; i < dim - 1; ++i) {\n        const similarityArr = [];\n        for (let j = i + 1; j < dim; ++j)\n            similarityArr.push(getSimilarityFromDistance(distances[i][j]));\n        simArr[i] = DG.Column.fromFloat32Array('similarity', Float32Array.from(similarityArr));\n    }\n    return simArr;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-cliffs.js","sourceRoot":"","sources":["activity-cliffs.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { Matrix } from '@datagrok-libraries/utils/src/type-declarations';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\n\nexport interface ILine {\n  id: number;\n  mols: number[];\n  selected: boolean;\n  a: number[]; // [x, y]\n  b: number[]; // [x, y]\n}\n\ninterface IRenderedLines {\n  lines: ILine[];\n  linesDf: DG.DataFrame;\n}\n\nexport interface ISequenceSpaceParams {\n    seqCol: DG.Column,\n    methodName: string,\n    similarityMetric: string,\n    embedAxesNames: string[],\n    options?: any\n}\n\nexport interface ISequenceSpaceResult {\n    distance: Matrix;\n    coordinates: DG.ColumnList;\n  }\n\nexport interface IDrawTooltipParams {\n  tooltips: any,\n  line: ILine,\n  df: DG.DataFrame,\n  seqCol: DG.Column,\n  activity: DG.Column,\n  x: number,\n  y: number\n}\n\nlet zoom = false;\n\n// Searches for activity cliffs in a chemical dataset by selected cutoff\nexport async function getActivityCliffs(\n    df: DG.DataFrame, \n    seqCol: DG.Column, \n    axesNames: string[],\n    scatterTitle: string,\n    activities: DG.Column, \n    similarity: number,\n    similarityMetric: string, \n    methodName: string, \n    semType: string,\n    units: string,\n    seqSpaceFunc: (params: ISequenceSpaceParams) => Promise<ISequenceSpaceResult>,\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>,\n    tooltipDrawFunc: (params: IDrawTooltipParams) => void,\n    options?: any) : Promise<DG.Viewer> {\n  const automaticSimilarityLimit = false;\n  const MIN_SIMILARITY = 80;\n\n  const initialSimilarityLimit = automaticSimilarityLimit ? MIN_SIMILARITY : similarity / 100;\n\n  const {distance, coordinates} = await seqSpaceFunc({\n    seqCol: seqCol,\n    methodName: methodName,\n    similarityMetric: similarityMetric,\n    embedAxesNames: axesNames,\n    options: options\n  });\n\n  for (const col of coordinates)\n    df.columns.add(col);\n\n  const dfSeq = DG.DataFrame.fromColumns([DG.Column.fromList('string', 'seq', seqCol.toList())]);\n  const dim = seqCol.length;\n  const simArr: DG.Column[] = Array(dim - 1);\n\n  if (!distance)\n    await getSimilaritiesMarix(dim, seqCol, dfSeq, simArr, simFunc);\n  else\n    getSimilaritiesMarixFromDistances(dim, distance, simArr);\n\n  const optSimilarityLimit = initialSimilarityLimit;\n\n  const simVals: number[] = [];\n  const saliVals: number[] = [];\n  const n1: number[] = [];\n  const n2: number[] = [];\n\n  for (let i = 0; i != dim - 1; ++i) {\n    for (let j = 0; j != dim - 1 - i; ++j) {\n      const sim: number = simArr[i].get(j);\n\n      if (sim >= optSimilarityLimit) {\n        n1.push(i);\n        n2.push(i + j + 1);\n        simVals.push(sim);\n        const diff = Math.abs(activities.get(i) - activities.get(i + j + 1));\n        if (sim != 1)\n          saliVals.push(diff / (1 - sim));\n        else\n          saliVals.push(Infinity);\n      }\n    }\n  }\n\n  const saliValsWithoutInfinity = saliVals.filter(it => it !== Infinity);\n  const saliMin = Math.min(...saliValsWithoutInfinity);\n  const saliMax = Math.max(...saliValsWithoutInfinity);\n  const saliOpacityCoef = 0.8/(saliMax - saliMin);\n\n\n  const neighboursCount = new Array(dim).fill(0);\n  const similarityCount = new Array(dim).fill(0);\n  const saliCount = new Array(dim).fill(0);\n\n  for (let i = 0; i != n1.length; ++i) {\n    neighboursCount[n1[i]] += 1;\n    neighboursCount[n2[i]] += 1;\n    similarityCount[n1[i]] += simVals[i];\n    similarityCount[n2[i]] += simVals[i];\n    if (saliVals[i] != Infinity) {\n      if (activities.get(n1[i]) > activities.get(n2[i]))\n        saliCount[n1[i]] += saliVals[i];\n      else\n        saliCount[n2[i]] += saliVals[i];\n    }\n  }\n\n  const sali: DG.Column = DG.Column.fromList('double', `sali_${axesNames[0].substring(axesNames[0].lastIndexOf('_'))}`, saliCount);\n\n  df.columns.add(sali);\n\n  const view = grok.shell.getTableView(df.name);\n  const sp = view.addViewer(DG.Viewer.scatterPlot(df, {\n    xColumnName: axesNames[0],\n    yColumnName: axesNames[1],\n    size: sali.name,\n    color: activities.name,\n    showXSelector: false,\n    showYSelector: false,\n    showSizeSelector: false,\n    showColorSelector: false,\n    markerMinSize: 5,\n    markerMaxSize: 25,\n    title: scatterTitle\n  })) as DG.ScatterPlotViewer;\n\n  const canvas = (sp.getInfo() as any)['canvas'];\n  const linesRes = createLines(n1, n2, seqCol, activities, saliVals, semType, units);\n  const tooltips: any = {};\n\n  linesRes.linesDf.onCurrentCellChanged.subscribe(() => {\n    const currentMolIdx = linesRes.linesDf.currentCol && linesRes.linesDf.currentCol.name === '2_seq' ? 1 : 0;\n    sp.dataFrame.currentRowIdx =\n      linesRes.linesDf.currentRowIdx !== -1 ? linesRes.lines[linesRes.linesDf.currentRowIdx].mols[currentMolIdx] : -1;\n    sp.dataFrame.selection.set(0, !linesRes.lines[0].selected);\n    sp.dataFrame.selection.set(0, linesRes.lines[0].selected);\n    linesDfGrid.invalidate();\n  });\n\n  linesRes.linesDf.onSelectionChanged.subscribe((_) => {\n    if (linesRes.linesDf.mouseOverRowIdx !== -1) {\n      const line = linesRes.lines[linesRes.linesDf.mouseOverRowIdx];\n      line.selected = !line.selected;\n      if (!line.selected)\n        df.selection.setAll(false);\n    }\n    linesRes.lines.forEach((l) => {\n      if (l.selected)\n        l.mols.forEach((m) => df.selection.set(m, true));\n    });\n    linesDfGrid.invalidate();\n  });\n\n  const linesDfGrid = linesRes.linesDf.plot.grid().sort(['act_diff'], [false]);\n\n  linesDfGrid.onCellClick.subscribe(() => {\n    zoom = true;\n  });\n\n  const listCliffsLink = ui.button(`${linesRes.linesDf.rowCount} cliffs`, () => {\n    const cliffsDialog = ui.dialog({title: 'Activity cliffs'})\n      .add(linesDfGrid.root)\n      .show();\n    cliffsDialog.root.id = 'cliffs_dialog';\n  });\n  listCliffsLink.style.position = 'absolute';\n  listCliffsLink.style.top = '10px';\n  listCliffsLink.style.right = '10px';\n  sp.root.append(listCliffsLink);\n\n  let timer: NodeJS.Timeout;\n  canvas.addEventListener('mousemove', function (event: MouseEvent) {\n    clearTimeout(timer);\n    timer = global.setTimeout(function () {\n      const line = checkCursorOnLine(event, canvas, linesRes.lines);\n      if (line && df.mouseOverRowIdx === -1) {\n        if (!tooltips[line.id]) {\n          const drawTooltipParams = {\n            tooltips: tooltips,\n            line: line,\n            df: df,\n            seqCol: seqCol,\n            activity: activities,\n            x: event.clientX,\n            y: event.clientY\n          }\n          tooltipDrawFunc(drawTooltipParams);\n        }\n        ui.tooltip.show(tooltips[line.id], event.clientX, event.clientY);\n      }\n    }, 1000);\n  });\n\n  canvas.addEventListener('mousedown', function(event: MouseEvent) {\n    const line = checkCursorOnLine(event, canvas, linesRes.lines);\n    if (line && df.mouseOverRowIdx === -1) {\n      if (event.ctrlKey) {\n        line.selected = !line.selected;\n        linesRes.linesDf.selection.set(line.id, line.selected);\n\n        if (!line.selected)\n          df.selection.setAll(false);\n\n        linesRes.lines.forEach((l) => {\n          if (l.selected)\n            l.mols.forEach((m) => df.selection.set(m, true));\n        });\n      } else {\n        if (linesRes.linesDf.currentRowIdx !== line.id) {\n          linesRes.linesDf.currentRowIdx = line.id;\n          df.currentRowIdx = line.mols[0];\n          df.selection.set(0, !linesRes.lines[0].selected);\n          df.selection.set(0, linesRes.lines[0].selected);\n        }\n      }\n    }\n  });\n\n  sp.onEvent('d4-before-draw-scene')\n    .subscribe((_) => {\n      const lines = renderLines(sp,\n        axesNames[0], axesNames[1], linesRes, saliVals, saliOpacityCoef, saliMin);\n      if (zoom) {\n        const currentLine = lines[linesRes.linesDf.currentRowIdx];\n        setTimeout(()=> {\n          const {zoomLeft, zoomRight, zoomTop, zoomBottom} = getZoomCoordinates(\n            sp.viewport.width,\n            sp.viewport.height,\n            sp.dataFrame.get(axesNames[0], currentLine.mols[0]),\n            sp.dataFrame.get(axesNames[1], currentLine.mols[0]),\n            sp.dataFrame.get(axesNames[0], currentLine.mols[1]),\n            sp.dataFrame.get(axesNames[1], currentLine.mols[1])\n          )        \n          sp.zoom(zoomLeft,\n            zoomTop,\n            zoomRight,\n            zoomBottom);\n        }, 300);\n        zoom = false;\n      }\n    });\n\n  sp.addProperty('similarityLimit', 'double', optSimilarityLimit);\n  return sp;\n}\n\nfunction getZoomCoordinates(W0: number, H0: number, x1: number, y1: number, x2: number, y2: number) {\n  const W1 = Math.abs(x1 - x2);\n  const H1 = Math.abs(y1 - y2);\n  const scaleW = W0 / W1;\n  const scaleH = H0 / H1;\n  const scale = Math.min(scaleW, scaleH);\n  const W2 = (W0 / scale) * 5;\n  const H2 = (H0 / scale) * 5;\n  const left = x1 < x2 ? x1 : x2;\n  const top = y1 > y2 ? y1 : y2;\n  const zoomLeft = (left + W1 / 2) - W2 / 2;\n  const zoomRight = zoomLeft + W2;\n  const zoomTop = (top - H1 / 2) + H2 / 2;\n  const zoomBottom = zoomTop - H2;\n  return {zoomLeft: zoomLeft, zoomRight: zoomRight, zoomTop: zoomTop, zoomBottom: zoomBottom};\n}\n\nfunction checkCursorOnLine(event: any, canvas: any, lines: ILine[]): ILine | null {\n  const rect = canvas.getBoundingClientRect();\n  const x = event.clientX - rect.left;\n  const y = event.clientY - rect.top;\n  for (const line of lines) {\n    const dist =\n      Math.abs(Math.hypot(line.a[0] - x, line.a[1] - y) +\n      Math.hypot(line.b[0] - x, line.b[1] - y) - Math.hypot(line.a[0] - line.b[0], line.a[1] - line.b[1]));\n    if (dist < 2)\n      return line;\n  }\n  return null;\n}\n\nfunction renderLines(sp: DG.ScatterPlotViewer,\n  xAxis: string, yAxis: string, linesRes: IRenderedLines, saliVals: number[], saliOpacityCoef: number, saliMin: number): ILine [] {\n  const lines = linesRes.lines;\n  const canvas = (sp.getInfo() as {[index: string] : any})['canvas'];\n  const ctx = canvas.getContext('2d') as CanvasRenderingContext2D;\n  const x = sp.dataFrame!.columns.byName(xAxis);\n  const y = sp.dataFrame!.columns.byName(yAxis);\n  for (let i = 0; i < lines.length; i++) {\n    const pointFrom = sp.worldToScreen(x.get(lines[i].mols[0]), y.get(lines[i].mols[0]));\n    const pointTo = sp.worldToScreen(x.get(lines[i].mols[1]), y.get(lines[i].mols[1]));\n    lines[i].a = [pointFrom.x, pointFrom.y];\n    lines[i].b = [pointTo.x, pointTo.y];\n    const line = new Path2D();\n    line.moveTo(lines[i].a[0], lines[i].a[1]);\n    const color = lines[i].selected ? '255,255,0' : '0,128,0';\n    const opacity = saliVals[i] === Infinity ? 1 : 0.2 + (saliVals[i] - saliMin)*saliOpacityCoef;\n    ctx.strokeStyle = `rgba(${color},${opacity})`;\n    ctx.lineWidth = lines[i].id === linesRes.linesDf.currentRowIdx ? 3 : 1;\n    line.lineTo(lines[i].b[0], lines[i].b[1]);\n    ctx.stroke(line);\n  }\n  return lines;\n}\n\nfunction createLines(\n  n1: number[], \n  n2: number[], \n  seq: DG.Column, \n  activities: DG.Column, \n  saliVals: number[],\n  semType: string,\n  units: string) : IRenderedLines {\n  const lines: ILine[] = [];\n  for (let i = 0; i < n1.length; i++) {\n    const num1 = n1[i];\n    const num2 = n2[i];\n    lines.push({id: i, mols: [num1, num2], selected: false, a: [], b: []});\n  }\n  const linesDf = DG.DataFrame.create(lines.length);\n  linesDf.columns.addNewString('1_seq').init((i: number) => seq.get(lines[i].mols[0]));\n  linesDf.columns.addNewString('2_seq').init((i: number) => seq.get(lines[i].mols[1]));\n  linesDf.columns.addNewFloat('act_diff')\n    .init((i: number) => Math.abs(activities.get(lines[i].mols[0]) - activities.get(lines[i].mols[1])));\n  linesDf.columns.addNewInt('line_index').init((i: number) => i);\n  linesDf.columns.addNewFloat('sali').init((i: number) => saliVals[i]);\n  linesDf.col('1_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('2_seq')!.tags[DG.TAGS.UNITS] = units;\n  linesDf.col('1_seq')!.semType = semType;\n  linesDf.col('2_seq')!.semType = semType;\n  return {lines, linesDf};\n}\n\nexport async function getSimilaritiesMarix(\n    dim: number, \n    seqCol: DG.Column, \n    dfSeq: DG.DataFrame, \n    simArr: DG.Column[],\n    simFunc: (col: DG.Column, mol: string) => Promise<DG.Column | null>\n    )\n  : Promise<DG.Column[]> {\n  for (let i = 0; i != dim - 1; ++i) {\n    const mol = seqCol.get(i);\n    dfSeq.rows.removeAt(0, 1, false);\n    simArr[i] = (await simFunc(dfSeq.col('seq')!, mol))!;\n  }\n  return simArr;\n}\n\nexport function getSimilaritiesMarixFromDistances(dim: number, distances: Matrix, simArr: DG.Column[])\n  : DG.Column[] {\n  for (let i = 0; i < dim - 1; ++i) {\n    const similarityArr = [];\n    for (let j = i + 1; j < dim; ++j)\n      similarityArr.push(getSimilarityFromDistance(distances[i][j]));\n    simArr[i] = DG.Column.fromFloat32Array('similarity', Float32Array.from(similarityArr));\n  }\n  return simArr;\n}"]}","export function createDimensinalityReducingWorker(dataMetric, method, options) {\n    return new Promise(function (resolve) {\n        const worker = new Worker(new URL('./dimensionality-reducer', import.meta.url));\n        worker.postMessage({\n            columnData: dataMetric.data,\n            method: method,\n            measure: dataMetric.metric,\n            options: options,\n        });\n        worker.onmessage = ({ data: { distance, embedding } }) => {\n            resolve({ distance: distance, embedding: embedding });\n        };\n    });\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltZW5zaW9uYWxpdHktcmVkdWNpbmctd29ya2VyLWNyZWF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJkaW1lbnNpb25hbGl0eS1yZWR1Y2luZy13b3JrZXItY3JlYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQkEsTUFBTSxVQUFVLGlDQUFpQyxDQUFDLFVBQXNCLEVBQUUsTUFBYyxFQUNsRixPQUFhO0lBRWpCLE9BQU8sSUFBSSxPQUFPLENBQUMsVUFBUyxPQUFPO1FBQ2pDLE1BQU0sTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDLDBCQUEwQixFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNoRixNQUFNLENBQUMsV0FBVyxDQUFDO1lBQ2pCLFVBQVUsRUFBRSxVQUFVLENBQUMsSUFBSTtZQUMzQixNQUFNLEVBQUUsTUFBTTtZQUNkLE9BQU8sRUFBRSxVQUFVLENBQUMsTUFBTTtZQUMxQixPQUFPLEVBQUUsT0FBTztTQUNqQixDQUFDLENBQUM7UUFDSCxNQUFNLENBQUMsU0FBUyxHQUFHLENBQUMsRUFBQyxJQUFJLEVBQUUsRUFBQyxRQUFRLEVBQUUsU0FBUyxFQUFDLEVBQUMsRUFBRSxFQUFFO1lBQ3BELE9BQU8sQ0FBQyxFQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBQyxDQUFDLENBQUM7UUFDckQsQ0FBQyxDQUFDO0lBQ0osQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF0cml4IH0gZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvdHlwZS1kZWNsYXJhdGlvbnMnO1xuaW1wb3J0IHtWYWxpZFR5cGVzfSBmcm9tICcuLi90eXBlZC1tZXRyaWNzJztcblxuLyoqXG4gKiBBIHdvcmtlciB0byBwZXJmb3JtIGRpbWVuc2lvbmFsaXR5IHJlZHVjdGlvbi5cbiAqXG4gKiBAcGFyYW0ge1ZhbGlkVHlwZXN9IGRhdGFNZXRyaWMgVGhlIGRhdGEgdG8gcHJvY2Vzcy5cbiAqIEBwYXJhbSB7c3RyaW5nfSBtZXRob2QgQSBtZXRob2Qgb2YgZGltZW5zaW9uYWxpdHkgcmVkdWN0aW9uLlxuICogQHBhcmFtIG9wdGlvbnMgLSBrZXktdmFsdWUgcGFpcnNcbiAqIEBwYXJhbSByZXR1cm5EaXN0YW5jZU1hdHJpeFxuICogQHJldHVybiB7UHJvbWlzZTxJUmVkdWNlRGltZW5zaW9uYWxpdHlSZXN1bHQ+fSBSZXN1bHRpbmcgZW1iZWRkaW5nIGFuZCBkaXN0YW5jZSBtYXRyaXguXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSVJlZHVjZURpbWVuc2lvbmFsaXR5UmVzdWx0IHtcbiAgZGlzdGFuY2U6IE1hdHJpeDtcbiAgZW1iZWRkaW5nOiBNYXRyaXg7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVEaW1lbnNpbmFsaXR5UmVkdWNpbmdXb3JrZXIoZGF0YU1ldHJpYzogVmFsaWRUeXBlcywgbWV0aG9kOiBzdHJpbmcsXG4gICAgICBvcHRpb25zPzogYW55KTogUHJvbWlzZTxJUmVkdWNlRGltZW5zaW9uYWxpdHlSZXN1bHQ+IHtcblxuICByZXR1cm4gbmV3IFByb21pc2UoZnVuY3Rpb24ocmVzb2x2ZSkge1xuICAgIGNvbnN0IHdvcmtlciA9IG5ldyBXb3JrZXIobmV3IFVSTCgnLi9kaW1lbnNpb25hbGl0eS1yZWR1Y2VyJywgaW1wb3J0Lm1ldGEudXJsKSk7XG4gICAgd29ya2VyLnBvc3RNZXNzYWdlKHtcbiAgICAgIGNvbHVtbkRhdGE6IGRhdGFNZXRyaWMuZGF0YSxcbiAgICAgIG1ldGhvZDogbWV0aG9kLFxuICAgICAgbWVhc3VyZTogZGF0YU1ldHJpYy5tZXRyaWMsXG4gICAgICBvcHRpb25zOiBvcHRpb25zLFxuICAgIH0pO1xuICAgIHdvcmtlci5vbm1lc3NhZ2UgPSAoe2RhdGE6IHtkaXN0YW5jZSwgZW1iZWRkaW5nfX0pID0+IHtcbiAgICAgcmVzb2x2ZSh7ZGlzdGFuY2U6IGRpc3RhbmNlLCBlbWJlZGRpbmc6IGVtYmVkZGluZ30pO1xuICAgIH07XG4gIH0pO1xufVxuIl19","/**\n * Generates single random float from 0 to range.\n *\n * @export\n * @param {number} range Max generating value.\n * @return {number} A random float generated.\n */\nexport function randomFloat(range) {\n    return Math.random() * range;\n}\n/**\n * Generates single random integer from 0 to range.\n *\n * @export\n * @param {number} range Max generating value.\n * @return {number} A random integer generated.\n */\nexport function randomInt(range) {\n    return Math.floor(randomFloat(range));\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZG9tLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicmFuZG9tLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxXQUFXLENBQUMsS0FBYTtJQUN2QyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxLQUFLLENBQUM7QUFDL0IsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxTQUFTLENBQUMsS0FBYTtJQUNyQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDeEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVzIHNpbmdsZSByYW5kb20gZmxvYXQgZnJvbSAwIHRvIHJhbmdlLlxuICpcbiAqIEBleHBvcnRcbiAqIEBwYXJhbSB7bnVtYmVyfSByYW5nZSBNYXggZ2VuZXJhdGluZyB2YWx1ZS5cbiAqIEByZXR1cm4ge251bWJlcn0gQSByYW5kb20gZmxvYXQgZ2VuZXJhdGVkLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmFuZG9tRmxvYXQocmFuZ2U6IG51bWJlcik6IG51bWJlciB7XG4gIHJldHVybiBNYXRoLnJhbmRvbSgpICogcmFuZ2U7XG59XG5cbi8qKlxuICogR2VuZXJhdGVzIHNpbmdsZSByYW5kb20gaW50ZWdlciBmcm9tIDAgdG8gcmFuZ2UuXG4gKlxuICogQGV4cG9ydFxuICogQHBhcmFtIHtudW1iZXJ9IHJhbmdlIE1heCBnZW5lcmF0aW5nIHZhbHVlLlxuICogQHJldHVybiB7bnVtYmVyfSBBIHJhbmRvbSBpbnRlZ2VyIGdlbmVyYXRlZC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJhbmRvbUludChyYW5nZTogbnVtYmVyKTogbnVtYmVyIHtcbiAgcmV0dXJuIE1hdGguZmxvb3IocmFuZG9tRmxvYXQocmFuZ2UpKTtcbn1cbiJdfQ==","import { randomInt } from './random';\nexport const similarityMetric = {\n    'Tanimoto': tanimotoSimilarity,\n    'Dice': diceSimilarity,\n    'Asymmetric': asymmetricSimilarity,\n    'Braun-Blanquet': braunBlanquetSimilarity,\n    'Cosine': cosineSimilarity,\n    'Kulczynski': kulczynskiSimilarity,\n    'Mc-Connaughey': mcConnaugheySimilarity,\n    'Rogot-Goldberg': rogotGoldbergSimilarity,\n    'Russel': russelSimilarity,\n    'Sokal': sokalSimilarity,\n    'Hamming': hammingSimilarity,\n    'Euclidean': euclideanSimilarity,\n};\nexport const distanceMetrics = {\n    'Tanimoto': tanimotoDistance,\n    'Dice': diceDistance,\n    'Asymmetric': asymmetricDistance,\n    'Braun-Blanquet': braunBlanquetDistance,\n    'Cosine': cosineDistance,\n    'Kulczynski': kulczynskiDistance,\n    'Mc-Connaughey': mcConnaugheyDistance,\n    'Rogot-Goldberg': rogotGoldbergDistance,\n    'Russel': russelDistance,\n    'Sokal': sokalDistance,\n    'Hamming': hammingDistance,\n    'Euclidean': euclideanDistance,\n};\nexport const CHEM_SIMILARITY_METRICS = ['Tanimoto', 'Dice', 'Cosine', 'Hamming', 'Euclidean'];\nexport function tanimotoSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    if (total == 0)\n        return 1.0;\n    const common = x.andWithCountBits(y, true);\n    return common / (total - common);\n}\nexport function tanimotoDistance(x, y) {\n    return getDistanceFromSimilarity(tanimotoSimilarity(x, y));\n}\nexport function diceSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    if (total == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return 2 * common / total;\n}\nexport function diceDistance(x, y) {\n    return getDistanceFromSimilarity(diceSimilarity(x, y));\n}\nexport function cosineSimilarity(x, y) {\n    const total = x.trueCount() * y.trueCount();\n    if (total == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / Math.sqrt(total);\n}\nexport function cosineDistance(x, y) {\n    return getDistanceFromSimilarity(cosineSimilarity(x, y));\n}\nexport function euclideanSimilarity(x, y) {\n    return getSimilarityFromDistance(euclideanDistance(x, y));\n}\nexport function euclideanDistance(x, y) {\n    return Math.sqrt(x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true));\n}\nexport function hammingSimilarity(x, y) {\n    return getSimilarityFromDistance(hammingDistance(x, y));\n}\nexport function hammingDistance(x, y) {\n    return x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true);\n}\nexport function sokalSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    const common = x.andWithCountBits(y, true);\n    return common / (2 * total - 3 * common);\n}\nexport function sokalDistance(x, y) {\n    return getDistanceFromSimilarity(sokalSimilarity(x, y));\n}\nexport function kulczynskiSimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    const totalProd = x.trueCount() * y.trueCount();\n    if (totalProd == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return (common * total) / (2 * totalProd);\n}\nexport function kulczynskiDistance(x, y) {\n    return getDistanceFromSimilarity(kulczynskiSimilarity(x, y));\n}\nexport function mcConnaugheySimilarity(x, y) {\n    const total = x.trueCount() + y.trueCount();\n    const totalProd = x.trueCount() * y.trueCount();\n    if (totalProd == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return (common * total - totalProd) / totalProd;\n}\nexport function mcConnaugheyDistance(x, y) {\n    return getDistanceFromSimilarity(mcConnaugheySimilarity(x, y));\n}\nexport function asymmetricSimilarity(x, y) {\n    const min = Math.min(x.trueCount(), y.trueCount());\n    if (min == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / min;\n}\nexport function asymmetricDistance(x, y) {\n    return getDistanceFromSimilarity(asymmetricSimilarity(x, y));\n}\nexport function braunBlanquetSimilarity(x, y) {\n    const max = Math.max(x.trueCount(), y.trueCount());\n    if (max == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / max;\n}\nexport function braunBlanquetDistance(x, y) {\n    return getDistanceFromSimilarity(braunBlanquetSimilarity(x, y));\n}\nexport function russelSimilarity(x, y) {\n    if (x.length == 0)\n        return 0.0;\n    const common = x.andWithCountBits(y, true);\n    return common / x.length;\n}\nexport function russelDistance(x, y) {\n    return getDistanceFromSimilarity(russelSimilarity(x, y));\n}\nexport function rogotGoldbergSimilarity(x, y) {\n    const common = x.andWithCountBits(y, true);\n    const total = x.countBits(true) + y.countBits(true);\n    const len = x.length;\n    const diff = len - total + common;\n    if ((common == len) || (diff == len))\n        return 1.0;\n    else\n        return common / total + diff / (2 * len - total);\n}\nexport function rogotGoldbergDistance(x, y) {\n    return getDistanceFromSimilarity(rogotGoldbergSimilarity(x, y));\n}\nexport function getSimilarityFromDistance(distance) {\n    return 1 / (1 + distance);\n}\nexport function getDistanceFromSimilarity(similarity) {\n    return 1 / similarity - 1;\n}\nexport function getDiverseSubset(length, n, dist) {\n    function maxBy(values, orderBy) {\n        let maxValue = null;\n        let maxOrderBy = null;\n        for (const element of values) {\n            const elementOrderBy = orderBy(element);\n            if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n                maxValue = element;\n                maxOrderBy = elementOrderBy;\n            }\n        }\n        return maxValue;\n    }\n    const subset = [randomInt(length - 1)];\n    const complement = new Set();\n    for (let i = 0; i < length; ++i) {\n        if (!subset.includes(i))\n            complement.add(i);\n    }\n    while (subset.length < n) {\n        const idx = maxBy(complement.values(), (i) => Math.min.apply(Math, subset.map(function (val, index) {\n            return dist(i, val);\n        })));\n        if (idx) {\n            subset.push(idx);\n            complement.delete(idx);\n        }\n    }\n    return subset;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"similarity-metrics.js","sourceRoot":"","sources":["similarity-metrics.ts"],"names":[],"mappings":"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","sourcesContent":["import BitArray from './bit-array';\nimport {randomInt} from './random';\n\nexport const similarityMetric: {[name: string]: (x: BitArray, y: BitArray) => number} = {\n  'Tanimoto': tanimotoSimilarity,\n  'Dice': diceSimilarity,\n  'Asymmetric': asymmetricSimilarity,\n  'Braun-Blanquet': braunBlanquetSimilarity,\n  'Cosine': cosineSimilarity,\n  'Kulczynski': kulczynskiSimilarity,\n  'Mc-Connaughey': mcConnaugheySimilarity,\n  'Rogot-Goldberg': rogotGoldbergSimilarity,\n  'Russel': russelSimilarity,\n  'Sokal': sokalSimilarity,\n  'Hamming': hammingSimilarity,\n  'Euclidean': euclideanSimilarity,\n};\n\nexport const distanceMetrics: {[name: string]: (x: BitArray, y: BitArray) => number} = {\n  'Tanimoto': tanimotoDistance,\n  'Dice': diceDistance,\n  'Asymmetric': asymmetricDistance,\n  'Braun-Blanquet': braunBlanquetDistance,\n  'Cosine': cosineDistance,\n  'Kulczynski': kulczynskiDistance,\n  'Mc-Connaughey': mcConnaugheyDistance,\n  'Rogot-Goldberg': rogotGoldbergDistance,\n  'Russel': russelDistance,\n  'Sokal': sokalDistance,\n  'Hamming': hammingDistance,\n  'Euclidean': euclideanDistance,\n};\n\nexport const CHEM_SIMILARITY_METRICS = ['Tanimoto', 'Dice', 'Cosine', 'Hamming', 'Euclidean'];\n\nexport function tanimotoSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  if (total == 0)\n    return 1.0;\n  const common = x.andWithCountBits(y, true);\n  return common / (total - common);\n}\n\nexport function tanimotoDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(tanimotoSimilarity(x, y));\n}\n\nexport function diceSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  if (total == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return 2 * common / total;\n}\n\nexport function diceDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(diceSimilarity(x, y));\n}\n\nexport function cosineSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() * y.trueCount();\n  if (total == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / Math.sqrt(total);\n}\n\nexport function cosineDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(cosineSimilarity(x, y));\n}\n\nexport function euclideanSimilarity(x: BitArray, y: BitArray): number {\n  return getSimilarityFromDistance(euclideanDistance(x, y));\n}\n\nexport function euclideanDistance(x: BitArray, y: BitArray): number {\n  return Math.sqrt(x.trueCount() + y.trueCount() - 2*x.andWithCountBits(y, true));\n}\n\nexport function hammingSimilarity(x: BitArray, y: BitArray): number {\n  return getSimilarityFromDistance(hammingDistance(x, y));\n}\n\nexport function hammingDistance(x: BitArray, y: BitArray): number {\n  return x.trueCount() + y.trueCount() - 2*x.andWithCountBits(y, true);\n}\n\nexport function sokalSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const common = x.andWithCountBits(y, true);\n  return common / (2 * total - 3 * common);\n}\n\nexport function sokalDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(sokalSimilarity(x, y));\n}\n\nexport function kulczynskiSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const totalProd = x.trueCount() * y.trueCount();\n  if (totalProd == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return (common * total) / (2 * totalProd);\n}\n\nexport function kulczynskiDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(kulczynskiSimilarity(x, y));\n}\n\nexport function mcConnaugheySimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const totalProd = x.trueCount() * y.trueCount();\n  if (totalProd == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return (common * total - totalProd) / totalProd;\n}\n\nexport function mcConnaugheyDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(mcConnaugheySimilarity(x, y));\n}\n\nexport function asymmetricSimilarity(x: BitArray, y: BitArray): number {\n  const min = Math.min(x.trueCount(), y.trueCount());\n  if (min == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / min;\n}\n\nexport function asymmetricDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(asymmetricSimilarity(x, y));\n}\n\nexport function braunBlanquetSimilarity(x: BitArray, y: BitArray): number {\n  const max = Math.max(x.trueCount(), y.trueCount());\n  if (max == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / max;\n}\n\nexport function braunBlanquetDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(braunBlanquetSimilarity(x, y));\n}\n\nexport function russelSimilarity(x: BitArray, y: BitArray): number {\n  if (x.length == 0)\n    return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / x.length;\n}\n\nexport function russelDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(russelSimilarity(x, y));\n}\n\nexport function rogotGoldbergSimilarity(x: BitArray, y: BitArray): number {\n  const common = x.andWithCountBits(y, true);\n  const total = x.countBits(true) + y.countBits(true);\n  const len = x.length;\n  const diff = len - total + common;\n  if ((common == len) || (diff == len)) return 1.0;\n  else return common / total + diff / (2 * len - total);\n}\n\nexport function rogotGoldbergDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(rogotGoldbergSimilarity(x, y));\n}\n\nexport function getSimilarityFromDistance(distance: number) {\n  return 1 / ( 1 + distance);\n}\n\nexport function getDistanceFromSimilarity(similarity: number) {\n  return 1 / similarity - 1;\n}\n\nexport function getDiverseSubset(length: number, n: number, dist: (i1: number, i2: number) => number) {\n  function maxBy(values: IterableIterator<number>, orderBy: (i: number) => number) {\n    let maxValue = null;\n    let maxOrderBy = null;\n\n    for (const element of values) {\n      const elementOrderBy = orderBy(element);\n      if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n        maxValue = element;\n        maxOrderBy = elementOrderBy;\n      }\n    }\n    return maxValue;\n  }\n\n  const subset = [randomInt(length - 1)];\n  const complement = new Set();\n\n  for (let i = 0; i < length; ++i) {\n    if (!subset.includes(i))\n      complement.add(i);\n  }\n\n  while (subset.length < n) {\n    const idx = maxBy(\n      complement.values() as IterableIterator<number>,\n      (i) => Math.min.apply(Math, subset.map(function(val, index) {\n        return dist(i, val);\n      })));\n    if (idx) {\n      subset.push(idx);\n      complement.delete(idx);\n    }\n  }\n  return subset;\n}\n"]}","/**\n * Denotes a vector of floating poit values.\n *\n * @export\n * @class Vector\n * @extends {Float32Array}\n */\nexport class Vector extends Float32Array {\n}\n/**\n * Denotes a two-dimensional matrix.\n *\n * @export\n * @class Matrix\n * @extends {Array<Vector>}\n */\nexport class Matrix extends Array {\n}\n/**\n * Denotes cartesian coordinates.\n *\n * @export\n * @class Coordinates\n * @extends {Matrix}\n */\nexport class Coordinates extends Matrix {\n}\n/**\n * Denotes an array of arbitrary-typed vectors.\n *\n * @export\n * @class Vectors\n * @extends {Array<any>}\n */\nexport class Vectors extends Array {\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS1kZWNsYXJhdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0eXBlLWRlY2xhcmF0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sTUFBTyxTQUFRLFlBQVk7Q0FBRztBQUUzQzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sTUFBTyxTQUFRLEtBQWE7Q0FBRztBQUU1Qzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sV0FBWSxTQUFRLE1BQU07Q0FBRztBQUUxQzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sT0FBUSxTQUFRLEtBQVU7Q0FBRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRGVub3RlcyBhIHZlY3RvciBvZiBmbG9hdGluZyBwb2l0IHZhbHVlcy5cbiAqXG4gKiBAZXhwb3J0XG4gKiBAY2xhc3MgVmVjdG9yXG4gKiBAZXh0ZW5kcyB7RmxvYXQzMkFycmF5fVxuICovXG5leHBvcnQgY2xhc3MgVmVjdG9yIGV4dGVuZHMgRmxvYXQzMkFycmF5IHt9XG5cbi8qKlxuICogRGVub3RlcyBhIHR3by1kaW1lbnNpb25hbCBtYXRyaXguXG4gKlxuICogQGV4cG9ydFxuICogQGNsYXNzIE1hdHJpeFxuICogQGV4dGVuZHMge0FycmF5PFZlY3Rvcj59XG4gKi9cbmV4cG9ydCBjbGFzcyBNYXRyaXggZXh0ZW5kcyBBcnJheTxWZWN0b3I+IHt9XG5cbi8qKlxuICogRGVub3RlcyBjYXJ0ZXNpYW4gY29vcmRpbmF0ZXMuXG4gKlxuICogQGV4cG9ydFxuICogQGNsYXNzIENvb3JkaW5hdGVzXG4gKiBAZXh0ZW5kcyB7TWF0cml4fVxuICovXG5leHBvcnQgY2xhc3MgQ29vcmRpbmF0ZXMgZXh0ZW5kcyBNYXRyaXgge31cblxuLyoqXG4gKiBEZW5vdGVzIGFuIGFycmF5IG9mIGFyYml0cmFyeS10eXBlZCB2ZWN0b3JzLlxuICpcbiAqIEBleHBvcnRcbiAqIEBjbGFzcyBWZWN0b3JzXG4gKiBAZXh0ZW5kcyB7QXJyYXk8YW55Pn1cbiAqL1xuZXhwb3J0IGNsYXNzIFZlY3RvcnMgZXh0ZW5kcyBBcnJheTxhbnk+IHt9XG5cbi8qKlxuICogRGVub3RlcyBhIGRpY3Rpb25hcnkgY29udGFpbmluZyBmdW5jdGlvbiBvcHRpb25zLlxuICpcbiAqIEBleHBvcnRcbiAqIEB0eXBlIE9wdGlvbnNcbiAqL1xuZXhwb3J0IHR5cGUgT3B0aW9ucyA9IHtbbmFtZTogc3RyaW5nXTogYW55fTtcblxuLyoqXG4gKiBEZW5vdGVzIGN1c3RvbSBkaXN0YW5jZSBtZXRyaWMgYmV0d2VlbiB0aGUgdHdvIGdpdmVuIHZlY3RvcnMuXG4gKlxuICogQGV4cG9ydFxuICogQHR5cGUgRGlzdGFuY2VNZXRyaWNcbiAqIEBwYXJhbSB7YW55fSB2MSBUaGUgZmlyc3QgdmVjdG9yLlxuICogQHBhcmFtIHthbnl9IHYyIFRoZSBzZWNvbmQgdmVjdG9yLlxuICogQHJldHVybiB7bnVtYmVyfSBEaXN0YW5jZSBiZXR3ZWVuIHRoZXNlIHR3byB2ZWN0b3JzLlxuICovXG5leHBvcnQgdHlwZSBEaXN0YW5jZU1ldHJpYyA9ICh2MTogYW55LCB2MjogYW55KSA9PiAobnVtYmVyKTtcblxuLyoqXG4gKiBEZW5vdGVzIGEgc2ltcGxlIHN0cmluZyB0byBzdHJpbmcgZGljdGlvbmFyeS5cbiAqXG4gKiBAZXhwb3J0XG4gKiBAdHlwZSBTdHJpbmdEaWN0aW9uYXJ5XG4gKi9cbmV4cG9ydCB0eXBlIFN0cmluZ0RpY3Rpb25hcnkgPSB7W2tleTogc3RyaW5nXTogc3RyaW5nfTtcbiJdfQ==","import { Vector } from './type-declarations';\nimport { randomFloat, randomInt } from './random';\n/**\n * Asserts a condition by throwing an Error.\n *\n * @export\n * @param {boolean} [condition=false] Condition to assert.\n * @param {string} [message='Assertion error.'] Message to output.\n * @throws {Error}\n */\nexport function assert(condition = false, message = 'Assertion error.') {\n    if (!condition)\n        throw new Error(message);\n}\n/**\n * Creates new two-dimensional array and fills it with the value given.\n *\n * @param {number} dimension1 The first dimension of the coordinates (number of rows).\n * @param {number} dimension2 The second dimension of the coordinates (number of columns).\n * @param {number} [fill=0] A value to fill the coordinates with.\n * @return {Coordinates} A two-dimensional filled with the value given.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nfunction initCoordinates(dimension1, dimension2, fill = 0) {\n    return new Array(dimension1).fill(fill).map(() => (new Vector(dimension2).fill(fill)));\n}\n/**\n * Transpose matrix.\n *\n * @export\n * @param {Matrix} matrix The matrix to be transposed.\n * @return {Matrix} Transposed matrix.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nexport function transposeMatrix(matrix) {\n    return new Array(matrix[0].length).fill(0)\n        .map((_, i) => (new Vector(matrix.length).fill(0).map((_, j) => (matrix[j][i]))));\n}\n/**\n * Adds two vectors with the second one to be multiplied by the given ratio.\n *\n * @export\n * @param {Vector} p The first vector to add.\n * @param {Vector} q The second vector to add.\n * @param {number} [multiplier=1] A multiplier to be used before the second vector is added.\n * @return {Vector} New vector contained the result of operation p+multiplier*q.\n */\nexport function vectorAdd(p, q, multiplier = 1) {\n    const nItems = p.length;\n    assert(nItems == q.length, 'Vector lengths do not match.');\n    const total = new Vector(nItems);\n    for (let i = 0; i < p.length; ++i)\n        total[i] = p[i] + multiplier * q[i];\n    return total;\n}\n/**\n * Sums the vector's items.\n *\n * @param {Vector} v The vector to be summed.\n * @return {number} The vector's items sum.\n */\nfunction itemsSum(v) {\n    let total = 0;\n    for (let i = 0; i < v.length; ++i)\n        total += v[i];\n    return total;\n}\n/**\n * Suqares the vector's items.\n *\n * @param {Vector} v The vector to square.\n * @return {Vector} A new vector containing the original's items squared.\n */\nfunction vectorSquare(v) {\n    const nItems = v.length;\n    const total = new Vector(nItems);\n    for (let i = 0; i < v.length; ++i)\n        total[i] = v[i] * v[i];\n    return total;\n}\nexport function vectorLength(v) {\n    let sqrSum = 0;\n    for (let i = 0; i < v.length; i++)\n        sqrSum += v[i] * v[i];\n    return Math.sqrt(sqrSum);\n}\nexport function vectorDotProduct(v1, v2) {\n    if (v1.length != v2.length)\n        throw Error('The dimensionality of the vectors must match');\n    let prod = 0;\n    for (let i = 0; i < v1.length; i++)\n        prod += v1[i] * v2[i];\n    return prod;\n}\n/**\n * Creates a matrix filled with random floating point values.\n *\n * @export\n * @param {number} dimension1 The first dimension of the matrix.\n * @param {number} dimension2 The second dimension of the matrix.\n * @param {number} [scale=1.] Max value given by random generator.\n * @return {Matrix} A new matrix filled with random floating point  values.\n */\nexport function fillRandomMatrix(dimension1, dimension2, scale = 1.) {\n    const matrix = initCoordinates(dimension1, dimension2);\n    for (let i = 0; i < dimension1; ++i) {\n        for (let j = 0; j < dimension2; ++j)\n            matrix[i][j] = randomFloat(scale);\n    }\n    return matrix;\n}\n/**\n * Calculates Euclidean distance between two vectors.\n *\n * @export\n * @param {Vector} p The first vector.\n * @param {Vector} q The second vector.\n * @return {number} Euclidean distance between the given vectors.\n */\nexport function calculateEuclideanDistance(p, q) {\n    const diff = vectorAdd(p, q, -1);\n    const sqdiff = vectorSquare(diff);\n    const sqdiffSumm = itemsSum(sqdiff);\n    return Math.sqrt(sqdiffSumm);\n}\n/**\n * Creates a distance matrix using a custom distance function.\n *\n * @export\n * @param {Vectors} data Input vectors to calculate distances.\n * @param {DistanceMetric} distance Custom distance function.\n * @return {Matrix} Calculated custom distance matrix.\n */\nexport function calcDistanceMatrix(data, distance) {\n    const nItems = data.length;\n    const matrix = initCoordinates(nItems, nItems, 0);\n    for (let i = 0; i < nItems; ++i) {\n        for (let j = i + 1; j < nItems; ++j) {\n            const d = (data[i] == null) || (data[j] == null) ? 0 : distance(data[i], data[j]);\n            matrix[i][j] = matrix[j][i] = d;\n        }\n    }\n    return matrix;\n}\n/** Generates array from a range [begin; end] or [begin; end) if endExclusive. **/\nexport function genRange(begin, end, endExclusive = false) {\n    const nItems = end - begin + (endExclusive ? 0 : 1);\n    const series = new Int32Array(nItems);\n    for (let i = 0; i < nItems; ++i)\n        series[i] = begin + i;\n    return series;\n}\n/**\n* Returns order of values as if they are sorted.\n*\n* @export\n* @param {any[]} values Input array.\n* @param {boolean} [reverse=false] Whether to return reversed order.\n* @return {number[]} The order computed.\n*/\nexport function argSort(values, reverse = false) {\n    const sortfn = reverse ? (a, b) => (b[0] - a[0]) : (a, b) => (a[0] - b[0]);\n    const decor = (v, i) => [v, i]; // set index to value\n    const undecor = (a) => a[1]; // leave only index\n    const _argsort = (arr) => arr.map(decor).sort(sortfn).map(undecor);\n    return _argsort(values);\n}\n/**\n * Returns the indexes of the most diverse objects according to the dist function\n * @param {number} length total number of objects\n * @param {number} n number of diverse elements to find\n * @param {(i1: number, i2: number) => number} dist a function which calculates distance between\n *                                                  two objects using their indexes\n * @returns {number[]} The indexes of the most diverse objects\n */\nexport function getDiverseSubset(length, n, dist) {\n    function maxBy(values, orderBy) {\n        let maxValue = null;\n        let maxOrderBy = null;\n        for (const element of values) {\n            const elementOrderBy = orderBy(element);\n            if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n                maxValue = element;\n                maxOrderBy = elementOrderBy;\n            }\n        }\n        return maxValue;\n    }\n    const subset = [randomInt(length - 1)];\n    const complement = new Set();\n    for (let i = 0; i < length; ++i) {\n        if (!subset.includes(i))\n            complement.add(i);\n    }\n    while (subset.length < n) {\n        const idx = maxBy(complement.values(), (i) => Math.min.apply(Math, subset.map(function (val, index) {\n            return dist(i, val);\n        })));\n        if (idx) {\n            subset.push(idx);\n            complement.delete(idx);\n        }\n    }\n    return subset;\n}\n/**\n * Returns normalized vector\n * @param {Vector} data numerical array\n */\nexport function normalize(data) {\n    let mean = 0;\n    let std = 0;\n    for (let i = 0; i < data.length; ++i)\n        mean += data[i];\n    mean /= data.length;\n    for (let i = 0; i < data.length; ++i)\n        std += (data[i] - mean) * (data[i] - mean);\n    std = Math.sqrt(std / data.length);\n    for (let i = 0; i < data.length; ++i)\n        data[i] = (data[i] - mean) / std;\n    return data;\n}\n/**\n * Finds set difference between two lists.\n * @param {any[]} a The first list.\n * @param {any[]} b The second list.\n * @return {any[]}\n */\nexport function setDifference(a, b) {\n    const bSet = new Set(b);\n    return Array.from(new Set(a.filter((x) => !bSet.has(x))).values());\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vector-operations.js","sourceRoot":"","sources":["vector-operations.ts"],"names":[],"mappings":"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","sourcesContent":["import {Matrix, Vector, Coordinates, Vectors, DistanceMetric} from './type-declarations';\nimport {randomFloat, randomInt} from './random';\n\n/**\n * Asserts a condition by throwing an Error.\n *\n * @export\n * @param {boolean} [condition=false] Condition to assert.\n * @param {string} [message='Assertion error.'] Message to output.\n * @throws {Error}\n */\nexport function assert(condition: boolean = false, message: string = 'Assertion error.') {\n  if (!condition)\n    throw new Error(message);\n}\n\n/**\n * Creates new two-dimensional array and fills it with the value given.\n *\n * @param {number} dimension1 The first dimension of the coordinates (number of rows).\n * @param {number} dimension2 The second dimension of the coordinates (number of columns).\n * @param {number} [fill=0] A value to fill the coordinates with.\n * @return {Coordinates} A two-dimensional filled with the value given.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nfunction initCoordinates(dimension1: number, dimension2: number, fill: number = 0): Coordinates {\n  return new Array(dimension1).fill(fill).map(() => (new Vector(dimension2).fill(fill)));\n}\n\n/**\n * Transpose matrix.\n *\n * @export\n * @param {Matrix} matrix The matrix to be transposed.\n * @return {Matrix} Transposed matrix.\n * @todo Might be slow since used Array.map. Probably needs performance revision.\n */\nexport function transposeMatrix(matrix: Matrix): Matrix {\n  return new Array(matrix[0].length).fill(0)\n    .map((_, i) => (new Vector(matrix.length).fill(0).map((_, j) => (matrix[j][i]))));\n}\n\n/**\n * Adds two vectors with the second one to be multiplied by the given ratio.\n *\n * @export\n * @param {Vector} p The first vector to add.\n * @param {Vector} q The second vector to add.\n * @param {number} [multiplier=1] A multiplier to be used before the second vector is added.\n * @return {Vector} New vector contained the result of operation p+multiplier*q.\n */\nexport function vectorAdd(p: Vector, q: Vector, multiplier: number = 1): Vector {\n  const nItems = p.length;\n\n  assert(nItems == q.length, 'Vector lengths do not match.');\n\n  const total = new Vector(nItems);\n\n  for (let i = 0; i < p.length; ++i)\n    total[i] = p[i] + multiplier * q[i];\n\n  return total;\n}\n\n/**\n * Sums the vector's items.\n *\n * @param {Vector} v The vector to be summed.\n * @return {number} The vector's items sum.\n */\nfunction itemsSum(v: Vector): number {\n  let total = 0;\n\n  for (let i = 0; i < v.length; ++i)\n    total += v[i];\n\n  return total;\n}\n\n/**\n * Suqares the vector's items.\n *\n * @param {Vector} v The vector to square.\n * @return {Vector} A new vector containing the original's items squared.\n */\nfunction vectorSquare(v: Vector): Vector {\n  const nItems = v.length;\n  const total = new Vector(nItems);\n\n  for (let i = 0; i < v.length; ++i)\n    total[i] = v[i] * v[i];\n\n  return total;\n}\n\nexport function vectorLength(v: Vector): number {\n  let sqrSum: number = 0;\n  for (let i: number = 0; i < v.length; i++)\n    sqrSum += v[i] * v[i];\n  return Math.sqrt(sqrSum);\n}\n\nexport function vectorDotProduct(v1: Vector, v2: Vector): number {\n  if (v1.length != v2.length)\n    throw Error('The dimensionality of the vectors must match');\n  let prod: number = 0;\n  for (let i: number = 0; i < v1.length; i++)\n    prod += v1[i] * v2[i];\n  return prod;\n}\n\n/**\n * Creates a matrix filled with random floating point values.\n *\n * @export\n * @param {number} dimension1 The first dimension of the matrix.\n * @param {number} dimension2 The second dimension of the matrix.\n * @param {number} [scale=1.] Max value given by random generator.\n * @return {Matrix} A new matrix filled with random floating point  values.\n */\nexport function fillRandomMatrix(dimension1: number, dimension2: number, scale: number = 1.): Matrix {\n  const matrix = initCoordinates(dimension1, dimension2);\n\n  for (let i = 0; i < dimension1; ++i) {\n    for (let j = 0; j < dimension2; ++j)\n      matrix[i][j] = randomFloat(scale);\n  }\n  return matrix;\n}\n\n/**\n * Calculates Euclidean distance between two vectors.\n *\n * @export\n * @param {Vector} p The first vector.\n * @param {Vector} q The second vector.\n * @return {number} Euclidean distance between the given vectors.\n */\nexport function calculateEuclideanDistance(p: Vector, q: Vector): number {\n  const diff = vectorAdd(p, q, -1);\n  const sqdiff = vectorSquare(diff);\n  const sqdiffSumm = itemsSum(sqdiff);\n  return Math.sqrt(sqdiffSumm);\n}\n\n/**\n * Creates a distance matrix using a custom distance function.\n *\n * @export\n * @param {Vectors} data Input vectors to calculate distances.\n * @param {DistanceMetric} distance Custom distance function.\n * @return {Matrix} Calculated custom distance matrix.\n */\nexport function calcDistanceMatrix(data: Vectors, distance: DistanceMetric): Matrix {\n  const nItems = data.length;\n  const matrix = initCoordinates(nItems, nItems, 0);\n\n  for (let i = 0; i < nItems; ++i) {\n    for (let j = i + 1; j < nItems; ++j) {\n      const d: number = (data[i] == null) || (data[j] == null) ? 0 : distance(data[i], data[j]);\n      matrix[i][j] = matrix[j][i] = d;\n    }\n  }\n  return matrix;\n}\n\n/** Generates array from a range [begin; end] or [begin; end) if endExclusive. **/\nexport function genRange(begin: number, end: number, endExclusive = false): Int32Array {\n  const nItems = end - begin + (endExclusive ? 0 : 1);\n  const series = new Int32Array(nItems);\n\n  for (let i = 0; i < nItems; ++i)\n    series[i] = begin + i;\n\n  return series;\n}\n\n /**\n * Returns order of values as if they are sorted.\n *\n * @export\n * @param {any[]} values Input array.\n * @param {boolean} [reverse=false] Whether to return reversed order.\n * @return {number[]} The order computed.\n */\nexport function argSort(values: any[], reverse = false): number[] {\n  const sortfn = reverse ? (a: any[], b: any[]) => (b[0] - a[0]) : (a: any[], b: any[]) => (a[0] - b[0]);\n  const decor = (v: any, i: number) => [v, i]; // set index to value\n  const undecor = (a: any[]) => a[1]; // leave only index\n  const _argsort = (arr: any[]) => arr.map(decor).sort(sortfn).map(undecor);\n  return _argsort(values);\n}\n\n/**\n * Returns the indexes of the most diverse objects according to the dist function\n * @param {number} length total number of objects\n * @param {number} n number of diverse elements to find\n * @param {(i1: number, i2: number) => number} dist a function which calculates distance between\n *                                                  two objects using their indexes\n * @returns {number[]} The indexes of the most diverse objects\n */\nexport function getDiverseSubset(length: number, n: number, dist: (i1: number, i2: number) => number): number[] {\n  function maxBy(values: IterableIterator<number>, orderBy: (i: number) => number) {\n    let maxValue = null;\n    let maxOrderBy = null;\n\n    for (const element of values) {\n      const elementOrderBy = orderBy(element);\n      if (maxOrderBy == null || elementOrderBy > maxOrderBy) {\n        maxValue = element;\n        maxOrderBy = elementOrderBy;\n      }\n    }\n    return maxValue;\n  }\n\n  const subset = [randomInt(length - 1)];\n  const complement = new Set();\n\n  for (let i = 0; i < length; ++i) {\n    if (!subset.includes(i))\n      complement.add(i);\n  }\n\n  while (subset.length < n) {\n    const idx = maxBy(\n      complement.values() as IterableIterator<number>,\n      (i) => Math.min.apply(Math, subset.map(function(val, index) {\n        return dist(i, val);\n      })));\n    if (idx) {\n      subset.push(idx);\n      complement.delete(idx);\n    }\n  }\n  return subset;\n}\n\n/**\n * Returns normalized vector\n * @param {Vector} data numerical array\n */\nexport function normalize(data: Vector): Vector {\n  let mean = 0;\n  let std = 0;\n\n  for (let i = 0; i < data.length; ++i)\n    mean += data[i];\n\n  mean /= data.length;\n\n  for (let i = 0; i < data.length; ++i)\n    std += (data[i] - mean) * (data[i] - mean);\n\n  std = Math.sqrt(std / data.length);\n\n  for (let i = 0; i < data.length; ++i)\n    data[i] = (data[i] - mean) / std;\n\n  return data;\n}\n\n/**\n * Finds set difference between two lists.\n * @param {any[]} a The first list.\n * @param {any[]} b The second list.\n * @return {any[]}\n */\nexport function setDifference(a: any[], b: any[]): any[] {\n  const bSet = new Set(b);\n  return Array.from(new Set(a.filter((x) => !bSet.has(x))).values());\n}\n"]}","\"use strict\";\nconst peq = new Uint32Array(0x10000);\nconst myers_32 = (a, b) => {\n  const n = a.length;\n  const m = b.length;\n  const lst = 1 << (n - 1);\n  let pv = -1;\n  let mv = 0;\n  let sc = n;\n  let i = n;\n  while (i--) {\n    peq[a.charCodeAt(i)] |= 1 << i;\n  }\n  for (i = 0; i < m; i++) {\n    let eq = peq[b.charCodeAt(i)];\n    const xv = eq | mv;\n    eq |= ((eq & pv) + pv) ^ pv;\n    mv |= ~(eq | pv);\n    pv &= eq;\n    if (mv & lst) {\n      sc++;\n    }\n    if (pv & lst) {\n      sc--;\n    }\n    mv = (mv << 1) | 1;\n    pv = (pv << 1) | ~(xv | mv);\n    mv &= xv;\n  }\n  i = n;\n  while (i--) {\n    peq[a.charCodeAt(i)] = 0;\n  }\n  return sc;\n};\n\nconst myers_x = (a, b) => {\n  const n = a.length;\n  const m = b.length;\n  const mhc = [];\n  const phc = [];\n  const hsize = Math.ceil(n / 32);\n  const vsize = Math.ceil(m / 32);\n  let score = m;\n  for (let i = 0; i < hsize; i++) {\n    phc[i] = -1;\n    mhc[i] = 0;\n  }\n  let j = 0;\n  for (; j < vsize - 1; j++) {\n    let mv = 0;\n    let pv = -1;\n    const start = j * 32;\n    const end = Math.min(32, m) + start;\n    for (let k = start; k < end; k++) {\n      peq[b.charCodeAt(k)] |= 1 << k;\n    }\n    score = m;\n    for (let i = 0; i < n; i++) {\n      const eq = peq[a.charCodeAt(i)];\n      const pb = (phc[(i / 32) | 0] >>> i) & 1;\n      const mb = (mhc[(i / 32) | 0] >>> i) & 1;\n      const xv = eq | mv;\n      const xh = ((((eq | mb) & pv) + pv) ^ pv) | eq | mb;\n      let ph = mv | ~(xh | pv);\n      let mh = pv & xh;\n      if ((ph >>> 31) ^ pb) {\n        phc[(i / 32) | 0] ^= 1 << i;\n      }\n      if ((mh >>> 31) ^ mb) {\n        mhc[(i / 32) | 0] ^= 1 << i;\n      }\n      ph = (ph << 1) | pb;\n      mh = (mh << 1) | mb;\n      pv = mh | ~(xv | ph);\n      mv = ph & xv;\n    }\n    for (let k = start; k < end; k++) {\n      peq[b.charCodeAt(k)] = 0;\n    }\n  }\n  let mv = 0;\n  let pv = -1;\n  const start = j * 32;\n  const end = Math.min(32, m - start) + start;\n  for (let k = start; k < end; k++) {\n    peq[b.charCodeAt(k)] |= 1 << k;\n  }\n  score = m;\n  for (let i = 0; i < n; i++) {\n    const eq = peq[a.charCodeAt(i)];\n    const pb = (phc[(i / 32) | 0] >>> i) & 1;\n    const mb = (mhc[(i / 32) | 0] >>> i) & 1;\n    const xv = eq | mv;\n    const xh = ((((eq | mb) & pv) + pv) ^ pv) | eq | mb;\n    let ph = mv | ~(xh | pv);\n    let mh = pv & xh;\n    score += (ph >>> (m - 1)) & 1;\n    score -= (mh >>> (m - 1)) & 1;\n    if ((ph >>> 31) ^ pb) {\n      phc[(i / 32) | 0] ^= 1 << i;\n    }\n    if ((mh >>> 31) ^ mb) {\n      mhc[(i / 32) | 0] ^= 1 << i;\n    }\n    ph = (ph << 1) | pb;\n    mh = (mh << 1) | mb;\n    pv = mh | ~(xv | ph);\n    mv = ph & xv;\n  }\n  for (let k = start; k < end; k++) {\n    peq[b.charCodeAt(k)] = 0;\n  }\n  return score;\n};\n\nconst distance = (a, b) => {\n  if (a.length > b.length) {\n    const tmp = b;\n    b = a;\n    a = tmp;\n  }\n  if (a.length === 0) {\n    return b.length;\n  }\n  if (a.length <= 32) {\n    return myers_32(a, b);\n  }\n  return myers_x(a, b);\n};\n\nconst closest = (str, arr) => {\n  let min_distance = Infinity;\n  let min_index = 0;\n  for (let i = 0; i < arr.length; i++) {\n    const dist = distance(str, arr[i]);\n    if (dist < min_distance) {\n      min_distance = dist;\n      min_index = i;\n    }\n  }\n  return arr[min_index];\n};\n\nmodule.exports = {\n  closest, distance\n}\n","\"use strict\";\n// Reference: https://www.geeksforgeeks.org/jaro-and-jaro-winkler-similarity/\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.jaroWinkler = exports.jaro = void 0;\n/**\n *\n * @param str1 String 1 for compare\n * @param str2 String 2 for compare\n * @param options to control case sensitive or not\n */\nfunction jaro(str1, str2, options) {\n    // Exit early if either are empty.\n    if (str1.length === 0 || str2.length === 0) {\n        return 0;\n    }\n    // Convert to upper if case-sensitive is false.\n    if (options && !options.caseSensitive) {\n        str1 = str1.toUpperCase();\n        str2 = str2.toUpperCase();\n    }\n    // Exact match\n    if (str1 === str2) {\n        return 1;\n    }\n    // Number of matches\n    var m = 0;\n    // Length of two Strings\n    var len1 = str1.length;\n    var len2 = str2.length;\n    // Maximum distance\n    var window = Math.floor(Math.max(len1, len2) / 2) - 1;\n    // Hash for matches\n    var str1Hash = new Array(len1);\n    var str2Hash = new Array(len2);\n    for (var i = 0; i < len1; i++) {\n        for (var j = Math.max(0, i - window); j <= Math.min(len2, i + window + 1); j++) {\n            if (!str1Hash[i] && !str2Hash[j] && str1[i] === str2[j]) {\n                ++m;\n                str1Hash[i] = str2Hash[j] = true;\n                break;\n            }\n        }\n    }\n    // Exit early if no matches were found.\n    if (m === 0) {\n        return 0;\n    }\n    // Count the transpositions.\n    var t = 0;\n    var point = 0;\n    for (var i = 0; i < len1; i++) {\n        if (str1Hash[i]) {\n            while (!str2Hash[point]) {\n                point++;\n            }\n            if (str1.charAt(i) !== str2.charAt(point++)) {\n                t++;\n            }\n        }\n    }\n    t /= 2;\n    return (m / len1 + m / len2 + (m - t) / m) / 3;\n}\nexports.jaro = jaro;\n/**\n *\n * @param str1 String 1 for compare\n * @param str2 String 2 for compare\n * @param options to control case sensitive or not\n */\nfunction jaroWinkler(str1, str2, options) {\n    // Jaro Distance\n    var jaroDist = jaro(str1, str2, options);\n    // Same prefix length, maxium is 4\n    var prefix = 0;\n    if (jaroDist > 0.7) {\n        var minIndex = Math.min(str1.length, str2.length);\n        var i = 0;\n        while (str1[i] === str2[i] && i < 4 && i < minIndex) {\n            ++prefix;\n            i++;\n        }\n        jaroDist += 0.1 * prefix * (1 - jaroDist);\n    }\n    return jaroDist;\n}\nexports.jaroWinkler = jaroWinkler;\n","class Cell {\n    constructor() {\n        this.value = 0;\n        this.parentI = 0;\n        this.parentJ = 0;\n    }\n}\n;\nexport class Aligned {\n    constructor(seq1_, seq2_, score_) {\n        this.seq1 = seq1_;\n        this.seq2 = seq2_;\n        this.score = score_;\n    }\n}\n;\nexport class SequenceAlignment {\n    constructor(seq1_, seq2_, gap_, alignGrid_ = \"\") {\n        this.seq1 = '';\n        this.seq2 = '';\n        this.gap = 1;\n        this.len1 = 0;\n        this.len2 = 0;\n        this.step = 1;\n        this.alignGrid = [];\n        this.scores = [];\n        this.dpGrid = [];\n        this.connections = {};\n        this.BLOSUM45 = [[5, -2, -1, -2, -1, -1, -1, 0, -2, -1, -1, -1, -1, -2, -1, 1, 0, -2, -2, 0, -1, -1, 0, -5],\n            [-2, 7, 0, -1, -3, 1, 0, -2, 0, -3, -2, 3, -1, -2, -2, -1, -1, -2, -1, -2, -1, 0, -1, -5],\n            [-1, 0, 6, 2, -2, 0, 0, 0, 1, -2, -3, 0, -2, -2, -2, 1, 0, -4, -2, -3, 4, 0, -1, -5],\n            [-2, -1, 2, 7, -3, 0, 2, -1, 0, -4, -3, 0, -3, -4, -1, 0, -1, -4, -2, -3, 5, 1, -1, -5],\n            [-1, -3, -2, -3, 12, -3, -3, -3, -3, -3, -2, -3, -2, -2, -4, -1, -1, -5, -3, -1, -2, -3, -2, -5],\n            [-1, 1, 0, 0, -3, 6, 2, -2, 1, -2, -2, 1, 0, -4, -1, 0, -1, -2, -1, -3, 0, 4, -1, -5],\n            [-1, 0, 0, 2, -3, 2, 6, -2, 0, -3, -2, 1, -2, -3, 0, 0, -1, -3, -2, -3, 1, 4, -1, -5],\n            [0, -2, 0, -1, -3, -2, -2, 7, -2, -4, -3, -2, -2, -3, -2, 0, -2, -2, -3, -3, -1, -2, -1, -5],\n            [-2, 0, 1, 0, -3, 1, 0, -2, 10, -3, -2, -1, 0, -2, -2, -1, -2, -3, 2, -3, 0, 0, -1, -5],\n            [-1, -3, -2, -4, -3, -2, -3, -4, -3, 5, 2, -3, 2, 0, -2, -2, -1, -2, 0, 3, -3, -3, -1, -5],\n            [-1, -2, -3, -3, -2, -2, -2, -3, -2, 2, 5, -3, 2, 1, -3, -3, -1, -2, 0, 1, -3, -2, -1, -5],\n            [-1, 3, 0, 0, -3, 1, 1, -2, -1, -3, -3, 5, -1, -3, -1, -1, -1, -2, -1, -2, 0, 1, -1, -5],\n            [-1, -1, -2, -3, -2, 0, -2, -2, 0, 2, 2, -1, 6, 0, -2, -2, -1, -2, 0, 1, -2, -1, -1, -5],\n            [-2, -2, -2, -4, -2, -4, -3, -3, -2, 0, 1, -3, 0, 8, -3, -2, -1, 1, 3, 0, -3, -3, -1, -5],\n            [-1, -2, -2, -1, -4, -1, 0, -2, -2, -2, -3, -1, -2, -3, 9, -1, -1, -3, -3, -3, -2, -1, -1, -5],\n            [1, -1, 1, 0, -1, 0, 0, 0, -1, -2, -3, -1, -2, -2, -1, 4, 2, -4, -2, -1, 0, 0, 0, -5],\n            [0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -1, -1, 2, 5, -3, -1, 0, 0, -1, 0, -5],\n            [-2, -2, -4, -4, -5, -2, -3, -2, -3, -2, -2, -2, -2, 1, -3, -4, -3, 15, 3, -3, -4, -2, -2, -5],\n            [-2, -1, -2, -2, -3, -1, -2, -3, 2, 0, 0, -1, 0, 3, -3, -2, -1, 3, 8, -1, -2, -2, -1, -5],\n            [0, -2, -3, -3, -1, -3, -3, -3, -3, 3, 1, -2, 1, 0, -3, -1, 0, -3, -1, 5, -3, -3, -1, -5],\n            [-1, -1, 4, 5, -2, 0, 1, -1, 0, -3, -3, 0, -2, -3, -2, 0, 0, -4, -2, -3, 4, 2, -1, -5],\n            [-1, 0, 0, 1, -3, 4, 4, -2, 0, -3, -2, 1, -1, -3, -1, 0, -1, -2, -2, -3, 2, 4, -1, -5],\n            [0, -1, -1, -1, -2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, 0, -2, -1, -1, -1, -1, -1, -5],\n            [-5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, 1]];\n        this.BLOSUM50 = [[5, -2, -1, -2, -1, -1, -1, 0, -2, -1, -2, -1, -1, -3, -1, 1, 0, -3, -2, 0, -2, -1, -1, -5],\n            [-2, 7, -1, -2, -4, 1, 0, -3, 0, -4, -3, 3, -2, -3, -3, -1, -1, -3, -1, -3, -1, 0, -1, -5],\n            [-1, -1, 7, 2, -2, 0, 0, 0, 1, -3, -4, 0, -2, -4, -2, 1, 0, -4, -2, -3, 4, 0, -1, -5],\n            [-2, -2, 2, 8, -4, 0, 2, -1, -1, -4, -4, -1, -4, -5, -1, 0, -1, -5, -3, -4, 5, 1, -1, -5],\n            [-1, -4, -2, -4, 13, -3, -3, -3, -3, -2, -2, -3, -2, -2, -4, -1, -1, -5, -3, -1, -3, -3, -2, -5],\n            [-1, 1, 0, 0, -3, 7, 2, -2, 1, -3, -2, 2, 0, -4, -1, 0, -1, -1, -1, -3, 0, 4, -1, -5],\n            [-1, 0, 0, 2, -3, 2, 6, -3, 0, -4, -3, 1, -2, -3, -1, -1, -1, -3, -2, -3, 1, 5, -1, -5],\n            [0, -3, 0, -1, -3, -2, -3, 8, -2, -4, -4, -2, -3, -4, -2, 0, -2, -3, -3, -4, -1, -2, -2, -5],\n            [-2, 0, 1, -1, -3, 1, 0, -2, 10, -4, -3, 0, -1, -1, -2, -1, -2, -3, 2, -4, 0, 0, -1, -5],\n            [-1, -4, -3, -4, -2, -3, -4, -4, -4, 5, 2, -3, 2, 0, -3, -3, -1, -3, -1, 4, -4, -3, -1, -5],\n            [-2, -3, -4, -4, -2, -2, -3, -4, -3, 2, 5, -3, 3, 1, -4, -3, -1, -2, -1, 1, -4, -3, -1, -5],\n            [-1, 3, 0, -1, -3, 2, 1, -2, 0, -3, -3, 6, -2, -4, -1, 0, -1, -3, -2, -3, 0, 1, -1, -5],\n            [-1, -2, -2, -4, -2, 0, -2, -3, -1, 2, 3, -2, 7, 0, -3, -2, -1, -1, 0, 1, -3, -1, -1, -5],\n            [-3, -3, -4, -5, -2, -4, -3, -4, -1, 0, 1, -4, 0, 8, -4, -3, -2, 1, 4, -1, -4, -4, -2, -5],\n            [-1, -3, -2, -1, -4, -1, -1, -2, -2, -3, -4, -1, -3, -4, 10, -1, -1, -4, -3, -3, -2, -1, -2, -5],\n            [1, -1, 1, 0, -1, 0, -1, 0, -1, -3, -3, 0, -2, -3, -1, 5, 2, -4, -2, -2, 0, 0, -1, -5],\n            [0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -2, -1, 2, 5, -3, -2, 0, 0, -1, 0, -5],\n            [-3, -3, -4, -5, -5, -1, -3, -3, -3, -3, -2, -3, -1, 1, -4, -4, -3, 15, 2, -3, -5, -2, -3, -5],\n            [-2, -1, -2, -3, -3, -1, -2, -3, 2, -1, -1, -2, 0, 4, -3, -2, -2, 2, 8, -1, -3, -2, -1, -5],\n            [0, -3, -3, -4, -1, -3, -3, -4, -4, 4, 1, -3, 1, -1, -3, -2, 0, -3, -1, 5, -4, -3, -1, -5],\n            [-2, -1, 4, 5, -3, 0, 1, -1, 0, -4, -4, 0, -3, -4, -2, 0, 0, -5, -3, -4, 5, 2, -1, -5],\n            [-1, 0, 0, 1, -3, 4, 5, -2, 0, -3, -3, 1, -1, -4, -1, 0, -1, -2, -2, -3, 2, 5, -1, -5],\n            [-1, -1, -1, -1, -2, -1, -1, -2, -1, -1, -1, -1, -1, -2, -2, -1, 0, -3, -1, -1, -1, -1, -1, -5],\n            [-5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, 1]];\n        this.BLOSUM62 = [[4, -1, -2, -2, 0, -1, -1, 0, -2, -1, -1, -1, -1, -2, -1, 1, 0, -3, -2, 0, -2, -1, 0, -4],\n            [-1, 5, 0, -2, -3, 1, 0, -2, 0, -3, -2, 2, -1, -3, -2, -1, -1, -3, -2, -3, -1, 0, -1, -4],\n            [-2, 0, 6, 1, -3, 0, 0, 0, 1, -3, -3, 0, -2, -3, -2, 1, 0, -4, -2, -3, 3, 0, -1, -4],\n            [-2, -2, 1, 6, -3, 0, 2, -1, -1, -3, -4, -1, -3, -3, -1, 0, -1, -4, -3, -3, 4, 1, -1, -4],\n            [0, -3, -3, -3, 9, -3, -4, -3, -3, -1, -1, -3, -1, -2, -3, -1, -1, -2, -2, -1, -3, -3, -2, -4],\n            [-1, 1, 0, 0, -3, 5, 2, -2, 0, -3, -2, 1, 0, -3, -1, 0, -1, -2, -1, -2, 0, 3, -1, -4],\n            [-1, 0, 0, 2, -4, 2, 5, -2, 0, -3, -3, 1, -2, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],\n            [0, -2, 0, -1, -3, -2, -2, 6, -2, -4, -4, -2, -3, -3, -2, 0, -2, -2, -3, -3, -1, -2, -1, -4],\n            [-2, 0, 1, -1, -3, 0, 0, -2, 8, -3, -3, -1, -2, -1, -2, -1, -2, -2, 2, -3, 0, 0, -1, -4],\n            [-1, -3, -3, -3, -1, -3, -3, -4, -3, 4, 2, -3, 1, 0, -3, -2, -1, -3, -1, 3, -3, -3, -1, -4],\n            [-1, -2, -3, -4, -1, -2, -3, -4, -3, 2, 4, -2, 2, 0, -3, -2, -1, -2, -1, 1, -4, -3, -1, -4],\n            [-1, 2, 0, -1, -3, 1, 1, -2, -1, -3, -2, 5, -1, -3, -1, 0, -1, -3, -2, -2, 0, 1, -1, -4],\n            [-1, -1, -2, -3, -1, 0, -2, -3, -2, 1, 2, -1, 5, 0, -2, -1, -1, -1, -1, 1, -3, -1, -1, -4],\n            [-2, -3, -3, -3, -2, -3, -3, -3, -1, 0, 0, -3, 0, 6, -4, -2, -2, 1, 3, -1, -3, -3, -1, -4],\n            [-1, -2, -2, -1, -3, -1, -1, -2, -2, -3, -3, -1, -2, -4, 7, -1, -1, -4, -3, -2, -2, -1, -2, -4],\n            [1, -1, 1, 0, -1, 0, 0, 0, -1, -2, -2, 0, -1, -2, -1, 4, 1, -3, -2, -2, 0, 0, 0, -4],\n            [0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -2, -1, 1, 5, -2, -2, 0, -1, -1, 0, -4],\n            [-3, -3, -4, -4, -2, -2, -3, -2, -2, -3, -2, -3, -1, 1, -4, -3, -2, 11, 2, -3, -4, -3, -2, -4],\n            [-2, -2, -2, -3, -2, -1, -2, -3, 2, -1, -1, -2, -1, 3, -3, -2, -2, 2, 7, -1, -3, -2, -1, -4],\n            [0, -3, -3, -3, -1, -2, -2, -3, -3, 3, 1, -2, 1, -1, -2, -2, 0, -3, -1, 4, -3, -2, -1, -4],\n            [-2, -1, 3, 4, -3, 0, 1, -1, 0, -3, -4, 0, -3, -3, -2, 0, -1, -4, -3, -3, 4, 1, -1, -4],\n            [-1, 0, 0, 1, -3, 3, 4, -2, 0, -3, -3, 1, -1, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],\n            [0, -1, -1, -1, -2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -2, 0, 0, -2, -1, -1, -1, -1, -1, -4],\n            [-4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, 1]];\n        this.BLOSUM80 = [[7, -3, -3, -3, -1, -2, -2, 0, -3, -3, -3, -1, -2, -4, -1, 2, 0, -5, -4, -1, -3, -2, -1, -8],\n            [-3, 9, -1, -3, -6, 1, -1, -4, 0, -5, -4, 3, -3, -5, -3, -2, -2, -5, -4, -4, -2, 0, -2, -8],\n            [-3, -1, 9, 2, -5, 0, -1, -1, 1, -6, -6, 0, -4, -6, -4, 1, 0, -7, -4, -5, 5, -1, -2, -8],\n            [-3, -3, 2, 10, -7, -1, 2, -3, -2, -7, -7, -2, -6, -6, -3, -1, -2, -8, -6, -6, 6, 1, -3, -8],\n            [-1, -6, -5, -7, 13, -5, -7, -6, -7, -2, -3, -6, -3, -4, -6, -2, -2, -5, -5, -2, -6, -7, -4, -8],\n            [-2, 1, 0, -1, -5, 9, 3, -4, 1, -5, -4, 2, -1, -5, -3, -1, -1, -4, -3, -4, -1, 5, -2, -8],\n            [-2, -1, -1, 2, -7, 3, 8, -4, 0, -6, -6, 1, -4, -6, -2, -1, -2, -6, -5, -4, 1, 6, -2, -8],\n            [0, -4, -1, -3, -6, -4, -4, 9, -4, -7, -7, -3, -5, -6, -5, -1, -3, -6, -6, -6, -2, -4, -3, -8],\n            [-3, 0, 1, -2, -7, 1, 0, -4, 12, -6, -5, -1, -4, -2, -4, -2, -3, -4, 3, -5, -1, 0, -2, -8],\n            [-3, -5, -6, -7, -2, -5, -6, -7, -6, 7, 2, -5, 2, -1, -5, -4, -2, -5, -3, 4, -6, -6, -2, -8],\n            [-3, -4, -6, -7, -3, -4, -6, -7, -5, 2, 6, -4, 3, 0, -5, -4, -3, -4, -2, 1, -7, -5, -2, -8],\n            [-1, 3, 0, -2, -6, 2, 1, -3, -1, -5, -4, 8, -3, -5, -2, -1, -1, -6, -4, -4, -1, 1, -2, -8],\n            [-2, -3, -4, -6, -3, -1, -4, -5, -4, 2, 3, -3, 9, 0, -4, -3, -1, -3, -3, 1, -5, -3, -2, -8],\n            [-4, -5, -6, -6, -4, -5, -6, -6, -2, -1, 0, -5, 0, 10, -6, -4, -4, 0, 4, -2, -6, -6, -3, -8],\n            [-1, -3, -4, -3, -6, -3, -2, -5, -4, -5, -5, -2, -4, -6, 12, -2, -3, -7, -6, -4, -4, -2, -3, -8],\n            [2, -2, 1, -1, -2, -1, -1, -1, -2, -4, -4, -1, -3, -4, -2, 7, 2, -6, -3, -3, 0, -1, -1, -8],\n            [0, -2, 0, -2, -2, -1, -2, -3, -3, -2, -3, -1, -1, -4, -3, 2, 8, -5, -3, 0, -1, -2, -1, -8],\n            [-5, -5, -7, -8, -5, -4, -6, -6, -4, -5, -4, -6, -3, 0, -7, -6, -5, 16, 3, -5, -8, -5, -5, -8],\n            [-4, -4, -4, -6, -5, -3, -5, -6, 3, -3, -2, -4, -3, 4, -6, -3, -3, 3, 11, -3, -5, -4, -3, -8],\n            [-1, -4, -5, -6, -2, -4, -4, -6, -5, 4, 1, -4, 1, -2, -4, -3, 0, -5, -3, 7, -6, -4, -2, -8],\n            [-3, -2, 5, 6, -6, -1, 1, -2, -1, -6, -7, -1, -5, -6, -4, 0, -1, -8, -5, -6, 6, 0, -3, -8],\n            [-2, 0, -1, 1, -7, 5, 6, -4, 0, -6, -5, 1, -3, -6, -2, -1, -2, -5, -4, -4, 0, 6, -1, -8],\n            [-1, -2, -2, -3, -4, -2, -2, -3, -2, -2, -2, -2, -2, -3, -3, -1, -1, -5, -3, -2, -3, -1, -2, -8],\n            [-8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, 1]];\n        this.BLOSUM90 = [[5, -2, -2, -3, -1, -1, -1, 0, -2, -2, -2, -1, -2, -3, -1, 1, 0, -4, -3, -1, -2, -1, -1, -6],\n            [-2, 6, -1, -3, -5, 1, -1, -3, 0, -4, -3, 2, -2, -4, -3, -1, -2, -4, -3, -3, -2, 0, -2, -6],\n            [-2, -1, 7, 1, -4, 0, -1, -1, 0, -4, -4, 0, -3, -4, -3, 0, 0, -5, -3, -4, 4, -1, -2, -6],\n            [-3, -3, 1, 7, -5, -1, 1, -2, -2, -5, -5, -1, -4, -5, -3, -1, -2, -6, -4, -5, 4, 0, -2, -6],\n            [-1, -5, -4, -5, 9, -4, -6, -4, -5, -2, -2, -4, -2, -3, -4, -2, -2, -4, -4, -2, -4, -5, -3, -6],\n            [-1, 1, 0, -1, -4, 7, 2, -3, 1, -4, -3, 1, 0, -4, -2, -1, -1, -3, -3, -3, -1, 4, -1, -6],\n            [-1, -1, -1, 1, -6, 2, 6, -3, -1, -4, -4, 0, -3, -5, -2, -1, -1, -5, -4, -3, 0, 4, -2, -6],\n            [0, -3, -1, -2, -4, -3, -3, 6, -3, -5, -5, -2, -4, -5, -3, -1, -3, -4, -5, -5, -2, -3, -2, -6],\n            [-2, 0, 0, -2, -5, 1, -1, -3, 8, -4, -4, -1, -3, -2, -3, -2, -2, -3, 1, -4, -1, 0, -2, -6],\n            [-2, -4, -4, -5, -2, -4, -4, -5, -4, 5, 1, -4, 1, -1, -4, -3, -1, -4, -2, 3, -5, -4, -2, -6],\n            [-2, -3, -4, -5, -2, -3, -4, -5, -4, 1, 5, -3, 2, 0, -4, -3, -2, -3, -2, 0, -5, -4, -2, -6],\n            [-1, 2, 0, -1, -4, 1, 0, -2, -1, -4, -3, 6, -2, -4, -2, -1, -1, -5, -3, -3, -1, 1, -1, -6],\n            [-2, -2, -3, -4, -2, 0, -3, -4, -3, 1, 2, -2, 7, -1, -3, -2, -1, -2, -2, 0, -4, -2, -1, -6],\n            [-3, -4, -4, -5, -3, -4, -5, -5, -2, -1, 0, -4, -1, 7, -4, -3, -3, 0, 3, -2, -4, -4, -2, -6],\n            [-1, -3, -3, -3, -4, -2, -2, -3, -3, -4, -4, -2, -3, -4, 8, -2, -2, -5, -4, -3, -3, -2, -2, -6],\n            [1, -1, 0, -1, -2, -1, -1, -1, -2, -3, -3, -1, -2, -3, -2, 5, 1, -4, -3, -2, 0, -1, -1, -6],\n            [0, -2, 0, -2, -2, -1, -1, -3, -2, -1, -2, -1, -1, -3, -2, 1, 6, -4, -2, -1, -1, -1, -1, -6],\n            [-4, -4, -5, -6, -4, -3, -5, -4, -3, -4, -3, -5, -2, 0, -5, -4, -4, 11, 2, -3, -6, -4, -3, -6],\n            [-3, -3, -3, -4, -4, -3, -4, -5, 1, -2, -2, -3, -2, 3, -4, -3, -2, 2, 8, -3, -4, -3, -2, -6],\n            [-1, -3, -4, -5, -2, -3, -3, -5, -4, 3, 0, -3, 0, -2, -3, -2, -1, -3, -3, 5, -4, -3, -2, -6],\n            [-2, -2, 4, 4, -4, -1, 0, -2, -1, -5, -5, -1, -4, -4, -3, 0, -1, -6, -4, -4, 4, 0, -2, -6],\n            [-1, 0, -1, 0, -5, 4, 4, -3, 0, -4, -4, 1, -2, -4, -2, -1, -1, -4, -3, -3, 0, 4, -1, -6],\n            [-1, -2, -2, -2, -3, -1, -2, -2, -2, -2, -2, -1, -1, -2, -2, -1, -1, -3, -2, -2, -2, -1, -2, -6],\n            [-6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, -6, 1]];\n        this.NUCLEOTIDES = [[1, -1, -1, -1],\n            [-1, 1, -1, -1],\n            [-1, -1, 1, -1],\n            [-1, -1, -1, 1]];\n        this.PAM30 = [[6, -7, -4, -3, -6, -4, -2, -2, -7, -5, -6, -7, -5, -8, -2, 0, -1, -13, -8, -2, -3, -3, -3, -17],\n            [-7, 8, -6, -10, -8, -2, -9, -9, -2, -5, -8, 0, -4, -9, -4, -3, -6, -2, -10, -8, -7, -4, -6, -17],\n            [-4, -6, 8, 2, -11, -3, -2, -3, 0, -5, -7, -1, -9, -9, -6, 0, -2, -8, -4, -8, 6, -3, -3, -17],\n            [-3, -10, 2, 8, -14, -2, 2, -3, -4, -7, -12, -4, -11, -15, -8, -4, -5, -15, -11, -8, 6, 1, -5, -17],\n            [-6, -8, -11, -14, 10, -14, -14, -9, -7, -6, -15, -14, -13, -13, -8, -3, -8, -15, -4, -6, -12, -14, -9, -17],\n            [-4, -2, -3, -2, -14, 8, 1, -7, 1, -8, -5, -3, -4, -13, -3, -5, -5, -13, -12, -7, -3, 6, -5, -17],\n            [-2, -9, -2, 2, -14, 1, 8, -4, -5, -5, -9, -4, -7, -14, -5, -4, -6, -17, -8, -6, 1, 6, -5, -17],\n            [-2, -9, -3, -3, -9, -7, -4, 6, -9, -11, -10, -7, -8, -9, -6, -2, -6, -15, -14, -5, -3, -5, -5, -17],\n            [-7, -2, 0, -4, -7, 1, -5, -9, 9, -9, -6, -6, -10, -6, -4, -6, -7, -7, -3, -6, -1, -1, -5, -17],\n            [-5, -5, -5, -7, -6, -8, -5, -11, -9, 8, -1, -6, -1, -2, -8, -7, -2, -14, -6, 2, -6, -6, -5, -17],\n            [-6, -8, -7, -12, -15, -5, -9, -10, -6, -1, 7, -8, 1, -3, -7, -8, -7, -6, -7, -2, -9, -7, -6, -17],\n            [-7, 0, -1, -4, -14, -3, -4, -7, -6, -6, -8, 7, -2, -14, -6, -4, -3, -12, -9, -9, -2, -4, -5, -17],\n            [-5, -4, -9, -11, -13, -4, -7, -8, -10, -1, 1, -2, 11, -4, -8, -5, -4, -13, -11, -1, -10, -5, -5, -17],\n            [-8, -9, -9, -15, -13, -13, -14, -9, -6, -2, -3, -14, -4, 9, -10, -6, -9, -4, 2, -8, -10, -13, -8, -17],\n            [-2, -4, -6, -8, -8, -3, -5, -6, -4, -8, -7, -6, -8, -10, 8, -2, -4, -14, -13, -6, -7, -4, -5, -17],\n            [0, -3, 0, -4, -3, -5, -4, -2, -6, -7, -8, -4, -5, -6, -2, 6, 0, -5, -7, -6, -1, -5, -3, -17],\n            [-1, -6, -2, -5, -8, -5, -6, -6, -7, -2, -7, -3, -4, -9, -4, 0, 7, -13, -6, -3, -3, -6, -4, -17],\n            [-13, -2, -8, -15, -15, -13, -17, -15, -7, -14, -6, -12, -13, -4, -14, -5, -13, 13, -5, -15, -10, -14, -11, -17],\n            [-8, -10, -4, -11, -4, -12, -8, -14, -3, -6, -7, -9, -11, 2, -13, -7, -6, -5, 10, -7, -6, -9, -7, -17],\n            [-2, -8, -8, -8, -6, -7, -6, -5, -6, 2, -2, -9, -1, -8, -6, -6, -3, -15, -7, 7, -8, -6, -5, -17],\n            [-3, -7, 6, 6, -12, -3, 1, -3, -1, -6, -9, -2, -10, -10, -7, -1, -3, -10, -6, -8, 6, 0, -5, -17],\n            [-3, -4, -3, 1, -14, 6, 6, -5, -1, -6, -7, -4, -5, -13, -4, -5, -6, -14, -9, -6, 0, 6, -5, -17],\n            [-3, -6, -3, -5, -9, -5, -5, -5, -5, -5, -6, -5, -5, -8, -5, -3, -4, -11, -7, -5, -5, -5, -5, -17],\n            [-17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, -17, 1]];\n        this.PAM70 = [[5, -4, -2, -1, -4, -2, -1, 0, -4, -2, -4, -4, -3, -6, 0, 1, 1, -9, -5, -1, -1, -1, -2, -11],\n            [-4, 8, -3, -6, -5, 0, -5, -6, 0, -3, -6, 2, -2, -7, -2, -1, -4, 0, -7, -5, -4, -2, -3, -11],\n            [-2, -3, 6, 3, -7, -1, 0, -1, 1, -3, -5, 0, -5, -6, -3, 1, 0, -6, -3, -5, 5, -1, -2, -11],\n            [-1, -6, 3, 6, -9, 0, 3, -1, -1, -5, -8, -2, -7, -10, -4, -1, -2, -10, -7, -5, 5, 2, -3, -11],\n            [-4, -5, -7, -9, 9, -9, -9, -6, -5, -4, -10, -9, -9, -8, -5, -1, -5, -11, -2, -4, -8, -9, -6, -11],\n            [-2, 0, -1, 0, -9, 7, 2, -4, 2, -5, -3, -1, -2, -9, -1, -3, -3, -8, -8, -4, -1, 5, -2, -11],\n            [-1, -5, 0, 3, -9, 2, 6, -2, -2, -4, -6, -2, -4, -9, -3, -2, -3, -11, -6, -4, 2, 5, -3, -11],\n            [0, -6, -1, -1, -6, -4, -2, 6, -6, -6, -7, -5, -6, -7, -3, 0, -3, -10, -9, -3, -1, -3, -3, -11],\n            [-4, 0, 1, -1, -5, 2, -2, -6, 8, -6, -4, -3, -6, -4, -2, -3, -4, -5, -1, -4, 0, 1, -3, -11],\n            [-2, -3, -3, -5, -4, -5, -4, -6, -6, 7, 1, -4, 1, 0, -5, -4, -1, -9, -4, 3, -4, -4, -3, -11],\n            [-4, -6, -5, -8, -10, -3, -6, -7, -4, 1, 6, -5, 2, -1, -5, -6, -4, -4, -4, 0, -6, -4, -4, -11],\n            [-4, 2, 0, -2, -9, -1, -2, -5, -3, -4, -5, 6, 0, -9, -4, -2, -1, -7, -7, -6, -1, -2, -3, -11],\n            [-3, -2, -5, -7, -9, -2, -4, -6, -6, 1, 2, 0, 10, -2, -5, -3, -2, -8, -7, 0, -6, -3, -3, -11],\n            [-6, -7, -6, -10, -8, -9, -9, -7, -4, 0, -1, -9, -2, 8, -7, -4, -6, -2, 4, -5, -7, -9, -5, -11],\n            [0, -2, -3, -4, -5, -1, -3, -3, -2, -5, -5, -4, -5, -7, 7, 0, -2, -9, -9, -3, -4, -2, -3, -11],\n            [1, -1, 1, -1, -1, -3, -2, 0, -3, -4, -6, -2, -3, -4, 0, 5, 2, -3, -5, -3, 0, -2, -1, -11],\n            [1, -4, 0, -2, -5, -3, -3, -3, -4, -1, -4, -1, -2, -6, -2, 2, 6, -8, -4, -1, -1, -3, -2, -11],\n            [-9, 0, -6, -10, -11, -8, -11, -10, -5, -9, -4, -7, -8, -2, -9, -3, -8, 13, -3, -10, -7, -10, -7, -11],\n            [-5, -7, -3, -7, -2, -8, -6, -9, -1, -4, -4, -7, -7, 4, -9, -5, -4, -3, 9, -5, -4, -7, -5, -11],\n            [-1, -5, -5, -5, -4, -4, -4, -3, -4, 3, 0, -6, 0, -5, -3, -3, -1, -10, -5, 6, -5, -4, -2, -11],\n            [-1, -4, 5, 5, -8, -1, 2, -1, 0, -4, -6, -1, -6, -7, -4, 0, -1, -7, -4, -5, 5, 1, -2, -11],\n            [-1, -2, -1, 2, -9, 5, 5, -3, 1, -4, -4, -2, -3, -9, -2, -2, -3, -10, -7, -4, 1, 5, -3, -11],\n            [-2, -3, -2, -3, -6, -2, -3, -3, -3, -3, -4, -3, -3, -5, -3, -1, -2, -7, -5, -2, -2, -3, -3, -11],\n            [-11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, -11, 1]];\n        this.PAM250 = [[2, -2, 0, 0, -2, 0, 0, 1, -1, -1, -2, -1, -1, -3, 1, 1, 1, -6, -3, 0, 0, 0, 0, -8],\n            [-2, 6, 0, -1, -4, 1, -1, -3, 2, -2, -3, 3, 0, -4, 0, 0, -1, 2, -4, -2, -1, 0, -1, -8],\n            [0, 0, 2, 2, -4, 1, 1, 0, 2, -2, -3, 1, -2, -3, 0, 1, 0, -4, -2, -2, 2, 1, 0, -8],\n            [0, -1, 2, 4, -5, 2, 3, 1, 1, -2, -4, 0, -3, -6, -1, 0, 0, -7, -4, -2, 3, 3, -1, -8],\n            [-2, -4, -4, -5, 12, -5, -5, -3, -3, -2, -6, -5, -5, -4, -3, 0, -2, -8, 0, -2, -4, -5, -3, -8],\n            [0, 1, 1, 2, -5, 4, 2, -1, 3, -2, -2, 1, -1, -5, 0, -1, -1, -5, -4, -2, 1, 3, -1, -8],\n            [0, -1, 1, 3, -5, 2, 4, 0, 1, -2, -3, 0, -2, -5, -1, 0, 0, -7, -4, -2, 3, 3, -1, -8],\n            [1, -3, 0, 1, -3, -1, 0, 5, -2, -3, -4, -2, -3, -5, 0, 1, 0, -7, -5, -1, 0, 0, -1, -8],\n            [-1, 2, 2, 1, -3, 3, 1, -2, 6, -2, -2, 0, -2, -2, 0, -1, -1, -3, 0, -2, 1, 2, -1, -8],\n            [-1, -2, -2, -2, -2, -2, -2, -3, -2, 5, 2, -2, 2, 1, -2, -1, 0, -5, -1, 4, -2, -2, -1, -8],\n            [-2, -3, -3, -4, -6, -2, -3, -4, -2, 2, 6, -3, 4, 2, -3, -3, -2, -2, -1, 2, -3, -3, -1, -8],\n            [-1, 3, 1, 0, -5, 1, 0, -2, 0, -2, -3, 5, 0, -5, -1, 0, 0, -3, -4, -2, 1, 0, -1, -8],\n            [-1, 0, -2, -3, -5, -1, -2, -3, -2, 2, 4, 0, 6, 0, -2, -2, -1, -4, -2, 2, -2, -2, -1, -8],\n            [-3, -4, -3, -6, -4, -5, -5, -5, -2, 1, 2, -5, 0, 9, -5, -3, -3, 0, 7, -1, -4, -5, -2, -8],\n            [1, 0, 0, -1, -3, 0, -1, 0, 0, -2, -3, -1, -2, -5, 6, 1, 0, -6, -5, -1, -1, 0, -1, -8],\n            [1, 0, 1, 0, 0, -1, 0, 1, -1, -1, -3, 0, -2, -3, 1, 2, 1, -2, -3, -1, 0, 0, 0, -8],\n            [1, -1, 0, 0, -2, -1, 0, 0, -1, 0, -2, 0, -1, -3, 0, 1, 3, -5, -3, 0, 0, -1, 0, -8],\n            [-6, 2, -4, -7, -8, -5, -7, -7, -3, -5, -2, -3, -4, 0, -6, -2, -5, 17, 0, -6, -5, -6, -4, -8],\n            [-3, -4, -2, -4, 0, -4, -4, -5, 0, -1, -1, -4, -2, 7, -5, -3, -3, 0, 10, -2, -3, -4, -2, -8],\n            [0, -2, -2, -2, -2, -2, -2, -1, -2, 4, 2, -2, 2, -1, -1, -1, 0, -6, -2, 4, -2, -2, -1, -8],\n            [0, -1, 2, 3, -4, 1, 3, 0, 1, -2, -3, 1, -2, -4, -1, 0, 0, -5, -3, -2, 3, 2, -1, -8],\n            [0, 0, 1, 3, -5, 3, 3, 0, 2, -2, -3, 0, -2, -5, 0, 0, -1, -6, -4, -2, 2, 3, -1, -8],\n            [0, -1, 0, -1, -3, -1, -1, -1, -1, -1, -1, -1, -1, -2, -1, 0, 0, -4, -2, -1, -1, -1, -1, -8],\n            [-8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, -8, 1]];\n        this.SCHNEIDER = [[11.6, -2.7, 9.7, -1.7, -2.7, -6.4, -3.9, -5.6, 5.1, -5.0, 3.6, -4.2, -6.3, -13.0, -7.1, -11.5, 0.4, -6.0, -1.9, -5.3, -8.5, -11.2, -8.9, -10.8, 2.1, 0.0, 1.4, 0.2, -10.2, -13.5, -13.0, -12.5, -2.6, -8.5, -5.0, -8.1, -6.3, -9.9, -7.5, -9.0, -7.1, -10.2, -8.2, -9.2, -8.2, -12.5, -11.1, -11.4, -50.0, -14.8, -50.0, -13.8, -7.3, -10.1, -8.4, -9.1, -50.0, -13.0, -13.5, -12.4, -10.7, -18.1, -11.8, -17.2,],\n            [-2.7, 13.0, -3.3, 10.9, -3.5, -0.4, -3.3, -1.8, -5.4, 4.6, -5.5, 3.0, -10.2, -7.9, -9.9, -9.6, -5.0, 0.5, -5.5, -1.0, -10.3, -8.1, -9.4, -9.6, -8.1, -5.0, -7.3, -6.3, -13.4, -11.3, -14.4, -12.9, -6.3, 0.8, -6.4, -1.1, -7.4, -5.0, -6.2, -6.5, -5.6, -1.6, -4.7, -3.0, -10.8, -8.7, -11.9, -10.0, -50.0, -6.2, -50.0, -7.5, -6.3, -4.3, -6.2, -5.4, -50.0, -7.0, -16.3, -8.2, -13.2, -12.3, -13.1, -13.3,],\n            [9.7, -3.3, 11.6, -2.8, -4.5, -6.7, -3.1, -6.9, 3.3, -5.5, 4.8, -5.1, -8.9, -13.2, -5.7, -12.6, -1.5, -6.1, -0.6, -6.1, -10.0, -11.8, -8.6, -11.9, 1.2, 0.5, 2.2, 0.1, -11.8, -14.0, -11.9, -13.4, -4.9, -9.1, -3.4, -8.9, -8.0, -10.0, -7.2, -10.0, -9.1, -10.2, -7.1, -9.9, -10.1, -13.0, -10.6, -12.7, -50.0, -14.9, -50.0, -14.4, -8.9, -10.8, -8.9, -10.4, -50.0, -13.1, -11.8, -13.0, -12.4, -19.4, -11.5, -17.8,],\n            [-1.7, 10.9, -2.8, 12.9, -2.7, -2.2, -2.8, 0.2, -4.8, 2.9, -5.2, 5.2, -9.1, -9.5, -9.0, -7.0, -4.0, -1.0, -5.0, 1.0, -9.0, -8.8, -8.9, -7.7, -7.0, -6.8, -7.1, -4.3, -12.4, -12.9, -13.9, -10.0, -4.9, -0.7, -5.6, 1.4, -6.0, -6.5, -6.2, -4.8, -5.1, -3.2, -5.0, -1.2, -9.8, -9.9, -11.3, -8.2, -50.0, -7.6, -50.0, -5.1, -5.5, -5.8, -5.9, -4.2, -50.0, -8.3, -15.5, -5.9, -11.6, -14.2, -12.0, -11.6,],\n            [-2.7, -3.5, -4.5, -2.7, 11.7, 9.0, 10.6, 9.6, -3.2, -0.7, -5.1, -0.4, 0.7, -4.6, -0.4, -3.6, -4.8, -8.9, -6.5, -7.8, -1.4, -4.1, -2.9, -3.3, -8.0, -9.1, -8.0, -8.2, -6.0, -9.3, -7.7, -8.5, -6.4, -10.1, -7.5, -8.6, 2.8, -0.7, 0.9, 0.1, -5.9, -7.3, -6.5, -6.5, -0.4, -3.9, -2.6, -3.1, -50.0, -14.6, -50.0, -12.6, 2.9, 0.1, 1.8, 1.0, -50.0, -9.2, -13.6, -7.7, -4.8, -12.2, -6.2, -11.0,],\n            [-6.4, -0.4, -6.7, -2.2, 9.0, 12.3, 9.8, 9.6, -7.1, 2.4, -7.2, 0.3, -2.9, -1.2, -3.0, -3.3, -7.6, -6.7, -8.1, -7.9, -4.9, -1.9, -4.5, -3.8, -9.5, -7.8, -9.3, -8.9, -9.4, -7.1, -9.0, -9.0, -9.4, -7.5, -9.3, -9.2, -0.7, 2.6, 0.2, -0.1, -8.0, -4.6, -7.7, -6.1, -3.6, -1.0, -4.1, -3.1, -50.0, -11.6, -50.0, -11.6, 0.2, 2.3, 0.4, 0.5, -50.0, -6.5, -15.3, -7.8, -8.4, -9.5, -8.3, -11.1,],\n            [-3.9, -3.3, -3.1, -2.8, 10.6, 9.8, 12.2, 9.8, -4.9, 0.1, -3.6, -0.2, -1.7, -4.1, 0.9, -3.5, -5.9, -8.9, -5.6, -8.5, -3.9, -3.9, -2.2, -4.5, -7.3, -7.5, -6.4, -8.5, -7.1, -8.2, -6.7, -7.8, -7.9, -9.1, -7.1, -9.4, 0.9, -0.2, 2.5, -0.3, -6.9, -6.5, -5.5, -6.8, -1.7, -3.4, -1.7, -2.8, -50.0, -13.0, -50.0, -11.5, 1.5, 0.7, 2.7, 0.6, -50.0, -8.9, -12.1, -7.4, -6.1, -11.5, -5.4, -10.4,],\n            [-5.6, -1.8, -6.9, 0.2, 9.6, 9.6, 9.8, 11.6, -6.6, 0.9, -7.2, 2.5, -2.3, -3.4, -2.3, -0.6, -6.5, -8.2, -8.0, -6.3, -3.7, -3.5, -3.9, -1.6, -9.9, -8.9, -9.6, -7.0, -8.6, -8.9, -8.8, -6.8, -8.6, -8.2, -8.8, -6.8, 0.3, 0.1, 0.2, 2.4, -7.4, -6.2, -6.9, -4.4, -2.9, -2.9, -3.5, -0.9, -50.0, -12.2, -50.0, -10.1, 1.2, 0.6, 1.2, 2.4, -50.0, -7.6, -16.1, -5.8, -7.2, -10.8, -7.4, -9.0,],\n            [5.1, -5.4, 3.3, -4.8, -3.2, -7.1, -4.9, -6.6, 13.3, -2.8, 11.2, -1.9, -5.7, -12.5, -7.2, -11.6, -0.7, -4.8, -3.1, -4.3, -10.0, -11.6, -8.8, -11.7, 10.5, 7.7, 9.1, 8.5, -9.8, -12.7, -11.7, -11.8, -6.3, -11.4, -8.8, -11.0, -7.5, -10.3, -8.3, -9.9, -1.9, -6.7, -4.1, -6.4, -7.9, -12.5, -11.4, -11.7, -50.0, -14.0, -50.0, -13.2, -8.5, -10.4, -9.1, -9.6, -50.0, -9.8, -7.7, -8.8, -10.3, -17.9, -11.8, -16.0,],\n            [-5.0, 4.6, -5.5, 2.9, -0.7, 2.4, 0.1, 0.9, -2.8, 12.8, -2.6, 11.0, -8.4, -6.3, -8.3, -7.7, -6.1, -2.9, -6.5, -4.2, -8.5, -5.9, -7.5, -7.7, -5.5, -2.4, -5.5, -4.1, -12.9, -10.3, -12.7, -11.3, -7.4, -3.1, -7.4, -4.9, -4.4, -1.8, -3.5, -3.5, -1.6, 3.0, -0.8, 0.9, -8.4, -6.3, -9.6, -7.3, -50.0, -9.0, -50.0, -9.7, -2.3, -0.2, -1.2, -1.5, -50.0, -0.7, -13.3, -2.0, -11.8, -11.9, -12.3, -12.7,],\n            [3.6, -5.5, 4.8, -5.2, -5.1, -7.2, -3.6, -7.2, 11.2, -2.6, 13.4, -2.1, -7.7, -12.5, -5.3, -11.9, -2.2, -4.4, -1.9, -4.8, -10.2, -11.5, -8.1, -12.0, 9.3, 8.2, 10.0, 8.0, -10.8, -11.9, -10.7, -12.4, -8.2, -11.8, -6.9, -11.5, -8.4, -9.9, -7.1, -10.6, -4.7, -6.8, -1.2, -7.0, -9.8, -11.6, -9.6, -12.1, -50.0, -14.1, -50.0, -12.7, -10.0, -10.8, -8.8, -10.5, -50.0, -9.2, -4.2, -9.3, -11.0, -18.2, -11.1, -16.1,],\n            [-4.2, 3.0, -5.1, 5.2, -0.4, 0.3, -0.2, 2.5, -1.9, 11.0, -2.1, 13.2, -7.6, -8.5, -8.0, -5.3, -5.6, -4.5, -6.8, -2.4, -7.8, -7.9, -7.9, -6.2, -5.7, -5.1, -5.4, -2.1, -12.4, -12.3, -13.1, -10.1, -6.6, -4.4, -6.9, -2.6, -3.6, -3.8, -3.7, -2.0, -1.4, 0.8, -0.9, 3.0, -8.2, -8.1, -9.2, -5.8, -50.0, -10.1, -50.0, -7.4, -1.7, -2.0, -1.5, -0.5, -50.0, -2.1, -12.6, -0.4, -11.6, -13.9, -11.4, -11.1,],\n            [-6.3, -10.2, -8.9, -9.1, 0.7, -2.9, -1.7, -2.3, -5.7, -8.4, -7.7, -7.6, 13.2, 9.6, 3.5, 9.7, -8.7, -12.4, -10.7, -10.7, -7.8, -10.2, -8.8, -9.6, -9.5, -11.9, -10.9, -10.5, 2.3, -0.4, -0.2, -0.3, -9.7, -15.5, -11.4, -13.7, -3.0, -6.4, -4.1, -5.4, -9.6, -11.9, -10.5, -11.8, 6.2, 3.3, 3.7, 3.6, -50.0, -13.6, -50.0, -11.9, -5.6, -8.8, -7.2, -8.9, -50.0, -12.4, -14.1, -11.6, 2.8, -6.4, 0.5, -5.2,],\n            [-13.0, -7.9, -13.2, -9.5, -4.6, -1.2, -4.1, -3.4, -12.5, -6.3, -12.5, -8.5, 9.6, 12.7, 0.2, 10.5, -12.4, -11.6, -13.2, -12.0, -12.4, -10.1, -11.6, -12.0, -15.1, -13.1, -14.3, -13.4, -1.4, 1.4, -1.6, -0.5, -14.9, -14.3, -15.2, -16.8, -7.7, -4.7, -6.3, -6.6, -14.6, -10.8, -12.8, -13.0, 2.3, 6.0, 2.5, 3.6, -50.0, -11.2, -50.0, -11.9, -10.5, -9.2, -10.5, -10.5, -50.0, -10.3, -16.2, -11.3, -1.7, -3.7, -2.5, -5.4,],\n            [-7.1, -9.9, -5.7, -9.0, -0.4, -3.0, 0.9, -2.3, -7.2, -8.3, -5.3, -8.0, 3.5, 0.2, 14.3, 1.0, -7.3, -11.2, -6.9, -9.7, -8.5, -10.2, -7.7, -9.8, -10.0, -10.4, -8.4, -10.2, 1.0, -0.6, 1.7, -0.5, -11.1, -14.8, -9.7, -14.5, -3.7, -5.8, -3.1, -5.6, -10.4, -11.5, -8.2, -11.1, 0.6, -1.6, 1.6, -1.1, -50.0, -12.4, -50.0, -11.5, -5.5, -8.0, -4.9, -7.2, -50.0, -12.4, -10.3, -11.6, 0.7, -6.8, 2.4, -6.0,],\n            [-11.5, -9.6, -12.6, -7.0, -3.6, -3.3, -3.5, -0.6, -11.6, -7.7, -11.9, -5.3, 9.7, 10.5, 1.0, 12.6, -12.0, -12.2, -12.5, -9.7, -11.1, -11.2, -11.9, -9.4, -12.9, -14.3, -14.0, -11.9, -1.0, -0.4, -1.6, 1.2, -13.9, -15.4, -13.7, -12.6, -6.2, -6.7, -6.3, -4.4, -13.0, -12.2, -13.0, -10.4, 2.9, 3.8, 2.5, 5.8, -50.0, -12.5, -50.0, -10.2, -9.6, -9.7, -9.6, -8.3, -50.0, -11.6, -15.4, -9.4, -1.1, -5.4, -1.6, -3.3,],\n            [0.4, -5.0, -1.5, -4.0, -4.8, -7.6, -5.9, -6.5, -0.7, -6.1, -2.2, -5.6, -8.7, -12.4, -7.3, -12.0, 12.8, 2.3, 10.2, 3.0, 0.0, -3.4, -0.7, -3.2, 2.5, -0.8, 0.9, 0.2, -3.0, -7.2, -5.7, -6.1, -0.2, -6.6, -1.8, -6.0, -5.3, -8.2, -5.7, -7.6, -6.7, -9.6, -7.5, -9.3, -7.1, -10.5, -9.6, -9.4, -50.0, -8.1, -50.0, -7.2, -4.3, -6.8, -5.7, -6.3, -50.0, -9.5, -9.6, -8.9, -6.2, -12.8, -6.8, -11.8,],\n            [-6.0, 0.5, -6.1, -1.0, -8.9, -6.7, -8.9, -8.2, -4.8, -2.9, -4.4, -4.5, -12.4, -11.6, -11.2, -12.2, 2.3, 14.6, 1.9, 12.9, -5.5, -2.6, -4.1, -4.7, -1.2, 3.0, -1.1, 1.6, -8.0, -4.7, -8.7, -6.0, -8.2, -4.7, -7.8, -6.7, -10.0, -8.3, -8.9, -9.9, -10.8, -7.1, -10.0, -9.2, -11.6, -10.1, -12.3, -11.9, -50.0, 2.2, -50.0, 0.9, -7.9, -5.9, -7.4, -6.9, -50.0, -4.6, -11.6, -5.6, -9.7, -5.9, -9.9, -7.3,],\n            [-1.9, -5.5, -0.6, -5.0, -6.5, -8.1, -5.6, -8.0, -3.1, -6.5, -1.9, -6.8, -10.7, -13.2, -6.9, -12.5, 10.2, 1.9, 11.9, 2.1, -2.3, -4.1, -0.5, -4.6, -0.1, -0.9, 2.4, -0.8, -5.1, -6.9, -4.8, -6.7, -2.3, -7.1, -0.8, -7.2, -7.2, -8.0, -5.6, -8.5, -9.4, -9.7, -7.2, -9.8, -9.2, -11.1, -9.5, -10.7, -50.0, -8.7, -50.0, -8.6, -6.1, -7.5, -5.5, -7.7, -50.0, -10.4, -7.7, -10.0, -7.3, -13.6, -6.4, -13.3,],\n            [-5.3, -1.0, -6.1, 1.0, -7.8, -7.9, -8.5, -6.3, -4.3, -4.2, -4.8, -2.4, -10.7, -12.0, -9.7, -9.7, 3.0, 12.9, 2.1, 14.7, -4.9, -3.8, -4.0, -2.4, -1.0, 0.8, -1.3, 3.4, -7.6, -5.7, -8.1, -3.5, -6.8, -5.8, -7.2, -4.2, -8.9, -10.2, -8.4, -8.2, -9.9, -8.4, -9.7, -6.4, -11.1, -11.1, -11.8, -10.0, -50.0, 0.4, -50.0, 2.6, -7.2, -7.0, -7.4, -5.1, -50.0, -5.7, -9.8, -3.2, -8.4, -7.4, -8.9, -5.9,],\n            [-8.5, -10.3, -10.0, -9.0, -1.4, -4.9, -3.9, -3.7, -10.0, -8.5, -10.2, -7.8, -7.8, -12.4, -8.5, -11.1, 0.0, -5.5, -2.3, -4.9, 12.6, 10.0, 11.1, 10.5, -6.0, -8.3, -6.9, -7.5, -2.2, -7.4, -5.3, -5.9, -8.9, -12.5, -9.4, -11.6, -0.7, -3.9, -2.3, -3.0, -9.1, -9.8, -9.2, -9.5, -5.6, -9.0, -8.0, -8.5, -50.0, -15.3, -50.0, -14.1, 2.3, -1.4, 0.3, -0.5, -50.0, -13.6, -14.3, -11.5, -5.3, -13.7, -6.1, -12.7,],\n            [-11.2, -8.1, -11.8, -8.8, -4.1, -1.9, -3.9, -3.5, -11.6, -5.9, -11.5, -7.9, -10.2, -10.1, -10.2, -11.2, -3.4, -2.6, -4.1, -3.8, 10.0, 13.1, 10.7, 10.6, -8.1, -5.2, -8.0, -6.7, -6.1, -3.7, -7.5, -5.6, -11.1, -10.3, -10.6, -11.9, -3.2, -1.0, -2.2, -2.8, -10.5, -8.1, -9.4, -9.5, -8.3, -6.9, -9.4, -8.8, -50.0, -11.3, -50.0, -12.8, -0.6, 2.2, -0.3, 0.1, -50.0, -10.1, -17.5, -11.1, -8.6, -9.9, -8.6, -11.9,],\n            [-8.9, -9.4, -8.6, -8.9, -2.9, -4.5, -2.2, -3.9, -8.8, -7.5, -8.1, -7.9, -8.8, -11.6, -7.7, -11.9, -0.7, -4.1, -0.5, -4.0, 11.1, 10.7, 13.2, 10.4, -5.7, -5.8, -3.5, -6.1, -3.6, -6.5, -3.3, -5.5, -9.4, -11.0, -8.7, -11.2, -1.8, -2.7, 0.7, -3.0, -9.1, -8.2, -7.3, -9.4, -7.2, -8.2, -7.2, -8.2, -50.0, -13.2, -50.0, -13.3, 0.5, -0.9, 1.8, -0.6, -50.0, -11.4, -11.1, -10.5, -6.1, -12.9, -5.0, -11.9,],\n            [-10.8, -9.6, -11.9, -7.7, -3.3, -3.8, -4.5, -1.6, -11.7, -7.7, -12.0, -6.2, -9.6, -12.0, -9.8, -9.4, -3.2, -4.7, -4.6, -2.4, 10.5, 10.6, 10.4, 12.6, -8.2, -7.9, -9.0, -4.7, -6.1, -6.0, -7.5, -2.9, -10.9, -12.2, -11.2, -10.9, -2.4, -2.9, -2.7, -0.9, -10.4, -9.7, -10.2, -8.0, -8.4, -9.1, -9.3, -6.5, -50.0, -13.3, -50.0, -11.0, -0.0, -0.4, -0.4, 2.3, -50.0, -10.9, -17.2, -8.3, -8.3, -12.7, -7.8, -9.3,],\n            [2.1, -8.1, 1.2, -7.0, -8.0, -9.5, -7.3, -9.9, 10.5, -5.5, 9.3, -5.7, -9.5, -15.1, -10.0, -12.9, 2.5, -1.2, -0.1, -1.0, -6.0, -8.1, -5.7, -8.2, 13.8, 11.3, 11.8, 12.1, -6.0, -9.1, -9.0, -9.5, -8.9, -13.4, -10.0, -13.1, -9.9, -11.7, -9.8, -12.8, -5.9, -9.4, -6.5, -8.1, -10.7, -14.0, -13.3, -13.9, -50.0, -11.9, -50.0, -9.7, -8.9, -10.8, -9.0, -11.1, -50.0, -6.5, -5.3, -6.3, -10.5, -16.2, -10.4, -15.2,],\n            [0.0, -5.0, 0.5, -6.8, -9.1, -7.8, -7.5, -8.9, 7.7, -2.4, 8.2, -5.1, -11.9, -13.1, -10.4, -14.3, -0.8, 3.0, -0.9, 0.8, -8.3, -5.2, -5.8, -7.9, 11.3, 15.0, 11.2, 12.8, -9.7, -5.3, -9.2, -7.8, -11.7, -10.6, -10.1, -12.2, -11.7, -8.8, -8.9, -11.8, -9.3, -5.0, -8.0, -8.2, -13.6, -11.4, -12.8, -13.0, -50.0, -7.2, -50.0, -8.4, -11.0, -7.7, -8.7, -10.2, -50.0, -1.5, -7.1, -4.9, -11.2, -11.6, -11.6, -15.0,],\n            [1.4, -7.3, 2.2, -7.1, -8.0, -9.3, -6.4, -9.6, 9.1, -5.5, 10.0, -5.4, -10.9, -14.3, -8.4, -14.0, 0.9, -1.1, 2.4, -1.3, -6.9, -8.0, -3.5, -9.0, 11.8, 11.2, 13.4, 11.4, -7.3, -8.8, -6.5, -8.5, -10.0, -12.5, -7.8, -12.5, -9.6, -11.0, -7.1, -10.7, -7.9, -8.0, -4.3, -9.4, -11.4, -12.3, -10.9, -12.9, -50.0, -11.8, -50.0, -11.2, -9.4, -9.8, -7.3, -10.5, -50.0, -6.2, -2.2, -6.7, -9.8, -15.2, -8.5, -14.9,],\n            [0.2, -6.3, 0.1, -4.3, -8.2, -8.9, -8.5, -7.0, 8.5, -4.1, 8.0, -2.1, -10.5, -13.4, -10.2, -11.9, 0.2, 1.6, -0.8, 3.4, -7.5, -6.7, -6.1, -4.7, 12.1, 12.8, 11.4, 14.7, -8.7, -7.4, -9.4, -5.3, -9.9, -11.8, -10.5, -10.3, -9.9, -10.1, -9.3, -9.3, -8.1, -7.2, -8.0, -5.2, -12.0, -12.1, -12.6, -10.9, -50.0, -7.9, -50.0, -5.3, -9.3, -8.8, -8.9, -7.0, -50.0, -3.6, -7.1, -1.2, -10.2, -12.7, -9.9, -11.0,],\n            [-10.2, -13.4, -11.8, -12.4, -6.0, -9.4, -7.1, -8.6, -9.8, -12.9, -10.8, -12.4, 2.3, -1.4, 1.0, -1.0, -3.0, -8.0, -5.1, -7.6, -2.2, -6.1, -3.6, -6.1, -6.0, -9.7, -7.3, -8.7, 11.2, 7.9, 8.9, 8.1, -12.1, -17.4, -13.2, -16.8, -6.3, -9.5, -7.5, -8.8, -12.7, -15.2, -13.1, -14.2, 0.0, -3.1, -1.8, -3.1, -50.0, -10.7, -50.0, -9.3, -4.6, -8.9, -5.9, -8.3, -50.0, -12.8, -9.6, -10.6, 9.5, -3.2, 8.2, -2.8,],\n            [-13.5, -11.3, -14.0, -12.9, -9.3, -7.1, -8.2, -8.9, -12.7, -10.3, -11.9, -12.3, -0.4, 1.4, -0.6, -0.4, -7.2, -4.7, -6.9, -5.7, -7.4, -3.7, -6.5, -6.0, -9.1, -5.3, -8.8, -7.4, 7.9, 11.9, 7.8, 9.3, -15.2, -15.1, -14.6, -17.2, -9.7, -7.3, -8.2, -9.2, -15.0, -12.8, -14.1, -14.9, -2.8, 0.2, -2.9, -2.3, -50.0, -7.4, -50.0, -8.7, -9.4, -7.3, -9.4, -9.4, -50.0, -8.0, -11.9, -9.7, 6.5, 0.5, 6.4, -1.8,],\n            [-13.0, -14.4, -11.9, -13.9, -7.7, -9.0, -6.7, -8.8, -11.7, -12.7, -10.7, -13.1, -0.2, -1.6, 1.7, -1.6, -5.7, -8.7, -4.8, -8.1, -5.3, -7.5, -3.3, -7.5, -9.0, -9.2, -6.5, -9.4, 8.9, 7.8, 10.1, 7.8, -14.3, -17.7, -13.0, -17.8, -8.0, -9.4, -6.2, -9.2, -15.1, -14.9, -12.2, -14.9, -1.8, -3.2, -0.8, -3.2, -50.0, -10.8, -50.0, -9.9, -7.3, -9.6, -6.4, -9.4, -50.0, -12.3, -8.7, -11.3, 7.6, -3.3, 8.7, -2.9,],\n            [-12.5, -12.9, -13.4, -10.0, -8.5, -9.0, -7.8, -6.8, -11.8, -11.3, -12.4, -10.1, -0.3, -0.5, -0.5, 1.2, -6.1, -6.0, -6.7, -3.5, -5.9, -5.6, -5.5, -2.9, -9.5, -7.8, -8.5, -5.3, 8.1, 9.3, 7.8, 11.8, -14.4, -15.7, -14.5, -14.6, -8.4, -8.7, -7.9, -7.1, -14.3, -13.8, -13.8, -12.3, -2.4, -2.2, -2.9, -0.2, -50.0, -8.9, -50.0, -7.1, -8.1, -9.1, -8.7, -6.6, -50.0, -9.7, -11.4, -8.0, 6.8, -1.8, 6.9, 0.4,],\n            [-2.6, -6.3, -4.9, -4.9, -6.4, -9.4, -7.9, -8.6, -6.3, -7.4, -8.2, -6.6, -9.7, -14.9, -11.1, -13.9, -0.2, -8.2, -2.3, -6.8, -8.9, -11.1, -9.4, -10.9, -8.9, -11.7, -10.0, -9.9, -12.1, -15.2, -14.3, -14.4, 11.1, 2.9, 9.2, 3.5, -3.0, -7.0, -4.3, -6.2, -2.2, -6.6, -3.7, -5.7, -6.0, -10.4, -8.6, -9.5, -50.0, -15.5, -50.0, -13.9, -7.8, -10.5, -8.7, -9.6, -50.0, -16.5, -17.1, -14.8, -12.1, -18.9, -12.4, -17.4,],\n            [-8.5, 0.8, -9.1, -0.7, -10.1, -7.5, -9.1, -8.2, -11.4, -3.1, -11.8, -4.4, -15.5, -14.3, -14.8, -15.4, -6.6, -4.7, -7.1, -5.8, -12.5, -10.3, -11.0, -12.2, -13.4, -10.6, -12.5, -11.8, -17.4, -15.1, -17.7, -15.7, 2.9, 12.5, 3.1, 10.3, -7.7, -5.2, -6.2, -7.3, -5.4, -1.7, -5.4, -3.7, -11.6, -9.1, -13.0, -10.8, -50.0, -10.3, -50.0, -11.2, -9.8, -8.3, -9.1, -9.7, -50.0, -12.7, -20.6, -13.1, -16.0, -16.6, -17.0, -18.4,],\n            [-5.0, -6.4, -3.4, -5.6, -7.5, -9.3, -7.1, -8.8, -8.8, -7.4, -6.9, -6.9, -11.4, -15.2, -9.7, -13.7, -1.8, -7.8, -0.8, -7.2, -9.4, -10.6, -8.7, -11.2, -10.0, -10.1, -7.8, -10.5, -13.2, -14.6, -13.0, -14.5, 9.2, 3.1, 10.8, 3.0, -4.5, -6.7, -2.7, -6.7, -5.0, -6.8, -2.5, -6.7, -7.5, -10.4, -7.4, -10.2, -50.0, -15.5, -50.0, -14.2, -8.9, -10.2, -8.5, -10.0, -50.0, -15.6, -15.3, -15.5, -13.0, -18.8, -12.6, -18.3,],\n            [-8.1, -1.1, -8.9, 1.4, -8.6, -9.2, -9.4, -6.8, -11.0, -4.9, -11.5, -2.6, -13.7, -16.8, -14.5, -12.6, -6.0, -6.7, -7.2, -4.2, -11.6, -11.9, -11.2, -10.9, -13.1, -12.2, -12.5, -10.3, -16.8, -17.2, -17.8, -14.6, 3.5, 10.3, 3.0, 12.4, -6.9, -7.5, -6.8, -4.9, -5.4, -4.2, -5.4, -1.3, -10.8, -11.5, -12.4, -8.2, -50.0, -12.5, -50.0, -8.9, -9.2, -10.0, -9.4, -7.9, -50.0, -14.3, -19.9, -11.4, -16.2, -19.2, -15.8, -15.9,],\n            [-6.3, -7.4, -8.0, -6.0, 2.8, -0.7, 0.9, 0.3, -7.5, -4.4, -8.4, -3.6, -3.0, -7.7, -3.7, -6.2, -5.3, -10.0, -7.2, -8.9, -0.7, -3.2, -1.8, -2.4, -9.9, -11.7, -9.6, -9.9, -6.3, -9.7, -8.0, -8.4, -3.0, -7.7, -4.5, -6.9, 11.3, 8.2, 9.4, 9.1, -1.0, -3.3, -1.8, -2.4, 1.5, -2.1, -0.4, -1.1, -50.0, -14.5, -50.0, -12.9, 2.8, -0.0, 1.4, 0.7, -50.0, -8.7, -14.1, -7.5, -5.2, -12.5, -6.5, -10.7,],\n            [-9.9, -5.0, -10.0, -6.5, -0.7, 2.6, -0.2, 0.1, -10.3, -1.8, -9.9, -3.8, -6.4, -4.7, -5.8, -6.7, -8.2, -8.3, -8.0, -10.2, -3.9, -1.0, -2.7, -2.9, -11.7, -8.8, -11.0, -10.1, -9.5, -7.3, -9.4, -8.7, -7.0, -5.2, -6.7, -7.5, 8.2, 11.6, 8.8, 9.1, -3.7, -0.9, -3.1, -3.0, -2.0, 1.2, -2.3, -1.3, -50.0, -12.1, -50.0, -12.6, 0.1, 2.5, 0.7, 0.6, -50.0, -6.0, -14.8, -7.5, -8.6, -9.4, -8.5, -11.2,],\n            [-7.5, -6.2, -7.2, -6.2, 0.9, 0.2, 2.5, 0.2, -8.3, -3.5, -7.1, -3.7, -4.1, -6.3, -3.1, -6.3, -5.7, -8.9, -5.6, -8.4, -2.3, -2.2, 0.7, -2.7, -9.8, -8.9, -7.1, -9.3, -7.5, -8.2, -6.2, -7.9, -4.3, -6.2, -2.7, -6.8, 9.4, 8.8, 12.1, 8.8, -2.1, -2.0, 0.1, -2.4, 0.0, -1.1, 1.3, -0.8, -50.0, -11.9, -50.0, -12.6, 1.2, 0.7, 3.5, 0.8, -50.0, -7.1, -12.4, -7.1, -7.1, -10.6, -5.0, -10.6,],\n            [-9.0, -6.5, -10.0, -4.8, 0.1, -0.1, -0.3, 2.4, -9.9, -3.5, -10.6, -2.0, -5.4, -6.6, -5.6, -4.4, -7.6, -9.9, -8.5, -8.2, -3.0, -2.8, -3.0, -0.9, -12.8, -11.8, -10.7, -9.3, -8.8, -9.2, -9.2, -7.1, -6.2, -7.3, -6.7, -4.9, 9.1, 9.1, 8.8, 11.2, -3.1, -3.0, -3.3, -1.0, -1.1, -1.4, -2.0, 1.2, -50.0, -12.8, -50.0, -10.9, 0.8, 0.5, 0.7, 2.3, -50.0, -7.5, -16.5, -5.9, -7.8, -11.1, -7.8, -9.0,],\n            [-7.1, -5.6, -9.1, -5.1, -5.9, -8.0, -6.9, -7.4, -1.9, -1.6, -4.7, -1.4, -9.6, -14.6, -10.4, -13.0, -6.7, -10.8, -9.4, -9.9, -9.1, -10.5, -9.1, -10.4, -5.9, -9.3, -7.9, -8.1, -12.7, -15.0, -15.1, -14.3, -2.2, -5.4, -5.0, -5.4, -1.0, -3.7, -2.1, -3.1, 12.8, 9.6, 11.1, 10.1, -4.8, -9.4, -8.1, -8.6, -50.0, -18.3, -50.0, -15.4, -5.9, -7.5, -6.6, -7.1, -50.0, -9.5, -11.7, -8.4, -12.5, -17.3, -13.2, -15.4,],\n            [-10.2, -1.6, -10.2, -3.2, -7.3, -4.6, -6.5, -6.2, -6.7, 3.0, -6.8, 0.8, -11.9, -10.8, -11.5, -12.2, -9.6, -7.1, -9.7, -8.4, -9.8, -8.1, -8.2, -9.7, -9.4, -5.0, -8.0, -7.2, -15.2, -12.8, -14.9, -13.8, -6.6, -1.7, -6.8, -4.2, -3.3, -0.9, -2.0, -3.0, 9.6, 12.8, 9.7, 10.5, -8.5, -5.6, -9.3, -7.8, -50.0, -12.7, -50.0, -13.8, -6.8, -5.1, -5.3, -6.5, -50.0, -4.1, -12.8, -5.8, -14.4, -14.1, -13.6, -14.8,],\n            [-8.2, -4.7, -7.1, -5.0, -6.5, -7.7, -5.5, -6.9, -4.1, -0.8, -1.2, -0.9, -10.5, -12.8, -8.2, -13.0, -7.5, -10.0, -7.2, -9.7, -9.2, -9.4, -7.3, -10.2, -6.5, -8.0, -4.3, -8.0, -13.1, -14.1, -12.2, -13.8, -3.7, -5.4, -2.5, -5.4, -1.8, -3.1, 0.1, -3.3, 11.1, 9.7, 12.9, 9.8, -5.5, -8.1, -5.4, -7.8, -50.0, -16.4, -50.0, -14.8, -5.9, -7.1, -4.7, -7.2, -50.0, -8.4, -6.4, -8.1, -12.1, -16.2, -10.3, -15.8,],\n            [-9.2, -3.0, -9.9, -1.2, -6.5, -6.1, -6.8, -4.4, -6.4, 0.9, -7.0, 3.0, -11.8, -13.0, -11.1, -10.4, -9.3, -9.2, -9.8, -6.4, -9.5, -9.5, -9.4, -8.0, -8.1, -8.2, -9.4, -5.2, -14.2, -14.9, -14.9, -12.3, -5.7, -3.7, -6.7, -1.3, -2.4, -3.0, -2.4, -1.0, 10.1, 10.5, 9.8, 13.1, -7.2, -8.0, -8.4, -5.0, -50.0, -14.7, -50.0, -11.4, -6.3, -6.7, -5.8, -5.0, -50.0, -6.1, -13.4, -3.6, -13.0, -16.0, -13.7, -13.3,],\n            [-8.2, -10.8, -10.1, -9.8, -0.4, -3.6, -1.7, -2.9, -7.9, -8.4, -9.8, -8.2, 6.2, 2.3, 0.6, 2.9, -7.1, -11.6, -9.2, -11.1, -5.6, -8.3, -7.2, -8.4, -10.7, -13.6, -11.4, -12.0, 0.0, -2.8, -1.8, -2.4, -6.0, -11.6, -7.5, -10.8, 1.5, -2.0, 0.0, -1.1, -4.8, -8.5, -5.5, -7.2, 11.9, 8.6, 10.0, 9.0, -50.0, -14.2, -50.0, -12.8, -4.1, -7.4, -5.7, -6.5, -50.0, -11.0, -14.3, -9.9, 1.4, -7.9, -0.7, -6.8,],\n            [-12.5, -8.7, -13.0, -9.9, -3.9, -1.0, -3.4, -2.9, -12.5, -6.3, -11.6, -8.1, 3.3, 6.0, -1.6, 3.8, -10.5, -10.1, -11.1, -11.1, -9.0, -6.9, -8.2, -9.1, -14.0, -11.4, -12.3, -12.1, -3.1, 0.2, -3.2, -2.2, -10.4, -9.1, -10.4, -11.5, -2.1, 1.2, -1.1, -1.4, -9.4, -5.6, -8.1, -8.0, 8.6, 12.4, 8.6, 9.5, -50.0, -10.4, -50.0, -11.6, -7.2, -5.7, -7.5, -7.4, -50.0, -8.6, -15.7, -9.7, -3.0, -3.7, -3.2, -5.9,],\n            [-11.1, -11.9, -10.6, -11.3, -2.6, -4.1, -1.7, -3.5, -11.4, -9.6, -9.6, -9.2, 3.7, 2.5, 1.6, 2.5, -9.6, -12.3, -9.5, -11.8, -8.0, -9.4, -7.2, -9.3, -13.3, -12.8, -10.9, -12.6, -1.8, -2.9, -0.8, -2.9, -8.6, -13.0, -7.4, -12.4, -0.4, -2.3, 1.3, -2.0, -8.1, -9.3, -5.4, -8.4, 10.0, 8.6, 11.4, 8.9, -50.0, -13.7, -50.0, -13.2, -6.1, -8.1, -5.5, -7.5, -50.0, -11.3, -12.7, -10.1, -1.6, -7.8, -0.3, -7.2,],\n            [-11.4, -10.0, -12.7, -8.2, -3.1, -3.1, -2.8, -0.9, -11.7, -7.3, -12.1, -5.8, 3.6, 3.6, -1.1, 5.8, -9.4, -11.9, -10.7, -10.0, -8.5, -8.8, -8.2, -6.5, -13.9, -13.0, -12.9, -10.9, -3.1, -2.3, -3.2, -0.2, -9.5, -10.8, -10.2, -8.2, -1.1, -1.3, -0.8, 1.2, -8.6, -7.8, -7.8, -5.0, 9.0, 9.5, 8.9, 12.0, -50.0, -13.0, -50.0, -10.3, -6.2, -7.0, -7.1, -5.4, -50.0, -9.3, -14.0, -8.2, -2.4, -6.3, -2.4, -3.9,],\n            [-50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, 33.3, -50.0, 30.6, -50.0, -50.0, -50.0, -50.0, -50.0, 29.2, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0,],\n            [-14.8, -6.2, -14.9, -7.6, -14.6, -11.6, -13.0, -12.2, -14.0, -9.0, -14.1, -10.1, -13.6, -11.2, -12.4, -12.5, -8.1, 2.2, -8.7, 0.4, -15.3, -11.3, -13.2, -13.3, -11.9, -7.2, -11.8, -7.9, -10.7, -7.4, -10.8, -8.9, -15.5, -10.3, -15.5, -12.5, -14.5, -12.1, -11.9, -12.8, -18.3, -12.7, -16.4, -14.7, -14.2, -10.4, -13.7, -13.0, -50.0, 15.1, -50.0, 13.3, -9.9, -5.8, -8.9, -7.6, -50.0, -1.5, -7.8, -3.0, -8.1, 3.6, -9.4, 2.0,],\n            [-50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, 30.6, -50.0, 35.2, -50.0, -50.0, -50.0, -50.0, -50.0, 28.5, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0,],\n            [-13.8, -7.5, -14.4, -5.1, -12.6, -11.6, -11.5, -10.1, -13.2, -9.7, -12.7, -7.4, -11.9, -11.9, -11.5, -10.2, -7.2, 0.9, -8.6, 2.6, -14.1, -12.8, -13.3, -11.0, -9.7, -8.4, -11.2, -5.3, -9.3, -8.7, -9.9, -7.1, -13.9, -11.2, -14.2, -8.9, -12.9, -12.6, -12.6, -10.9, -15.4, -13.8, -14.8, -11.4, -12.8, -11.6, -13.2, -10.3, -50.0, 13.3, -50.0, 15.2, -8.6, -7.0, -8.4, -4.8, -50.0, -3.0, -7.1, -0.1, -7.3, 2.3, -8.7, 3.9,],\n            [-7.3, -6.3, -8.9, -5.5, 2.9, 0.2, 1.5, 1.2, -8.5, -2.3, -10.0, -1.7, -5.6, -10.5, -5.5, -9.6, -4.3, -7.9, -6.1, -7.2, 2.3, -0.6, 0.5, -0.0, -8.9, -11.0, -9.4, -9.3, -4.6, -9.4, -7.3, -8.1, -7.8, -9.8, -8.9, -9.2, 2.8, 0.1, 1.2, 0.8, -5.9, -6.8, -5.9, -6.3, -4.1, -7.2, -6.1, -6.2, -50.0, -9.9, -50.0, -8.6, 12.5, 9.4, 11.0, 9.8, -50.0, -4.8, -8.7, -3.5, -0.0, -8.6, -2.1, -7.0,],\n            [-10.1, -4.3, -10.8, -5.8, 0.1, 2.3, 0.7, 0.6, -10.4, -0.2, -10.8, -2.0, -8.8, -9.2, -8.0, -9.7, -6.8, -5.9, -7.5, -7.0, -1.4, 2.2, -0.9, -0.4, -10.8, -7.7, -9.8, -8.8, -8.9, -7.3, -9.6, -9.1, -10.5, -8.3, -10.2, -10.0, -0.0, 2.5, 0.7, 0.5, -7.5, -5.1, -7.1, -6.7, -7.4, -5.7, -8.1, -7.0, -50.0, -5.8, -50.0, -7.0, 9.4, 12.7, 10.1, 10.0, -50.0, -1.5, -11.3, -3.3, -5.4, -4.2, -5.6, -6.8,],\n            [-8.4, -6.2, -8.9, -5.9, 1.8, 0.4, 2.7, 1.2, -9.1, -1.2, -8.8, -1.5, -7.2, -10.5, -4.9, -9.6, -5.7, -7.4, -5.5, -7.4, 0.3, -0.3, 1.8, -0.4, -9.0, -8.7, -7.3, -8.9, -5.9, -9.4, -6.4, -8.7, -8.7, -9.1, -8.5, -9.4, 1.4, 0.7, 3.5, 0.7, -6.6, -5.3, -4.7, -5.8, -5.7, -7.5, -5.5, -7.1, -50.0, -8.9, -50.0, -8.4, 11.0, 10.1, 13.2, 10.2, -50.0, -4.2, -6.1, -3.6, -3.5, -8.4, -1.2, -6.8,],\n            [-9.1, -5.4, -10.4, -4.2, 1.0, 0.5, 0.6, 2.4, -9.6, -1.5, -10.5, -0.5, -8.9, -10.5, -7.2, -8.3, -6.3, -6.9, -7.7, -5.1, -0.5, 0.1, -0.6, 2.3, -11.1, -10.2, -10.5, -7.0, -8.3, -9.4, -9.4, -6.6, -9.6, -9.7, -10.0, -7.9, 0.7, 0.6, 0.8, 2.3, -7.1, -6.5, -7.2, -5.0, -6.5, -7.4, -7.5, -5.4, -50.0, -7.6, -50.0, -4.8, 9.8, 10.0, 10.2, 12.1, -50.0, -3.1, -11.4, -0.7, -4.6, -6.6, -4.9, -3.9,],\n            [-50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, 29.2, -50.0, 28.5, -50.0, -50.0, -50.0, -50.0, -50.0, 33.3, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0, -50.0,],\n            [-13.0, -7.0, -13.1, -8.3, -9.2, -6.5, -8.9, -7.6, -9.8, -0.7, -9.2, -2.1, -12.4, -10.3, -12.4, -11.6, -9.5, -4.6, -10.4, -5.7, -13.6, -10.1, -11.4, -10.9, -6.5, -1.5, -6.2, -3.6, -12.8, -8.0, -12.3, -9.7, -16.5, -12.7, -15.6, -14.3, -8.7, -6.0, -7.1, -7.5, -9.5, -4.1, -8.4, -6.1, -11.0, -8.6, -11.3, -9.3, -50.0, -1.5, -50.0, -3.0, -4.8, -1.5, -4.2, -3.1, -50.0, 16.4, -5.1, 14.2, -10.1, -4.3, -10.0, -5.4,],\n            [-13.5, -16.3, -11.8, -15.5, -13.6, -15.3, -12.1, -16.1, -7.7, -13.3, -4.2, -12.6, -14.1, -16.2, -10.3, -15.4, -9.6, -11.6, -7.7, -9.8, -14.3, -17.5, -11.1, -17.2, -5.3, -7.1, -2.2, -7.1, -9.6, -11.9, -8.7, -11.4, -17.1, -20.6, -15.3, -19.9, -14.1, -14.8, -12.4, -16.5, -11.7, -12.8, -6.4, -13.4, -14.3, -15.7, -12.7, -14.0, -50.0, -7.8, -50.0, -7.1, -8.7, -11.3, -6.1, -11.4, -50.0, -5.1, 18.6, -4.8, -8.6, -8.1, -4.5, -7.3,],\n            [-12.4, -8.2, -13.0, -5.9, -7.7, -7.8, -7.4, -5.8, -8.8, -2.0, -9.3, -0.4, -11.6, -11.3, -11.6, -9.4, -8.9, -5.6, -10.0, -3.2, -11.5, -11.1, -10.5, -8.3, -6.3, -4.9, -6.7, -1.2, -10.6, -9.7, -11.3, -8.0, -14.8, -13.1, -15.5, -11.4, -7.5, -7.5, -7.1, -5.9, -8.4, -5.8, -8.1, -3.6, -9.9, -9.7, -10.1, -8.2, -50.0, -3.0, -50.0, -0.1, -3.5, -3.3, -3.6, -0.7, -50.0, 14.2, -4.8, 16.4, -8.9, -5.8, -8.9, -3.4,],\n            [-10.7, -13.2, -12.4, -11.6, -4.8, -8.4, -6.1, -7.2, -10.3, -11.8, -11.0, -11.6, 2.8, -1.7, 0.7, -1.1, -6.2, -9.7, -7.3, -8.4, -5.3, -8.6, -6.1, -8.3, -10.5, -11.2, -9.8, -10.2, 9.5, 6.5, 7.6, 6.8, -12.1, -16.0, -13.0, -16.2, -5.2, -8.6, -7.1, -7.8, -12.5, -14.4, -12.1, -13.0, 1.4, -3.0, -1.6, -2.4, -50.0, -8.1, -50.0, -7.3, -0.0, -5.4, -3.5, -4.6, -50.0, -10.1, -8.6, -8.9, 13.2, -0.9, 9.7, -0.3,],\n            [-18.1, -12.3, -19.4, -14.2, -12.2, -9.5, -11.5, -10.8, -17.9, -11.9, -18.2, -13.9, -6.4, -3.7, -6.8, -5.4, -12.8, -5.9, -13.6, -7.4, -13.7, -9.9, -12.9, -12.7, -16.2, -11.6, -15.2, -12.7, -3.2, 0.5, -3.3, -1.8, -18.9, -16.6, -18.8, -19.2, -12.5, -9.4, -10.6, -11.1, -17.3, -14.1, -16.2, -16.0, -7.9, -3.7, -7.8, -6.3, -50.0, 3.6, -50.0, 2.3, -8.6, -4.2, -8.4, -6.6, -50.0, -4.3, -8.1, -5.8, -0.9, 14.2, -1.8, 11.6,],\n            [-11.8, -13.1, -11.5, -12.0, -6.2, -8.3, -5.4, -7.4, -11.8, -12.3, -11.1, -11.4, 0.5, -2.5, 2.4, -1.6, -6.8, -9.9, -6.4, -8.9, -6.1, -8.6, -5.0, -7.8, -10.4, -11.6, -8.5, -9.9, 8.2, 6.4, 8.7, 6.9, -12.4, -17.0, -12.6, -15.8, -6.5, -8.5, -5.0, -7.8, -13.2, -13.6, -10.3, -13.7, -0.7, -3.2, -0.3, -2.4, -50.0, -9.4, -50.0, -8.7, -2.1, -5.6, -1.2, -4.9, -50.0, -10.0, -4.5, -8.9, 9.7, -1.8, 11.3, -0.9,],\n            [-17.2, -13.3, -17.8, -11.6, -11.0, -11.1, -10.4, -9.0, -16.0, -12.7, -16.1, -11.1, -5.2, -5.4, -6.0, -3.3, -11.8, -7.3, -13.3, -5.9, -12.7, -11.9, -11.9, -9.3, -15.2, -15.0, -14.9, -11.0, -2.8, -1.8, -2.9, 0.4, -17.4, -18.4, -18.3, -15.9, -10.7, -11.2, -10.6, -9.0, -15.4, -14.8, -15.8, -13.3, -6.8, -5.9, -7.2, -3.9, -50.0, 2.0, -50.0, 3.9, -7.0, -6.8, -6.8, -3.9, -50.0, -5.4, -7.3, -3.4, -0.3, 11.6, -0.9, 14.1,]];\n        this.TRANS = [[5, 0, 0, 4],\n            [0, 5, 4, 0],\n            [0, 4, 5, 0],\n            [4, 0, 0, 5]];\n        this.CONBLO = { 'A': 0, 'R': 1, 'N': 2, 'D': 3, 'C': 4, 'Q': 5, 'E': 6, 'G': 7, 'H': 8, 'I': 9, 'L': 10, 'K': 11, 'M': 12, 'F': 13, 'P': 14, 'S': 15, 'T': 16, 'W': 17, 'Y': 18, 'V': 19, 'B': 20, 'Z': 21, 'X': 22, '*': 23 };\n        this.CONNUCL = { 'A': 0, 'T': 1, 'C': 2, 'G': 3 };\n        this.CONSCHN = { 'AAA': 0, 'AAC': 1, 'AAG': 2, 'AAT': 3, 'ACA': 4, 'ACC': 5, 'ACG': 6, 'ACT': 7, 'AGA': 8, 'AGC': 9, 'AGG': 10, 'AGT': 11, 'ATA': 12, 'ATC': 13, 'ATG': 14, 'ATT': 15, 'CAA': 16, 'CAC': 17, 'CAG': 18, 'CAT': 19, 'CCA': 20, 'CCC': 21, 'CCG': 22, 'CCT': 23, 'CGA': 24, 'CGC': 25, 'CGG': 26, 'CGT': 27, 'CTA': 28, 'CTC': 29, 'CTG': 30, 'CTT': 31, 'GAA': 32, 'GAC': 33, 'GAG': 34, 'GAT': 35, 'GCA': 36, 'GCC': 37, 'GCG': 38, 'GCT': 39, 'GGA': 40, 'GGC': 41, 'GGG': 42, 'GGT': 43, 'GTA': 44, 'GTC': 45, 'GTG': 46, 'GTT': 47, 'TAA': 48, 'TAC': 49, 'TAG': 50, 'TAT': 51, 'TCA': 52, 'TCC': 53, 'TCG': 54, 'TCT': 55, 'TGA': 56, 'TGC': 57, 'TGG': 58, 'TGT': 59, 'TTA': 60, 'TTC': 61, 'TTG': 62, 'TTT': 63 };\n        this.setMethod(alignGrid_);\n        this.setSequences(seq1_, seq2_);\n        this.setGap(gap_);\n    }\n    fillNeedleman() {\n        for (let i = 0; i <= this.len1; i++) {\n            this.dpGrid[i][0].value = -i * this.gap;\n            this.dpGrid[i][0].parentI = i - 1;\n            this.dpGrid[i][0].parentJ = 0;\n        }\n        for (let i = 1; i <= this.len2; i++) {\n            this.dpGrid[0][i].value = -i * this.gap;\n            this.dpGrid[0][i].parentI = 0;\n            this.dpGrid[0][i].parentJ = i - 1;\n        }\n    }\n    fillOne(i, j) {\n        this.dpGrid[i][j].value = Math.max(this.dpGrid[i - 1][j - 1].value + this.scores[i - 1][j - 1], Math.max(this.dpGrid[i - 1][j].value - this.gap, this.dpGrid[i][j - 1].value - this.gap));\n        if (this.dpGrid[i][j].value == this.dpGrid[i - 1][j - 1].value + this.scores[i - 1][j - 1]) {\n            this.dpGrid[i][j].parentI = i - 1;\n            this.dpGrid[i][j].parentJ = j - 1;\n        }\n        else if (this.dpGrid[i][j].value == this.dpGrid[i - 1][j].value - this.gap) {\n            this.dpGrid[i][j].parentI = i - 1;\n            this.dpGrid[i][j].parentJ = j;\n        }\n        else {\n            this.dpGrid[i][j].parentI = i;\n            this.dpGrid[i][j].parentJ = j - 1;\n        }\n    }\n    gridFromName(path) {\n        switch (path) {\n            case 'BLOSUM45':\n                this.alignGrid = this.BLOSUM45;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM50':\n                this.alignGrid = this.BLOSUM50;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM62':\n                this.alignGrid = this.BLOSUM62;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM80':\n                this.alignGrid = this.BLOSUM80;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'BLOSUM90':\n                this.alignGrid = this.BLOSUM90;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'PAM30':\n                this.alignGrid = this.PAM30;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'PAM70':\n                this.alignGrid = this.PAM70;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'PAM250':\n                this.alignGrid = this.PAM250;\n                this.connections = this.CONBLO;\n                this.step = 1;\n                break;\n            case 'NUCLEOTIDES':\n                this.alignGrid = this.NUCLEOTIDES;\n                this.connections = this.CONNUCL;\n                this.step = 1;\n                break;\n            case 'TRANS':\n                this.alignGrid = this.TRANS;\n                this.connections = this.CONNUCL;\n                this.step = 1;\n                break;\n            case 'SCHNEIDER':\n                this.alignGrid = this.SCHNEIDER;\n                this.connections = this.CONSCHN;\n                this.step = 3;\n                break;\n        }\n        this.fillScores();\n    }\n    constructResult(i, j) {\n        let res1 = \"\", res2 = \"\", gapS = \"\";\n        let total = this.dpGrid[i][j].value;\n        for (let i = 0; i < this.step; i++) {\n            gapS += '|';\n        }\n        while (i > 0 || j > 0) {\n            if (this.dpGrid[i][j].parentI == i) {\n                res1 = gapS + res1;\n                res2 = this.seq2.substr((j - 1) * this.step, this.step) + res2;\n            }\n            else if (this.dpGrid[i][j].parentJ == j) {\n                res2 = gapS + res2;\n                res1 = this.seq1.substr((i - 1) * this.step, this.step) + res1;\n            }\n            else {\n                if (i - 1 >= 0)\n                    res1 = this.seq1.substr((i - 1) * this.step, this.step) + res1;\n                else\n                    res1 = gapS + res1;\n                if (j - 1 >= 0)\n                    res2 = this.seq2.substr((j - 1) * this.step, this.step) + res2;\n                else\n                    res2 = gapS + res2;\n            }\n            let tempI = i;\n            i = this.dpGrid[i][j].parentI;\n            j = this.dpGrid[tempI][j].parentJ;\n        }\n        return new Aligned(res1, res2, total);\n    }\n    fillScores() {\n        this.scores = [];\n        for (let i = 0; i < this.len1; i++) {\n            this.scores.push([]);\n            for (let j = 0; j < this.len2; j++) {\n                this.scores[i].push(this.alignGrid[this.connections[this.seq1.substr(i * this.step, this.step)]][this.connections[this.seq2.substr(j * this.step, this.step)]]);\n            }\n        }\n    }\n    typeRec() {\n        if (/[ATGC]*/.test(this.seq1) && /[ATGC]*/.test(this.seq2))\n            return \"NUCLEOTIDES\";\n        if (/[ARNDCQEGHILKMFPSTWYVBZX*]*/.test(this.seq1) && /[ARNDCQEGHILKMFPSTWYVBZX*]*/.test(this.seq2))\n            return \"BLOSUM62\";\n        throw Error(\"Can't recognize sequence type\");\n    }\n    needlemanWunch() {\n        this.dpGrid = [];\n        for (let i = 0; i < this.len1 + 1; i++) {\n            let row = [];\n            for (let j = 0; j < this.len2 + 1; j++)\n                row.push(new Cell());\n            this.dpGrid.push(row);\n        }\n        this.fillNeedleman();\n        for (let i = 1; i <= this.len1; i++) {\n            for (let j = 1; j <= this.len2; j++) {\n                this.fillOne(i, j);\n            }\n        }\n        return this.constructResult(this.len1, this.len2);\n    }\n    smithWaterman() {\n        this.dpGrid = [];\n        for (let i = 0; i < this.len1 + 1; i++) {\n            let row = [];\n            for (let j = 0; j < this.len2 + 1; j++)\n                row.push(new Cell());\n            this.dpGrid.push(row);\n        }\n        let bestVal = 0;\n        let bestI = 0, bestJ = 0;\n        for (let i = 1; i <= this.len1; i++) {\n            for (let j = 1; j <= this.len2; j++) {\n                this.fillOne(i, j);\n                if (this.dpGrid[i][j].value <= 0) {\n                    this.dpGrid[i][j].value = 0;\n                    this.dpGrid[i][j].parentI = 0;\n                    this.dpGrid[i][j].parentJ = 0;\n                }\n                else if (this.dpGrid[this.dpGrid[i][j].parentI][this.dpGrid[i][j].parentJ].value == 0) {\n                    this.dpGrid[i][j].parentI = 0;\n                    this.dpGrid[i][j].parentJ = 0;\n                }\n                if (this.dpGrid[i][j].value > bestVal) {\n                    bestVal = this.dpGrid[i][j].value;\n                    bestI = i;\n                    bestJ = j;\n                }\n            }\n        }\n        return this.constructResult(bestI, bestJ);\n    }\n    setSequences(seq1_, seq2_) {\n        this.seq1 = seq1_;\n        this.seq2 = seq2_;\n        this.len1 = this.seq1.length / this.step;\n        this.len2 = this.seq2.length / this.step;\n        this.fillScores();\n    }\n    setGap(gap_) {\n        this.gap = gap_;\n    }\n    setMethod(alignGrid_ = \"\") {\n        if (alignGrid_ == \"AUTO\") {\n            alignGrid_ = this.typeRec();\n        }\n        this.gridFromName(alignGrid_);\n    }\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as grok from 'datagrok-api/grok';\nexport function getMacroMol(monomers) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let result = [];\n        const moduleRdkit = yield grok.functions.call('Chem:getRdKitModule');\n        for (let i = 0; i < monomers.length; i++) {\n            for (let j = 0; j < monomers[i].length; j++) {\n                const mol = moduleRdkit.get_mol(monomers[i][j]['molfile']);\n                const a = mol.get_v3Kmolblock();\n                const indices = getIndices(monomers[i][j], a);\n                monomers[i][j]['indices'] = indices;\n                monomers[i][j]['molfile'] = yield rotateBackboneV3000(a, indices);\n                mol === null || mol === void 0 ? void 0 : mol.delete();\n            }\n            result.push(linkV3000(monomers[i]));\n        }\n        return result;\n    });\n}\nfunction getIndices(monomer, molV3000) {\n    const molfile = monomer[\"molfile\"];\n    let indexStart = molfile.indexOf('M  RGP', 0) + 8;\n    let indexEnd = molfile.indexOf('\\n', indexStart);\n    const indicesData = molfile.substring(indexStart, indexEnd).replaceAll('  ', ' ').replaceAll('  ', ' ');\n    let parsedData = indicesData.split(' ');\n    const remFirst = parsedData[2] == '1' ? parseInt(parsedData[1]) : parseInt(parsedData[3]);\n    const remLast = parsedData[2] == '2' ? parseInt(parsedData[1]) : parseInt(parsedData[3]);\n    const numbers = extractAtomsBondsNumbersV3000(molV3000);\n    let indexBonds = molV3000.indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n    indexBonds = molV3000.indexOf('\\n', indexBonds);\n    indexStart = indexBonds;\n    indexEnd = indexBonds;\n    let first = 0;\n    let last = 0;\n    let remBondFirst = 0;\n    let remBondLast = 0;\n    for (let j = 0; j < numbers.nbond; j++) {\n        if (first == 0 || last == 0) {\n            indexStart = molV3000.indexOf('V30', indexStart) + 4;\n            indexEnd = molV3000.indexOf('\\n', indexStart);\n            const bondData = molV3000.substring(indexStart, indexEnd).replaceAll('  ', ' ').replaceAll('  ', ' ');\n            parsedData = bondData.split(' ');\n            if (parseInt(parsedData[2]) == remFirst) {\n                first = parseInt(parsedData[3]);\n                remBondFirst = parseInt(parsedData[0]);\n            }\n            else if (parseInt(parsedData[3]) == remFirst) {\n                first = parseInt(parsedData[2]);\n                remBondFirst = parseInt(parsedData[0]);\n            }\n            else if (parseInt(parsedData[2]) == remLast) {\n                last = parseInt(parsedData[3]);\n                remBondLast = parseInt(parsedData[0]);\n            }\n            else if (parseInt(parsedData[3]) == remLast) {\n                last = parseInt(parsedData[2]);\n                remBondLast = parseInt(parsedData[0]);\n            }\n        }\n    }\n    return { first, last, remFirst, remLast, remBondFirst, remBondLast };\n}\nfunction rotateBackboneV3000(molBlock, indices) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const coordinates = extractAtomDataV3000(molBlock);\n        const natom = coordinates.atomIndex.length;\n        const first = indices['first'];\n        const last = indices['last'];\n        const xCenter = (coordinates.x[last] + coordinates.x[first]) / 2;\n        const yCenter = (coordinates.y[last] + coordinates.y[first]) / 2;\n        //place to center\n        for (let i = 0; i < natom; i++) {\n            coordinates.x[i] -= xCenter;\n            coordinates.y[i] -= yCenter;\n        }\n        let angle = 0;\n        if (coordinates.x[first] == 0)\n            angle = coordinates.y[first] > coordinates.y[last] ? Math.PI / 2 : 3 * Math.PI / 2;\n        else if (coordinates.y[first] == 0)\n            angle = coordinates.x[first] > coordinates.x[last] ? Math.PI : 0;\n        else {\n            const derivative = coordinates.y[first] / coordinates.x[first];\n            if (coordinates.x[first] < coordinates.x[last])\n                angle = derivative > 0 ? Math.PI - Math.atan(derivative) : Math.atan(derivative);\n            else\n                angle = derivative > 0 ? Math.atan(derivative) : Math.PI - Math.atan(derivative);\n        }\n        const cos = Math.cos(angle);\n        const sin = Math.sin(angle);\n        for (let i = 0; i < natom; i++) {\n            const xAdd = coordinates.x[i];\n            coordinates.x[i] = xAdd * cos - coordinates.y[i] * sin;\n            coordinates.y[i] = xAdd * sin + coordinates.y[i] * cos;\n        }\n        //place to right\n        const xShift = coordinates.x[first];\n        for (let i = 0; i < natom; i++)\n            coordinates.x[i] -= xShift;\n        //rewrite molBlock\n        let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        index = molBlock.indexOf('\\n', index);\n        let indexEnd = index;\n        for (let i = 0; i < natom; i++) {\n            index = molBlock.indexOf('V30', index) + 4;\n            index = molBlock.indexOf(' ', index) + 1;\n            index = molBlock.indexOf(' ', index) + 1;\n            indexEnd = molBlock.indexOf(' ', index) + 1;\n            indexEnd = molBlock.indexOf(' ', indexEnd);\n            molBlock = molBlock.slice(0, index) +\n                coordinates.x[i] + ' ' + coordinates.y[i] +\n                molBlock.slice(indexEnd);\n            index = molBlock.indexOf('\\n', index) + 1;\n        }\n        return molBlock;\n    });\n}\nfunction extractAtomDataV3000(molBlock) {\n    const numbers = extractAtomsBondsNumbersV3000(molBlock);\n    let index = molBlock.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n    index = molBlock.indexOf('\\n', index);\n    let indexEnd = index;\n    const indexes = Array(numbers.natom);\n    const types = Array(numbers.natom);\n    const x = Array(numbers.natom);\n    const y = Array(numbers.natom);\n    for (let i = 0; i < numbers.natom; i++) {\n        index = molBlock.indexOf('V30', index) + 4;\n        indexEnd = molBlock.indexOf(' ', index);\n        indexes[i] = parseInt(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        types[i] = molBlock.substring(index, indexEnd);\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        x[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = indexEnd + 1;\n        indexEnd = molBlock.indexOf(' ', index);\n        y[i] = parseFloat(molBlock.substring(index, indexEnd));\n        index = molBlock.indexOf('\\n', index) + 1;\n    }\n    return { atomIndex: indexes, atomType: types, x: x, y: y };\n}\nfunction linkV3000(monomers) {\n    let macroMolBlock = '\\nDatagrok macromolecule handler\\n\\n';\n    macroMolBlock += '  0  0  0  0  0  0            999 V3000\\n';\n    macroMolBlock += 'M  V30 BEGIN CTAB\\n';\n    let atomBlock = '';\n    let bondBlock = '';\n    let collectionBlock = '';\n    const collection = [];\n    let natom = 0;\n    let nbond = 0;\n    let xShift = 0;\n    for (let i = 0; i < monomers.length; i++) {\n        let molfile = monomers[i]['molfile'];\n        const first = monomers[i]['indices']['first'];\n        const last = monomers[i]['indices']['last'];\n        const remFirst = monomers[i]['indices']['remFirst'];\n        const remLast = monomers[i]['indices']['remLast'];\n        const remBondFirst = monomers[i]['indices']['remBondFirst'];\n        const remBondLast = monomers[i]['indices']['remBondLast'];\n        molfile = molfile.replaceAll('(-\\nM  V30 ', '(')\n            .replaceAll('-\\nM  V30 ', '').replaceAll(' )', ')');\n        const numbers = extractAtomsBondsNumbersV3000(molfile);\n        const coordinates = extractAtomDataV3000(molfile);\n        let indexAtoms = molfile.indexOf('M  V30 BEGIN ATOM'); // V3000 index for atoms coordinates\n        indexAtoms = molfile.indexOf('\\n', indexAtoms);\n        let index = indexAtoms;\n        let indexEnd = indexAtoms;\n        const totalShift = xShift - coordinates.x[first - 1];\n        for (let j = 0; j < numbers.natom; j++) {\n            if (coordinates.atomIndex[j] != remFirst && coordinates.atomIndex[j] != remLast) { //|| i == 0) {\n                //rewrite atom number\n                index = molfile.indexOf('V30', index) + 4;\n                indexEnd = molfile.indexOf(' ', index);\n                let atomNumber = parseInt(molfile.substring(index, indexEnd));\n                atomNumber = (atomNumber > remFirst && atomNumber > remLast) ? atomNumber - 2 :\n                    (atomNumber > remFirst || atomNumber > remLast) ? atomNumber - 1 : atomNumber;\n                atomNumber += natom;\n                molfile = molfile.slice(0, index) + atomNumber + molfile.slice(indexEnd);\n                //rewrite coordinates\n                index = molfile.indexOf(' ', index) + 1;\n                index = molfile.indexOf(' ', index) + 1;\n                indexEnd = molfile.indexOf(' ', index);\n                let coordinate = Math.round(10000 * (parseFloat(molfile.substring(index, indexEnd)) + totalShift)) / 10000;\n                molfile = molfile.slice(0, index) + coordinate + molfile.slice(indexEnd);\n                index = molfile.indexOf(' ', index) + 1;\n                indexEnd = molfile.indexOf(' ', index);\n                coordinate = Math.round(10000 * (parseFloat(molfile.substring(index, indexEnd)))) / 10000;\n                molfile = molfile.slice(0, index) + coordinate + molfile.slice(indexEnd);\n                index = molfile.indexOf('\\n', index) + 1;\n            }\n            else {\n                index = molfile.indexOf('M  V30', index) - 1;\n                indexEnd = molfile.indexOf('\\n', index + 1);\n                molfile = molfile.slice(0, index) + molfile.slice(indexEnd);\n            }\n        }\n        const indexAtomsEnd = molfile.indexOf('M  V30 END ATOM');\n        atomBlock += molfile.substring(indexAtoms + 1, indexAtomsEnd);\n        let indexBonds = molfile.indexOf('M  V30 BEGIN BOND'); // V3000 index for bonds\n        indexBonds = molfile.indexOf('\\n', indexBonds);\n        index = indexBonds;\n        indexEnd = indexBonds;\n        let bondNumber = 0;\n        for (let j = 0; j < numbers.nbond; j++) {\n            //rewrite bond number\n            index = molfile.indexOf('V30', index) + 4;\n            indexEnd = molfile.indexOf(' ', index);\n            bondNumber = parseInt(molfile.substring(index, indexEnd));\n            if (bondNumber == remBondFirst || bondNumber == remBondLast) {\n                indexEnd = molfile.indexOf('\\n', index) + 1;\n                index -= 7;\n                molfile = molfile.slice(0, index) + molfile.slice(indexEnd);\n                continue;\n            }\n            bondNumber = (bondNumber > remBondFirst && bondNumber > remBondLast) ? bondNumber - 2 :\n                (bondNumber > remBondFirst || bondNumber > remBondLast) ? bondNumber - 1 : bondNumber;\n            bondNumber += nbond;\n            molfile = molfile.slice(0, index) + bondNumber + molfile.slice(indexEnd);\n            //rewrite atom pair in bond\n            index = molfile.indexOf(' ', index) + 1;\n            index = molfile.indexOf(' ', index) + 1;\n            indexEnd = molfile.indexOf(' ', index);\n            let atomNumber = parseInt(molfile.substring(index, indexEnd));\n            atomNumber = (atomNumber > remFirst && atomNumber > remLast) ? atomNumber - 2 :\n                (atomNumber > remFirst || atomNumber > remLast) ? atomNumber - 1 : atomNumber;\n            atomNumber += natom;\n            molfile = molfile.slice(0, index) + atomNumber + molfile.slice(indexEnd);\n            index = molfile.indexOf(' ', index) + 1;\n            indexEnd = Math.min(molfile.indexOf('\\n', index), molfile.indexOf(' ', index));\n            atomNumber = parseInt(molfile.substring(index, indexEnd));\n            atomNumber = (atomNumber > remFirst && atomNumber > remLast) ? atomNumber - 2 :\n                (atomNumber > remFirst || atomNumber > remLast) ? atomNumber - 1 : atomNumber;\n            atomNumber += natom;\n            molfile = molfile.slice(0, index) + atomNumber + molfile.slice(indexEnd);\n            index = molfile.indexOf('\\n', index) + 1;\n        }\n        const indexBondEnd = molfile.indexOf('M  V30 END BOND');\n        bondBlock += molfile.substring(indexBonds + 1, indexBondEnd);\n        //let indexCollection = molfile.indexOf('M  V30 MDLV30/STEABS ATOMS=('); // V3000 index for collections\n        // while (indexCollection != -1) {\n        //   indexCollection += 28;\n        //   const collectionEnd = molfile.indexOf(')', indexCollection);\n        //   const collectionEntries = molfile.substring(indexCollection, collectionEnd).split(' ').slice(1);\n        //   collectionEntries.forEach((e: string) => {\n        //     collection.push(parseInt(e) + natom);\n        //   });\n        //   indexCollection = collectionEnd;\n        //   indexCollection = molfile.indexOf('M  V30 MDLV30/STEABS ATOMS=(', indexCollection);\n        // }\n        natom += numbers.natom - 2;\n        nbond += numbers.nbond - 2;\n        xShift += coordinates.x[last] - coordinates.x[first] + 1;\n        if (i == monomers.length - 1) {\n            natom++;\n            const shift = xShift + 0.2;\n            atomBlock += 'M  V30 ' + natom + ' O ' + shift + ' 0 0.000000 0\\n';\n        }\n        nbond++;\n        if (i == monomers.length - 1) {\n            const rightTerminal = (last > remFirst && last > remLast) ? last + natom - (numbers.natom - 2) - 3 :\n                (last > remFirst || last > remLast) ? last + natom - (numbers.natom - 2) - 2 :\n                    last + natom - (numbers.natom - 2) - 1;\n            bondBlock += 'M  V30 ' + nbond + ' 1 ' + rightTerminal + ' ' + natom + '\\n';\n        }\n        else {\n            const rightTerminal = (last > remFirst && last > remLast) ? last + natom - (numbers.natom - 2) - 2 :\n                (last > remFirst || last > remLast) ? last + natom - (numbers.natom - 2) - 1 :\n                    last + natom - (numbers.natom - 2);\n            const next = monomers[i + 1]['indices'];\n            const nextFirst = next['first'];\n            const nextRemFirst = next['remFirst'];\n            const nextRemLast = next['remLast'];\n            const leftTerminal = (nextFirst > nextRemFirst && nextFirst > nextRemLast) ? nextFirst + natom - 2 :\n                (nextFirst > nextRemFirst || nextFirst > nextRemLast) ? nextFirst + natom - 1 :\n                    nextFirst + natom;\n            bondBlock += 'M  V30 ' + nbond + ' 1 ' + rightTerminal + ' ' + leftTerminal + '\\n';\n        }\n    }\n    // const entries = 4;\n    // const collNumber = Math.ceil(collection.length / entries);\n    // collectionBlock += 'M  V30 MDLV30/STEABS ATOMS=(' + collection.length + ' -\\n';\n    // for (let i = 0; i < collNumber; i++) {\n    //   collectionBlock += 'M  V30 ';\n    //   const entriesCurrent = i + 1 == collNumber ? collection.length - (collNumber - 1)*entries : entries;\n    //   for (let j = 0; j < entriesCurrent; j++) {\n    //     collectionBlock += (j + 1 == entriesCurrent) ?\n    //       (i == collNumber - 1 ? collection[entries*i + j] + ')\\n' : collection[entries*i + j] + ' -\\n') :\n    //       collection[entries*i + j] + ' ';\n    //   }\n    // }\n    //generate file\n    macroMolBlock += 'M  V30 COUNTS ' + natom + ' ' + nbond + ' 0 0 0\\n';\n    macroMolBlock += 'M  V30 BEGIN ATOM\\n';\n    macroMolBlock += atomBlock;\n    macroMolBlock += 'M  V30 END ATOM\\n';\n    macroMolBlock += 'M  V30 BEGIN BOND\\n';\n    macroMolBlock += bondBlock;\n    macroMolBlock += 'M  V30 END BOND\\n';\n    //macroMolBlock += 'M  V30 BEGIN COLLECTION\\n';\n    //macroMolBlock += collectionBlock;\n    //macroMolBlock += 'M  V30 END COLLECTION\\n';\n    macroMolBlock += 'M  V30 END CTAB\\n';\n    macroMolBlock += 'M  END\\n';\n    return macroMolBlock;\n}\nfunction extractAtomsBondsNumbersV3000(molBlock) {\n    molBlock = molBlock.replaceAll('\\r', ''); //equalize old and new sdf standards\n    let index = molBlock.indexOf('COUNTS') + 7; // V3000 index for atoms and bonds number\n    let indexEnd = molBlock.indexOf(' ', index);\n    const atomsNumber = parseInt(molBlock.substring(index, indexEnd));\n    index = indexEnd + 1;\n    indexEnd = molBlock.indexOf(' ', index);\n    const bondsNumber = parseInt(molBlock.substring(index, indexEnd));\n    return { natom: atomsNumber, nbond: bondsNumber };\n}\n","import * as C from './constants';\nimport * as DG from 'datagrok-api/dg';\nimport { AminoacidsPalettes } from '@datagrok-libraries/bio/src/aminoacids';\nimport { NucleotidesPalettes } from '@datagrok-libraries/bio/src/nucleotides';\nimport { UnknownSeqPalettes } from '@datagrok-libraries/bio/src/unknown';\nimport { WebLogo } from '@datagrok-libraries/bio/src/viewers/web-logo';\nimport * as ui from 'datagrok-api/ui';\nconst lru = new DG.LruCache();\nconst undefinedColor = 'rgb(100,100,100)';\nfunction getPalleteByType(paletteType) {\n    switch (paletteType) {\n        case 'PT':\n            return AminoacidsPalettes.GrokGroups;\n        case 'NT':\n            return NucleotidesPalettes.Chromatogram;\n        case 'DNA':\n            return NucleotidesPalettes.Chromatogram;\n        case 'RNA':\n            return NucleotidesPalettes.Chromatogram;\n        // other\n        default:\n            return UnknownSeqPalettes.Color;\n    }\n}\nexport function processSequence(subParts) {\n    const simplified = !subParts.some((amino, index) => amino.length > 1 &&\n        index != 0 &&\n        index != subParts.length - 1);\n    const text = [];\n    const gap = simplified ? '' : ' ';\n    subParts.forEach((amino, index) => {\n        if (index < subParts.length)\n            amino += `${amino ? '' : '-'}${gap}`;\n        text.push(amino);\n    });\n    return [text, simplified];\n}\n/**\n * A function that prints a string aligned to left or centered.\n *\n * @param {number} x x coordinate.\n * @param {number} y y coordinate.\n * @param {number} w Width.\n * @param {number} h Height.\n * @param {CanvasRenderingContext2D} g Canvas rendering context.\n * @param {string} s String to print.\n * @param {string} [color=undefinedColor] String color.\n * @param {number} [pivot=0] Pirvot.\n * @param {boolean} [left=false] Is left aligned.\n * @param {number} [transparencyRate=0.0] Transparency rate where 1.0 is fully transparent\n * @param {string} [separator=''] Is separator for sequence.\n * @param {boolean} [last=false] Is checker if element last or not.\n * @return {number} x coordinate to start printing at.\n */\nfunction printLeftOrCentered(x, y, w, h, g, s, color = undefinedColor, pivot = 0, left = false, transparencyRate = 1.0, separator = '', last = false) {\n    g.textAlign = 'start';\n    const colorPart = s.substring(0);\n    let grayPart = separator;\n    if (last) {\n        grayPart = '';\n    }\n    const textSize = g.measureText(colorPart + grayPart);\n    const indent = 5;\n    const colorTextSize = g.measureText(colorPart);\n    const dy = (textSize.fontBoundingBoxAscent + textSize.fontBoundingBoxDescent) / 2;\n    function draw(dx1, dx2) {\n        g.fillStyle = color;\n        g.globalAlpha = transparencyRate;\n        g.fillText(colorPart, x + dx1, y + dy);\n        g.fillStyle = '#808080';\n        g.fillText(grayPart, x + dx2, y + dy);\n    }\n    if (left || textSize.width > w) {\n        draw(indent, indent + colorTextSize.width);\n        return x + colorTextSize.width + g.measureText(grayPart).width;\n    }\n    else {\n        const dx = (w - textSize.width) / 2;\n        draw(dx, dx + colorTextSize.width);\n        return x + dx + colorTextSize.width;\n    }\n}\nexport class MacromoleculeSequenceCellRenderer extends DG.GridCellRenderer {\n    get name() { return 'macromoleculeSequence'; }\n    get cellType() { return C.SEM_TYPES.Macro_Molecule; }\n    get defaultHeight() { return 30; }\n    get defaultWidth() { return 230; }\n    /**\n     * Cell renderer function.\n     *\n     * @param {CanvasRenderingContext2D} g Canvas rendering context.\n     * @param {number} x x coordinate on the canvas.\n     * @param {number} y y coordinate on the canvas.\n     * @param {number} w width of the cell.\n     * @param {number} h height of the cell.\n     * @param {DG.GridCell} gridCell Grid cell.\n     * @param {DG.GridCellStyle} cellStyle Cell style.\n     * @memberof AlignedSequenceCellRenderer\n     */\n    render(g, x, y, w, h, gridCell, cellStyle) {\n        var _a, _b;\n        const grid = gridCell.gridRow !== -1 ? gridCell.grid : undefined;\n        const cell = gridCell.cell;\n        const tag = gridCell.cell.column.getTag(DG.TAGS.UNITS);\n        if (tag === 'HELM') {\n            const host = ui.div([], { style: { width: `${w}px`, height: `${h}px` } });\n            host.setAttribute('dataformat', 'helm');\n            host.setAttribute('data', gridCell.cell.value);\n            gridCell.element = host;\n            //@ts-ignore\n            const canvas = new JSDraw2.Editor(host, { width: w, height: h, skin: 'w8', viewonly: true });\n            const formula = canvas.getFormula(true);\n            if (!formula) {\n                gridCell.element = ui.divText(gridCell.cell.value, { style: { color: 'red' } });\n            }\n            else {\n                gridCell.element = host;\n                const molWeight = Math.round(canvas.getMolWeight() * 100) / 100;\n                const coef = Math.round(canvas.getExtinctionCoefficient(true) * 100) / 100;\n                const molfile = canvas.getMolfile();\n                const result = formula + ', ' + molWeight + ', ' + coef + ', ' + molfile;\n                lru.set(gridCell.cell.value, result);\n            }\n        }\n        else {\n            const [type, subtype, paletteType] = gridCell.cell.column.getTag(DG.TAGS.UNITS).split(':');\n            w = grid ? Math.min(grid.canvas.width - x, w) : g.canvas.width - x;\n            g.save();\n            g.beginPath();\n            g.rect(x, y, w, h);\n            g.clip();\n            g.font = '12px monospace';\n            g.textBaseline = 'top';\n            const s = (_a = cell.value) !== null && _a !== void 0 ? _a : '';\n            //TODO: can this be replaced/merged with splitSequence?\n            const units = gridCell.cell.column.getTag(DG.TAGS.UNITS);\n            const palette = getPalleteByType(paletteType);\n            const separator = (_b = gridCell.cell.column.getTag('separator')) !== null && _b !== void 0 ? _b : '';\n            const splitterFunc = WebLogo.getSplitter(units, gridCell.cell.column.getTag('separator'));\n            const subParts = splitterFunc(cell.value);\n            // console.log(subParts);\n            let x1 = x;\n            let color = undefinedColor;\n            subParts.forEach((amino, index) => {\n                color = palette.get(amino);\n                g.fillStyle = undefinedColor;\n                let last = false;\n                if (index === subParts.length - 1) {\n                    last = true;\n                }\n                x1 = printLeftOrCentered(x1, y, w, h, g, amino, color, 0, true, 1.0, separator, last);\n            });\n            g.restore();\n        }\n    }\n}\n","export var COLUMNS_NAMES;\n(function (COLUMNS_NAMES) {\n    COLUMNS_NAMES[\"SPLIT_COL\"] = \"~split\";\n    COLUMNS_NAMES[\"ACTIVITY\"] = \"~activity\";\n    COLUMNS_NAMES[\"ACTIVITY_SCALED\"] = \"activity_scaled\";\n    COLUMNS_NAMES[\"ALIGNED_SEQUENCE\"] = \"~aligned_sequence\";\n    COLUMNS_NAMES[\"AMINO_ACID_RESIDUE\"] = \"AAR\";\n    COLUMNS_NAMES[\"POSITION\"] = \"Pos\";\n    COLUMNS_NAMES[\"P_VALUE\"] = \"pValue\";\n    COLUMNS_NAMES[\"MEAN_DIFFERENCE\"] = \"Mean difference\";\n})(COLUMNS_NAMES || (COLUMNS_NAMES = {}));\nexport var CATEGORIES;\n(function (CATEGORIES) {\n    CATEGORIES[\"OTHER\"] = \"Other\";\n    CATEGORIES[\"ALL\"] = \"All\";\n})(CATEGORIES || (CATEGORIES = {}));\nexport var TAGS;\n(function (TAGS) {\n    TAGS[\"AAR\"] = \"AAR\";\n    TAGS[\"POSITION\"] = \"Pos\";\n    TAGS[\"SEPARATOR\"] = \"monomer-separator\";\n    TAGS[\"SELECTION\"] = \"selection\";\n})(TAGS || (TAGS = {}));\nexport var SEM_TYPES;\n(function (SEM_TYPES) {\n    SEM_TYPES[\"AMINO_ACIDS\"] = \"aminoAcids\";\n    SEM_TYPES[\"ALIGNED_SEQUENCE\"] = \"alignedSequence\";\n    SEM_TYPES[\"ALIGNED_SEQUENCE_DIFFERENCE\"] = \"alignedSequenceDifference\";\n    SEM_TYPES[\"ACTIVITY\"] = \"activity\";\n    SEM_TYPES[\"ACTIVITY_SCALED\"] = \"activityScaled\";\n    SEM_TYPES[\"Macro_Molecule\"] = \"Macromolecule\";\n})(SEM_TYPES || (SEM_TYPES = {}));\nexport const STATS = 'stats';\nexport const EMBEDDING_STATUS = 'embeddingStatus';\nexport const PEPTIDES_ANALYSIS = 'isPeptidesAnalysis';\nexport var FLAGS;\n(function (FLAGS) {\n    FLAGS[\"CELL_CHANGING\"] = \"isCellChanging\";\n})(FLAGS || (FLAGS = {}));\nexport const aarGroups = {\n    'R': 'PC', 'H': 'PC', 'K': 'PC',\n    'D': 'NC', 'E': 'NC',\n    'S': 'U', 'T': 'U', 'N': 'U', 'Q': 'U',\n    'C': 'SC', 'U': 'SC', 'G': 'SC', 'P': 'SC',\n    'A': 'H', 'V': 'H', 'I': 'H', 'L': 'H', 'M': 'H', 'F': 'H', 'Y': 'H', 'W': 'H',\n    '-': '-',\n};\nexport const groupDescription = {\n    'PC': { 'description': 'Positive Amino Acids, with Electrically Charged Side Chains', 'aminoAcids': ['R', 'H', 'K'] },\n    'NC': { 'description': 'Negative Amino Acids, with Electrically Charged Side Chains', 'aminoAcids': ['D', 'E'] },\n    'U': { 'description': 'Amino Acids with Polar Uncharged Side Chains', 'aminoAcids': ['S', 'T', 'N', 'Q'] },\n    'SC': { 'description': 'Special Cases', 'aminoAcids': ['C', 'U', 'G', 'P'] },\n    'H': {\n        'description': 'Amino Acids with Hydrophobic Side Chain',\n        'aminoAcids': ['A', 'V', 'I', 'L', 'M', 'F', 'Y', 'W'],\n    },\n    '-': { 'description': 'Unknown Amino Acid', 'aminoAcids': ['-'] },\n};\n","import * as ui from 'datagrok-api/ui';\nimport { NotationConverter } from './notation-converter';\n/**\n * Converts notations of a Macromolecule column\n *\n * @param {DG.column} col Column with 'Macromolecule' semantic type\n */\nexport function convert(col) {\n    const converter = new NotationConverter(col);\n    const current = converter.sourceNotation;\n    //TODO: read all notations\n    const notations = [\n        \"FASTA\" /* NOTATION.FASTA */,\n        \"SEPARATOR\" /* NOTATION.SEPARATOR */,\n        \"HELM\" /* NOTATION.HELM */\n    ];\n    const separatorArray = ['-', '.', '/'];\n    const filteredNotations = notations.filter((e) => e !== current);\n    const targetNotationInput = ui.choiceInput('Convert to', filteredNotations[0], filteredNotations);\n    const separatorInput = ui.choiceInput('Choose separator', separatorArray[0], separatorArray);\n    ui.dialog('Convert sequence notation')\n        .add(ui.div([\n        ui.h1('Current notation: ' + current),\n        targetNotationInput.root,\n        // TODO: conditional separator input\n        separatorInput.root\n    ]))\n        .onOK(() => {\n        //TODO: create new converted column\n        const targetNotation = targetNotationInput.value;\n        const separator = separatorInput.value;\n        const newColumn = converter.convert(targetNotation, separator);\n        col.dataFrame.columns.add(newColumn);\n    })\n        .show();\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\n//@ts-ignore\nimport Aioli from '@biowasm/aioli';\nimport { AlignedSequenceEncoder } from '@datagrok-libraries/bio/src/sequence-encoder';\n/**\n * Converts array of sequences into simple fasta string.\n *\n * @param {string[]} sequences Input list of sequences.\n * @return {string} Fasta-formatted string.\n */\nfunction _stringsToFasta(sequences) {\n    return sequences.reduce((a, v, i) => a + `>sample${i + 1}\\n${v}\\n`, '');\n}\n/**\n * Extracts array of sequences from simple fasta string.\n *\n * @param {string} fasta Fasta-formatted string.\n * @return {string[]} Output list of sequences.\n */\nfunction _fastaToStrings(fasta) {\n    return fasta.replace(/>sample\\d+(\\r\\n|\\r|\\n)/g, '').split('\\n');\n}\n/**\n * Runs Aioli environment with kalign tool.\n *\n * @param {DG.Column} srcCol Column with sequences.\n * @param {boolean} isAligned Whether the column is aligned.\n * @return {Promise<DG.Column>} Aligned sequences.\n */\nexport function runKalign(srcCol, isAligned = false) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let sequences = srcCol.toList();\n        if (isAligned)\n            sequences = sequences.map((v, _) => AlignedSequenceEncoder.clean(v).replace(/\\-/g, ''));\n        const fasta = _stringsToFasta(sequences);\n        const CLI = yield new Aioli({\n            tool: 'kalign',\n            version: '3.3.1',\n            reinit: true,\n        });\n        console.log(['fasta.length =', fasta.length]);\n        yield CLI.fs.writeFile('input.fa', fasta);\n        const output = yield CLI.exec('kalign input.fa -f fasta -o result.fasta');\n        console.warn(output);\n        const buf = yield CLI.cat('result.fasta');\n        if (!buf)\n            throw new Error(`kalign output no result`);\n        const aligned = _fastaToStrings(buf).slice(0, sequences.length);\n        const tgtCol = DG.Column.fromStrings(`msa(${srcCol.name})`, aligned);\n        // units\n        const srcUnits = srcCol.getTag(DG.TAGS.UNITS);\n        const tgtUnits = srcUnits.split(':').map((p, i) => i == 1 ? p + '.MSA' : p).join(':');\n        tgtCol.setTag(DG.TAGS.UNITS, tgtUnits);\n        tgtCol.semType = DG.SEMTYPE.MACROMOLECULE;\n        return tgtCol;\n    });\n}\nexport function testMSAEnoughMemory(col) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const sequencesCount = col.length;\n        const delta = sequencesCount / 100;\n        for (let i = delta; i < sequencesCount; i += delta) {\n            try {\n                yield runKalign(DG.Column.fromStrings(col.name, col.toList().slice(0, Math.round(i))));\n                console.log(`runKalign succeeded on ${i}`);\n            }\n            catch (error) {\n                console.log(`runKalign failed on ${i} with '${error}'`);\n            }\n        }\n    });\n}\n","import * as DG from 'datagrok-api/dg';\nimport { WebLogo } from '@datagrok-libraries/bio/src/viewers/web-logo';\n/** Class for handling conversion of notation systems in Macromolecule columns */\nexport class NotationConverter {\n    constructor(col) {\n        this._defaultGapSymbolsDict = {\n            helm: '*',\n            separator: '',\n            fasta: '-',\n        };\n        this._sourceColumn = col;\n        const units = this._sourceColumn.tags[DG.TAGS.UNITS];\n        if (units !== null)\n            this._sourceUnits = units;\n        else\n            throw new Error('Units are not specified in column');\n        this._sourceNotation = this.getSourceNotation();\n        this._defaultGapSymbol = (this.isFasta()) ? this._defaultGapSymbolsDict.fasta :\n            (this.isHelm()) ? this._defaultGapSymbolsDict.helm :\n                this._defaultGapSymbolsDict.separator;\n    }\n    get sourceUnits() { return this._sourceUnits; }\n    get sourceColumn() { return this._sourceColumn; }\n    get sourceNotation() { return this._sourceNotation; }\n    get defaultGapSymbol() { return this._defaultGapSymbol; }\n    get separator() {\n        const separator = this.sourceColumn.getTag('separator');\n        if (separator !== null)\n            return separator;\n        else\n            throw new Error('Separator not set');\n    }\n    isFasta() { return this.sourceNotation === \"FASTA\" /* NOTATION.FASTA */; }\n    isSeparator() { return this.sourceNotation === \"SEPARATOR\" /* NOTATION.SEPARATOR */; }\n    isHelm() { return this.sourceNotation === \"HELM\" /* NOTATION.HELM */; }\n    toFasta(targetNotation) { return targetNotation === \"FASTA\" /* NOTATION.FASTA */; }\n    toSeparator(targetNotation) { return targetNotation === \"SEPARATOR\" /* NOTATION.SEPARATOR */; }\n    toHelm(targetNotation) { return targetNotation === \"HELM\" /* NOTATION.HELM */; }\n    isRna() { return this.sourceUnits.toLowerCase().endsWith('rna'); }\n    isDna() { return this.sourceUnits.toLowerCase().endsWith('dna'); }\n    isPeptide() { return this.sourceUnits.toLowerCase().endsWith('pt'); }\n    /** Associate notation types with the corresponding units */\n    /**\n     * @return {NOTATION}     Notation associated with the units type\n     */\n    getSourceNotation() {\n        if (this.sourceUnits.toLowerCase().startsWith('fasta'))\n            return \"FASTA\" /* NOTATION.FASTA */;\n        else if (this.sourceUnits.toLowerCase().startsWith('separator'))\n            return \"SEPARATOR\" /* NOTATION.SEPARATOR */;\n        else if (this.sourceUnits.toLowerCase().startsWith('helm'))\n            return \"HELM\" /* NOTATION.HELM */;\n        else\n            throw new Error('The column has units that do not correspond to any notation');\n    }\n    /**\n     * Create a new empty column of the specified notation type and the same\n     * length as sourceColumn\n     *\n     * @param {NOTATION} targetNotation\n     * @return {DG.Column}\n     */\n    getNewColumn(targetNotation) {\n        const col = this.sourceColumn;\n        const len = col.length;\n        const name = targetNotation + '(' + col.name + ')';\n        const newColName = col.dataFrame.columns.getUnusedName(name);\n        // dummy code\n        const newColumn = DG.Column.fromList('string', newColName, new Array(len).fill(''));\n        newColumn.semType = DG.SEMTYPE.MACROMOLECULE;\n        newColumn.setTag(DG.TAGS.UNITS, this.sourceUnits.replace(this.sourceNotation.toLowerCase().toString(), targetNotation.toLowerCase().toString()));\n        // TODO: specify cell renderers for all cases\n        if (this.toFasta(targetNotation)) {\n            newColumn.setTag(DG.TAGS.CELL_RENDERER, \n            // TODO: replace by the enumeration value\n            'Macromolecule');\n        }\n        return newColumn;\n    }\n    /**\n     * Convert a Macromolecule column from FASTA to SEPARATOR notation\n     *\n     * @param {string} separator  A specific separator to be used\n     * @param {string} gapSymbol  Gap symbol in FASTA, '-' by default\n     * @return {DG.Column}        A new column in SEPARATOR notation\n     */\n    convertFastaToSeparator(separator, gapSymbol = '-') {\n        // a function splitting FASTA sequence into an array of monomers:\n        const splitterAsFasta = WebLogo.splitterAsFasta;\n        const newColumn = this.getNewColumn(\"SEPARATOR\" /* NOTATION.SEPARATOR */);\n        // assign the values to the newly created empty column\n        newColumn.init((idx) => {\n            const fastaPolymer = this.sourceColumn.get(idx);\n            const fastaMonomersArray = splitterAsFasta(fastaPolymer);\n            for (let i = 0; i < fastaMonomersArray.length; i++) {\n                if (fastaMonomersArray[i] === gapSymbol)\n                    fastaMonomersArray[i] = '';\n            }\n            return fastaMonomersArray.join(separator);\n        });\n        return newColumn;\n    }\n    convertToHelm(sourceGapSymbol = null) {\n        if (sourceGapSymbol === null)\n            sourceGapSymbol = this.defaultGapSymbol;\n        // A function splitting a sequence into an array of monomers according to\n        // its notation\n        const splitter = WebLogo.getSplitterForColumn(this.sourceColumn);\n        const prefix = (this.isDna()) ? 'DNA1{' :\n            (this.isRna()) ? 'RNA1{' :\n                (this.isPeptide()) ? 'PEPTIDE1{' :\n                    'Unknown'; // this case should be handled as exceptional\n        if (prefix === 'Unknown')\n            throw new Error('Neither peptide, nor nucleotide');\n        const postfix = '}$$$';\n        const leftWrapper = (this.isDna()) ? 'D(' :\n            (this.isRna()) ? 'R(' : ''; // no wrapper for peptides\n        const rightWrapper = (this.isDna() || this.isRna()) ? ')P' : ''; // no wrapper for peptides\n        const newColumn = this.getNewColumn(\"HELM\" /* NOTATION.HELM */);\n        // assign the values to the empty column\n        newColumn.init((idx) => {\n            const sourcePolymer = this.sourceColumn.get(idx);\n            const sourceMonomersArray = splitter(sourcePolymer);\n            const helmArray = [prefix];\n            let firstIteration = true;\n            for (let i = 0; i < sourceMonomersArray.length; i++) {\n                const dot = firstIteration ? '' : '.';\n                let token = sourceMonomersArray[i];\n                if (token === sourceGapSymbol)\n                    token = this._defaultGapSymbolsDict.helm;\n                const item = [dot, leftWrapper, token, rightWrapper];\n                helmArray.push(item.join(''));\n                firstIteration = false;\n            }\n            helmArray.push(postfix);\n            return helmArray.join('');\n        });\n        return newColumn;\n    }\n    handleSeparatorItemForFasta(idx, separatorItemsArray, separator, gapSymbol, fastaMonomersArray) {\n        const item = separatorItemsArray[idx];\n        if (item.length > 1) {\n            // the case of a multi-character monomer\n            const monomer = '[' + item + ']';\n            fastaMonomersArray.push(monomer);\n        }\n        if (item === separator) {\n            if (idx !== 0 && separatorItemsArray[idx - 1] === separator)\n                fastaMonomersArray.push(gapSymbol);\n        }\n    }\n    convertSeparatorToFasta(separator = null, gapSymbol = '-') {\n        // TODO: implementation\n        // * similarly to fasta2separator, divide string into monomers\n        // * adjacent separators is a gap (symbol to be specified)\n        // * the monomers MUST be single-character onles, otherwise forbid\n        // * NO, they can be multi-characters\n        // conversion\n        // * consider automatic determining the separator\n        if (separator === null)\n            separator = this.separator;\n        // a function splitting FASTA sequence into an array of monomers\n        //const splitterAsSeparator = WebLogo.getSplitterWithSeparator(separator);\n        const splitter = WebLogo.getSplitterForColumn(this.sourceColumn);\n        const newColumn = this.getNewColumn(\"FASTA\" /* NOTATION.FASTA */);\n        // assign the values to the empty column\n        newColumn.init((idx) => {\n            const separatorPolymer = this.sourceColumn.get(idx);\n            // items can be monomers or separators\n            const separatorItemsArray = splitter(separatorPolymer);\n            const fastaMonomersArray = [];\n            for (let i = 0; i < separatorItemsArray.length; i++) {\n                const item = separatorItemsArray[i];\n                if (item.length === 0) {\n                    fastaMonomersArray.push(gapSymbol);\n                }\n                else if (item.length > 1) {\n                    // the case of a multi-character monomer\n                    const monomer = '[' + item + ']';\n                    fastaMonomersArray.push(monomer);\n                }\n                else {\n                    fastaMonomersArray.push(item);\n                }\n            }\n            return fastaMonomersArray.join('');\n        });\n        return newColumn;\n    }\n    convertHelmToFasta() {\n        // TODO: implementation\n        return this.getNewColumn(\"FASTA\" /* NOTATION.FASTA */);\n    }\n    convertHelmToSeparator() {\n        // TODO: implementatioreturn this.getNewColumn();\n        return this.getNewColumn(\"SEPARATOR\" /* NOTATION.SEPARATOR */);\n    }\n    /** Dispatcher method for notation conversion\n     *\n     * @param {NOTATION} targetNotation   Notation we want to convert to\n     * @param {string | null} tgtSeparator   Possible separator\n     * @return {DG.Column}                Converted column\n     */\n    convert(targetNotation, tgtSeparator = null) {\n        // possible exceptions\n        if (this.sourceNotation === targetNotation)\n            throw new Error('Target notation is invalid');\n        if (this.toSeparator(targetNotation) && tgtSeparator === null)\n            throw new Error('Target separator is not specified');\n        if (this.isFasta() && this.toSeparator(targetNotation) && tgtSeparator !== null)\n            return this.convertFastaToSeparator(tgtSeparator);\n        else if ((this.isFasta() || this.isSeparator()) && this.toHelm(targetNotation))\n            return this.convertToHelm();\n        else if (this.isSeparator() && this.toFasta(targetNotation))\n            return this.convertSeparatorToFasta(tgtSeparator);\n        else if (this.isHelm() && this.toFasta(targetNotation))\n            return this.convertHelmToFasta();\n        else\n            return this.convertHelmToSeparator();\n    }\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport { getSimilarityFromDistance } from '@datagrok-libraries/utils/src/similarity-metrics';\nimport { AvailableMetrics } from '@datagrok-libraries/ml/src/typed-metrics';\nexport function sequenceGetSimilarities(col, seq) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const stringArray = col.toList();\n        const distances = new Array(stringArray.length).fill(0.0);\n        for (let i = 0; i < stringArray.length; ++i)\n            distances[i] = getSimilarityFromDistance(AvailableMetrics['String']['Levenshtein'](stringArray[i], seq));\n        return DG.Column.fromList(DG.COLUMN_TYPE.FLOAT, 'distances', distances);\n    });\n}\nexport function drawTooltip(params) {\n    params.tooltips[params.line.id] = ui.divH([]);\n    const columnNames = ui.divV([\n        ui.divText('sequense'),\n        ui.divText(params.activity.name),\n    ]);\n    columnNames.style.fontWeight = 'bold';\n    columnNames.style.display = 'flex';\n    columnNames.style.justifyContent = 'space-between';\n    params.tooltips[params.line.id].append(columnNames);\n    params.line.mols.forEach((mol) => {\n        const seq = ui.divText(params.df.get(params.seqCol.name, mol));\n        const activity = ui.divText(params.df.get(params.activity.name, mol).toFixed(2));\n        activity.style.display = 'flex';\n        activity.style.justifyContent = 'left';\n        activity.style.paddingLeft = '30px';\n        params.tooltips[params.line.id].append(ui.divV([\n            seq,\n            activity,\n        ], { style: { paddingLeft: '5px' } }));\n    });\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as DG from 'datagrok-api/dg';\nimport { AvailableMetrics } from '@datagrok-libraries/ml/src/typed-metrics';\nimport { reduceDimensinalityWithNormalization } from '@datagrok-libraries/ml/src/sequence-space';\nexport function sequenceSpace(spaceParams) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let preparedData;\n        if (!(spaceParams.seqCol.tags[DG.TAGS.UNITS] === 'HELM')) {\n            const sep = spaceParams.seqCol.getTag('separator');\n            const sepFinal = sep ? sep === '.' ? '\\\\\\.' : sep : '-';\n            const regex = new RegExp(sepFinal, 'g');\n            if (Object.keys(AvailableMetrics['String']).includes(spaceParams.similarityMetric))\n                preparedData = spaceParams.seqCol.toList().map((v) => v.replace(regex, ''));\n            else\n                preparedData = spaceParams.seqCol.toList().map((v) => v.replace(regex, ''));\n        }\n        else {\n            preparedData = spaceParams.seqCol.toList();\n        }\n        const sequenceSpaceResult = yield reduceDimensinalityWithNormalization(preparedData, spaceParams.methodName, spaceParams.similarityMetric, spaceParams.options);\n        const cols = spaceParams.embedAxesNames.map((name, index) => DG.Column.fromFloat32Array(name, sequenceSpaceResult.embedding[index]));\n        return { distance: sequenceSpaceResult.distance, coordinates: new DG.ColumnList(cols) };\n    });\n}\nexport function getEmbeddingColsNames(df) {\n    const axes = ['Embed_X', 'Embed_Y'];\n    const colNameInd = df.columns.names().filter((it) => it.includes(axes[0])).length + 1;\n    return axes.map((it) => `${it}_${colNameInd}`);\n}\n","import * as DG from 'datagrok-api/dg';\nimport { WebLogo } from '@datagrok-libraries/bio/src/viewers/web-logo';\nimport * as grok from 'datagrok-api/grok';\nexport const HELM_CORE_LIB_FILENAME = '/samples/HELMCoreLibrary.json';\nexport const HELM_CORE_LIB_MONOMER_SYMBOL = 'symbol';\nexport const HELM_CORE_LIB_MOLFILE = 'molfile';\nexport const HELM_CORE_FIELDS = ['symbol', 'molfile', 'rgroups', 'name'];\nexport function getMolfilesFromSeq(col, monomersLibObject) {\n    const units = col.tags[DG.TAGS.UNITS];\n    const sep = col.getTag('separator');\n    const splitterFunc = WebLogo.getSplitter(units, sep);\n    const monomersDict = createMomomersMolDict(monomersLibObject);\n    const molFiles = [];\n    for (let i = 0; i < col.length; ++i) {\n        const monomers = splitterFunc(col.get(i));\n        const molFilesForSeq = [];\n        for (let j = 0; j < monomers.length; ++j) {\n            if (monomers[j]) {\n                if (!monomersDict[monomers[j]]) {\n                    grok.shell.warning(`Monomer ${monomers[j]} is missing in HELM library. Structure cannot be created`);\n                    return null;\n                }\n                molFilesForSeq.push(JSON.parse(JSON.stringify(monomersDict[monomers[j]])));\n            }\n        }\n        molFiles.push(molFilesForSeq);\n    }\n    return molFiles;\n}\nexport function createMomomersMolDict(lib) {\n    const dict = {};\n    lib.forEach((it) => {\n        if (it['polymerType'] === 'PEPTIDE') {\n            const monomerObject = {};\n            HELM_CORE_FIELDS.forEach((field) => {\n                monomerObject[field] = it[field];\n            });\n            dict[it[HELM_CORE_LIB_MONOMER_SYMBOL]] = monomerObject;\n        }\n    });\n    return dict;\n}\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { VdRegionType } from '@datagrok-libraries/bio/src/vd-regions';\nconst vrt = VdRegionType;\n// Positions of regions for numbering schemes\n// http://www.bioinf.org.uk/abs/info.html\n// const imgtRegions: VdRegion[] = [\n//   new VdRegion(vrt.FR, 'FR1', 'Light', 1, '1', '26'),\n//   new VdRegion(vrt.FR, 'FR1', 'Heavy', 1, '1', '26'),\n//\n//   new VdRegion(vrt.CDR, 'CDR1', 'Light', 2, '27', '38'), // 27-32\n//   new VdRegion(vrt.CDR, 'CDR1', 'Heavy', 2, '27', '38'), // 27-32\n//\n//   new VdRegion(vrt.FR, 'FR2', 'Light', 3, '39', '55'),\n//   new VdRegion(vrt.FR, 'FR2', 'Heavy', 3, '39', '55'),\n//\n//   new VdRegion(vrt.CDR, 'CDR2', 'Light', 4, '56', '65'),\n//   new VdRegion(vrt.CDR, 'CDR2', 'Heavy', 4, '56', '65'),\n//\n//   new VdRegion(vrt.FR, 'FR3', 'Light', 5, '66', '104'),\n//   new VdRegion(vrt.FR, 'FR3', 'Heavy', 5, '66', '104'),\n//\n//   new VdRegion(vrt.CDR, 'CDR3', 'Light', 6, '105', '117'),\n//   new VdRegion(vrt.CDR, 'CDR3', 'Heavy', 6, '105', '117'),\n//\n//   new VdRegion(vrt.FR, 'FR4', 'Light', 7, '118', null/*127*/),\n//   new VdRegion(vrt.FR, 'FR4', 'Heavy', 7, '118', null/*128*/),\n// ];\n/** Viewer with tabs based on description of chain regions.\n *  Used to define regions of an immunoglobulin LC.\n */\nexport class VdRegionsViewer extends DG.JsViewer {\n    constructor() {\n        super();\n        // private regionsDf: DG.DataFrame;\n        this.regionsFg = null;\n        // private regionsTV: DG.TableView;\n        this.regionsRoot = null;\n        this.isOpened = false;\n        this.panelNode = null;\n        this.regions = [];\n        // #region -- Handle controls' events --\n        this.resizing = false;\n        // #endregion\n        //#region -- View --\n        this.host = null;\n        this.mainLayout = null;\n        this.logos = [];\n        // To prevent ambiguous numbering scheme in MLB\n        this.regionTypes = this.stringList('regionTypes', [vrt.CDR], { choices: Object.values(vrt).filter((t) => t != vrt.Unknown) });\n        this.chains = this.stringList('chains', ['Heavy', 'Light'], { choices: ['Heavy', 'Light'] });\n        this.sequenceColumnNamePostfix = this.string('sequenceColumnNamePostfix', 'chain sequence');\n    }\n    get df() {\n        return this.dataFrame;\n    }\n    // TODO: .onTableAttached is not calling on dataFrame set, onPropertyChanged  also not calling\n    setDf(value, regions) {\n        return __awaiter(this, void 0, void 0, function* () {\n            console.debug('VdRegionsViewer.setDf()');\n            yield this.destroyView();\n            this.regions = regions;\n            this.dataFrame = value;\n            yield this.buildView();\n        });\n    }\n    init() {\n        return __awaiter(this, void 0, void 0, function* () {\n            //#region regionsDF with filter\n            // this.regionsDf = DG.DataFrame.fromObjects(this.regions);\n            // this.regionsDf.rows.filter((row) => row.name == 'CDR1');\n            // // To available options /\n            // this.regionsFg = (await this.regionsDf.plot.fromType(DG.VIEWER.FILTERS, {\n            //   // columnNames: ['name',],\n            //   showFilterCountsIndication: false,\n            //   showHeader: false,\n            //   showSearchBox: false,\n            //   filters: [\n            //     {type: DG.FILTER_TYPE.CATEGORICAL, column: 'type', label: 'Region name', showHistogram: false},\n            //     {type: DG.FILTER_TYPE.CATEGORICAL, column: 'name', label: 'Region type', showHistogram: false},\n            //   ],\n            //   title: 'Regions filter',\n            //   showTitle: true,\n            //   description: 'Filter for regions of multiple alignment by IMGT nomenclature',\n            //   someProperty: 'Hello',\n            // })) as DG.FilterGroup;\n            //#endregion regionsDF with filter\n            // this.mlbView.dockManager.dock(this.regionsFg.root, DG.DOCK_TYPE.LEFT, rootNode, 'Filter regions', 0.2);\n            this.subs.push(ui.onSizeChanged(this.root).subscribe(this.rootOnSizeChanged.bind(this)));\n            // rxjs.fromEvent(this.root, 'mousemove').subscribe(this.onMouseMoveRoot.bind(this));\n            this.root.addEventListener('mousemove', this.onMouseMoveRoot.bind(this));\n            yield this.buildView();\n        });\n    }\n    onTableAttached() {\n        return __awaiter(this, void 0, void 0, function* () {\n            yield this.init();\n        });\n    }\n    onPropertyChanged(property) {\n        const _super = Object.create(null, {\n            onPropertyChanged: { get: () => super.onPropertyChanged }\n        });\n        return __awaiter(this, void 0, void 0, function* () {\n            _super.onPropertyChanged.call(this, property);\n            if (property) {\n                switch (property.name) {\n                    case 'regionTypes':\n                        break;\n                    case 'chains':\n                        break;\n                    case 'sequenceColumnNamePostfix':\n                        break;\n                }\n            }\n        });\n    }\n    reset() {\n        return __awaiter(this, void 0, void 0, function* () {\n        });\n    }\n    open(mlbView) {\n        return __awaiter(this, void 0, void 0, function* () {\n            if (!this.isOpened) {\n                this.isOpened = true;\n                this.panelNode = mlbView.dockManager.dock(this.root, DG.DOCK_TYPE.TOP, null, 'Regions', 0.2);\n            }\n        });\n    }\n    show(mlbView) {\n        return __awaiter(this, void 0, void 0, function* () {\n        });\n    }\n    rootOnSizeChanged(args) {\n        this.calcSize();\n    }\n    destroyView() {\n        return __awaiter(this, void 0, void 0, function* () {\n            // TODO: Unsubscribe from and remove all view elements\n            console.debug(`VdRegionsViewer.destroyView( mainLayout = ${!this.mainLayout ? 'none' : 'value'} )`);\n            if (this.mainLayout != null) {\n                // this.root.removeChild(this.host);\n                this.mainLayout.remove();\n                this.host.remove();\n                this.host = null;\n                this.mainLayout = null;\n            }\n        });\n    }\n    buildView() {\n        return __awaiter(this, void 0, void 0, function* () {\n            console.debug('VdRegionsViewer.buildView() start');\n            const colNames = Object.assign({}, ...this.chains.map((chain) => ({ [chain]: `${chain} ${this.sequenceColumnNamePostfix}` })));\n            const regionsFiltered = this.regions.filter((r) => this.regionTypes.includes(r.type));\n            const orderList = Array.from(new Set(regionsFiltered.map((r) => r.order))).sort();\n            this.logos = [];\n            for (let orderI = 0; orderI < orderList.length; orderI++) {\n                const regionChains = {};\n                for (const chain of this.chains) {\n                    const region = regionsFiltered\n                        .find((r) => r.order == orderList[orderI] && r.chain == chain);\n                    regionChains[chain] = (yield this.dataFrame.plot.fromType('WebLogo', {\n                        sequenceColumnName: colNames[chain],\n                        startPositionName: region.positionStartName,\n                        endPositionName: region.positionEndName,\n                        fixWidth: true,\n                    }));\n                }\n                // WebLogo creation fires onRootSizeChanged event even before control being added to this.logos\n                this.logos[orderI] = regionChains;\n            }\n            // ui.tableFromMap()\n            // DG.HtmlTable.create()\n            this.mainLayout = ui.table(this.chains, (chain) => {\n                const elements = [\n                    // This is chain label\n                    ...(orderList.length > 0 ? [ui.div(chain, {\n                            style: {\n                                transform: 'rotate(-90deg)',\n                                font: '12px Roboto, Roboto Local, sans-serif',\n                                textAlign: 'center',\n                                width: '16px',\n                                marginTop: '24px',\n                                marginLeft: '6px',\n                            }\n                        })] : []),\n                    // List with controls for regions\n                    ...[...Array(orderList.length).keys()].map((orderI) => {\n                        const wl = this.logos[orderI][chain];\n                        wl.root.style.height = '100%';\n                        const resDiv = ui.div([wl.root] /*`${chain} ${regionsFiltered[rI]}`*/, {\n                            style: {\n                                // height: '100%',\n                                marginTop: '4px',\n                                marginBottom: '4px',\n                            }\n                        });\n                        return resDiv;\n                    })\n                ];\n                return elements;\n            }, ['', ...[...Array(orderList.length).keys()].map((orderI) => regionsFiltered.find((r) => r.order == orderList[orderI] && r.chain == this.chains[0]).name || 'Name')]);\n            this.mainLayout.className = 'mlb-vd-regions-viewer-table2';\n            // this.mainLayout.style.background = '#EEEEFF';\n            // this.mainLayout.style.height = '100%';\n            // this.mainLayout.style.border = '1px solid black';\n            const color = `#ffbb${Math.ceil(Math.random() * 255).toString(16)}`;\n            this.host = ui.box(this.mainLayout, { /*style: {backgroundColor: color}*/});\n            this.root.appendChild(this.host);\n            this.root.style.overflowX = 'auto';\n            this.calcSize();\n            console.debug('VdRegionsViewer.buildView() end');\n        });\n    }\n    calcSize() {\n        const logoHeight = (this.root.clientHeight - 54) / this.chains.length;\n        const maxHeight = Math.min(logoHeight, Math.max(...this.logos.map((wlDict) => Math.max(...Object.values(wlDict).map((wl) => wl.maxHeight)))));\n        for (let orderI = 0; orderI < this.logos.length; orderI++) {\n            for (let chainI = 0; chainI < this.chains.length; chainI++) {\n                const chain = this.chains[chainI];\n                this.logos[orderI][chain].root.style.height = `${maxHeight}px`;\n            }\n        }\n    }\n    //#endregion -- View --\n    onMouseMoveRoot(e) {\n        // ui.tooltip.show('text', e.x + 8, e.y + 8,);\n        // console.log(`onMouseMoveRoot.( x: ${e.x}, y: ${e.y} )`);\n    }\n}\n","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"wu\"] = factory();\n\telse\n\t\troot[\"wu\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\texports: {},\n/******/ \t\t\tid: moduleId,\n/******/ \t\t\tloaded: false\n/******/ \t\t};\n\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.loaded = true;\n\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n\n\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t\"use strict\";\n\n\tvar _toConsumableArray = __webpack_require__(1)[\"default\"];\n\n\tvar _slicedToArray = __webpack_require__(39)[\"default\"];\n\n\tvar _Symbol$iterator = __webpack_require__(52)[\"default\"];\n\n\tvar _getIterator = __webpack_require__(40)[\"default\"];\n\n\tvar _regeneratorRuntime = __webpack_require__(54)[\"default\"];\n\n\tvar _Object$keys = __webpack_require__(80)[\"default\"];\n\n\tvar _Set = __webpack_require__(84)[\"default\"];\n\n\tvar _Promise = __webpack_require__(65)[\"default\"];\n\n\tvar wu = module.exports = function wu(iterable) {\n\t  if (!isIterable(iterable)) {\n\t    throw new Error(\"wu: `\" + iterable + \"` is not iterable!\");\n\t  }\n\t  return new Wu(iterable);\n\t};\n\n\tfunction Wu(iterable) {\n\t  var iterator = getIterator(iterable);\n\t  this.next = iterator.next.bind(iterator);\n\t}\n\twu.prototype = Wu.prototype;\n\n\twu.prototype[_Symbol$iterator] = function () {\n\t  return this;\n\t};\n\n\t/*\n\t * Internal utilities\n\t */\n\n\t// An internal placeholder value.\n\tvar MISSING = {};\n\n\t// Return whether a thing is iterable.\n\tvar isIterable = function isIterable(thing) {\n\t  return thing && typeof thing[_Symbol$iterator] === \"function\";\n\t};\n\n\t// Get the iterator for the thing or throw an error.\n\tvar getIterator = function getIterator(thing) {\n\t  if (isIterable(thing)) {\n\t    return _getIterator(thing);\n\t  }\n\t  throw new TypeError(\"Not iterable: \" + thing);\n\t};\n\n\t// Define a static method on `wu` and set its prototype to the shared\n\t// `Wu.prototype`.\n\tvar staticMethod = function staticMethod(name, fn) {\n\t  fn.prototype = Wu.prototype;\n\t  wu[name] = fn;\n\t};\n\n\t// Define a function that is attached as both a `Wu.prototype` method and a\n\t// curryable static method on `wu` directly that takes an iterable as its last\n\t// parameter.\n\tvar prototypeAndStatic = function prototypeAndStatic(name, fn) {\n\t  var expectedArgs = arguments.length <= 2 || arguments[2] === undefined ? fn.length : arguments[2];\n\t  return (function () {\n\t    fn.prototype = Wu.prototype;\n\t    Wu.prototype[name] = fn;\n\n\t    // +1 for the iterable, which is the `this` value of the function so it\n\t    // isn't reflected by the length property.\n\t    expectedArgs += 1;\n\n\t    wu[name] = wu.curryable(function () {\n\t      var _wu;\n\n\t      for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n\t        args[_key] = arguments[_key];\n\t      }\n\n\t      var iterable = args.pop();\n\t      return (_wu = wu(iterable))[name].apply(_wu, args);\n\t    }, expectedArgs);\n\t  })();\n\t};\n\n\t// A decorator for rewrapping a method's returned iterable in wu to maintain\n\t// chainability.\n\tvar rewrap = function rewrap(fn) {\n\t  return function () {\n\t    for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n\t      args[_key2] = arguments[_key2];\n\t    }\n\n\t    return wu(fn.call.apply(fn, [this].concat(args)));\n\t  };\n\t};\n\n\tvar rewrapStaticMethod = function rewrapStaticMethod(name, fn) {\n\t  return staticMethod(name, rewrap(fn));\n\t};\n\tvar rewrapPrototypeAndStatic = function rewrapPrototypeAndStatic(name, fn, expectedArgs) {\n\t  return prototypeAndStatic(name, rewrap(fn), expectedArgs);\n\t};\n\n\t// Return a wrapped version of `fn` bound with the initial arguments\n\t// `...args`.\n\tfunction curry(fn, args) {\n\t  return function () {\n\t    for (var _len3 = arguments.length, moreArgs = Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n\t      moreArgs[_key3] = arguments[_key3];\n\t    }\n\n\t    return fn.call.apply(fn, [this].concat(_toConsumableArray(args), moreArgs));\n\t  };\n\t}\n\n\t/*\n\t * Public utilities\n\t */\n\n\tstaticMethod(\"curryable\", function (fn) {\n\t  var expected = arguments.length <= 1 || arguments[1] === undefined ? fn.length : arguments[1];\n\t  return (function () {\n\t    return function f() {\n\t      for (var _len4 = arguments.length, args = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n\t        args[_key4] = arguments[_key4];\n\t      }\n\n\t      return args.length >= expected ? fn.apply(this, args) : curry(f, args);\n\t    };\n\t  })();\n\t});\n\n\trewrapStaticMethod(\"entries\", _regeneratorRuntime.mark(function callee$0$0(obj) {\n\t  var _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, k;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion = true;\n\t        _didIteratorError = false;\n\t        _iteratorError = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator = _getIterator(_Object$keys(obj));\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion = (_step = _iterator.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        k = _step.value;\n\t        context$1$0.next = 9;\n\t        return [k, obj[k]];\n\n\t      case 9:\n\t        _iteratorNormalCompletion = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError = true;\n\t        _iteratorError = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion && _iterator[\"return\"]) {\n\t          _iterator[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapStaticMethod(\"keys\", _regeneratorRuntime.mark(function callee$0$0(obj) {\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_Object$keys(obj), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"values\", _regeneratorRuntime.mark(function callee$0$0(obj) {\n\t  var _iteratorNormalCompletion2, _didIteratorError2, _iteratorError2, _iterator2, _step2, k;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion2 = true;\n\t        _didIteratorError2 = false;\n\t        _iteratorError2 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator2 = _getIterator(_Object$keys(obj));\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        k = _step2.value;\n\t        context$1$0.next = 9;\n\t        return obj[k];\n\n\t      case 9:\n\t        _iteratorNormalCompletion2 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError2 = true;\n\t        _iteratorError2 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion2 && _iterator2[\"return\"]) {\n\t          _iterator2[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError2) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError2;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\t/*\n\t * Infinite iterators\n\t */\n\n\trewrapPrototypeAndStatic(\"cycle\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var saved, _iteratorNormalCompletion3, _didIteratorError3, _iteratorError3, _iterator3, _step3, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        saved = [];\n\t        _iteratorNormalCompletion3 = true;\n\t        _didIteratorError3 = false;\n\t        _iteratorError3 = undefined;\n\t        context$1$0.prev = 4;\n\t        _iterator3 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        x = _step3.value;\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        saved.push(x);\n\n\t      case 11:\n\t        _iteratorNormalCompletion3 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.next = 20;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.prev = 16;\n\t        context$1$0.t0 = context$1$0[\"catch\"](4);\n\t        _didIteratorError3 = true;\n\t        _iteratorError3 = context$1$0.t0;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.prev = 21;\n\n\t        if (!_iteratorNormalCompletion3 && _iterator3[\"return\"]) {\n\t          _iterator3[\"return\"]();\n\t        }\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\n\t        if (!_didIteratorError3) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        throw _iteratorError3;\n\n\t      case 26:\n\t        return context$1$0.finish(23);\n\n\t      case 27:\n\t        return context$1$0.finish(20);\n\n\t      case 28:\n\t        if (!saved) {\n\t          context$1$0.next = 32;\n\t          break;\n\t        }\n\n\t        return context$1$0.delegateYield(saved, \"t1\", 30);\n\n\t      case 30:\n\t        context$1$0.next = 28;\n\t        break;\n\n\t      case 32:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[4, 16, 20, 28], [21,, 23, 27]]);\n\t}));\n\n\trewrapStaticMethod(\"count\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var start = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\t  var step = arguments.length <= 1 || arguments[1] === undefined ? 1 : arguments[1];\n\t  var n;\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        n = start;\n\n\t      case 1:\n\t        if (false) {\n\t          context$1$0.next = 7;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 4;\n\t        return n;\n\n\t      case 4:\n\t        n += step;\n\t        context$1$0.next = 1;\n\t        break;\n\n\t      case 7:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"repeat\", _regeneratorRuntime.mark(function callee$0$0(thing) {\n\t  var times = arguments.length <= 1 || arguments[1] === undefined ? Infinity : arguments[1];\n\t  var i;\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (!(times === Infinity)) {\n\t          context$1$0.next = 8;\n\t          break;\n\t        }\n\n\t      case 1:\n\t        if (false) {\n\t          context$1$0.next = 6;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 4;\n\t        return thing;\n\n\t      case 4:\n\t        context$1$0.next = 1;\n\t        break;\n\n\t      case 6:\n\t        context$1$0.next = 15;\n\t        break;\n\n\t      case 8:\n\t        i = 0;\n\n\t      case 9:\n\t        if (!(i < times)) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 12;\n\t        return thing;\n\n\t      case 12:\n\t        i++;\n\t        context$1$0.next = 9;\n\t        break;\n\n\t      case 15:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\t/*\n\t * Iterators that terminate once the input sequence has been exhausted\n\t */\n\n\trewrapStaticMethod(\"chain\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var _iteratorNormalCompletion4,\n\t      _didIteratorError4,\n\t      _iteratorError4,\n\t      _len5,\n\t      iterables,\n\t      _key5,\n\t      _iterator4,\n\t      _step4,\n\t      it,\n\t      args$1$0 = arguments;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion4 = true;\n\t        _didIteratorError4 = false;\n\t        _iteratorError4 = undefined;\n\t        context$1$0.prev = 3;\n\n\t        for (_len5 = args$1$0.length, iterables = Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {\n\t          iterables[_key5] = args$1$0[_key5];\n\t        }\n\n\t        _iterator4 = _getIterator(iterables);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        it = _step4.value;\n\t        return context$1$0.delegateYield(it, \"t0\", 9);\n\n\t      case 9:\n\t        _iteratorNormalCompletion4 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t1 = context$1$0[\"catch\"](3);\n\t        _didIteratorError4 = true;\n\t        _iteratorError4 = context$1$0.t1;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion4 && _iterator4[\"return\"]) {\n\t          _iterator4[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError4) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError4;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"chunk\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var n = arguments.length <= 0 || arguments[0] === undefined ? 2 : arguments[0];\n\n\t  var items, index, _iteratorNormalCompletion5, _didIteratorError5, _iteratorError5, _iterator5, _step5, item;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        items = [];\n\t        index = 0;\n\t        _iteratorNormalCompletion5 = true;\n\t        _didIteratorError5 = false;\n\t        _iteratorError5 = undefined;\n\t        context$1$0.prev = 5;\n\t        _iterator5 = _getIterator(this);\n\n\t      case 7:\n\t        if (_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done) {\n\t          context$1$0.next = 18;\n\t          break;\n\t        }\n\n\t        item = _step5.value;\n\n\t        items[index++] = item;\n\n\t        if (!(index === n)) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 13;\n\t        return items;\n\n\t      case 13:\n\t        items = [];\n\t        index = 0;\n\n\t      case 15:\n\t        _iteratorNormalCompletion5 = true;\n\t        context$1$0.next = 7;\n\t        break;\n\n\t      case 18:\n\t        context$1$0.next = 24;\n\t        break;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.t0 = context$1$0[\"catch\"](5);\n\t        _didIteratorError5 = true;\n\t        _iteratorError5 = context$1$0.t0;\n\n\t      case 24:\n\t        context$1$0.prev = 24;\n\t        context$1$0.prev = 25;\n\n\t        if (!_iteratorNormalCompletion5 && _iterator5[\"return\"]) {\n\t          _iterator5[\"return\"]();\n\t        }\n\n\t      case 27:\n\t        context$1$0.prev = 27;\n\n\t        if (!_didIteratorError5) {\n\t          context$1$0.next = 30;\n\t          break;\n\t        }\n\n\t        throw _iteratorError5;\n\n\t      case 30:\n\t        return context$1$0.finish(27);\n\n\t      case 31:\n\t        return context$1$0.finish(24);\n\n\t      case 32:\n\t        if (!index) {\n\t          context$1$0.next = 35;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 35;\n\t        return items;\n\n\t      case 35:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[5, 20, 24, 32], [25,, 27, 31]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"concatMap\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var _iteratorNormalCompletion6, _didIteratorError6, _iteratorError6, _iterator6, _step6, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion6 = true;\n\t        _didIteratorError6 = false;\n\t        _iteratorError6 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator6 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion6 = (_step6 = _iterator6.next()).done) {\n\t          context$1$0.next = 11;\n\t          break;\n\t        }\n\n\t        x = _step6.value;\n\t        return context$1$0.delegateYield(fn(x), \"t0\", 8);\n\n\t      case 8:\n\t        _iteratorNormalCompletion6 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 11:\n\t        context$1$0.next = 17;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.prev = 13;\n\t        context$1$0.t1 = context$1$0[\"catch\"](3);\n\t        _didIteratorError6 = true;\n\t        _iteratorError6 = context$1$0.t1;\n\n\t      case 17:\n\t        context$1$0.prev = 17;\n\t        context$1$0.prev = 18;\n\n\t        if (!_iteratorNormalCompletion6 && _iterator6[\"return\"]) {\n\t          _iterator6[\"return\"]();\n\t        }\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\n\t        if (!_didIteratorError6) {\n\t          context$1$0.next = 23;\n\t          break;\n\t        }\n\n\t        throw _iteratorError6;\n\n\t      case 23:\n\t        return context$1$0.finish(20);\n\n\t      case 24:\n\t        return context$1$0.finish(17);\n\n\t      case 25:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 13, 17, 25], [18,, 20, 24]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"drop\", _regeneratorRuntime.mark(function callee$0$0(n) {\n\t  var i, _iteratorNormalCompletion7, _didIteratorError7, _iteratorError7, _iterator7, _step7, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        i = 0;\n\t        _iteratorNormalCompletion7 = true;\n\t        _didIteratorError7 = false;\n\t        _iteratorError7 = undefined;\n\t        context$1$0.prev = 4;\n\t        _iterator7 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion7 = (_step7 = _iterator7.next()).done) {\n\t          context$1$0.next = 16;\n\t          break;\n\t        }\n\n\t        x = _step7.value;\n\n\t        if (!(i++ < n)) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"continue\", 13);\n\n\t      case 10:\n\t        context$1$0.next = 12;\n\t        return x;\n\n\t      case 12:\n\t        return context$1$0.abrupt(\"break\", 16);\n\n\t      case 13:\n\t        _iteratorNormalCompletion7 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.next = 22;\n\t        break;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.t0 = context$1$0[\"catch\"](4);\n\t        _didIteratorError7 = true;\n\t        _iteratorError7 = context$1$0.t0;\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\t        context$1$0.prev = 23;\n\n\t        if (!_iteratorNormalCompletion7 && _iterator7[\"return\"]) {\n\t          _iterator7[\"return\"]();\n\t        }\n\n\t      case 25:\n\t        context$1$0.prev = 25;\n\n\t        if (!_didIteratorError7) {\n\t          context$1$0.next = 28;\n\t          break;\n\t        }\n\n\t        throw _iteratorError7;\n\n\t      case 28:\n\t        return context$1$0.finish(25);\n\n\t      case 29:\n\t        return context$1$0.finish(22);\n\n\t      case 30:\n\t        return context$1$0.delegateYield(this, \"t1\", 31);\n\n\t      case 31:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[4, 18, 22, 30], [23,, 25, 29]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"dropWhile\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion8, _didIteratorError8, _iteratorError8, _iterator8, _step8, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion8 = true;\n\t        _didIteratorError8 = false;\n\t        _iteratorError8 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator8 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion8 = (_step8 = _iterator8.next()).done) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        x = _step8.value;\n\n\t        if (!fn(x)) {\n\t          context$1$0.next = 9;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"continue\", 12);\n\n\t      case 9:\n\t        context$1$0.next = 11;\n\t        return x;\n\n\t      case 11:\n\t        return context$1$0.abrupt(\"break\", 15);\n\n\t      case 12:\n\t        _iteratorNormalCompletion8 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.next = 21;\n\t        break;\n\n\t      case 17:\n\t        context$1$0.prev = 17;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError8 = true;\n\t        _iteratorError8 = context$1$0.t0;\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\t        context$1$0.prev = 22;\n\n\t        if (!_iteratorNormalCompletion8 && _iterator8[\"return\"]) {\n\t          _iterator8[\"return\"]();\n\t        }\n\n\t      case 24:\n\t        context$1$0.prev = 24;\n\n\t        if (!_didIteratorError8) {\n\t          context$1$0.next = 27;\n\t          break;\n\t        }\n\n\t        throw _iteratorError8;\n\n\t      case 27:\n\t        return context$1$0.finish(24);\n\n\t      case 28:\n\t        return context$1$0.finish(21);\n\n\t      case 29:\n\t        return context$1$0.delegateYield(this, \"t1\", 30);\n\n\t      case 30:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 17, 21, 29], [22,, 24, 28]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"enumerate\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip([this, wu.count()]), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapPrototypeAndStatic(\"filter\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion9, _didIteratorError9, _iteratorError9, _iterator9, _step9, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion9 = true;\n\t        _didIteratorError9 = false;\n\t        _iteratorError9 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator9 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion9 = (_step9 = _iterator9.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step9.value;\n\n\t        if (!fn(x)) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        _iteratorNormalCompletion9 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError9 = true;\n\t        _iteratorError9 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion9 && _iterator9[\"return\"]) {\n\t          _iterator9[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError9) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError9;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"flatten\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var shallow = arguments.length <= 0 || arguments[0] === undefined ? false : arguments[0];\n\n\t  var _iteratorNormalCompletion10, _didIteratorError10, _iteratorError10, _iterator10, _step10, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion10 = true;\n\t        _didIteratorError10 = false;\n\t        _iteratorError10 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator10 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion10 = (_step10 = _iterator10.next()).done) {\n\t          context$1$0.next = 16;\n\t          break;\n\t        }\n\n\t        x = _step10.value;\n\n\t        if (!(typeof x !== \"string\" && isIterable(x))) {\n\t          context$1$0.next = 11;\n\t          break;\n\t        }\n\n\t        return context$1$0.delegateYield(shallow ? x : wu(x).flatten(), \"t0\", 9);\n\n\t      case 9:\n\t        context$1$0.next = 13;\n\t        break;\n\n\t      case 11:\n\t        context$1$0.next = 13;\n\t        return x;\n\n\t      case 13:\n\t        _iteratorNormalCompletion10 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.next = 22;\n\t        break;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.t1 = context$1$0[\"catch\"](3);\n\t        _didIteratorError10 = true;\n\t        _iteratorError10 = context$1$0.t1;\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\t        context$1$0.prev = 23;\n\n\t        if (!_iteratorNormalCompletion10 && _iterator10[\"return\"]) {\n\t          _iterator10[\"return\"]();\n\t        }\n\n\t      case 25:\n\t        context$1$0.prev = 25;\n\n\t        if (!_didIteratorError10) {\n\t          context$1$0.next = 28;\n\t          break;\n\t        }\n\n\t        throw _iteratorError10;\n\n\t      case 28:\n\t        return context$1$0.finish(25);\n\n\t      case 29:\n\t        return context$1$0.finish(22);\n\n\t      case 30:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 18, 22, 30], [23,, 25, 29]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"invoke\", _regeneratorRuntime.mark(function callee$0$0(name) {\n\t  var _iteratorNormalCompletion11,\n\t      _didIteratorError11,\n\t      _iteratorError11,\n\t      _len6,\n\t      args,\n\t      _key6,\n\t      _iterator11,\n\t      _step11,\n\t      x,\n\t      args$1$0 = arguments;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion11 = true;\n\t        _didIteratorError11 = false;\n\t        _iteratorError11 = undefined;\n\t        context$1$0.prev = 3;\n\n\t        for (_len6 = args$1$0.length, args = Array(_len6 > 1 ? _len6 - 1 : 0), _key6 = 1; _key6 < _len6; _key6++) {\n\t          args[_key6 - 1] = args$1$0[_key6];\n\t        }\n\n\t        _iterator11 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion11 = (_step11 = _iterator11.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step11.value;\n\t        context$1$0.next = 10;\n\t        return x[name].apply(x, args);\n\n\t      case 10:\n\t        _iteratorNormalCompletion11 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError11 = true;\n\t        _iteratorError11 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion11 && _iterator11[\"return\"]) {\n\t          _iterator11[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError11) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError11;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"map\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var _iteratorNormalCompletion12, _didIteratorError12, _iteratorError12, _iterator12, _step12, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion12 = true;\n\t        _didIteratorError12 = false;\n\t        _iteratorError12 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator12 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion12 = (_step12 = _iterator12.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        x = _step12.value;\n\t        context$1$0.next = 9;\n\t        return fn(x);\n\n\t      case 9:\n\t        _iteratorNormalCompletion12 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError12 = true;\n\t        _iteratorError12 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion12 && _iterator12[\"return\"]) {\n\t          _iterator12[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError12) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError12;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"pluck\", _regeneratorRuntime.mark(function callee$0$0(name) {\n\t  var _iteratorNormalCompletion13, _didIteratorError13, _iteratorError13, _iterator13, _step13, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion13 = true;\n\t        _didIteratorError13 = false;\n\t        _iteratorError13 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator13 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion13 = (_step13 = _iterator13.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        x = _step13.value;\n\t        context$1$0.next = 9;\n\t        return x[name];\n\n\t      case 9:\n\t        _iteratorNormalCompletion13 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError13 = true;\n\t        _iteratorError13 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion13 && _iterator13[\"return\"]) {\n\t          _iterator13[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError13) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError13;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"reductions\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var initial = arguments.length <= 1 || arguments[1] === undefined ? undefined : arguments[1];\n\n\t  var val, _iteratorNormalCompletion14, _didIteratorError14, _iteratorError14, _iterator14, _step14, x, _iteratorNormalCompletion15, _didIteratorError15, _iteratorError15, _iterator15, _step15;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        val = initial;\n\n\t        if (!(val === undefined)) {\n\t          context$1$0.next = 28;\n\t          break;\n\t        }\n\n\t        _iteratorNormalCompletion14 = true;\n\t        _didIteratorError14 = false;\n\t        _iteratorError14 = undefined;\n\t        context$1$0.prev = 5;\n\t        _iterator14 = _getIterator(this);\n\n\t      case 7:\n\t        if (_iteratorNormalCompletion14 = (_step14 = _iterator14.next()).done) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        x = _step14.value;\n\n\t        val = x;\n\t        return context$1$0.abrupt(\"break\", 14);\n\n\t      case 11:\n\t        _iteratorNormalCompletion14 = true;\n\t        context$1$0.next = 7;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.next = 20;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.prev = 16;\n\t        context$1$0.t0 = context$1$0[\"catch\"](5);\n\t        _didIteratorError14 = true;\n\t        _iteratorError14 = context$1$0.t0;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.prev = 21;\n\n\t        if (!_iteratorNormalCompletion14 && _iterator14[\"return\"]) {\n\t          _iterator14[\"return\"]();\n\t        }\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\n\t        if (!_didIteratorError14) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        throw _iteratorError14;\n\n\t      case 26:\n\t        return context$1$0.finish(23);\n\n\t      case 27:\n\t        return context$1$0.finish(20);\n\n\t      case 28:\n\t        context$1$0.next = 30;\n\t        return val;\n\n\t      case 30:\n\t        _iteratorNormalCompletion15 = true;\n\t        _didIteratorError15 = false;\n\t        _iteratorError15 = undefined;\n\t        context$1$0.prev = 33;\n\t        _iterator15 = _getIterator(this);\n\n\t      case 35:\n\t        if (_iteratorNormalCompletion15 = (_step15 = _iterator15.next()).done) {\n\t          context$1$0.next = 42;\n\t          break;\n\t        }\n\n\t        x = _step15.value;\n\t        context$1$0.next = 39;\n\t        return val = fn(val, x);\n\n\t      case 39:\n\t        _iteratorNormalCompletion15 = true;\n\t        context$1$0.next = 35;\n\t        break;\n\n\t      case 42:\n\t        context$1$0.next = 48;\n\t        break;\n\n\t      case 44:\n\t        context$1$0.prev = 44;\n\t        context$1$0.t1 = context$1$0[\"catch\"](33);\n\t        _didIteratorError15 = true;\n\t        _iteratorError15 = context$1$0.t1;\n\n\t      case 48:\n\t        context$1$0.prev = 48;\n\t        context$1$0.prev = 49;\n\n\t        if (!_iteratorNormalCompletion15 && _iterator15[\"return\"]) {\n\t          _iterator15[\"return\"]();\n\t        }\n\n\t      case 51:\n\t        context$1$0.prev = 51;\n\n\t        if (!_didIteratorError15) {\n\t          context$1$0.next = 54;\n\t          break;\n\t        }\n\n\t        throw _iteratorError15;\n\n\t      case 54:\n\t        return context$1$0.finish(51);\n\n\t      case 55:\n\t        return context$1$0.finish(48);\n\n\t      case 56:\n\t        return context$1$0.abrupt(\"return\", val);\n\n\t      case 57:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[5, 16, 20, 28], [21,, 23, 27], [33, 44, 48, 56], [49,, 51, 55]]);\n\t}), 2);\n\n\trewrapPrototypeAndStatic(\"reject\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion16, _didIteratorError16, _iteratorError16, _iterator16, _step16, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion16 = true;\n\t        _didIteratorError16 = false;\n\t        _iteratorError16 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator16 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion16 = (_step16 = _iterator16.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step16.value;\n\n\t        if (fn(x)) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        _iteratorNormalCompletion16 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError16 = true;\n\t        _iteratorError16 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion16 && _iterator16[\"return\"]) {\n\t          _iterator16[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError16) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError16;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"slice\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var start = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\t  var stop = arguments.length <= 1 || arguments[1] === undefined ? Infinity : arguments[1];\n\n\t  var _iteratorNormalCompletion17, _didIteratorError17, _iteratorError17, _iterator17, _step17, _step17$value, x, i;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (!(stop < start)) {\n\t          context$1$0.next = 2;\n\t          break;\n\t        }\n\n\t        throw new RangeError(\"parameter `stop` (= \" + stop + \") must be >= `start` (= \" + start + \")\");\n\n\t      case 2:\n\t        _iteratorNormalCompletion17 = true;\n\t        _didIteratorError17 = false;\n\t        _iteratorError17 = undefined;\n\t        context$1$0.prev = 5;\n\t        _iterator17 = _getIterator(this.enumerate());\n\n\t      case 7:\n\t        if (_iteratorNormalCompletion17 = (_step17 = _iterator17.next()).done) {\n\t          context$1$0.next = 20;\n\t          break;\n\t        }\n\n\t        _step17$value = _slicedToArray(_step17.value, 2);\n\t        x = _step17$value[0];\n\t        i = _step17$value[1];\n\n\t        if (!(i < start)) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"continue\", 17);\n\n\t      case 13:\n\t        if (!(i >= stop)) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"break\", 20);\n\n\t      case 15:\n\t        context$1$0.next = 17;\n\t        return x;\n\n\t      case 17:\n\t        _iteratorNormalCompletion17 = true;\n\t        context$1$0.next = 7;\n\t        break;\n\n\t      case 20:\n\t        context$1$0.next = 26;\n\t        break;\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\t        context$1$0.t0 = context$1$0[\"catch\"](5);\n\t        _didIteratorError17 = true;\n\t        _iteratorError17 = context$1$0.t0;\n\n\t      case 26:\n\t        context$1$0.prev = 26;\n\t        context$1$0.prev = 27;\n\n\t        if (!_iteratorNormalCompletion17 && _iterator17[\"return\"]) {\n\t          _iterator17[\"return\"]();\n\t        }\n\n\t      case 29:\n\t        context$1$0.prev = 29;\n\n\t        if (!_didIteratorError17) {\n\t          context$1$0.next = 32;\n\t          break;\n\t        }\n\n\t        throw _iteratorError17;\n\n\t      case 32:\n\t        return context$1$0.finish(29);\n\n\t      case 33:\n\t        return context$1$0.finish(26);\n\n\t      case 34:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[5, 22, 26, 34], [27,, 29, 33]]);\n\t}), 2);\n\n\trewrapPrototypeAndStatic(\"spreadMap\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  var _iteratorNormalCompletion18, _didIteratorError18, _iteratorError18, _iterator18, _step18, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion18 = true;\n\t        _didIteratorError18 = false;\n\t        _iteratorError18 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator18 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion18 = (_step18 = _iterator18.next()).done) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        x = _step18.value;\n\t        context$1$0.next = 9;\n\t        return fn.apply(undefined, _toConsumableArray(x));\n\n\t      case 9:\n\t        _iteratorNormalCompletion18 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 12:\n\t        context$1$0.next = 18;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.prev = 14;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError18 = true;\n\t        _iteratorError18 = context$1$0.t0;\n\n\t      case 18:\n\t        context$1$0.prev = 18;\n\t        context$1$0.prev = 19;\n\n\t        if (!_iteratorNormalCompletion18 && _iterator18[\"return\"]) {\n\t          _iterator18[\"return\"]();\n\t        }\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\n\t        if (!_didIteratorError18) {\n\t          context$1$0.next = 24;\n\t          break;\n\t        }\n\n\t        throw _iteratorError18;\n\n\t      case 24:\n\t        return context$1$0.finish(21);\n\n\t      case 25:\n\t        return context$1$0.finish(18);\n\n\t      case 26:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 14, 18, 26], [19,, 21, 25]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"take\", _regeneratorRuntime.mark(function callee$0$0(n) {\n\t  var i, _iteratorNormalCompletion19, _didIteratorError19, _iteratorError19, _iterator19, _step19, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (!(n < 1)) {\n\t          context$1$0.next = 2;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\");\n\n\t      case 2:\n\t        i = 0;\n\t        _iteratorNormalCompletion19 = true;\n\t        _didIteratorError19 = false;\n\t        _iteratorError19 = undefined;\n\t        context$1$0.prev = 6;\n\t        _iterator19 = _getIterator(this);\n\n\t      case 8:\n\t        if (_iteratorNormalCompletion19 = (_step19 = _iterator19.next()).done) {\n\t          context$1$0.next = 17;\n\t          break;\n\t        }\n\n\t        x = _step19.value;\n\t        context$1$0.next = 12;\n\t        return x;\n\n\t      case 12:\n\t        if (!(++i >= n)) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"break\", 17);\n\n\t      case 14:\n\t        _iteratorNormalCompletion19 = true;\n\t        context$1$0.next = 8;\n\t        break;\n\n\t      case 17:\n\t        context$1$0.next = 23;\n\t        break;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.t0 = context$1$0[\"catch\"](6);\n\t        _didIteratorError19 = true;\n\t        _iteratorError19 = context$1$0.t0;\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\t        context$1$0.prev = 24;\n\n\t        if (!_iteratorNormalCompletion19 && _iterator19[\"return\"]) {\n\t          _iterator19[\"return\"]();\n\t        }\n\n\t      case 26:\n\t        context$1$0.prev = 26;\n\n\t        if (!_didIteratorError19) {\n\t          context$1$0.next = 29;\n\t          break;\n\t        }\n\n\t        throw _iteratorError19;\n\n\t      case 29:\n\t        return context$1$0.finish(26);\n\n\t      case 30:\n\t        return context$1$0.finish(23);\n\n\t      case 31:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[6, 19, 23, 31], [24,, 26, 30]]);\n\t}));\n\n\trewrapPrototypeAndStatic(\"takeWhile\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\n\t  var _iteratorNormalCompletion20, _didIteratorError20, _iteratorError20, _iterator20, _step20, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion20 = true;\n\t        _didIteratorError20 = false;\n\t        _iteratorError20 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator20 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion20 = (_step20 = _iterator20.next()).done) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        x = _step20.value;\n\n\t        if (fn(x)) {\n\t          context$1$0.next = 9;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"break\", 14);\n\n\t      case 9:\n\t        context$1$0.next = 11;\n\t        return x;\n\n\t      case 11:\n\t        _iteratorNormalCompletion20 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 14:\n\t        context$1$0.next = 20;\n\t        break;\n\n\t      case 16:\n\t        context$1$0.prev = 16;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError20 = true;\n\t        _iteratorError20 = context$1$0.t0;\n\n\t      case 20:\n\t        context$1$0.prev = 20;\n\t        context$1$0.prev = 21;\n\n\t        if (!_iteratorNormalCompletion20 && _iterator20[\"return\"]) {\n\t          _iterator20[\"return\"]();\n\t        }\n\n\t      case 23:\n\t        context$1$0.prev = 23;\n\n\t        if (!_didIteratorError20) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        throw _iteratorError20;\n\n\t      case 26:\n\t        return context$1$0.finish(23);\n\n\t      case 27:\n\t        return context$1$0.finish(20);\n\n\t      case 28:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 16, 20, 28], [21,, 23, 27]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"tap\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? console.log.bind(console) : arguments[0];\n\n\t  var _iteratorNormalCompletion21, _didIteratorError21, _iteratorError21, _iterator21, _step21, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        _iteratorNormalCompletion21 = true;\n\t        _didIteratorError21 = false;\n\t        _iteratorError21 = undefined;\n\t        context$1$0.prev = 3;\n\t        _iterator21 = _getIterator(this);\n\n\t      case 5:\n\t        if (_iteratorNormalCompletion21 = (_step21 = _iterator21.next()).done) {\n\t          context$1$0.next = 13;\n\t          break;\n\t        }\n\n\t        x = _step21.value;\n\n\t        fn(x);\n\t        context$1$0.next = 10;\n\t        return x;\n\n\t      case 10:\n\t        _iteratorNormalCompletion21 = true;\n\t        context$1$0.next = 5;\n\t        break;\n\n\t      case 13:\n\t        context$1$0.next = 19;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.prev = 15;\n\t        context$1$0.t0 = context$1$0[\"catch\"](3);\n\t        _didIteratorError21 = true;\n\t        _iteratorError21 = context$1$0.t0;\n\n\t      case 19:\n\t        context$1$0.prev = 19;\n\t        context$1$0.prev = 20;\n\n\t        if (!_iteratorNormalCompletion21 && _iterator21[\"return\"]) {\n\t          _iterator21[\"return\"]();\n\t        }\n\n\t      case 22:\n\t        context$1$0.prev = 22;\n\n\t        if (!_didIteratorError21) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        throw _iteratorError21;\n\n\t      case 25:\n\t        return context$1$0.finish(22);\n\n\t      case 26:\n\t        return context$1$0.finish(19);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[3, 15, 19, 27], [20,, 22, 26]]);\n\t}), 1);\n\n\trewrapPrototypeAndStatic(\"unique\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  var seen, _iteratorNormalCompletion22, _didIteratorError22, _iteratorError22, _iterator22, _step22, x;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        seen = new _Set();\n\t        _iteratorNormalCompletion22 = true;\n\t        _didIteratorError22 = false;\n\t        _iteratorError22 = undefined;\n\t        context$1$0.prev = 4;\n\t        _iterator22 = _getIterator(this);\n\n\t      case 6:\n\t        if (_iteratorNormalCompletion22 = (_step22 = _iterator22.next()).done) {\n\t          context$1$0.next = 15;\n\t          break;\n\t        }\n\n\t        x = _step22.value;\n\n\t        if (seen.has(x)) {\n\t          context$1$0.next = 12;\n\t          break;\n\t        }\n\n\t        context$1$0.next = 11;\n\t        return x;\n\n\t      case 11:\n\t        seen.add(x);\n\n\t      case 12:\n\t        _iteratorNormalCompletion22 = true;\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 15:\n\t        context$1$0.next = 21;\n\t        break;\n\n\t      case 17:\n\t        context$1$0.prev = 17;\n\t        context$1$0.t0 = context$1$0[\"catch\"](4);\n\t        _didIteratorError22 = true;\n\t        _iteratorError22 = context$1$0.t0;\n\n\t      case 21:\n\t        context$1$0.prev = 21;\n\t        context$1$0.prev = 22;\n\n\t        if (!_iteratorNormalCompletion22 && _iterator22[\"return\"]) {\n\t          _iterator22[\"return\"]();\n\t        }\n\n\t      case 24:\n\t        context$1$0.prev = 24;\n\n\t        if (!_didIteratorError22) {\n\t          context$1$0.next = 27;\n\t          break;\n\t        }\n\n\t        throw _iteratorError22;\n\n\t      case 27:\n\t        return context$1$0.finish(24);\n\n\t      case 28:\n\t        return context$1$0.finish(21);\n\n\t      case 29:\n\t        seen.clear();\n\n\t      case 30:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[4, 17, 21, 29], [22,, 24, 28]]);\n\t}));\n\n\tvar _zip = rewrap(_regeneratorRuntime.mark(function callee$0$0(iterables) {\n\t  var longest = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1];\n\n\t  var iters, numIters, numFinished, finished, zipped, _iteratorNormalCompletion23, _didIteratorError23, _iteratorError23, _iterator23, _step23, it, _it$next, value, done;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        if (iterables.length) {\n\t          context$1$0.next = 2;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\");\n\n\t      case 2:\n\t        iters = iterables.map(getIterator);\n\t        numIters = iterables.length;\n\t        numFinished = 0;\n\t        finished = false;\n\n\t      case 6:\n\t        if (finished) {\n\t          context$1$0.next = 44;\n\t          break;\n\t        }\n\n\t        zipped = [];\n\t        _iteratorNormalCompletion23 = true;\n\t        _didIteratorError23 = false;\n\t        _iteratorError23 = undefined;\n\t        context$1$0.prev = 11;\n\t        _iterator23 = _getIterator(iters);\n\n\t      case 13:\n\t        if (_iteratorNormalCompletion23 = (_step23 = _iterator23.next()).done) {\n\t          context$1$0.next = 26;\n\t          break;\n\t        }\n\n\t        it = _step23.value;\n\t        _it$next = it.next();\n\t        value = _it$next.value;\n\t        done = _it$next.done;\n\n\t        if (!done) {\n\t          context$1$0.next = 22;\n\t          break;\n\t        }\n\n\t        if (longest) {\n\t          context$1$0.next = 21;\n\t          break;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\");\n\n\t      case 21:\n\t        if (++numFinished == numIters) {\n\t          finished = true;\n\t        }\n\n\t      case 22:\n\t        if (value === undefined) {\n\t          // Leave a hole in the array so that you can distinguish an iterable\n\t          // that's done (via `index in array == false`) from an iterable\n\t          // yielding `undefined`.\n\t          zipped.length++;\n\t        } else {\n\t          zipped.push(value);\n\t        }\n\n\t      case 23:\n\t        _iteratorNormalCompletion23 = true;\n\t        context$1$0.next = 13;\n\t        break;\n\n\t      case 26:\n\t        context$1$0.next = 32;\n\t        break;\n\n\t      case 28:\n\t        context$1$0.prev = 28;\n\t        context$1$0.t0 = context$1$0[\"catch\"](11);\n\t        _didIteratorError23 = true;\n\t        _iteratorError23 = context$1$0.t0;\n\n\t      case 32:\n\t        context$1$0.prev = 32;\n\t        context$1$0.prev = 33;\n\n\t        if (!_iteratorNormalCompletion23 && _iterator23[\"return\"]) {\n\t          _iterator23[\"return\"]();\n\t        }\n\n\t      case 35:\n\t        context$1$0.prev = 35;\n\n\t        if (!_didIteratorError23) {\n\t          context$1$0.next = 38;\n\t          break;\n\t        }\n\n\t        throw _iteratorError23;\n\n\t      case 38:\n\t        return context$1$0.finish(35);\n\n\t      case 39:\n\t        return context$1$0.finish(32);\n\n\t      case 40:\n\t        context$1$0.next = 42;\n\t        return zipped;\n\n\t      case 42:\n\t        context$1$0.next = 6;\n\t        break;\n\n\t      case 44:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this, [[11, 28, 32, 40], [33,, 35, 39]]);\n\t}));\n\n\trewrapStaticMethod(\"zip\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  for (var _len7 = arguments.length, iterables = Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {\n\t    iterables[_key7] = arguments[_key7];\n\t  }\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip(iterables), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"zipLongest\", _regeneratorRuntime.mark(function callee$0$0() {\n\t  for (var _len8 = arguments.length, iterables = Array(_len8), _key8 = 0; _key8 < _len8; _key8++) {\n\t    iterables[_key8] = arguments[_key8];\n\t  }\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip(iterables, true), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\trewrapStaticMethod(\"zipWith\", _regeneratorRuntime.mark(function callee$0$0(fn) {\n\t  for (var _len9 = arguments.length, iterables = Array(_len9 > 1 ? _len9 - 1 : 0), _key9 = 1; _key9 < _len9; _key9++) {\n\t    iterables[_key9 - 1] = arguments[_key9];\n\t  }\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        return context$1$0.delegateYield(_zip(iterables).spreadMap(fn), \"t0\", 1);\n\n\t      case 1:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\n\t/*\n\t * Functions that force iteration to completion and return a value.\n\t */\n\n\t// The maximum number of milliseconds we will block the main thread at a time\n\t// while in `asyncEach`.\n\twu.MAX_BLOCK = 15;\n\t// The number of milliseconds to yield to the main thread between bursts of\n\t// work.\n\twu.TIMEOUT = 1;\n\n\tprototypeAndStatic(\"asyncEach\", function (fn) {\n\t  var maxBlock = arguments.length <= 1 || arguments[1] === undefined ? wu.MAX_BLOCK : arguments[1];\n\t  var timeout = arguments.length <= 2 || arguments[2] === undefined ? wu.TIMEOUT : arguments[2];\n\n\t  var iter = getIterator(this);\n\n\t  return new _Promise(function (resolve, reject) {\n\t    (function loop() {\n\t      var start = Date.now();\n\n\t      var _iteratorNormalCompletion24 = true;\n\t      var _didIteratorError24 = false;\n\t      var _iteratorError24 = undefined;\n\n\t      try {\n\t        for (var _iterator24 = _getIterator(iter), _step24; !(_iteratorNormalCompletion24 = (_step24 = _iterator24.next()).done); _iteratorNormalCompletion24 = true) {\n\t          var x = _step24.value;\n\n\t          try {\n\t            fn(x);\n\t          } catch (e) {\n\t            reject(e);\n\t            return;\n\t          }\n\n\t          if (Date.now() - start > maxBlock) {\n\t            setTimeout(loop, timeout);\n\t            return;\n\t          }\n\t        }\n\t      } catch (err) {\n\t        _didIteratorError24 = true;\n\t        _iteratorError24 = err;\n\t      } finally {\n\t        try {\n\t          if (!_iteratorNormalCompletion24 && _iterator24[\"return\"]) {\n\t            _iterator24[\"return\"]();\n\t          }\n\t        } finally {\n\t          if (_didIteratorError24) {\n\t            throw _iteratorError24;\n\t          }\n\t        }\n\t      }\n\n\t      resolve();\n\t    })();\n\t  });\n\t}, 3);\n\n\tprototypeAndStatic(\"every\", function () {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\t  var _iteratorNormalCompletion25 = true;\n\t  var _didIteratorError25 = false;\n\t  var _iteratorError25 = undefined;\n\n\t  try {\n\t    for (var _iterator25 = _getIterator(this), _step25; !(_iteratorNormalCompletion25 = (_step25 = _iterator25.next()).done); _iteratorNormalCompletion25 = true) {\n\t      var x = _step25.value;\n\n\t      if (!fn(x)) {\n\t        return false;\n\t      }\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError25 = true;\n\t    _iteratorError25 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion25 && _iterator25[\"return\"]) {\n\t        _iterator25[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError25) {\n\t        throw _iteratorError25;\n\t      }\n\t    }\n\t  }\n\n\t  return true;\n\t}, 1);\n\n\tprototypeAndStatic(\"find\", function (fn) {\n\t  var _iteratorNormalCompletion26 = true;\n\t  var _didIteratorError26 = false;\n\t  var _iteratorError26 = undefined;\n\n\t  try {\n\t    for (var _iterator26 = _getIterator(this), _step26; !(_iteratorNormalCompletion26 = (_step26 = _iterator26.next()).done); _iteratorNormalCompletion26 = true) {\n\t      var x = _step26.value;\n\n\t      if (fn(x)) {\n\t        return x;\n\t      }\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError26 = true;\n\t    _iteratorError26 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion26 && _iterator26[\"return\"]) {\n\t        _iterator26[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError26) {\n\t        throw _iteratorError26;\n\t      }\n\t    }\n\t  }\n\t});\n\n\tprototypeAndStatic(\"forEach\", function (fn) {\n\t  var _iteratorNormalCompletion27 = true;\n\t  var _didIteratorError27 = false;\n\t  var _iteratorError27 = undefined;\n\n\t  try {\n\t    for (var _iterator27 = _getIterator(this), _step27; !(_iteratorNormalCompletion27 = (_step27 = _iterator27.next()).done); _iteratorNormalCompletion27 = true) {\n\t      var x = _step27.value;\n\n\t      fn(x);\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError27 = true;\n\t    _iteratorError27 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion27 && _iterator27[\"return\"]) {\n\t        _iterator27[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError27) {\n\t        throw _iteratorError27;\n\t      }\n\t    }\n\t  }\n\t});\n\n\tprototypeAndStatic(\"has\", function (thing) {\n\t  return this.some(function (x) {\n\t    return x === thing;\n\t  });\n\t});\n\n\tprototypeAndStatic(\"reduce\", function (fn) {\n\t  var initial = arguments.length <= 1 || arguments[1] === undefined ? undefined : arguments[1];\n\n\t  var val = initial;\n\t  if (val === undefined) {\n\t    var _iteratorNormalCompletion28 = true;\n\t    var _didIteratorError28 = false;\n\t    var _iteratorError28 = undefined;\n\n\t    try {\n\t      for (var _iterator28 = _getIterator(this), _step28; !(_iteratorNormalCompletion28 = (_step28 = _iterator28.next()).done); _iteratorNormalCompletion28 = true) {\n\t        var x = _step28.value;\n\n\t        val = x;\n\t        break;\n\t      }\n\t    } catch (err) {\n\t      _didIteratorError28 = true;\n\t      _iteratorError28 = err;\n\t    } finally {\n\t      try {\n\t        if (!_iteratorNormalCompletion28 && _iterator28[\"return\"]) {\n\t          _iterator28[\"return\"]();\n\t        }\n\t      } finally {\n\t        if (_didIteratorError28) {\n\t          throw _iteratorError28;\n\t        }\n\t      }\n\t    }\n\t  }\n\n\t  var _iteratorNormalCompletion29 = true;\n\t  var _didIteratorError29 = false;\n\t  var _iteratorError29 = undefined;\n\n\t  try {\n\t    for (var _iterator29 = _getIterator(this), _step29; !(_iteratorNormalCompletion29 = (_step29 = _iterator29.next()).done); _iteratorNormalCompletion29 = true) {\n\t      var x = _step29.value;\n\n\t      val = fn(val, x);\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError29 = true;\n\t    _iteratorError29 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion29 && _iterator29[\"return\"]) {\n\t        _iterator29[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError29) {\n\t        throw _iteratorError29;\n\t      }\n\t    }\n\t  }\n\n\t  return val;\n\t}, 2);\n\n\tprototypeAndStatic(\"some\", function () {\n\t  var fn = arguments.length <= 0 || arguments[0] === undefined ? Boolean : arguments[0];\n\t  var _iteratorNormalCompletion30 = true;\n\t  var _didIteratorError30 = false;\n\t  var _iteratorError30 = undefined;\n\n\t  try {\n\t    for (var _iterator30 = _getIterator(this), _step30; !(_iteratorNormalCompletion30 = (_step30 = _iterator30.next()).done); _iteratorNormalCompletion30 = true) {\n\t      var x = _step30.value;\n\n\t      if (fn(x)) {\n\t        return true;\n\t      }\n\t    }\n\t  } catch (err) {\n\t    _didIteratorError30 = true;\n\t    _iteratorError30 = err;\n\t  } finally {\n\t    try {\n\t      if (!_iteratorNormalCompletion30 && _iterator30[\"return\"]) {\n\t        _iterator30[\"return\"]();\n\t      }\n\t    } finally {\n\t      if (_didIteratorError30) {\n\t        throw _iteratorError30;\n\t      }\n\t    }\n\t  }\n\n\t  return false;\n\t}, 1);\n\n\tprototypeAndStatic(\"toArray\", function () {\n\t  return [].concat(_toConsumableArray(this));\n\t});\n\n\t/*\n\t * Methods that return an array of iterables.\n\t */\n\n\tvar MAX_CACHE = 500;\n\n\tvar _tee = rewrap(_regeneratorRuntime.mark(function callee$0$0(iterator, cache) {\n\t  var items, index, _iterator$next, done, value;\n\n\t  return _regeneratorRuntime.wrap(function callee$0$0$(context$1$0) {\n\t    while (1) switch (context$1$0.prev = context$1$0.next) {\n\t      case 0:\n\t        items = cache.items;\n\t        index = 0;\n\n\t      case 2:\n\t        if (false) {\n\t          context$1$0.next = 25;\n\t          break;\n\t        }\n\n\t        if (!(index === items.length)) {\n\t          context$1$0.next = 14;\n\t          break;\n\t        }\n\n\t        _iterator$next = iterator.next();\n\t        done = _iterator$next.done;\n\t        value = _iterator$next.value;\n\n\t        if (!done) {\n\t          context$1$0.next = 10;\n\t          break;\n\t        }\n\n\t        if (cache.returned === MISSING) {\n\t          cache.returned = value;\n\t        }\n\t        return context$1$0.abrupt(\"break\", 25);\n\n\t      case 10:\n\t        context$1$0.next = 12;\n\t        return items[index++] = value;\n\n\t      case 12:\n\t        context$1$0.next = 23;\n\t        break;\n\n\t      case 14:\n\t        if (!(index === cache.tail)) {\n\t          context$1$0.next = 21;\n\t          break;\n\t        }\n\n\t        value = items[index];\n\n\t        if (index === MAX_CACHE) {\n\t          items = cache.items = items.slice(index);\n\t          index = 0;\n\t          cache.tail = 0;\n\t        } else {\n\t          items[index] = undefined;\n\t          cache.tail = ++index;\n\t        }\n\t        context$1$0.next = 19;\n\t        return value;\n\n\t      case 19:\n\t        context$1$0.next = 23;\n\t        break;\n\n\t      case 21:\n\t        context$1$0.next = 23;\n\t        return items[index++];\n\n\t      case 23:\n\t        context$1$0.next = 2;\n\t        break;\n\n\t      case 25:\n\n\t        if (cache.tail === index) {\n\t          items.length = 0;\n\t        }\n\n\t        return context$1$0.abrupt(\"return\", cache.returned);\n\n\t      case 27:\n\t      case \"end\":\n\t        return context$1$0.stop();\n\t    }\n\t  }, callee$0$0, this);\n\t}));\n\t_tee.prototype = Wu.prototype;\n\n\tprototypeAndStatic(\"tee\", function () {\n\t  var n = arguments.length <= 0 || arguments[0] === undefined ? 2 : arguments[0];\n\n\t  var iterables = new Array(n);\n\t  var cache = { tail: 0, items: [], returned: MISSING };\n\n\t  while (n--) {\n\t    iterables[n] = _tee(this, cache);\n\t  }\n\n\t  return iterables;\n\t}, 1);\n\n\tprototypeAndStatic(\"unzip\", function () {\n\t  var n = arguments.length <= 0 || arguments[0] === undefined ? 2 : arguments[0];\n\n\t  return this.tee(n).map(function (iter, i) {\n\t    return iter.pluck(i);\n\t  });\n\t}, 1);\n\n\t/*\n\t * Number of chambers.\n\t */\n\n\twu.tang = { clan: 36 };\n\n\t// We don't have a cached item for this index, we need to force its\n\t// evaluation.\n\n\t// If we are the last iterator to use a cached value, clean up after\n\t// ourselves.\n\n\t// We have an item in the cache for this index, so yield it.\n\n/***/ },\n/* 1 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t\"use strict\";\n\n\tvar _Array$from = __webpack_require__(2)[\"default\"];\n\n\texports[\"default\"] = function (arr) {\n\t  if (Array.isArray(arr)) {\n\t    for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n\t    return arr2;\n\t  } else {\n\t    return _Array$from(arr);\n\t  }\n\t};\n\n\texports.__esModule = true;\n\n/***/ },\n/* 2 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(3), __esModule: true };\n\n/***/ },\n/* 3 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(4);\n\t__webpack_require__(26);\n\tmodule.exports = __webpack_require__(12).Array.from;\n\n/***/ },\n/* 4 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $at  = __webpack_require__(5)(true);\n\n\t// 21.1.3.27 String.prototype[@@iterator]()\n\t__webpack_require__(8)(String, 'String', function(iterated){\n\t  this._t = String(iterated); // target\n\t  this._i = 0;                // next index\n\t// 21.1.5.2.1 %StringIteratorPrototype%.next()\n\t}, function(){\n\t  var O     = this._t\n\t    , index = this._i\n\t    , point;\n\t  if(index >= O.length)return {value: undefined, done: true};\n\t  point = $at(O, index);\n\t  this._i += point.length;\n\t  return {value: point, done: false};\n\t});\n\n/***/ },\n/* 5 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// true  -> String#at\n\t// false -> String#codePointAt\n\tvar toInteger = __webpack_require__(6)\n\t  , defined   = __webpack_require__(7);\n\tmodule.exports = function(TO_STRING){\n\t  return function(that, pos){\n\t    var s = String(defined(that))\n\t      , i = toInteger(pos)\n\t      , l = s.length\n\t      , a, b;\n\t    if(i < 0 || i >= l)return TO_STRING ? '' : undefined;\n\t    a = s.charCodeAt(i);\n\t    return a < 0xd800 || a > 0xdbff || i + 1 === l\n\t      || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\n\t        ? TO_STRING ? s.charAt(i) : a\n\t        : TO_STRING ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\n\t  };\n\t};\n\n/***/ },\n/* 6 */\n/***/ function(module, exports) {\n\n\t// 7.1.4 ToInteger\n\tvar ceil  = Math.ceil\n\t  , floor = Math.floor;\n\tmodule.exports = function(it){\n\t  return isNaN(it = +it) ? 0 : (it > 0 ? floor : ceil)(it);\n\t};\n\n/***/ },\n/* 7 */\n/***/ function(module, exports) {\n\n\t// 7.2.1 RequireObjectCoercible(argument)\n\tmodule.exports = function(it){\n\t  if(it == undefined)throw TypeError(\"Can't call method on  \" + it);\n\t  return it;\n\t};\n\n/***/ },\n/* 8 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar LIBRARY         = __webpack_require__(9)\n\t  , $def            = __webpack_require__(10)\n\t  , $redef          = __webpack_require__(13)\n\t  , hide            = __webpack_require__(14)\n\t  , has             = __webpack_require__(19)\n\t  , SYMBOL_ITERATOR = __webpack_require__(20)('iterator')\n\t  , Iterators       = __webpack_require__(23)\n\t  , BUGGY           = !([].keys && 'next' in [].keys()) // Safari has buggy iterators w/o `next`\n\t  , FF_ITERATOR     = '@@iterator'\n\t  , KEYS            = 'keys'\n\t  , VALUES          = 'values';\n\tvar returnThis = function(){ return this; };\n\tmodule.exports = function(Base, NAME, Constructor, next, DEFAULT, IS_SET, FORCE){\n\t  __webpack_require__(24)(Constructor, NAME, next);\n\t  var createMethod = function(kind){\n\t    switch(kind){\n\t      case KEYS: return function keys(){ return new Constructor(this, kind); };\n\t      case VALUES: return function values(){ return new Constructor(this, kind); };\n\t    } return function entries(){ return new Constructor(this, kind); };\n\t  };\n\t  var TAG      = NAME + ' Iterator'\n\t    , proto    = Base.prototype\n\t    , _native  = proto[SYMBOL_ITERATOR] || proto[FF_ITERATOR] || DEFAULT && proto[DEFAULT]\n\t    , _default = _native || createMethod(DEFAULT)\n\t    , methods, key;\n\t  // Fix native\n\t  if(_native){\n\t    var IteratorPrototype = __webpack_require__(15).getProto(_default.call(new Base));\n\t    // Set @@toStringTag to native iterators\n\t    __webpack_require__(25)(IteratorPrototype, TAG, true);\n\t    // FF fix\n\t    if(!LIBRARY && has(proto, FF_ITERATOR))hide(IteratorPrototype, SYMBOL_ITERATOR, returnThis);\n\t  }\n\t  // Define iterator\n\t  if(!LIBRARY || FORCE)hide(proto, SYMBOL_ITERATOR, _default);\n\t  // Plug for library\n\t  Iterators[NAME] = _default;\n\t  Iterators[TAG]  = returnThis;\n\t  if(DEFAULT){\n\t    methods = {\n\t      keys:    IS_SET            ? _default : createMethod(KEYS),\n\t      values:  DEFAULT == VALUES ? _default : createMethod(VALUES),\n\t      entries: DEFAULT != VALUES ? _default : createMethod('entries')\n\t    };\n\t    if(FORCE)for(key in methods){\n\t      if(!(key in proto))$redef(proto, key, methods[key]);\n\t    } else $def($def.P + $def.F * BUGGY, NAME, methods);\n\t  }\n\t};\n\n/***/ },\n/* 9 */\n/***/ function(module, exports) {\n\n\tmodule.exports = true;\n\n/***/ },\n/* 10 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar global    = __webpack_require__(11)\n\t  , core      = __webpack_require__(12)\n\t  , PROTOTYPE = 'prototype';\n\tvar ctx = function(fn, that){\n\t  return function(){\n\t    return fn.apply(that, arguments);\n\t  };\n\t};\n\tvar $def = function(type, name, source){\n\t  var key, own, out, exp\n\t    , isGlobal = type & $def.G\n\t    , isProto  = type & $def.P\n\t    , target   = isGlobal ? global : type & $def.S\n\t        ? global[name] : (global[name] || {})[PROTOTYPE]\n\t    , exports  = isGlobal ? core : core[name] || (core[name] = {});\n\t  if(isGlobal)source = name;\n\t  for(key in source){\n\t    // contains in native\n\t    own = !(type & $def.F) && target && key in target;\n\t    if(own && key in exports)continue;\n\t    // export native or passed\n\t    out = own ? target[key] : source[key];\n\t    // prevent global pollution for namespaces\n\t    if(isGlobal && typeof target[key] != 'function')exp = source[key];\n\t    // bind timers to global for call from export context\n\t    else if(type & $def.B && own)exp = ctx(out, global);\n\t    // wrap global constructors for prevent change them in library\n\t    else if(type & $def.W && target[key] == out)!function(C){\n\t      exp = function(param){\n\t        return this instanceof C ? new C(param) : C(param);\n\t      };\n\t      exp[PROTOTYPE] = C[PROTOTYPE];\n\t    }(out);\n\t    else exp = isProto && typeof out == 'function' ? ctx(Function.call, out) : out;\n\t    // export\n\t    exports[key] = exp;\n\t    if(isProto)(exports[PROTOTYPE] || (exports[PROTOTYPE] = {}))[key] = out;\n\t  }\n\t};\n\t// type bitmap\n\t$def.F = 1;  // forced\n\t$def.G = 2;  // global\n\t$def.S = 4;  // static\n\t$def.P = 8;  // proto\n\t$def.B = 16; // bind\n\t$def.W = 32; // wrap\n\tmodule.exports = $def;\n\n/***/ },\n/* 11 */\n/***/ function(module, exports) {\n\n\t// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\n\tvar UNDEFINED = 'undefined';\n\tvar global = module.exports = typeof window != UNDEFINED && window.Math == Math\n\t  ? window : typeof self != UNDEFINED && self.Math == Math ? self : Function('return this')();\n\tif(typeof __g == 'number')__g = global; // eslint-disable-line no-undef\n\n/***/ },\n/* 12 */\n/***/ function(module, exports) {\n\n\tvar core = module.exports = {version: '1.2.0'};\n\tif(typeof __e == 'number')__e = core; // eslint-disable-line no-undef\n\n/***/ },\n/* 13 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(14);\n\n/***/ },\n/* 14 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $          = __webpack_require__(15)\n\t  , createDesc = __webpack_require__(16);\n\tmodule.exports = __webpack_require__(17) ? function(object, key, value){\n\t  return $.setDesc(object, key, createDesc(1, value));\n\t} : function(object, key, value){\n\t  object[key] = value;\n\t  return object;\n\t};\n\n/***/ },\n/* 15 */\n/***/ function(module, exports) {\n\n\tvar $Object = Object;\n\tmodule.exports = {\n\t  create:     $Object.create,\n\t  getProto:   $Object.getPrototypeOf,\n\t  isEnum:     {}.propertyIsEnumerable,\n\t  getDesc:    $Object.getOwnPropertyDescriptor,\n\t  setDesc:    $Object.defineProperty,\n\t  setDescs:   $Object.defineProperties,\n\t  getKeys:    $Object.keys,\n\t  getNames:   $Object.getOwnPropertyNames,\n\t  getSymbols: $Object.getOwnPropertySymbols,\n\t  each:       [].forEach\n\t};\n\n/***/ },\n/* 16 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(bitmap, value){\n\t  return {\n\t    enumerable  : !(bitmap & 1),\n\t    configurable: !(bitmap & 2),\n\t    writable    : !(bitmap & 4),\n\t    value       : value\n\t  };\n\t};\n\n/***/ },\n/* 17 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// Thank's IE8 for his funny defineProperty\n\tmodule.exports = !__webpack_require__(18)(function(){\n\t  return Object.defineProperty({}, 'a', {get: function(){ return 7; }}).a != 7;\n\t});\n\n/***/ },\n/* 18 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(exec){\n\t  try {\n\t    return !!exec();\n\t  } catch(e){\n\t    return true;\n\t  }\n\t};\n\n/***/ },\n/* 19 */\n/***/ function(module, exports) {\n\n\tvar hasOwnProperty = {}.hasOwnProperty;\n\tmodule.exports = function(it, key){\n\t  return hasOwnProperty.call(it, key);\n\t};\n\n/***/ },\n/* 20 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar store  = __webpack_require__(21)('wks')\n\t  , Symbol = __webpack_require__(11).Symbol;\n\tmodule.exports = function(name){\n\t  return store[name] || (store[name] =\n\t    Symbol && Symbol[name] || (Symbol || __webpack_require__(22))('Symbol.' + name));\n\t};\n\n/***/ },\n/* 21 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar global = __webpack_require__(11)\n\t  , SHARED = '__core-js_shared__'\n\t  , store  = global[SHARED] || (global[SHARED] = {});\n\tmodule.exports = function(key){\n\t  return store[key] || (store[key] = {});\n\t};\n\n/***/ },\n/* 22 */\n/***/ function(module, exports) {\n\n\tvar id = 0\n\t  , px = Math.random();\n\tmodule.exports = function(key){\n\t  return 'Symbol('.concat(key === undefined ? '' : key, ')_', (++id + px).toString(36));\n\t};\n\n/***/ },\n/* 23 */\n/***/ function(module, exports) {\n\n\tmodule.exports = {};\n\n/***/ },\n/* 24 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $ = __webpack_require__(15)\n\t  , IteratorPrototype = {};\n\n\t// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\n\t__webpack_require__(14)(IteratorPrototype, __webpack_require__(20)('iterator'), function(){ return this; });\n\n\tmodule.exports = function(Constructor, NAME, next){\n\t  Constructor.prototype = $.create(IteratorPrototype, {next: __webpack_require__(16)(1,next)});\n\t  __webpack_require__(25)(Constructor, NAME + ' Iterator');\n\t};\n\n/***/ },\n/* 25 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar has  = __webpack_require__(19)\n\t  , hide = __webpack_require__(14)\n\t  , TAG  = __webpack_require__(20)('toStringTag');\n\n\tmodule.exports = function(it, tag, stat){\n\t  if(it && !has(it = stat ? it : it.prototype, TAG))hide(it, TAG, tag);\n\t};\n\n/***/ },\n/* 26 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar ctx         = __webpack_require__(27)\n\t  , $def        = __webpack_require__(10)\n\t  , toObject    = __webpack_require__(29)\n\t  , call        = __webpack_require__(30)\n\t  , isArrayIter = __webpack_require__(33)\n\t  , toLength    = __webpack_require__(34)\n\t  , getIterFn   = __webpack_require__(35);\n\t$def($def.S + $def.F * !__webpack_require__(38)(function(iter){ Array.from(iter); }), 'Array', {\n\t  // 22.1.2.1 Array.from(arrayLike, mapfn = undefined, thisArg = undefined)\n\t  from: function from(arrayLike/*, mapfn = undefined, thisArg = undefined*/){\n\t    var O       = toObject(arrayLike)\n\t      , C       = typeof this == 'function' ? this : Array\n\t      , mapfn   = arguments[1]\n\t      , mapping = mapfn !== undefined\n\t      , index   = 0\n\t      , iterFn  = getIterFn(O)\n\t      , length, result, step, iterator;\n\t    if(mapping)mapfn = ctx(mapfn, arguments[2], 2);\n\t    // if object isn't iterable or it's array with default iterator - use simple case\n\t    if(iterFn != undefined && !(C == Array && isArrayIter(iterFn))){\n\t      for(iterator = iterFn.call(O), result = new C; !(step = iterator.next()).done; index++){\n\t        result[index] = mapping ? call(iterator, mapfn, [step.value, index], true) : step.value;\n\t      }\n\t    } else {\n\t      length = toLength(O.length);\n\t      for(result = new C(length); length > index; index++){\n\t        result[index] = mapping ? mapfn(O[index], index) : O[index];\n\t      }\n\t    }\n\t    result.length = index;\n\t    return result;\n\t  }\n\t});\n\n\n/***/ },\n/* 27 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// optional / simple context binding\n\tvar aFunction = __webpack_require__(28);\n\tmodule.exports = function(fn, that, length){\n\t  aFunction(fn);\n\t  if(that === undefined)return fn;\n\t  switch(length){\n\t    case 1: return function(a){\n\t      return fn.call(that, a);\n\t    };\n\t    case 2: return function(a, b){\n\t      return fn.call(that, a, b);\n\t    };\n\t    case 3: return function(a, b, c){\n\t      return fn.call(that, a, b, c);\n\t    };\n\t  }\n\t  return function(/* ...args */){\n\t    return fn.apply(that, arguments);\n\t  };\n\t};\n\n/***/ },\n/* 28 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(it){\n\t  if(typeof it != 'function')throw TypeError(it + ' is not a function!');\n\t  return it;\n\t};\n\n/***/ },\n/* 29 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// 7.1.13 ToObject(argument)\n\tvar defined = __webpack_require__(7);\n\tmodule.exports = function(it){\n\t  return Object(defined(it));\n\t};\n\n/***/ },\n/* 30 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// call something on iterator step with safe closing on error\n\tvar anObject = __webpack_require__(31);\n\tmodule.exports = function(iterator, fn, value, entries){\n\t  try {\n\t    return entries ? fn(anObject(value)[0], value[1]) : fn(value);\n\t  // 7.4.6 IteratorClose(iterator, completion)\n\t  } catch(e){\n\t    var ret = iterator['return'];\n\t    if(ret !== undefined)anObject(ret.call(iterator));\n\t    throw e;\n\t  }\n\t};\n\n/***/ },\n/* 31 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar isObject = __webpack_require__(32);\n\tmodule.exports = function(it){\n\t  if(!isObject(it))throw TypeError(it + ' is not an object!');\n\t  return it;\n\t};\n\n/***/ },\n/* 32 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(it){\n\t  return typeof it === 'object' ? it !== null : typeof it === 'function';\n\t};\n\n/***/ },\n/* 33 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// check on default Array iterator\n\tvar Iterators = __webpack_require__(23)\n\t  , ITERATOR  = __webpack_require__(20)('iterator');\n\tmodule.exports = function(it){\n\t  return (Iterators.Array || Array.prototype[ITERATOR]) === it;\n\t};\n\n/***/ },\n/* 34 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// 7.1.15 ToLength\n\tvar toInteger = __webpack_require__(6)\n\t  , min       = Math.min;\n\tmodule.exports = function(it){\n\t  return it > 0 ? min(toInteger(it), 0x1fffffffffffff) : 0; // pow(2, 53) - 1 == 9007199254740991\n\t};\n\n/***/ },\n/* 35 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar classof   = __webpack_require__(36)\n\t  , ITERATOR  = __webpack_require__(20)('iterator')\n\t  , Iterators = __webpack_require__(23);\n\tmodule.exports = __webpack_require__(12).getIteratorMethod = function(it){\n\t  if(it != undefined)return it[ITERATOR] || it['@@iterator'] || Iterators[classof(it)];\n\t};\n\n/***/ },\n/* 36 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// getting tag from 19.1.3.6 Object.prototype.toString()\n\tvar cof = __webpack_require__(37)\n\t  , TAG = __webpack_require__(20)('toStringTag')\n\t  // ES3 wrong here\n\t  , ARG = cof(function(){ return arguments; }()) == 'Arguments';\n\n\tmodule.exports = function(it){\n\t  var O, T, B;\n\t  return it === undefined ? 'Undefined' : it === null ? 'Null'\n\t    // @@toStringTag case\n\t    : typeof (T = (O = Object(it))[TAG]) == 'string' ? T\n\t    // builtinTag case\n\t    : ARG ? cof(O)\n\t    // ES3 arguments fallback\n\t    : (B = cof(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : B;\n\t};\n\n/***/ },\n/* 37 */\n/***/ function(module, exports) {\n\n\tvar toString = {}.toString;\n\n\tmodule.exports = function(it){\n\t  return toString.call(it).slice(8, -1);\n\t};\n\n/***/ },\n/* 38 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar SYMBOL_ITERATOR = __webpack_require__(20)('iterator')\n\t  , SAFE_CLOSING    = false;\n\ttry {\n\t  var riter = [7][SYMBOL_ITERATOR]();\n\t  riter['return'] = function(){ SAFE_CLOSING = true; };\n\t  Array.from(riter, function(){ throw 2; });\n\t} catch(e){ /* empty */ }\n\tmodule.exports = function(exec){\n\t  if(!SAFE_CLOSING)return false;\n\t  var safe = false;\n\t  try {\n\t    var arr  = [7]\n\t      , iter = arr[SYMBOL_ITERATOR]();\n\t    iter.next = function(){ safe = true; };\n\t    arr[SYMBOL_ITERATOR] = function(){ return iter; };\n\t    exec(arr);\n\t  } catch(e){ /* empty */ }\n\t  return safe;\n\t};\n\n/***/ },\n/* 39 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t\"use strict\";\n\n\tvar _getIterator = __webpack_require__(40)[\"default\"];\n\n\tvar _isIterable = __webpack_require__(49)[\"default\"];\n\n\texports[\"default\"] = (function () {\n\t  function sliceIterator(arr, i) {\n\t    var _arr = [];\n\t    var _n = true;\n\t    var _d = false;\n\t    var _e = undefined;\n\n\t    try {\n\t      for (var _i = _getIterator(arr), _s; !(_n = (_s = _i.next()).done); _n = true) {\n\t        _arr.push(_s.value);\n\n\t        if (i && _arr.length === i) break;\n\t      }\n\t    } catch (err) {\n\t      _d = true;\n\t      _e = err;\n\t    } finally {\n\t      try {\n\t        if (!_n && _i[\"return\"]) _i[\"return\"]();\n\t      } finally {\n\t        if (_d) throw _e;\n\t      }\n\t    }\n\n\t    return _arr;\n\t  }\n\n\t  return function (arr, i) {\n\t    if (Array.isArray(arr)) {\n\t      return arr;\n\t    } else if (_isIterable(Object(arr))) {\n\t      return sliceIterator(arr, i);\n\t    } else {\n\t      throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n\t    }\n\t  };\n\t})();\n\n\texports.__esModule = true;\n\n/***/ },\n/* 40 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(41), __esModule: true };\n\n/***/ },\n/* 41 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(42);\n\t__webpack_require__(4);\n\tmodule.exports = __webpack_require__(48);\n\n/***/ },\n/* 42 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(43);\n\tvar Iterators = __webpack_require__(23);\n\tIterators.NodeList = Iterators.HTMLCollection = Iterators.Array;\n\n/***/ },\n/* 43 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar setUnscope = __webpack_require__(44)\n\t  , step       = __webpack_require__(45)\n\t  , Iterators  = __webpack_require__(23)\n\t  , toIObject  = __webpack_require__(46);\n\n\t// 22.1.3.4 Array.prototype.entries()\n\t// 22.1.3.13 Array.prototype.keys()\n\t// 22.1.3.29 Array.prototype.values()\n\t// 22.1.3.30 Array.prototype[@@iterator]()\n\t__webpack_require__(8)(Array, 'Array', function(iterated, kind){\n\t  this._t = toIObject(iterated); // target\n\t  this._i = 0;                   // next index\n\t  this._k = kind;                // kind\n\t// 22.1.5.2.1 %ArrayIteratorPrototype%.next()\n\t}, function(){\n\t  var O     = this._t\n\t    , kind  = this._k\n\t    , index = this._i++;\n\t  if(!O || index >= O.length){\n\t    this._t = undefined;\n\t    return step(1);\n\t  }\n\t  if(kind == 'keys'  )return step(0, index);\n\t  if(kind == 'values')return step(0, O[index]);\n\t  return step(0, [index, O[index]]);\n\t}, 'values');\n\n\t// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\n\tIterators.Arguments = Iterators.Array;\n\n\tsetUnscope('keys');\n\tsetUnscope('values');\n\tsetUnscope('entries');\n\n/***/ },\n/* 44 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(){ /* empty */ };\n\n/***/ },\n/* 45 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(done, value){\n\t  return {value: value, done: !!done};\n\t};\n\n/***/ },\n/* 46 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// to indexed object, toObject with fallback for non-array-like ES3 strings\r\n\tvar IObject = __webpack_require__(47)\r\n\t  , defined = __webpack_require__(7);\r\n\tmodule.exports = function(it){\r\n\t  return IObject(defined(it));\r\n\t};\n\n/***/ },\n/* 47 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// indexed object, fallback for non-array-like ES3 strings\n\tvar cof = __webpack_require__(37);\n\tmodule.exports = 0 in Object('z') ? Object : function(it){\n\t  return cof(it) == 'String' ? it.split('') : Object(it);\n\t};\n\n/***/ },\n/* 48 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar anObject = __webpack_require__(31)\n\t  , get      = __webpack_require__(35);\n\tmodule.exports = __webpack_require__(12).getIterator = function(it){\n\t  var iterFn = get(it);\n\t  if(typeof iterFn != 'function')throw TypeError(it + ' is not iterable!');\n\t  return anObject(iterFn.call(it));\n\t};\n\n/***/ },\n/* 49 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(50), __esModule: true };\n\n/***/ },\n/* 50 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(42);\n\t__webpack_require__(4);\n\tmodule.exports = __webpack_require__(51);\n\n/***/ },\n/* 51 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar classof   = __webpack_require__(36)\n\t  , ITERATOR  = __webpack_require__(20)('iterator')\n\t  , Iterators = __webpack_require__(23);\n\tmodule.exports = __webpack_require__(12).isIterable = function(it){\n\t  var O = Object(it);\n\t  return ITERATOR in O || '@@iterator' in O || Iterators.hasOwnProperty(classof(O));\n\t};\n\n/***/ },\n/* 52 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(53), __esModule: true };\n\n/***/ },\n/* 53 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(4);\n\t__webpack_require__(42);\n\tmodule.exports = __webpack_require__(20)('iterator');\n\n/***/ },\n/* 54 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(global) {// This method of obtaining a reference to the global object needs to be\n\t// kept identical to the way it is obtained in runtime.js\n\tvar g =\n\t  typeof global === \"object\" ? global :\n\t  typeof window === \"object\" ? window :\n\t  typeof self === \"object\" ? self : this;\n\n\t// Use `getOwnPropertyNames` because not all browsers support calling\n\t// `hasOwnProperty` on the global `self` object in a worker. See #183.\n\tvar hadRuntime = g.regeneratorRuntime &&\n\t  Object.getOwnPropertyNames(g).indexOf(\"regeneratorRuntime\") >= 0;\n\n\t// Save the old regeneratorRuntime in case it needs to be restored later.\n\tvar oldRuntime = hadRuntime && g.regeneratorRuntime;\n\n\t// Force reevalutation of runtime.js.\n\tg.regeneratorRuntime = undefined;\n\n\tmodule.exports = __webpack_require__(55);\n\n\tif (hadRuntime) {\n\t  // Restore the original runtime.\n\t  g.regeneratorRuntime = oldRuntime;\n\t} else {\n\t  // Remove the global property added by runtime.js.\n\t  try {\n\t    delete g.regeneratorRuntime;\n\t  } catch(e) {\n\t    g.regeneratorRuntime = undefined;\n\t  }\n\t}\n\n\tmodule.exports = { \"default\": module.exports, __esModule: true };\n\n\t/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))\n\n/***/ },\n/* 55 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(global, process) {/**\n\t * Copyright (c) 2014, Facebook, Inc.\n\t * All rights reserved.\n\t *\n\t * This source code is licensed under the BSD-style license found in the\n\t * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n\t * additional grant of patent rights can be found in the PATENTS file in\n\t * the same directory.\n\t */\n\n\t\"use strict\";\n\n\tvar _Symbol = __webpack_require__(57)[\"default\"];\n\n\tvar _Symbol$iterator = __webpack_require__(52)[\"default\"];\n\n\tvar _Object$create = __webpack_require__(63)[\"default\"];\n\n\tvar _Promise = __webpack_require__(65)[\"default\"];\n\n\t!(function (global) {\n\t  \"use strict\";\n\n\t  var hasOwn = Object.prototype.hasOwnProperty;\n\t  var undefined; // More compressible than void 0.\n\t  var iteratorSymbol = typeof _Symbol === \"function\" && _Symbol$iterator || \"@@iterator\";\n\n\t  var inModule = typeof module === \"object\";\n\t  var runtime = global.regeneratorRuntime;\n\t  if (runtime) {\n\t    if (inModule) {\n\t      // If regeneratorRuntime is defined globally and we're in a module,\n\t      // make the exports object identical to regeneratorRuntime.\n\t      module.exports = runtime;\n\t    }\n\t    // Don't bother evaluating the rest of this file if the runtime was\n\t    // already defined globally.\n\t    return;\n\t  }\n\n\t  // Define the runtime globally (as expected by generated code) as either\n\t  // module.exports (if we're in a module) or a new, empty object.\n\t  runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n\t  function wrap(innerFn, outerFn, self, tryLocsList) {\n\t    // If outerFn provided, then outerFn.prototype instanceof Generator.\n\t    var generator = _Object$create((outerFn || Generator).prototype);\n\n\t    generator._invoke = makeInvokeMethod(innerFn, self || null, new Context(tryLocsList || []));\n\n\t    return generator;\n\t  }\n\t  runtime.wrap = wrap;\n\n\t  // Try/catch helper to minimize deoptimizations. Returns a completion\n\t  // record like context.tryEntries[i].completion. This interface could\n\t  // have been (and was previously) designed to take a closure to be\n\t  // invoked without arguments, but in all the cases we care about we\n\t  // already have an existing method we want to call, so there's no need\n\t  // to create a new function object. We can even get away with assuming\n\t  // the method takes exactly one argument, since that happens to be true\n\t  // in every case, so we don't have to touch the arguments object. The\n\t  // only additional allocation required is the completion record, which\n\t  // has a stable shape and so hopefully should be cheap to allocate.\n\t  function tryCatch(fn, obj, arg) {\n\t    try {\n\t      return { type: \"normal\", arg: fn.call(obj, arg) };\n\t    } catch (err) {\n\t      return { type: \"throw\", arg: err };\n\t    }\n\t  }\n\n\t  var GenStateSuspendedStart = \"suspendedStart\";\n\t  var GenStateSuspendedYield = \"suspendedYield\";\n\t  var GenStateExecuting = \"executing\";\n\t  var GenStateCompleted = \"completed\";\n\n\t  // Returning this object from the innerFn has the same effect as\n\t  // breaking out of the dispatch switch statement.\n\t  var ContinueSentinel = {};\n\n\t  // Dummy constructor functions that we use as the .constructor and\n\t  // .constructor.prototype properties for functions that return Generator\n\t  // objects. For full spec compliance, you may wish to configure your\n\t  // minifier not to mangle the names of these two functions.\n\t  function Generator() {}\n\t  function GeneratorFunction() {}\n\t  function GeneratorFunctionPrototype() {}\n\n\t  var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n\t  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n\t  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n\t  GeneratorFunction.displayName = \"GeneratorFunction\";\n\n\t  // Helper for defining the .next, .throw, and .return methods of the\n\t  // Iterator interface in terms of a single ._invoke method.\n\t  function defineIteratorMethods(prototype) {\n\t    [\"next\", \"throw\", \"return\"].forEach(function (method) {\n\t      prototype[method] = function (arg) {\n\t        return this._invoke(method, arg);\n\t      };\n\t    });\n\t  }\n\n\t  runtime.isGeneratorFunction = function (genFun) {\n\t    var ctor = typeof genFun === \"function\" && genFun.constructor;\n\t    return ctor ? ctor === GeneratorFunction ||\n\t    // For the native GeneratorFunction constructor, the best we can\n\t    // do is to check its .name property.\n\t    (ctor.displayName || ctor.name) === \"GeneratorFunction\" : false;\n\t  };\n\n\t  runtime.mark = function (genFun) {\n\t    genFun.__proto__ = GeneratorFunctionPrototype;\n\t    genFun.prototype = _Object$create(Gp);\n\t    return genFun;\n\t  };\n\n\t  // Within the body of any async function, `await x` is transformed to\n\t  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n\t  // `value instanceof AwaitArgument` to determine if the yielded value is\n\t  // meant to be awaited. Some may consider the name of this method too\n\t  // cutesy, but they are curmudgeons.\n\t  runtime.awrap = function (arg) {\n\t    return new AwaitArgument(arg);\n\t  };\n\n\t  function AwaitArgument(arg) {\n\t    this.arg = arg;\n\t  }\n\n\t  function AsyncIterator(generator) {\n\t    // This invoke function is written in a style that assumes some\n\t    // calling function (or Promise) will handle exceptions.\n\t    function invoke(method, arg) {\n\t      var result = generator[method](arg);\n\t      var value = result.value;\n\t      return value instanceof AwaitArgument ? _Promise.resolve(value.arg).then(invokeNext, invokeThrow) : _Promise.resolve(value).then(function (unwrapped) {\n\t        // When a yielded Promise is resolved, its final value becomes\n\t        // the .value of the Promise<{value,done}> result for the\n\t        // current iteration. If the Promise is rejected, however, the\n\t        // result for this iteration will be rejected with the same\n\t        // reason. Note that rejections of yielded Promises are not\n\t        // thrown back into the generator function, as is the case\n\t        // when an awaited Promise is rejected. This difference in\n\t        // behavior between yield and await is important, because it\n\t        // allows the consumer to decide what to do with the yielded\n\t        // rejection (swallow it and continue, manually .throw it back\n\t        // into the generator, abandon iteration, whatever). With\n\t        // await, by contrast, there is no opportunity to examine the\n\t        // rejection reason outside the generator function, so the\n\t        // only option is to throw it from the await expression, and\n\t        // let the generator function handle the exception.\n\t        result.value = unwrapped;\n\t        return result;\n\t      });\n\t    }\n\n\t    if (typeof process === \"object\" && process.domain) {\n\t      invoke = process.domain.bind(invoke);\n\t    }\n\n\t    var invokeNext = invoke.bind(generator, \"next\");\n\t    var invokeThrow = invoke.bind(generator, \"throw\");\n\t    var invokeReturn = invoke.bind(generator, \"return\");\n\t    var previousPromise;\n\n\t    function enqueue(method, arg) {\n\t      var enqueueResult =\n\t      // If enqueue has been called before, then we want to wait until\n\t      // all previous Promises have been resolved before calling invoke,\n\t      // so that results are always delivered in the correct order. If\n\t      // enqueue has not been called before, then it is important to\n\t      // call invoke immediately, without waiting on a callback to fire,\n\t      // so that the async generator function has the opportunity to do\n\t      // any necessary setup in a predictable way. This predictability\n\t      // is why the Promise constructor synchronously invokes its\n\t      // executor callback, and why async functions synchronously\n\t      // execute code before the first await. Since we implement simple\n\t      // async functions in terms of async generators, it is especially\n\t      // important to get this right, even though it requires care.\n\t      previousPromise ? previousPromise.then(function () {\n\t        return invoke(method, arg);\n\t      }) : new _Promise(function (resolve) {\n\t        resolve(invoke(method, arg));\n\t      });\n\n\t      // Avoid propagating enqueueResult failures to Promises returned by\n\t      // later invocations of the iterator.\n\t      previousPromise = enqueueResult[\"catch\"](function (ignored) {});\n\n\t      return enqueueResult;\n\t    }\n\n\t    // Define the unified helper method that is used to implement .next,\n\t    // .throw, and .return (see defineIteratorMethods).\n\t    this._invoke = enqueue;\n\t  }\n\n\t  defineIteratorMethods(AsyncIterator.prototype);\n\n\t  // Note that simple async functions are implemented on top of\n\t  // AsyncIterator objects; they just return a Promise for the value of\n\t  // the final result produced by the iterator.\n\t  runtime.async = function (innerFn, outerFn, self, tryLocsList) {\n\t    var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList));\n\n\t    return runtime.isGeneratorFunction(outerFn) ? iter // If outerFn is a generator, return the full iterator.\n\t    : iter.next().then(function (result) {\n\t      return result.done ? result.value : iter.next();\n\t    });\n\t  };\n\n\t  function makeInvokeMethod(innerFn, self, context) {\n\t    var state = GenStateSuspendedStart;\n\n\t    return function invoke(method, arg) {\n\t      if (state === GenStateExecuting) {\n\t        throw new Error(\"Generator is already running\");\n\t      }\n\n\t      if (state === GenStateCompleted) {\n\t        if (method === \"throw\") {\n\t          throw arg;\n\t        }\n\n\t        // Be forgiving, per 25.3.3.3.3 of the spec:\n\t        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n\t        return doneResult();\n\t      }\n\n\t      while (true) {\n\t        var delegate = context.delegate;\n\t        if (delegate) {\n\t          if (method === \"return\" || method === \"throw\" && delegate.iterator[method] === undefined) {\n\t            // A return or throw (when the delegate iterator has no throw\n\t            // method) always terminates the yield* loop.\n\t            context.delegate = null;\n\n\t            // If the delegate iterator has a return method, give it a\n\t            // chance to clean up.\n\t            var returnMethod = delegate.iterator[\"return\"];\n\t            if (returnMethod) {\n\t              var record = tryCatch(returnMethod, delegate.iterator, arg);\n\t              if (record.type === \"throw\") {\n\t                // If the return method threw an exception, let that\n\t                // exception prevail over the original return or throw.\n\t                method = \"throw\";\n\t                arg = record.arg;\n\t                continue;\n\t              }\n\t            }\n\n\t            if (method === \"return\") {\n\t              // Continue with the outer return, now that the delegate\n\t              // iterator has been terminated.\n\t              continue;\n\t            }\n\t          }\n\n\t          var record = tryCatch(delegate.iterator[method], delegate.iterator, arg);\n\n\t          if (record.type === \"throw\") {\n\t            context.delegate = null;\n\n\t            // Like returning generator.throw(uncaught), but without the\n\t            // overhead of an extra function call.\n\t            method = \"throw\";\n\t            arg = record.arg;\n\t            continue;\n\t          }\n\n\t          // Delegate generator ran and handled its own exceptions so\n\t          // regardless of what the method was, we continue as if it is\n\t          // \"next\" with an undefined arg.\n\t          method = \"next\";\n\t          arg = undefined;\n\n\t          var info = record.arg;\n\t          if (info.done) {\n\t            context[delegate.resultName] = info.value;\n\t            context.next = delegate.nextLoc;\n\t          } else {\n\t            state = GenStateSuspendedYield;\n\t            return info;\n\t          }\n\n\t          context.delegate = null;\n\t        }\n\n\t        if (method === \"next\") {\n\t          if (state === GenStateSuspendedYield) {\n\t            context.sent = arg;\n\t          } else {\n\t            context.sent = undefined;\n\t          }\n\t        } else if (method === \"throw\") {\n\t          if (state === GenStateSuspendedStart) {\n\t            state = GenStateCompleted;\n\t            throw arg;\n\t          }\n\n\t          if (context.dispatchException(arg)) {\n\t            // If the dispatched exception was caught by a catch block,\n\t            // then let that catch block handle the exception normally.\n\t            method = \"next\";\n\t            arg = undefined;\n\t          }\n\t        } else if (method === \"return\") {\n\t          context.abrupt(\"return\", arg);\n\t        }\n\n\t        state = GenStateExecuting;\n\n\t        var record = tryCatch(innerFn, self, context);\n\t        if (record.type === \"normal\") {\n\t          // If an exception is thrown from innerFn, we leave state ===\n\t          // GenStateExecuting and loop back for another invocation.\n\t          state = context.done ? GenStateCompleted : GenStateSuspendedYield;\n\n\t          var info = {\n\t            value: record.arg,\n\t            done: context.done\n\t          };\n\n\t          if (record.arg === ContinueSentinel) {\n\t            if (context.delegate && method === \"next\") {\n\t              // Deliberately forget the last sent value so that we don't\n\t              // accidentally pass it on to the delegate.\n\t              arg = undefined;\n\t            }\n\t          } else {\n\t            return info;\n\t          }\n\t        } else if (record.type === \"throw\") {\n\t          state = GenStateCompleted;\n\t          // Dispatch the exception by looping back around to the\n\t          // context.dispatchException(arg) call above.\n\t          method = \"throw\";\n\t          arg = record.arg;\n\t        }\n\t      }\n\t    };\n\t  }\n\n\t  // Define Generator.prototype.{next,throw,return} in terms of the\n\t  // unified ._invoke helper method.\n\t  defineIteratorMethods(Gp);\n\n\t  Gp[iteratorSymbol] = function () {\n\t    return this;\n\t  };\n\n\t  Gp.toString = function () {\n\t    return \"[object Generator]\";\n\t  };\n\n\t  function pushTryEntry(locs) {\n\t    var entry = { tryLoc: locs[0] };\n\n\t    if (1 in locs) {\n\t      entry.catchLoc = locs[1];\n\t    }\n\n\t    if (2 in locs) {\n\t      entry.finallyLoc = locs[2];\n\t      entry.afterLoc = locs[3];\n\t    }\n\n\t    this.tryEntries.push(entry);\n\t  }\n\n\t  function resetTryEntry(entry) {\n\t    var record = entry.completion || {};\n\t    record.type = \"normal\";\n\t    delete record.arg;\n\t    entry.completion = record;\n\t  }\n\n\t  function Context(tryLocsList) {\n\t    // The root entry object (effectively a try statement without a catch\n\t    // or a finally block) gives us a place to store values thrown from\n\t    // locations where there is no enclosing try statement.\n\t    this.tryEntries = [{ tryLoc: \"root\" }];\n\t    tryLocsList.forEach(pushTryEntry, this);\n\t    this.reset(true);\n\t  }\n\n\t  runtime.keys = function (object) {\n\t    var keys = [];\n\t    for (var key in object) {\n\t      keys.push(key);\n\t    }\n\t    keys.reverse();\n\n\t    // Rather than returning an object with a next method, we keep\n\t    // things simple and return the next function itself.\n\t    return function next() {\n\t      while (keys.length) {\n\t        var key = keys.pop();\n\t        if (key in object) {\n\t          next.value = key;\n\t          next.done = false;\n\t          return next;\n\t        }\n\t      }\n\n\t      // To avoid creating an additional object, we just hang the .value\n\t      // and .done properties off the next function object itself. This\n\t      // also ensures that the minifier will not anonymize the function.\n\t      next.done = true;\n\t      return next;\n\t    };\n\t  };\n\n\t  function values(iterable) {\n\t    if (iterable) {\n\t      var iteratorMethod = iterable[iteratorSymbol];\n\t      if (iteratorMethod) {\n\t        return iteratorMethod.call(iterable);\n\t      }\n\n\t      if (typeof iterable.next === \"function\") {\n\t        return iterable;\n\t      }\n\n\t      if (!isNaN(iterable.length)) {\n\t        var i = -1,\n\t            next = function next() {\n\t          while (++i < iterable.length) {\n\t            if (hasOwn.call(iterable, i)) {\n\t              next.value = iterable[i];\n\t              next.done = false;\n\t              return next;\n\t            }\n\t          }\n\n\t          next.value = undefined;\n\t          next.done = true;\n\n\t          return next;\n\t        };\n\n\t        return next.next = next;\n\t      }\n\t    }\n\n\t    // Return an iterator with no values.\n\t    return { next: doneResult };\n\t  }\n\t  runtime.values = values;\n\n\t  function doneResult() {\n\t    return { value: undefined, done: true };\n\t  }\n\n\t  Context.prototype = {\n\t    constructor: Context,\n\n\t    reset: function reset(skipTempReset) {\n\t      this.prev = 0;\n\t      this.next = 0;\n\t      this.sent = undefined;\n\t      this.done = false;\n\t      this.delegate = null;\n\n\t      this.tryEntries.forEach(resetTryEntry);\n\n\t      if (!skipTempReset) {\n\t        for (var name in this) {\n\t          // Not sure about the optimal order of these conditions:\n\t          if (name.charAt(0) === \"t\" && hasOwn.call(this, name) && !isNaN(+name.slice(1))) {\n\t            this[name] = undefined;\n\t          }\n\t        }\n\t      }\n\t    },\n\n\t    stop: function stop() {\n\t      this.done = true;\n\n\t      var rootEntry = this.tryEntries[0];\n\t      var rootRecord = rootEntry.completion;\n\t      if (rootRecord.type === \"throw\") {\n\t        throw rootRecord.arg;\n\t      }\n\n\t      return this.rval;\n\t    },\n\n\t    dispatchException: function dispatchException(exception) {\n\t      if (this.done) {\n\t        throw exception;\n\t      }\n\n\t      var context = this;\n\t      function handle(loc, caught) {\n\t        record.type = \"throw\";\n\t        record.arg = exception;\n\t        context.next = loc;\n\t        return !!caught;\n\t      }\n\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        var record = entry.completion;\n\n\t        if (entry.tryLoc === \"root\") {\n\t          // Exception thrown outside of any try block that could handle\n\t          // it, so set the completion value of the entire function to\n\t          // throw the exception.\n\t          return handle(\"end\");\n\t        }\n\n\t        if (entry.tryLoc <= this.prev) {\n\t          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n\t          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n\t          if (hasCatch && hasFinally) {\n\t            if (this.prev < entry.catchLoc) {\n\t              return handle(entry.catchLoc, true);\n\t            } else if (this.prev < entry.finallyLoc) {\n\t              return handle(entry.finallyLoc);\n\t            }\n\t          } else if (hasCatch) {\n\t            if (this.prev < entry.catchLoc) {\n\t              return handle(entry.catchLoc, true);\n\t            }\n\t          } else if (hasFinally) {\n\t            if (this.prev < entry.finallyLoc) {\n\t              return handle(entry.finallyLoc);\n\t            }\n\t          } else {\n\t            throw new Error(\"try statement without catch or finally\");\n\t          }\n\t        }\n\t      }\n\t    },\n\n\t    abrupt: function abrupt(type, arg) {\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n\t          var finallyEntry = entry;\n\t          break;\n\t        }\n\t      }\n\n\t      if (finallyEntry && (type === \"break\" || type === \"continue\") && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc) {\n\t        // Ignore the finally entry if control is not jumping to a\n\t        // location outside the try/catch block.\n\t        finallyEntry = null;\n\t      }\n\n\t      var record = finallyEntry ? finallyEntry.completion : {};\n\t      record.type = type;\n\t      record.arg = arg;\n\n\t      if (finallyEntry) {\n\t        this.next = finallyEntry.finallyLoc;\n\t      } else {\n\t        this.complete(record);\n\t      }\n\n\t      return ContinueSentinel;\n\t    },\n\n\t    complete: function complete(record, afterLoc) {\n\t      if (record.type === \"throw\") {\n\t        throw record.arg;\n\t      }\n\n\t      if (record.type === \"break\" || record.type === \"continue\") {\n\t        this.next = record.arg;\n\t      } else if (record.type === \"return\") {\n\t        this.rval = record.arg;\n\t        this.next = \"end\";\n\t      } else if (record.type === \"normal\" && afterLoc) {\n\t        this.next = afterLoc;\n\t      }\n\t    },\n\n\t    finish: function finish(finallyLoc) {\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        if (entry.finallyLoc === finallyLoc) {\n\t          this.complete(entry.completion, entry.afterLoc);\n\t          resetTryEntry(entry);\n\t          return ContinueSentinel;\n\t        }\n\t      }\n\t    },\n\n\t    \"catch\": function _catch(tryLoc) {\n\t      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n\t        var entry = this.tryEntries[i];\n\t        if (entry.tryLoc === tryLoc) {\n\t          var record = entry.completion;\n\t          if (record.type === \"throw\") {\n\t            var thrown = record.arg;\n\t            resetTryEntry(entry);\n\t          }\n\t          return thrown;\n\t        }\n\t      }\n\n\t      // The context.catch method must only be called with a location\n\t      // argument that corresponds to a known catch block.\n\t      throw new Error(\"illegal catch attempt\");\n\t    },\n\n\t    delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n\t      this.delegate = {\n\t        iterator: values(iterable),\n\t        resultName: resultName,\n\t        nextLoc: nextLoc\n\t      };\n\n\t      return ContinueSentinel;\n\t    }\n\t  };\n\t})(\n\t// Among the various tricks for obtaining a reference to the global\n\t// object, this seems to be the most reliable technique that does not\n\t// use indirect eval (which violates Content Security Policy).\n\ttypeof global === \"object\" ? global : typeof window === \"object\" ? window : typeof self === \"object\" ? self : undefined);\n\t/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()), __webpack_require__(56)))\n\n/***/ },\n/* 56 */\n/***/ function(module, exports) {\n\n\t// shim for using process in browser\n\n\tvar process = module.exports = {};\n\tvar queue = [];\n\tvar draining = false;\n\tvar currentQueue;\n\tvar queueIndex = -1;\n\n\tfunction cleanUpNextTick() {\n\t    draining = false;\n\t    if (currentQueue.length) {\n\t        queue = currentQueue.concat(queue);\n\t    } else {\n\t        queueIndex = -1;\n\t    }\n\t    if (queue.length) {\n\t        drainQueue();\n\t    }\n\t}\n\n\tfunction drainQueue() {\n\t    if (draining) {\n\t        return;\n\t    }\n\t    var timeout = setTimeout(cleanUpNextTick);\n\t    draining = true;\n\n\t    var len = queue.length;\n\t    while(len) {\n\t        currentQueue = queue;\n\t        queue = [];\n\t        while (++queueIndex < len) {\n\t            if (currentQueue) {\n\t                currentQueue[queueIndex].run();\n\t            }\n\t        }\n\t        queueIndex = -1;\n\t        len = queue.length;\n\t    }\n\t    currentQueue = null;\n\t    draining = false;\n\t    clearTimeout(timeout);\n\t}\n\n\tprocess.nextTick = function (fun) {\n\t    var args = new Array(arguments.length - 1);\n\t    if (arguments.length > 1) {\n\t        for (var i = 1; i < arguments.length; i++) {\n\t            args[i - 1] = arguments[i];\n\t        }\n\t    }\n\t    queue.push(new Item(fun, args));\n\t    if (queue.length === 1 && !draining) {\n\t        setTimeout(drainQueue, 0);\n\t    }\n\t};\n\n\t// v8 likes predictible objects\n\tfunction Item(fun, array) {\n\t    this.fun = fun;\n\t    this.array = array;\n\t}\n\tItem.prototype.run = function () {\n\t    this.fun.apply(null, this.array);\n\t};\n\tprocess.title = 'browser';\n\tprocess.browser = true;\n\tprocess.env = {};\n\tprocess.argv = [];\n\tprocess.version = ''; // empty string to avoid regexp issues\n\tprocess.versions = {};\n\n\tfunction noop() {}\n\n\tprocess.on = noop;\n\tprocess.addListener = noop;\n\tprocess.once = noop;\n\tprocess.off = noop;\n\tprocess.removeListener = noop;\n\tprocess.removeAllListeners = noop;\n\tprocess.emit = noop;\n\n\tprocess.binding = function (name) {\n\t    throw new Error('process.binding is not supported');\n\t};\n\n\tprocess.cwd = function () { return '/' };\n\tprocess.chdir = function (dir) {\n\t    throw new Error('process.chdir is not supported');\n\t};\n\tprocess.umask = function() { return 0; };\n\n\n/***/ },\n/* 57 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(58), __esModule: true };\n\n/***/ },\n/* 58 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(59);\n\tmodule.exports = __webpack_require__(12).Symbol;\n\n/***/ },\n/* 59 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t// ECMAScript 6 symbols shim\n\tvar $              = __webpack_require__(15)\n\t  , global         = __webpack_require__(11)\n\t  , has            = __webpack_require__(19)\n\t  , SUPPORT_DESC   = __webpack_require__(17)\n\t  , $def           = __webpack_require__(10)\n\t  , $redef         = __webpack_require__(13)\n\t  , $fails         = __webpack_require__(18)\n\t  , shared         = __webpack_require__(21)\n\t  , setTag         = __webpack_require__(25)\n\t  , uid            = __webpack_require__(22)\n\t  , wks            = __webpack_require__(20)\n\t  , keyOf          = __webpack_require__(60)\n\t  , $names         = __webpack_require__(61)\n\t  , enumKeys       = __webpack_require__(62)\n\t  , isObject       = __webpack_require__(32)\n\t  , anObject       = __webpack_require__(31)\n\t  , toIObject      = __webpack_require__(46)\n\t  , createDesc     = __webpack_require__(16)\n\t  , getDesc        = $.getDesc\n\t  , setDesc        = $.setDesc\n\t  , _create        = $.create\n\t  , getNames       = $names.get\n\t  , $Symbol        = global.Symbol\n\t  , setter         = false\n\t  , HIDDEN         = wks('_hidden')\n\t  , isEnum         = $.isEnum\n\t  , SymbolRegistry = shared('symbol-registry')\n\t  , AllSymbols     = shared('symbols')\n\t  , useNative      = typeof $Symbol == 'function'\n\t  , ObjectProto    = Object.prototype;\n\n\t// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\n\tvar setSymbolDesc = SUPPORT_DESC && $fails(function(){\n\t  return _create(setDesc({}, 'a', {\n\t    get: function(){ return setDesc(this, 'a', {value: 7}).a; }\n\t  })).a != 7;\n\t}) ? function(it, key, D){\n\t  var protoDesc = getDesc(ObjectProto, key);\n\t  if(protoDesc)delete ObjectProto[key];\n\t  setDesc(it, key, D);\n\t  if(protoDesc && it !== ObjectProto)setDesc(ObjectProto, key, protoDesc);\n\t} : setDesc;\n\n\tvar wrap = function(tag){\n\t  var sym = AllSymbols[tag] = _create($Symbol.prototype);\n\t  sym._k = tag;\n\t  SUPPORT_DESC && setter && setSymbolDesc(ObjectProto, tag, {\n\t    configurable: true,\n\t    set: function(value){\n\t      if(has(this, HIDDEN) && has(this[HIDDEN], tag))this[HIDDEN][tag] = false;\n\t      setSymbolDesc(this, tag, createDesc(1, value));\n\t    }\n\t  });\n\t  return sym;\n\t};\n\n\tvar $defineProperty = function defineProperty(it, key, D){\n\t  if(D && has(AllSymbols, key)){\n\t    if(!D.enumerable){\n\t      if(!has(it, HIDDEN))setDesc(it, HIDDEN, createDesc(1, {}));\n\t      it[HIDDEN][key] = true;\n\t    } else {\n\t      if(has(it, HIDDEN) && it[HIDDEN][key])it[HIDDEN][key] = false;\n\t      D = _create(D, {enumerable: createDesc(0, false)});\n\t    } return setSymbolDesc(it, key, D);\n\t  } return setDesc(it, key, D);\n\t};\n\tvar $defineProperties = function defineProperties(it, P){\n\t  anObject(it);\n\t  var keys = enumKeys(P = toIObject(P))\n\t    , i    = 0\n\t    , l = keys.length\n\t    , key;\n\t  while(l > i)$defineProperty(it, key = keys[i++], P[key]);\n\t  return it;\n\t};\n\tvar $create = function create(it, P){\n\t  return P === undefined ? _create(it) : $defineProperties(_create(it), P);\n\t};\n\tvar $propertyIsEnumerable = function propertyIsEnumerable(key){\n\t  var E = isEnum.call(this, key);\n\t  return E || !has(this, key) || !has(AllSymbols, key) || has(this, HIDDEN) && this[HIDDEN][key]\n\t    ? E : true;\n\t};\n\tvar $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(it, key){\n\t  var D = getDesc(it = toIObject(it), key);\n\t  if(D && has(AllSymbols, key) && !(has(it, HIDDEN) && it[HIDDEN][key]))D.enumerable = true;\n\t  return D;\n\t};\n\tvar $getOwnPropertyNames = function getOwnPropertyNames(it){\n\t  var names  = getNames(toIObject(it))\n\t    , result = []\n\t    , i      = 0\n\t    , key;\n\t  while(names.length > i)if(!has(AllSymbols, key = names[i++]) && key != HIDDEN)result.push(key);\n\t  return result;\n\t};\n\tvar $getOwnPropertySymbols = function getOwnPropertySymbols(it){\n\t  var names  = getNames(toIObject(it))\n\t    , result = []\n\t    , i      = 0\n\t    , key;\n\t  while(names.length > i)if(has(AllSymbols, key = names[i++]))result.push(AllSymbols[key]);\n\t  return result;\n\t};\n\n\t// 19.4.1.1 Symbol([description])\n\tif(!useNative){\n\t  $Symbol = function Symbol(){\n\t    if(this instanceof $Symbol)throw TypeError('Symbol is not a constructor');\n\t    return wrap(uid(arguments[0]));\n\t  };\n\t  $redef($Symbol.prototype, 'toString', function toString(){\n\t    return this._k;\n\t  });\n\n\t  $.create     = $create;\n\t  $.isEnum     = $propertyIsEnumerable;\n\t  $.getDesc    = $getOwnPropertyDescriptor;\n\t  $.setDesc    = $defineProperty;\n\t  $.setDescs   = $defineProperties;\n\t  $.getNames   = $names.get = $getOwnPropertyNames;\n\t  $.getSymbols = $getOwnPropertySymbols;\n\n\t  if(SUPPORT_DESC && !__webpack_require__(9)){\n\t    $redef(ObjectProto, 'propertyIsEnumerable', $propertyIsEnumerable, true);\n\t  }\n\t}\n\n\t// MS Edge converts symbol values to JSON as {}\n\tif(!useNative || $fails(function(){\n\t  return JSON.stringify([$Symbol()]) != '[null]';\n\t}))$redef($Symbol.prototype, 'toJSON', function toJSON(){\n\t  if(useNative && isObject(this))return this;\n\t});\n\n\tvar symbolStatics = {\n\t  // 19.4.2.1 Symbol.for(key)\n\t  'for': function(key){\n\t    return has(SymbolRegistry, key += '')\n\t      ? SymbolRegistry[key]\n\t      : SymbolRegistry[key] = $Symbol(key);\n\t  },\n\t  // 19.4.2.5 Symbol.keyFor(sym)\n\t  keyFor: function keyFor(key){\n\t    return keyOf(SymbolRegistry, key);\n\t  },\n\t  useSetter: function(){ setter = true; },\n\t  useSimple: function(){ setter = false; }\n\t};\n\t// 19.4.2.2 Symbol.hasInstance\n\t// 19.4.2.3 Symbol.isConcatSpreadable\n\t// 19.4.2.4 Symbol.iterator\n\t// 19.4.2.6 Symbol.match\n\t// 19.4.2.8 Symbol.replace\n\t// 19.4.2.9 Symbol.search\n\t// 19.4.2.10 Symbol.species\n\t// 19.4.2.11 Symbol.split\n\t// 19.4.2.12 Symbol.toPrimitive\n\t// 19.4.2.13 Symbol.toStringTag\n\t// 19.4.2.14 Symbol.unscopables\n\t$.each.call((\n\t    'hasInstance,isConcatSpreadable,iterator,match,replace,search,' +\n\t    'species,split,toPrimitive,toStringTag,unscopables'\n\t  ).split(','), function(it){\n\t    var sym = wks(it);\n\t    symbolStatics[it] = useNative ? sym : wrap(sym);\n\t  }\n\t);\n\n\tsetter = true;\n\n\t$def($def.G + $def.W, {Symbol: $Symbol});\n\n\t$def($def.S, 'Symbol', symbolStatics);\n\n\t$def($def.S + $def.F * !useNative, 'Object', {\n\t  // 19.1.2.2 Object.create(O [, Properties])\n\t  create: $create,\n\t  // 19.1.2.4 Object.defineProperty(O, P, Attributes)\n\t  defineProperty: $defineProperty,\n\t  // 19.1.2.3 Object.defineProperties(O, Properties)\n\t  defineProperties: $defineProperties,\n\t  // 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\n\t  getOwnPropertyDescriptor: $getOwnPropertyDescriptor,\n\t  // 19.1.2.7 Object.getOwnPropertyNames(O)\n\t  getOwnPropertyNames: $getOwnPropertyNames,\n\t  // 19.1.2.8 Object.getOwnPropertySymbols(O)\n\t  getOwnPropertySymbols: $getOwnPropertySymbols\n\t});\n\n\t// 19.4.3.5 Symbol.prototype[@@toStringTag]\n\tsetTag($Symbol, 'Symbol');\n\t// 20.2.1.9 Math[@@toStringTag]\n\tsetTag(Math, 'Math', true);\n\t// 24.3.3 JSON[@@toStringTag]\n\tsetTag(global.JSON, 'JSON', true);\n\n/***/ },\n/* 60 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $         = __webpack_require__(15)\n\t  , toIObject = __webpack_require__(46);\n\tmodule.exports = function(object, el){\n\t  var O      = toIObject(object)\n\t    , keys   = $.getKeys(O)\n\t    , length = keys.length\n\t    , index  = 0\n\t    , key;\n\t  while(length > index)if(O[key = keys[index++]] === el)return key;\n\t};\n\n/***/ },\n/* 61 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\n\tvar toString  = {}.toString\n\t  , toIObject = __webpack_require__(46)\n\t  , getNames  = __webpack_require__(15).getNames;\n\n\tvar windowNames = typeof window == 'object' && Object.getOwnPropertyNames\n\t  ? Object.getOwnPropertyNames(window) : [];\n\n\tvar getWindowNames = function(it){\n\t  try {\n\t    return getNames(it);\n\t  } catch(e){\n\t    return windowNames.slice();\n\t  }\n\t};\n\n\tmodule.exports.get = function getOwnPropertyNames(it){\n\t  if(windowNames && toString.call(it) == '[object Window]')return getWindowNames(it);\n\t  return getNames(toIObject(it));\n\t};\n\n/***/ },\n/* 62 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// all enumerable object keys, includes symbols\n\tvar $ = __webpack_require__(15);\n\tmodule.exports = function(it){\n\t  var keys       = $.getKeys(it)\n\t    , getSymbols = $.getSymbols;\n\t  if(getSymbols){\n\t    var symbols = getSymbols(it)\n\t      , isEnum  = $.isEnum\n\t      , i       = 0\n\t      , key;\n\t    while(symbols.length > i)if(isEnum.call(it, key = symbols[i++]))keys.push(key);\n\t  }\n\t  return keys;\n\t};\n\n/***/ },\n/* 63 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(64), __esModule: true };\n\n/***/ },\n/* 64 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $ = __webpack_require__(15);\n\tmodule.exports = function create(P, D){\n\t  return $.create(P, D);\n\t};\n\n/***/ },\n/* 65 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(66), __esModule: true };\n\n/***/ },\n/* 66 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(67);\n\t__webpack_require__(4);\n\t__webpack_require__(42);\n\t__webpack_require__(68);\n\tmodule.exports = __webpack_require__(12).Promise;\n\n/***/ },\n/* 67 */\n/***/ function(module, exports) {\n\n\t\n\n/***/ },\n/* 68 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $          = __webpack_require__(15)\n\t  , LIBRARY    = __webpack_require__(9)\n\t  , global     = __webpack_require__(11)\n\t  , ctx        = __webpack_require__(27)\n\t  , classof    = __webpack_require__(36)\n\t  , $def       = __webpack_require__(10)\n\t  , isObject   = __webpack_require__(32)\n\t  , anObject   = __webpack_require__(31)\n\t  , aFunction  = __webpack_require__(28)\n\t  , strictNew  = __webpack_require__(69)\n\t  , forOf      = __webpack_require__(70)\n\t  , setProto   = __webpack_require__(71).set\n\t  , same       = __webpack_require__(72)\n\t  , species    = __webpack_require__(73)\n\t  , SPECIES    = __webpack_require__(20)('species')\n\t  , RECORD     = __webpack_require__(22)('record')\n\t  , asap       = __webpack_require__(74)\n\t  , PROMISE    = 'Promise'\n\t  , process    = global.process\n\t  , isNode     = classof(process) == 'process'\n\t  , P          = global[PROMISE]\n\t  , Wrapper;\n\n\tvar testResolve = function(sub){\n\t  var test = new P(function(){});\n\t  if(sub)test.constructor = Object;\n\t  return P.resolve(test) === test;\n\t};\n\n\tvar useNative = function(){\n\t  var works = false;\n\t  function P2(x){\n\t    var self = new P(x);\n\t    setProto(self, P2.prototype);\n\t    return self;\n\t  }\n\t  try {\n\t    works = P && P.resolve && testResolve();\n\t    setProto(P2, P);\n\t    P2.prototype = $.create(P.prototype, {constructor: {value: P2}});\n\t    // actual Firefox has broken subclass support, test that\n\t    if(!(P2.resolve(5).then(function(){}) instanceof P2)){\n\t      works = false;\n\t    }\n\t    // actual V8 bug, https://code.google.com/p/v8/issues/detail?id=4162\n\t    if(works && __webpack_require__(17)){\n\t      var thenableThenGotten = false;\n\t      P.resolve($.setDesc({}, 'then', {\n\t        get: function(){ thenableThenGotten = true; }\n\t      }));\n\t      works = thenableThenGotten;\n\t    }\n\t  } catch(e){ works = false; }\n\t  return works;\n\t}();\n\n\t// helpers\n\tvar isPromise = function(it){\n\t  return isObject(it) && (useNative ? classof(it) == 'Promise' : RECORD in it);\n\t};\n\tvar sameConstructor = function(a, b){\n\t  // library wrapper special case\n\t  if(LIBRARY && a === P && b === Wrapper)return true;\n\t  return same(a, b);\n\t};\n\tvar getConstructor = function(C){\n\t  var S = anObject(C)[SPECIES];\n\t  return S != undefined ? S : C;\n\t};\n\tvar isThenable = function(it){\n\t  var then;\n\t  return isObject(it) && typeof (then = it.then) == 'function' ? then : false;\n\t};\n\tvar notify = function(record, isReject){\n\t  if(record.n)return;\n\t  record.n = true;\n\t  var chain = record.c;\n\t  asap(function(){\n\t    var value = record.v\n\t      , ok    = record.s == 1\n\t      , i     = 0;\n\t    var run = function(react){\n\t      var cb = ok ? react.ok : react.fail\n\t        , ret, then;\n\t      try {\n\t        if(cb){\n\t          if(!ok)record.h = true;\n\t          ret = cb === true ? value : cb(value);\n\t          if(ret === react.P){\n\t            react.rej(TypeError('Promise-chain cycle'));\n\t          } else if(then = isThenable(ret)){\n\t            then.call(ret, react.res, react.rej);\n\t          } else react.res(ret);\n\t        } else react.rej(value);\n\t      } catch(err){\n\t        react.rej(err);\n\t      }\n\t    };\n\t    while(chain.length > i)run(chain[i++]); // variable length - can't use forEach\n\t    chain.length = 0;\n\t    record.n = false;\n\t    if(isReject)setTimeout(function(){\n\t      var promise = record.p\n\t        , handler, console;\n\t      if(isUnhandled(promise)){\n\t        if(isNode){\n\t          process.emit('unhandledRejection', value, promise);\n\t        } else if(handler = global.onunhandledrejection){\n\t          handler({promise: promise, reason: value});\n\t        } else if((console = global.console) && console.error){\n\t          console.error('Unhandled promise rejection', value);\n\t        }\n\t      } record.a = undefined;\n\t    }, 1);\n\t  });\n\t};\n\tvar isUnhandled = function(promise){\n\t  var record = promise[RECORD]\n\t    , chain  = record.a || record.c\n\t    , i      = 0\n\t    , react;\n\t  if(record.h)return false;\n\t  while(chain.length > i){\n\t    react = chain[i++];\n\t    if(react.fail || !isUnhandled(react.P))return false;\n\t  } return true;\n\t};\n\tvar $reject = function(value){\n\t  var record = this;\n\t  if(record.d)return;\n\t  record.d = true;\n\t  record = record.r || record; // unwrap\n\t  record.v = value;\n\t  record.s = 2;\n\t  record.a = record.c.slice();\n\t  notify(record, true);\n\t};\n\tvar $resolve = function(value){\n\t  var record = this\n\t    , then;\n\t  if(record.d)return;\n\t  record.d = true;\n\t  record = record.r || record; // unwrap\n\t  try {\n\t    if(then = isThenable(value)){\n\t      asap(function(){\n\t        var wrapper = {r: record, d: false}; // wrap\n\t        try {\n\t          then.call(value, ctx($resolve, wrapper, 1), ctx($reject, wrapper, 1));\n\t        } catch(e){\n\t          $reject.call(wrapper, e);\n\t        }\n\t      });\n\t    } else {\n\t      record.v = value;\n\t      record.s = 1;\n\t      notify(record, false);\n\t    }\n\t  } catch(e){\n\t    $reject.call({r: record, d: false}, e); // wrap\n\t  }\n\t};\n\n\t// constructor polyfill\n\tif(!useNative){\n\t  // 25.4.3.1 Promise(executor)\n\t  P = function Promise(executor){\n\t    aFunction(executor);\n\t    var record = {\n\t      p: strictNew(this, P, PROMISE),         // <- promise\n\t      c: [],                                  // <- awaiting reactions\n\t      a: undefined,                           // <- checked in isUnhandled reactions\n\t      s: 0,                                   // <- state\n\t      d: false,                               // <- done\n\t      v: undefined,                           // <- value\n\t      h: false,                               // <- handled rejection\n\t      n: false                                // <- notify\n\t    };\n\t    this[RECORD] = record;\n\t    try {\n\t      executor(ctx($resolve, record, 1), ctx($reject, record, 1));\n\t    } catch(err){\n\t      $reject.call(record, err);\n\t    }\n\t  };\n\t  __webpack_require__(79)(P.prototype, {\n\t    // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\n\t    then: function then(onFulfilled, onRejected){\n\t      var S = anObject(anObject(this).constructor)[SPECIES];\n\t      var react = {\n\t        ok:   typeof onFulfilled == 'function' ? onFulfilled : true,\n\t        fail: typeof onRejected == 'function'  ? onRejected  : false\n\t      };\n\t      var promise = react.P = new (S != undefined ? S : P)(function(res, rej){\n\t        react.res = res;\n\t        react.rej = rej;\n\t      });\n\t      aFunction(react.res);\n\t      aFunction(react.rej);\n\t      var record = this[RECORD];\n\t      record.c.push(react);\n\t      if(record.a)record.a.push(react);\n\t      if(record.s)notify(record, false);\n\t      return promise;\n\t    },\n\t    // 25.4.5.1 Promise.prototype.catch(onRejected)\n\t    'catch': function(onRejected){\n\t      return this.then(undefined, onRejected);\n\t    }\n\t  });\n\t}\n\n\t// export\n\t$def($def.G + $def.W + $def.F * !useNative, {Promise: P});\n\t__webpack_require__(25)(P, PROMISE);\n\tspecies(P);\n\tspecies(Wrapper = __webpack_require__(12)[PROMISE]);\n\n\t// statics\n\t$def($def.S + $def.F * !useNative, PROMISE, {\n\t  // 25.4.4.5 Promise.reject(r)\n\t  reject: function reject(r){\n\t    return new this(function(res, rej){ rej(r); });\n\t  }\n\t});\n\t$def($def.S + $def.F * (!useNative || testResolve(true)), PROMISE, {\n\t  // 25.4.4.6 Promise.resolve(x)\n\t  resolve: function resolve(x){\n\t    return isPromise(x) && sameConstructor(x.constructor, this)\n\t      ? x : new this(function(res){ res(x); });\n\t  }\n\t});\n\t$def($def.S + $def.F * !(useNative && __webpack_require__(38)(function(iter){\n\t  P.all(iter)['catch'](function(){});\n\t})), PROMISE, {\n\t  // 25.4.4.1 Promise.all(iterable)\n\t  all: function all(iterable){\n\t    var C      = getConstructor(this)\n\t      , values = [];\n\t    return new C(function(res, rej){\n\t      forOf(iterable, false, values.push, values);\n\t      var remaining = values.length\n\t        , results   = Array(remaining);\n\t      if(remaining)$.each.call(values, function(promise, index){\n\t        C.resolve(promise).then(function(value){\n\t          results[index] = value;\n\t          --remaining || res(results);\n\t        }, rej);\n\t      });\n\t      else res(results);\n\t    });\n\t  },\n\t  // 25.4.4.4 Promise.race(iterable)\n\t  race: function race(iterable){\n\t    var C = getConstructor(this);\n\t    return new C(function(res, rej){\n\t      forOf(iterable, false, function(promise){\n\t        C.resolve(promise).then(res, rej);\n\t      });\n\t    });\n\t  }\n\t});\n\n/***/ },\n/* 69 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(it, Constructor, name){\n\t  if(!(it instanceof Constructor))throw TypeError(name + \": use the 'new' operator!\");\n\t  return it;\n\t};\n\n/***/ },\n/* 70 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar ctx         = __webpack_require__(27)\n\t  , call        = __webpack_require__(30)\n\t  , isArrayIter = __webpack_require__(33)\n\t  , anObject    = __webpack_require__(31)\n\t  , toLength    = __webpack_require__(34)\n\t  , getIterFn   = __webpack_require__(35);\n\tmodule.exports = function(iterable, entries, fn, that){\n\t  var iterFn = getIterFn(iterable)\n\t    , f      = ctx(fn, that, entries ? 2 : 1)\n\t    , index  = 0\n\t    , length, step, iterator;\n\t  if(typeof iterFn != 'function')throw TypeError(iterable + ' is not iterable!');\n\t  // fast case for arrays with default iterator\n\t  if(isArrayIter(iterFn))for(length = toLength(iterable.length); length > index; index++){\n\t    entries ? f(anObject(step = iterable[index])[0], step[1]) : f(iterable[index]);\n\t  } else for(iterator = iterFn.call(iterable); !(step = iterator.next()).done; ){\n\t    call(iterator, f, step.value, entries);\n\t  }\n\t};\n\n/***/ },\n/* 71 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// Works with __proto__ only. Old v8 can't work with null proto objects.\n\t/* eslint-disable no-proto */\n\tvar getDesc  = __webpack_require__(15).getDesc\n\t  , isObject = __webpack_require__(32)\n\t  , anObject = __webpack_require__(31);\n\tvar check = function(O, proto){\n\t  anObject(O);\n\t  if(!isObject(proto) && proto !== null)throw TypeError(proto + \": can't set as prototype!\");\n\t};\n\tmodule.exports = {\n\t  set: Object.setPrototypeOf || ('__proto__' in {} ? // eslint-disable-line no-proto\n\t    function(test, buggy, set){\n\t      try {\n\t        set = __webpack_require__(27)(Function.call, getDesc(Object.prototype, '__proto__').set, 2);\n\t        set(test, []);\n\t        buggy = !(test instanceof Array);\n\t      } catch(e){ buggy = true; }\n\t      return function setPrototypeOf(O, proto){\n\t        check(O, proto);\n\t        if(buggy)O.__proto__ = proto;\n\t        else set(O, proto);\n\t        return O;\n\t      };\n\t    }({}, false) : undefined),\n\t  check: check\n\t};\n\n/***/ },\n/* 72 */\n/***/ function(module, exports) {\n\n\tmodule.exports = Object.is || function is(x, y){\n\t  return x === y ? x !== 0 || 1 / x === 1 / y : x != x && y != y;\n\t};\n\n/***/ },\n/* 73 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $       = __webpack_require__(15)\n\t  , SPECIES = __webpack_require__(20)('species');\n\tmodule.exports = function(C){\n\t  if(__webpack_require__(17) && !(SPECIES in C))$.setDesc(C, SPECIES, {\n\t    configurable: true,\n\t    get: function(){ return this; }\n\t  });\n\t};\n\n/***/ },\n/* 74 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar global    = __webpack_require__(11)\r\n\t  , macrotask = __webpack_require__(75).set\r\n\t  , Observer  = global.MutationObserver || global.WebKitMutationObserver\r\n\t  , process   = global.process\r\n\t  , isNode    = __webpack_require__(37)(process) == 'process'\r\n\t  , head, last, notify;\r\n\r\n\tvar flush = function(){\r\n\t  var parent, domain;\r\n\t  if(isNode && (parent = process.domain)){\r\n\t    process.domain = null;\r\n\t    parent.exit();\r\n\t  }\r\n\t  while(head){\r\n\t    domain = head.domain;\r\n\t    if(domain)domain.enter();\r\n\t    head.fn.call(); // <- currently we use it only for Promise - try / catch not required\r\n\t    if(domain)domain.exit();\r\n\t    head = head.next;\r\n\t  } last = undefined;\r\n\t  if(parent)parent.enter();\r\n\t}\r\n\r\n\t// Node.js\r\n\tif(isNode){\r\n\t  notify = function(){\r\n\t    process.nextTick(flush);\r\n\t  };\r\n\t// browsers with MutationObserver\r\n\t} else if(Observer){\r\n\t  var toggle = 1\r\n\t    , node   = document.createTextNode('');\r\n\t  new Observer(flush).observe(node, {characterData: true}); // eslint-disable-line no-new\r\n\t  notify = function(){\r\n\t    node.data = toggle = -toggle;\r\n\t  };\r\n\t// for other environments - macrotask based on:\r\n\t// - setImmediate\r\n\t// - MessageChannel\r\n\t// - window.postMessag\r\n\t// - onreadystatechange\r\n\t// - setTimeout\r\n\t} else {\r\n\t  notify = function(){\r\n\t    // strange IE + webpack dev server bug - use .call(global)\r\n\t    macrotask.call(global, flush);\r\n\t  };\r\n\t}\r\n\r\n\tmodule.exports = function asap(fn){\r\n\t  var task = {fn: fn, next: undefined, domain: isNode && process.domain};\r\n\t  if(last)last.next = task;\r\n\t  if(!head){\r\n\t    head = task;\r\n\t    notify();\r\n\t  } last = task;\r\n\t};\n\n/***/ },\n/* 75 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar ctx                = __webpack_require__(27)\n\t  , invoke             = __webpack_require__(76)\n\t  , html               = __webpack_require__(77)\n\t  , cel                = __webpack_require__(78)\n\t  , global             = __webpack_require__(11)\n\t  , process            = global.process\n\t  , setTask            = global.setImmediate\n\t  , clearTask          = global.clearImmediate\n\t  , MessageChannel     = global.MessageChannel\n\t  , counter            = 0\n\t  , queue              = {}\n\t  , ONREADYSTATECHANGE = 'onreadystatechange'\n\t  , defer, channel, port;\n\tvar run = function(){\n\t  var id = +this;\n\t  if(queue.hasOwnProperty(id)){\n\t    var fn = queue[id];\n\t    delete queue[id];\n\t    fn();\n\t  }\n\t};\n\tvar listner = function(event){\n\t  run.call(event.data);\n\t};\n\t// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\n\tif(!setTask || !clearTask){\n\t  setTask = function setImmediate(fn){\n\t    var args = [], i = 1;\n\t    while(arguments.length > i)args.push(arguments[i++]);\n\t    queue[++counter] = function(){\n\t      invoke(typeof fn == 'function' ? fn : Function(fn), args);\n\t    };\n\t    defer(counter);\n\t    return counter;\n\t  };\n\t  clearTask = function clearImmediate(id){\n\t    delete queue[id];\n\t  };\n\t  // Node.js 0.8-\n\t  if(__webpack_require__(37)(process) == 'process'){\n\t    defer = function(id){\n\t      process.nextTick(ctx(run, id, 1));\n\t    };\n\t  // Browsers with MessageChannel, includes WebWorkers\n\t  } else if(MessageChannel){\n\t    channel = new MessageChannel;\n\t    port    = channel.port2;\n\t    channel.port1.onmessage = listner;\n\t    defer = ctx(port.postMessage, port, 1);\n\t  // Browsers with postMessage, skip WebWorkers\n\t  // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n\t  } else if(global.addEventListener && typeof postMessage == 'function' && !global.importScript){\n\t    defer = function(id){\n\t      global.postMessage(id + '', '*');\n\t    };\n\t    global.addEventListener('message', listner, false);\n\t  // IE8-\n\t  } else if(ONREADYSTATECHANGE in cel('script')){\n\t    defer = function(id){\n\t      html.appendChild(cel('script'))[ONREADYSTATECHANGE] = function(){\n\t        html.removeChild(this);\n\t        run.call(id);\n\t      };\n\t    };\n\t  // Rest old browsers\n\t  } else {\n\t    defer = function(id){\n\t      setTimeout(ctx(run, id, 1), 0);\n\t    };\n\t  }\n\t}\n\tmodule.exports = {\n\t  set:   setTask,\n\t  clear: clearTask\n\t};\n\n/***/ },\n/* 76 */\n/***/ function(module, exports) {\n\n\t// fast apply, http://jsperf.lnkit.com/fast-apply/5\n\tmodule.exports = function(fn, args, that){\n\t  var un = that === undefined;\n\t  switch(args.length){\n\t    case 0: return un ? fn()\n\t                      : fn.call(that);\n\t    case 1: return un ? fn(args[0])\n\t                      : fn.call(that, args[0]);\n\t    case 2: return un ? fn(args[0], args[1])\n\t                      : fn.call(that, args[0], args[1]);\n\t    case 3: return un ? fn(args[0], args[1], args[2])\n\t                      : fn.call(that, args[0], args[1], args[2]);\n\t    case 4: return un ? fn(args[0], args[1], args[2], args[3])\n\t                      : fn.call(that, args[0], args[1], args[2], args[3]);\n\t  } return              fn.apply(that, args);\n\t};\n\n/***/ },\n/* 77 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(11).document && document.documentElement;\n\n/***/ },\n/* 78 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar isObject = __webpack_require__(32)\n\t  , document = __webpack_require__(11).document\n\t  // in old IE typeof document.createElement is 'object'\n\t  , is = isObject(document) && isObject(document.createElement);\n\tmodule.exports = function(it){\n\t  return is ? document.createElement(it) : {};\n\t};\n\n/***/ },\n/* 79 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tvar $redef = __webpack_require__(13);\n\tmodule.exports = function(target, src){\n\t  for(var key in src)$redef(target, key, src[key]);\n\t  return target;\n\t};\n\n/***/ },\n/* 80 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(81), __esModule: true };\n\n/***/ },\n/* 81 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(82);\n\tmodule.exports = __webpack_require__(12).Object.keys;\n\n/***/ },\n/* 82 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// 19.1.2.14 Object.keys(O)\n\tvar toObject = __webpack_require__(29);\n\n\t__webpack_require__(83)('keys', function($keys){\n\t  return function keys(it){\n\t    return $keys(toObject(it));\n\t  };\n\t});\n\n/***/ },\n/* 83 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// most Object methods by ES6 should accept primitives\n\tmodule.exports = function(KEY, exec){\n\t  var $def = __webpack_require__(10)\n\t    , fn   = (__webpack_require__(12).Object || {})[KEY] || Object[KEY]\n\t    , exp  = {};\n\t  exp[KEY] = exec(fn);\n\t  $def($def.S + $def.F * __webpack_require__(18)(function(){ fn(1); }), 'Object', exp);\n\t};\n\n/***/ },\n/* 84 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = { \"default\": __webpack_require__(85), __esModule: true };\n\n/***/ },\n/* 85 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t__webpack_require__(67);\n\t__webpack_require__(4);\n\t__webpack_require__(42);\n\t__webpack_require__(86);\n\t__webpack_require__(89);\n\tmodule.exports = __webpack_require__(12).Set;\n\n/***/ },\n/* 86 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar strong = __webpack_require__(87);\n\n\t// 23.2 Set Objects\n\t__webpack_require__(88)('Set', function(get){\n\t  return function Set(){ return get(this, arguments[0]); };\n\t}, {\n\t  // 23.2.3.1 Set.prototype.add(value)\n\t  add: function add(value){\n\t    return strong.def(this, value = value === 0 ? 0 : value, value);\n\t  }\n\t}, strong);\n\n/***/ },\n/* 87 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $            = __webpack_require__(15)\n\t  , hide         = __webpack_require__(14)\n\t  , ctx          = __webpack_require__(27)\n\t  , species      = __webpack_require__(73)\n\t  , strictNew    = __webpack_require__(69)\n\t  , defined      = __webpack_require__(7)\n\t  , forOf        = __webpack_require__(70)\n\t  , step         = __webpack_require__(45)\n\t  , ID           = __webpack_require__(22)('id')\n\t  , $has         = __webpack_require__(19)\n\t  , isObject     = __webpack_require__(32)\n\t  , isExtensible = Object.isExtensible || isObject\n\t  , SUPPORT_DESC = __webpack_require__(17)\n\t  , SIZE         = SUPPORT_DESC ? '_s' : 'size'\n\t  , id           = 0;\n\n\tvar fastKey = function(it, create){\n\t  // return primitive with prefix\n\t  if(!isObject(it))return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;\n\t  if(!$has(it, ID)){\n\t    // can't set id to frozen object\n\t    if(!isExtensible(it))return 'F';\n\t    // not necessary to add id\n\t    if(!create)return 'E';\n\t    // add missing object id\n\t    hide(it, ID, ++id);\n\t  // return object id with prefix\n\t  } return 'O' + it[ID];\n\t};\n\n\tvar getEntry = function(that, key){\n\t  // fast case\n\t  var index = fastKey(key), entry;\n\t  if(index !== 'F')return that._i[index];\n\t  // frozen object case\n\t  for(entry = that._f; entry; entry = entry.n){\n\t    if(entry.k == key)return entry;\n\t  }\n\t};\n\n\tmodule.exports = {\n\t  getConstructor: function(wrapper, NAME, IS_MAP, ADDER){\n\t    var C = wrapper(function(that, iterable){\n\t      strictNew(that, C, NAME);\n\t      that._i = $.create(null); // index\n\t      that._f = undefined;      // first entry\n\t      that._l = undefined;      // last entry\n\t      that[SIZE] = 0;           // size\n\t      if(iterable != undefined)forOf(iterable, IS_MAP, that[ADDER], that);\n\t    });\n\t    __webpack_require__(79)(C.prototype, {\n\t      // 23.1.3.1 Map.prototype.clear()\n\t      // 23.2.3.2 Set.prototype.clear()\n\t      clear: function clear(){\n\t        for(var that = this, data = that._i, entry = that._f; entry; entry = entry.n){\n\t          entry.r = true;\n\t          if(entry.p)entry.p = entry.p.n = undefined;\n\t          delete data[entry.i];\n\t        }\n\t        that._f = that._l = undefined;\n\t        that[SIZE] = 0;\n\t      },\n\t      // 23.1.3.3 Map.prototype.delete(key)\n\t      // 23.2.3.4 Set.prototype.delete(value)\n\t      'delete': function(key){\n\t        var that  = this\n\t          , entry = getEntry(that, key);\n\t        if(entry){\n\t          var next = entry.n\n\t            , prev = entry.p;\n\t          delete that._i[entry.i];\n\t          entry.r = true;\n\t          if(prev)prev.n = next;\n\t          if(next)next.p = prev;\n\t          if(that._f == entry)that._f = next;\n\t          if(that._l == entry)that._l = prev;\n\t          that[SIZE]--;\n\t        } return !!entry;\n\t      },\n\t      // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\n\t      // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\n\t      forEach: function forEach(callbackfn /*, that = undefined */){\n\t        var f = ctx(callbackfn, arguments[1], 3)\n\t          , entry;\n\t        while(entry = entry ? entry.n : this._f){\n\t          f(entry.v, entry.k, this);\n\t          // revert to the last existing entry\n\t          while(entry && entry.r)entry = entry.p;\n\t        }\n\t      },\n\t      // 23.1.3.7 Map.prototype.has(key)\n\t      // 23.2.3.7 Set.prototype.has(value)\n\t      has: function has(key){\n\t        return !!getEntry(this, key);\n\t      }\n\t    });\n\t    if(SUPPORT_DESC)$.setDesc(C.prototype, 'size', {\n\t      get: function(){\n\t        return defined(this[SIZE]);\n\t      }\n\t    });\n\t    return C;\n\t  },\n\t  def: function(that, key, value){\n\t    var entry = getEntry(that, key)\n\t      , prev, index;\n\t    // change existing entry\n\t    if(entry){\n\t      entry.v = value;\n\t    // create new entry\n\t    } else {\n\t      that._l = entry = {\n\t        i: index = fastKey(key, true), // <- index\n\t        k: key,                        // <- key\n\t        v: value,                      // <- value\n\t        p: prev = that._l,             // <- previous entry\n\t        n: undefined,                  // <- next entry\n\t        r: false                       // <- removed\n\t      };\n\t      if(!that._f)that._f = entry;\n\t      if(prev)prev.n = entry;\n\t      that[SIZE]++;\n\t      // add to index\n\t      if(index !== 'F')that._i[index] = entry;\n\t    } return that;\n\t  },\n\t  getEntry: getEntry,\n\t  setStrong: function(C, NAME, IS_MAP){\n\t    // add .keys, .values, .entries, [@@iterator]\n\t    // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11\n\t    __webpack_require__(8)(C, NAME, function(iterated, kind){\n\t      this._t = iterated;  // target\n\t      this._k = kind;      // kind\n\t      this._l = undefined; // previous\n\t    }, function(){\n\t      var that  = this\n\t        , kind  = that._k\n\t        , entry = that._l;\n\t      // revert to the last existing entry\n\t      while(entry && entry.r)entry = entry.p;\n\t      // get next entry\n\t      if(!that._t || !(that._l = entry = entry ? entry.n : that._t._f)){\n\t        // or finish the iteration\n\t        that._t = undefined;\n\t        return step(1);\n\t      }\n\t      // return step by kind\n\t      if(kind == 'keys'  )return step(0, entry.k);\n\t      if(kind == 'values')return step(0, entry.v);\n\t      return step(0, [entry.k, entry.v]);\n\t    }, IS_MAP ? 'entries' : 'values' , !IS_MAP, true);\n\n\t    // add [@@species], 23.1.2.2, 23.2.2.2\n\t    species(C);\n\t    species(__webpack_require__(12)[NAME]); // for wrapper\n\t  }\n\t};\n\n/***/ },\n/* 88 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\tvar $          = __webpack_require__(15)\n\t  , $def       = __webpack_require__(10)\n\t  , hide       = __webpack_require__(14)\n\t  , forOf      = __webpack_require__(70)\n\t  , strictNew  = __webpack_require__(69);\n\n\tmodule.exports = function(NAME, wrapper, methods, common, IS_MAP, IS_WEAK){\n\t  var Base  = __webpack_require__(11)[NAME]\n\t    , C     = Base\n\t    , ADDER = IS_MAP ? 'set' : 'add'\n\t    , proto = C && C.prototype\n\t    , O     = {};\n\t  if(!__webpack_require__(17) || typeof C != 'function'\n\t    || !(IS_WEAK || proto.forEach && !__webpack_require__(18)(function(){ new C().entries().next(); }))\n\t  ){\n\t    // create collection constructor\n\t    C = common.getConstructor(wrapper, NAME, IS_MAP, ADDER);\n\t    __webpack_require__(79)(C.prototype, methods);\n\t  } else {\n\t    C = wrapper(function(target, iterable){\n\t      strictNew(target, C, NAME);\n\t      target._c = new Base;\n\t      if(iterable != undefined)forOf(iterable, IS_MAP, target[ADDER], target);\n\t    });\n\t    $.each.call('add,clear,delete,forEach,get,has,set,keys,values,entries'.split(','),function(KEY){\n\t      var chain = KEY == 'add' || KEY == 'set';\n\t      if(KEY in proto && !(IS_WEAK && KEY == 'clear'))hide(C.prototype, KEY, function(a, b){\n\t        var result = this._c[KEY](a === 0 ? 0 : a, b);\n\t        return chain ? this : result;\n\t      });\n\t    });\n\t    if('size' in proto)$.setDesc(C.prototype, 'size', {\n\t      get: function(){\n\t        return this._c.size;\n\t      }\n\t    });\n\t  }\n\n\t  __webpack_require__(25)(C, NAME);\n\n\t  O[NAME] = C;\n\t  $def($def.G + $def.W + $def.F, O);\n\n\t  if(!IS_WEAK)common.setStrong(C, NAME, IS_MAP);\n\n\t  return C;\n\t};\n\n/***/ },\n/* 89 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// https://github.com/DavidBruant/Map-Set.prototype.toJSON\n\tvar $def  = __webpack_require__(10);\n\n\t$def($def.P, 'Set', {toJSON: __webpack_require__(90)('Set')});\n\n/***/ },\n/* 90 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// https://github.com/DavidBruant/Map-Set.prototype.toJSON\n\tvar forOf   = __webpack_require__(70)\n\t  , classof = __webpack_require__(36);\n\tmodule.exports = function(NAME){\n\t  return function toJSON(){\n\t    if(classof(this) != NAME)throw TypeError(NAME + \"#toJSON isn't generic\");\n\t    var arr = [];\n\t    forOf(this, false, arr.push, arr);\n\t    return arr;\n\t  };\n\t};\n\n/***/ }\n/******/ ])\n});\n;","module.exports = DG;","module.exports = grok;","module.exports = rxjs;","module.exports = ui;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + chunkId + \".js\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) scriptUrl = scripts[scripts.length - 1].src\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = document.baseURI || self.location.href;\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t\"package\": 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// no jsonp function","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\n/* Do not change these import lines to match external modules in webpack configuration */\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nexport const _package = new DG.Package();\nimport { WebLogo } from '@datagrok-libraries/bio/src/viewers/web-logo';\nimport { VdRegionsViewer } from './viewers/vd-regions-viewer';\nimport { runKalign } from './utils/multiple-sequence-alignment';\nimport { SequenceAlignment } from './seq_align';\nimport { convert } from './utils/convert';\nimport { getEmbeddingColsNames, sequenceSpace } from './utils/sequence-space';\nimport { getActivityCliffs } from '@datagrok-libraries/ml/src/viewers/activity-cliffs';\nimport { sequenceGetSimilarities, drawTooltip } from './utils/sequence-activity-cliffs';\nimport { getMolfilesFromSeq, HELM_CORE_LIB_FILENAME } from './utils/utils';\nimport { getMacroMol } from './utils/atomic-works';\nimport { MacromoleculeSequenceCellRenderer } from './utils/cell-renderer';\n//tags: init\nexport function initBio() {\n    return __awaiter(this, void 0, void 0, function* () {\n        // apparently HELMWebEditor requires dojo to be initialized first\n        return new Promise((resolve, reject) => {\n            // @ts-ignore\n            dojo.ready(function () { resolve(null); });\n        });\n    });\n}\n//name: macromoleculeSequenceCellRenderer\n//tags: cellRenderer\n//meta.cellType: Macromolecule\n//output: grid_cell_renderer result\nexport function macromoleculeSequenceCellRenderer() {\n    return new MacromoleculeSequenceCellRenderer();\n}\nfunction checkInputColumn(col, name, allowedNotations = [], allowedAlphabets = []) {\n    const units = col.getTag(DG.TAGS.UNITS);\n    if (col.semType !== DG.SEMTYPE.MACROMOLECULE) {\n        grok.shell.warning(name + ' analysis is allowed for Macromolecules semantic type');\n        return false;\n    }\n    else if ((allowedAlphabets.length > 0 &&\n        !allowedAlphabets.some((a) => units.toUpperCase().endsWith(a.toUpperCase()))) ||\n        (allowedNotations.length > 0 &&\n            !allowedNotations.some((n) => units.toUpperCase().startsWith(n.toUpperCase())))) {\n        const notationAdd = allowedNotations.length == 0 ? 'any notation' :\n            (`notation${allowedNotations.length > 1 ? 's' : ''} ${allowedNotations.map((n) => `\"${n}\"`).join(', ')} `);\n        const alphabetAdd = allowedNotations.length == 0 ? 'any alphabet' :\n            (`alphabet${allowedAlphabets.length > 1 ? 's' : ''} ${allowedAlphabets.map((a) => `\"${a}\"`).join(', ')}.`);\n        grok.shell.warning(name + ' analysis is allowed for Macromolecules with ' + notationAdd + ' and ' + alphabetAdd);\n        return false;\n    }\n    return true;\n}\n//name: sequenceAlignment\n//input: string alignType {choices: ['Local alignment', 'Global alignment']}\n// eslint-disable-next-line max-len\n//input: string alignTable {choices: ['AUTO', 'NUCLEOTIDES', 'BLOSUM45', 'BLOSUM50','BLOSUM62','BLOSUM80','BLOSUM90','PAM30','PAM70','PAM250','SCHNEIDER','TRANS']}\n//input: double gap\n//input: string seq1\n//input: string seq2\n//output: object res\nexport function sequenceAlignment(alignType, alignTable, gap, seq1, seq2) {\n    const toAlign = new SequenceAlignment(seq1, seq2, gap, alignTable);\n    const res = alignType == 'Local alignment' ? toAlign.smithWaterman() : toAlign.needlemanWunch();\n    return res;\n}\n//name: WebLogo\n//description: WebLogo viewer\n//tags: viewer, panel\n//output: viewer result\nexport function webLogoViewer() {\n    return new WebLogo();\n}\n//name: VdRegions\n//description: V-Domain regions viewer\n//tags: viewer, panel\n//output: viewer result\nexport function vdRegionViewer() {\n    return new VdRegionsViewer();\n}\n//top-menu: Bio | Sequence Activity Cliffs...\n//name: Sequence Activity Cliffs\n//description: detect activity cliffs\n//input: dataframe table [Input data table]\n//input: column macroMolecule {semType: Macromolecule}\n//input: column activities\n//input: double similarity = 80 [Similarity cutoff]\n//input: string methodName { choices:[\"UMAP\", \"t-SNE\", \"SPE\"] }\nexport function activityCliffs(df, macroMolecule, activities, similarity, methodName) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!checkInputColumn(macroMolecule, 'Activity Cliffs'))\n            return;\n        const axesNames = getEmbeddingColsNames(df);\n        const options = {\n            'SPE': { cycles: 2000, lambda: 1.0, dlambda: 0.0005 },\n        };\n        const units = macroMolecule.tags[DG.TAGS.UNITS];\n        yield getActivityCliffs(df, macroMolecule, axesNames, 'Activity cliffs', activities, similarity, 'Levenshtein', methodName, DG.SEMTYPE.MACROMOLECULE, units, sequenceSpace, sequenceGetSimilarities, drawTooltip, options[methodName]);\n    });\n}\n//top-menu: Bio | Sequence Space...\n//name: Sequence Space\n//input: dataframe table\n//input: column macroMolecule { semType: Macromolecule }\n//input: string methodName { choices:[\"UMAP\", \"t-SNE\", \"SPE\"] }\n//input: string similarityMetric { choices:[\"Levenshtein\", \"Tanimoto\"] }\n//input: bool plotEmbeddings = true\nexport function sequenceSpaceTopMenu(table, macroMolecule, methodName, similarityMetric = 'Levenshtein', plotEmbeddings) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!checkInputColumn(macroMolecule, 'Activity Cliffs'))\n            return;\n        const embedColsNames = getEmbeddingColsNames(table);\n        const chemSpaceParams = {\n            seqCol: macroMolecule,\n            methodName: methodName,\n            similarityMetric: similarityMetric,\n            embedAxesNames: embedColsNames\n        };\n        const sequenceSpaceRes = yield sequenceSpace(chemSpaceParams);\n        const embeddings = sequenceSpaceRes.coordinates;\n        for (const col of embeddings)\n            table.columns.add(col);\n        if (plotEmbeddings) {\n            for (const v of grok.shell.views) {\n                if (v.name === table.name)\n                    v.scatterPlot({ x: embedColsNames[0], y: embedColsNames[1], title: 'Sequence space' });\n            }\n        }\n    });\n}\n;\n//top-menu: Bio | To Atomic Level...\n//name: To Atomic Level\n//description: returns molfiles for each monomer from HELM library\n//input: dataframe df [Input data table]\n//input: column macroMolecule {semType: Macromolecule}\nexport function toAtomicLevel(df, macroMolecule) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (DG.Func.find({ package: 'Chem', name: 'getRdKitModule' }).length === 0) {\n            grok.shell.warning('Transformation to atomic level requires package \"Chem\" installed.');\n            return;\n        }\n        if (!checkInputColumn(macroMolecule, 'To Atomic Level'))\n            return;\n        let currentView;\n        for (let view of grok.shell.tableViews) {\n            if (df.name === view.name) {\n                currentView = view;\n            }\n        }\n        const file = yield _package.files.readAsText('tests/sar-small.csv');\n        const df2 = DG.DataFrame.fromCsv(file);\n        const v = grok.shell.addTableView(df2);\n        setTimeout(() => {\n            grok.shell.closeTable(df2);\n            v.close();\n            grok.shell.v = currentView;\n        }, 100);\n        const monomersLibFile = yield _package.files.readAsText(HELM_CORE_LIB_FILENAME);\n        const monomersLibObject = JSON.parse(monomersLibFile);\n        const atomicCodes = getMolfilesFromSeq(macroMolecule, monomersLibObject);\n        const result = yield getMacroMol(atomicCodes);\n        const col = DG.Column.fromStrings('regenerated', result);\n        col.semType = DG.SEMTYPE.MOLECULE;\n        col.tags[DG.TAGS.UNITS] = 'molblock';\n        df.columns.add(col, true);\n    });\n}\n//top-menu: Bio | MSA...\n//name: MSA\n//input: dataframe table\n//input: column sequence { semType: Macromolecule }\n//output: column result\nexport function multipleSequenceAlignmentAny(table, col) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!checkInputColumn(col, 'MSA', ['fasta'], ['DNA', 'RNA', 'PT']))\n            return null;\n        const msaCol = yield runKalign(col, false);\n        table.columns.add(msaCol);\n        // This call is required to enable cell renderer activation\n        yield grok.data.detectSemanticTypes(table);\n        // const tv: DG.TableView = grok.shell.tv;\n        // tv.grid.invalidate();\n        return msaCol;\n    });\n}\n//name: Composition Analysis\n//top-menu: Bio | Composition Analysis\n//output: viewer result\nexport function compositionAnalysis() {\n    return __awaiter(this, void 0, void 0, function* () {\n        // Higher priority for columns with MSA data to show with WebLogo.\n        const tv = grok.shell.tv;\n        const df = tv.dataFrame;\n        const col = WebLogo.pickUpSeqCol2(df);\n        if (!col) {\n            grok.shell.error('Current table does not contain sequences');\n            return;\n        }\n        if (!checkInputColumn(col, 'Composition'))\n            return;\n        const allowedNotations = ['fasta', 'separator'];\n        const units = col.getTag(DG.TAGS.UNITS);\n        if (!allowedNotations.some((n) => units.toUpperCase().startsWith(n.toUpperCase()))) {\n            grok.shell.warning('Composition analysis is allowed for ' +\n                `notation${allowedNotations.length > 1 ? 's' : ''} ${allowedNotations.map((n) => `\"${n}\"`).join(', ')}.`);\n            return;\n        }\n        tv.addViewer('WebLogo', { sequenceColumnName: col.name });\n    });\n}\n// helper function for importFasta\nfunction parseMacromolecule(fileContent, startOfSequence, endOfSequence) {\n    const seq = fileContent.slice(startOfSequence, endOfSequence);\n    const seqArray = seq.split(/\\s/);\n    return seqArray.join('');\n}\n//name: importFasta\n//description: Opens FASTA file\n//tags: file-handler\n//meta.ext: fasta, fna, ffn, faa, frn, fa, fst\n//input: string fileContent\n//output: list tables\nexport function importFasta(fileContent) {\n    const regex = /^>(.*)$/gm; // match lines starting with >\n    const descriptionsArray = [];\n    const sequencesArray = [];\n    let startOfSequence = 0;\n    let match; // match.index is the beginning of the matched line\n    while (match = regex.exec(fileContent)) {\n        const description = fileContent.substring(match.index + 1, regex.lastIndex);\n        descriptionsArray.push(description);\n        if (startOfSequence !== 0)\n            sequencesArray.push(parseMacromolecule(fileContent, startOfSequence, match.index));\n        startOfSequence = regex.lastIndex + 1;\n    }\n    sequencesArray.push(parseMacromolecule(fileContent, startOfSequence, -1));\n    const descriptionsArrayCol = DG.Column.fromStrings('description', descriptionsArray);\n    const sequenceCol = DG.Column.fromStrings('sequence', sequencesArray);\n    sequenceCol.semType = 'Macromolecule';\n    const stats = WebLogo.getStats(sequenceCol, 5, WebLogo.splitterAsFasta);\n    const seqType = stats.sameLength ? 'SEQ.MSA' : 'SEQ';\n    const PeptideFastaAlphabet = new Set([\n        'G', 'L', 'Y', 'S', 'E', 'Q', 'D', 'N', 'F', 'A',\n        'K', 'R', 'H', 'C', 'V', 'P', 'W', 'I', 'M', 'T',\n    ]);\n    const DnaFastaAlphabet = new Set(['A', 'C', 'G', 'T']);\n    const RnaFastaAlphabet = new Set(['A', 'C', 'G', 'U']);\n    //const SmilesRawAlphabet = new Set([\n    //  'O', 'C', 'c', 'N', 'S', 'F', '(', ')',\n    //  '1', '2', '3', '4', '5', '6', '7',\n    //  '+', '-', '@', '[', ']', '/', '\\\\', '#', '=']);\n    const alphabetCandidates = [\n        ['PT', PeptideFastaAlphabet],\n        ['DNA', DnaFastaAlphabet],\n        ['RNA', RnaFastaAlphabet],\n    ];\n    //const alphabetCandidates: [string, Set<string>][] = [\n    //  ['NT', new Set(Object.keys(Nucleotides.Names))],\n    //  ['PT', new Set(Object.keys(Aminoacids.Names))],\n    //];\n    // Calculate likelihoods for alphabet_candidates\n    const alphabetCandidatesSim = alphabetCandidates.map((c) => WebLogo.getAlphabetSimilarity(stats.freq, c[1]));\n    const maxCos = Math.max(...alphabetCandidatesSim);\n    const alphabet = maxCos > 0.65 ? alphabetCandidates[alphabetCandidatesSim.indexOf(maxCos)][0] : 'UN';\n    sequenceCol.semType = DG.SEMTYPE.MACROMOLECULE;\n    const units = `fasta:${seqType}:${alphabet}`;\n    sequenceCol.setTag(DG.TAGS.UNITS, units);\n    return [DG.DataFrame.fromColumns([\n            descriptionsArrayCol,\n            sequenceCol,\n        ])];\n}\n//name: Bio | Convert\n//friendly-name: Bio | Convert\n//tags: panel, bio\n//input: column col {semType: Macromolecule}\nexport function convertPanel(col) {\n    convert(col);\n}\n"],"names":[],"sourceRoot":""}