@datagrok/eda 1.1.0 → 1.1.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
@@ -1,2 +1,2 @@
1
- var eda;(()=>{"use strict";var t={m:{},d:(e,n)=>{for(var r in n)t.o(n,r)&&!t.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:n[r]})},u:t=>t+".js"};t.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}(),t.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),t.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},(()=>{var e;t.g.importScripts&&(e=t.g.location+"");var n=t.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var r=n.getElementsByTagName("script");if(r.length)for(var a=r.length-1;a>-1&&!e;)e=r[a--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),t.p=e})(),t.b=document.baseURI||self.location.href;var e={};t.r(e),t.d(e,{PCA:()=>Pe,PLS:()=>Le,_package:()=>ke,applyLinearKernelSVM:()=>Re,applyPolynomialKernelSVM:()=>Me,applyRBFkernelSVM:()=>Te,applySigmoidKernelSVM:()=>$e,demoMultivariateAnalysis:()=>Ee,info:()=>De,init:()=>Fe,testDataLinearNonSeparable:()=>xe,testDataLinearSeparable:()=>Ie,trainLinearKernelSVM:()=>Ve,trainPolynomialKernelSVM:()=>Be,trainRBFkernelSVM:()=>Ne,trainSigmoidKernelSVM:()=>Oe});const n=grok,r=ui,a=DG;var o;function i(t){return e=this,n=void 0,a=function*(){yield new Promise((e=>setTimeout(e,t)))},new((r=void 0)||(r=Promise))((function(t,o){function i(t){try{l(a.next(t))}catch(t){o(t)}}function s(t){try{l(a.throw(t))}catch(t){o(t)}}function l(e){var n;e.done?t(e.value):(n=e.value,n instanceof r?n:new r((function(t){t(n)}))).then(i,s)}l((a=a.apply(e,n||[])).next())}));var e,n,r,a}!function(t){t.notNull=function(t,e){if(null==t)throw new Error(`${null==e?"Value":e} not defined`)}}(o||(o={}));var s=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};class l{constructor(t,e,n=!1,a){var o;this.name="",this.description="",this._isAutomatic=!1,this._autoStartFirstStep=!1,this._currentStep=0,this._isStopped=!1,this._isCancelled=!1,this._isStepProcessed=!1,this._root=r.div([],{id:"demo-script",classes:"tutorials-root tutorials-track demo-app-script"}),this._steps=[],this._mainHeader=r.panel([],"tutorials-main-header"),this._header=r.h2(""),this._headerDiv=r.divH([],"tutorials-root-header"),this._stopStartBtn=r.button(r.iconFA("pause"),(()=>this._changeStopState()),"Play / pause"),this._restartBtn=r.button(r.iconFA("redo"),(()=>this._restartScript()),"Restart"),this._nextStepBtn=r.button(r.iconFA("play"),(()=>{this._isStepProcessed||this._nextStep()}),"Next step"),this._activity=r.panel([],"tutorials-root-description"),this._progressDiv=r.divV([],"tutorials-root-progress"),this._progress=r.element("progress"),this._progressSteps=r.divText(""),this._closeBtn=r.button(r.iconFA("chevron-left"),(()=>this._closeDock()),"Back to demo"),this.name=t,this.description=e,this._isAutomatic=n,this._autoStartFirstStep=null!==(o=null==a?void 0:a.autoStartFirstStep)&&void 0!==o&&o,this._progress.max=0,this._progress.value=1,l.currentObject=this}get steps(){return this._steps}get stepNumber(){return this._steps.length}_addHeader(){this._createHeaderDiv(),this._createProgressDiv(),this._mainHeader.append(this._headerDiv,this._progressDiv)}_createHeaderDiv(){this._header.innerText=this.name,this._headerDiv.append(this._closeBtn),this._headerDiv.append(this._header),this._nextStepBtn.firstChild.className="grok-icon fas fa-play",this._headerDiv.append(this._isAutomatic?this._stopStartBtn:this._nextStepBtn)}_createProgressDiv(){this._progress.max=this.stepNumber,this._progressDiv.append(this._progress),this._progressSteps=r.divText(`Step: ${this._progress.value} of ${this.stepNumber}`),this._progressDiv.append(this._progressSteps)}_addDescription(){var t;this._activity.append(r.div(this.description,"tutorials-root-description"));for(let e=0;e<this.stepNumber;e++){let n=r.iconFA("clock");this._isAutomatic||0===e&&(n=r.iconFA("play",(()=>this._nextStep()),"Next step"),n.className="grok-icon fas fa-play");const a=r.div(this._steps[e].name,"grok-tutorial-entry-instruction"),o=r.div(null===(t=this._steps[e].options)||void 0===t?void 0:t.description,"grok-tutorial-step-description hidden"),i=r.divH([n,a],"grok-tutorial-entry");this._activity.append(i,o)}}_initRoot(){var t,e,r;n.shell.windows.showContextPanel=!0,n.shell.windows.showHelp=!1;const o=Array.from(n.shell.dockManager.rootNode.children)[0];this._node=n.shell.dockManager.dock(this._root,a.DOCK_TYPE.FILL,o,""),(null===(e=null===(t=o.parent.container.containerElement.firstElementChild)||void 0===t?void 0:t.lastElementChild)||void 0===e?void 0:e.classList.contains("tab-handle-list-container"))&&(null===(r=o.parent.container.containerElement.firstElementChild)||void 0===r||r.lastElementChild.remove()),this._node.container.containerElement.classList.add("tutorials-demo-script-container"),this._addHeader(),this._root.append(this._mainHeader),this._addDescription(),this._root.append(this._activity)}_nextStep(){var t,e;return s(this,void 0,void 0,(function*(){this._isStepProcessed=!0,this._isAutomatic||(this._nextStepBtn.classList.add("disabled"),this._nextStepBtn.firstChild.classList.add("fa-disabled"));const n=this._activity.getElementsByClassName("grok-tutorial-entry")[this._currentStep],a=this._activity.getElementsByClassName("grok-icon")[this._currentStep],o=this._activity.getElementsByClassName("grok-tutorial-step-description")[this._currentStep];a.className="grok-icon far fa-spinner-third fa-spin",o.classList.remove("hidden"),o.classList.add("visible");const s=n,l=(null===(t=this._steps[this._currentStep].options)||void 0===t?void 0:t.delay)?null===(e=this._steps[this._currentStep].options)||void 0===e?void 0:e.delay:2e3;yield this._steps[this._currentStep].func(),this._scrollTo(this._root,s.offsetTop-this._mainHeader.offsetHeight),yield this._countdown(n,a,l),yield i(l);const c=r.iconFA("check");if(a.replaceWith(c),c.className="grok-icon far fa-check",this._progress.value++,this._progressSteps.innerText=`Step: ${this._progress.value} of ${this.stepNumber}`,this._currentStep++,this._isStepProcessed=!1,this._currentStep!==this.stepNumber){if(!this._isAutomatic){const t=this._activity.getElementsByClassName("grok-icon")[this._currentStep],e=r.iconFA("play",(()=>this._nextStep()),"Next step");e.className="grok-icon fas fa-play",t.replaceWith(e),this._nextStepBtn.classList.remove("disabled"),this._nextStepBtn.firstChild.classList.remove("fa-disabled")}}else this._isAutomatic?this._stopStartBtn.replaceWith(this._restartBtn):this._nextStepBtn.replaceWith(this._restartBtn)}))}_startScript(){return s(this,void 0,void 0,(function*(){for(let t=this._currentStep;t<this.stepNumber&&!this._isStopped&&!this._isCancelled;t++)yield this._nextStep()}))}_scrollTo(t,e){t.focus(),t.scrollTop=e}_countdown(t,e,n){return s(this,void 0,void 0,(function*(){const a=r.div([],"demo-script-countdown");e.classList.add("hidden");let o=n/1e3;const i=this._createSVGIndicator(o);a.append(i),t.prepend(a);const s=setInterval((()=>{o--,0===o&&(clearInterval(s),a.remove(),e.classList.remove("hidden"),e.classList.add("visible"))}),1e3)}))}_createSVGIndicator(t){const e=document.createElementNS("http://www.w3.org/2000/svg","svg"),n=document.createElementNS("http://www.w3.org/2000/svg","circle");return n.setAttributeNS(null,"cx","7"),n.setAttributeNS(null,"cy","7"),n.setAttributeNS(null,"r","6"),n.setAttributeNS(null,"style",`animation: countdown ${t}s linear infinite forwards`),e.append(n),e}_changeStopState(){const t=this._stopStartBtn.getElementsByClassName("grok-icon");t[0].className="grok-icon fas fa-play",this._isStopped=!this._isStopped,this._isStopped||(t[0].className="grok-icon fal fa-pause",this._isStepProcessed||this._startScript())}_restartScript(){n.shell.dockManager.close(this._node),n.shell.closeAll(),this._clearRoot(),this._setInitParams(),this.start()}_clearRoot(){this._root=r.div([],{id:"demo-script",classes:"tutorials-root tutorials-track demo-app-script"}),this._mainHeader=r.panel([],"tutorials-main-header"),this._header=r.h2(""),this._headerDiv=r.divH([],"tutorials-root-header"),this._activity=r.panel([],"tutorials-root-description"),this._progressDiv=r.divV([],"tutorials-root-progress"),this._progress=r.element("progress"),this._progressSteps=r.divText(""),this._progress.max=0,this._progress.value=1}_setInitParams(){this._currentStep=0,this._isStopped=!1,this._isCancelled=!1,this._stopStartBtn.getElementsByClassName("grok-icon")[0].className="grok-icon fal fa-pause",this._nextStepBtn.classList.remove("disabled")}_closeDock(){n.shell.dockManager.close(this._node),this.cancelScript()}cancelScript(){this._isCancelled=!0,l.currentObject=null}step(t,e,n){return this._steps[this.steps.length]={name:t,func:e,options:n},this}start(){return s(this,void 0,void 0,(function*(){this._initRoot(),n.shell.newView(this.name),this._isAutomatic?this._startScript():this._autoStartFirstStep&&(yield this._nextStep())}))}}l.currentObject=null,Int32Array,Float32Array,DG.Column.fromInt32Array,DG.Column.fromFloat32Array;const c="num",u="floatColumn",m="intColumn",d="floatColumns",h="newFloatColumns",p="intColumns",f="newIntColumns",y="newFloatColumn",v="newIntColumn",w="column",g="_callResult",_="numOfRows",b="numOfColumns",S="ref",C="value",A="tableFromColumns",k="objects",D="int",F="double",P={intColumn:Int32Array,floatColumn:Float32Array,floatColumns:Float32Array,newFloatColumns:Float32Array,intColumns:Int32Array,newIntColumns:Int32Array,newFloatColumn:Float32Array,newIntColumn:Int32Array};function L(t,e){let n,r=[],a=0;for(const o in t){const i=t[o],s=i.type;if(o!==g){switch(s){case c:case D:case F:i.data=e[a],a++;break;case m:case u:let r,o=e[a];r=o.type===D&&s===m||o.type===F&&s===u?o.getRawData():new P[s](o.getRawData()),i.data={array:r,numOfRows:r.length},a++;break;case v:case y:let l=0;n=i[_][S],l=t[n].type===c?t[n].data:t[n].data[i[_][C]],i.data={numOfRows:l},a++;break;case p:case d:let w=[];for(let t of e[a].toList())t.type===D&&s===m||t.type===F&&s===u?w.push(t.getRawData()):w.push(new P[s](t.getRawData()));i.data={arrays:w,numOfRows:w[0].length,numOfColumns:w.length},a++;break;case f:case h:let g=0,A=0;n=i[_][S],g=t[n].type===c?t[n].data:t[n].data[i[_][C]],n=i[b][S],A=t[n].type===c?t[n].data:t[n].data[i[b][C]],i.data={numOfRows:g,numOfColumns:A},a++;break;default:return}r.push(i)}}return r}function E(t,e){t.arguments._callResult=e.callResult,function(t,e){const n={newFloatColumns:DG.Column.fromFloat32Array,newIntColumns:DG.Column.fromInt32Array,newFloatColumn:DG.Column.fromFloat32Array,newIntColumn:DG.Column.fromInt32Array};let r=0;for(const a in t){const o=t[a];switch(o.type){case c:case D:case F:case m:case u:case d:case p:break;case y:case v:let t;null==o.name?t=(0).toString():s=o.name,o.column=n[o.type](t,e[r].array);break;case f:case h:let a=[],i=e[r].arrays.length,s=[];if(null==o.names)for(let t=1;t<=i;t++)s.push(t.toString());else s=o.names;for(let t=0;t<i;t++)a.push(n[o.type](s[t],e[r].arrays[t]));o.columns=a}r++}}(t.arguments,e.args);let n=function(t){let e=t.output;const n={newFloatColumns:"columns",newIntColumns:"columns",newFloatColumn:"column",newIntColumn:"column"};switch(e.type){case c:case D:case F:return t.arguments[e.source];case w:return t.arguments[e.source].column;case A:return DG.DataFrame.fromColumns(t.arguments[e.source].columns);case k:let r=[];for(let a of e.source){let e=t.arguments[a];r.push(e[n[e.type]])}return r}}(t);return function(t){for(const e in t){const n=t[e];switch(n.type){case c:case D:case F:case m:case u:case p:case d:break;case v:case y:n.column=null;break;case f:case h:n.columns=null}}}(t.arguments),n}const I=1,x=1,V=1,R=0,N=100,T=1e8,B="components must be positive.",M="components must not be greater than feautures count.",O="min must be less than max.",$="features must be positive.",H="samples must be positive.",W="violators percentage must be from the range from 0 to 100.",j="dataframe is too big.";function G(t,e){if(e<I)throw new Error(B);if(e>t.length)throw new Error(M);if(t.length*t.byIndex(0).length>T)throw new Error(j)}var z=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};function K(e,n,r,a){return z(this,void 0,void 0,(function*(){let e;G(n,a);let o=async function(e,n,r,a){return new Promise(((e,o)=>{const i=new Worker(new URL(t.p+t.u(93),t.b));i.postMessage(L(EDA.partialLeastSquareRegression.arguments,[n,r,a])),i.onmessage=function(t){i.terminate(),e(E(EDA.partialLeastSquareRegression,t.data))}}))}(0,n,r,a);return yield o.then((t=>{e=t}),(t=>{throw new Error(`Error: ${t}`)})),e}))}function U(t,e,n){n.name=e.name+"(predicted)";let r=a.DataFrame.fromColumns([t,e,n]);return r.name="Reference vs. Predicted",a.Viewer.scatterPlot(r,{title:r.name,x:e.name,y:n.name,showRegressionLine:!0,markerType:"circle",labels:t.name})}function q(t,e){e.name="regression coefficient";let n=[];for(const e of t)n.push(e.name);let r=a.Column.fromStrings("feature",n),o=a.DataFrame.fromColumns([r,e]);return o.name="Regression Coefficients",a.Viewer.barChart(o,{title:o.name,split:"feature",value:"regression coefficient",valueAggrType:"avg"})}function Y(t,e,n){let r=[t];for(let t=0;t<e.length;t++)e[t].name=`x.score.t${t+1}`,r.push(e[t]);for(let t=0;t<n.length;t++)n[t].name=`y.score.u${t+1}`,r.push(n[t]);let o=a.DataFrame.fromColumns(r);o.name="Scores";const i=e.length>1?1:0;return a.Viewer.scatterPlot(o,{title:o.name,x:e[0].name,y:e[i].name,markerType:"circle",labels:t.name})}var J=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};const Q=0,X=1,Z="Feature #",tt="Label";function et(){return a.DataFrame.fromColumns([a.Column.fromStrings("model",["alfaromeo","audi","bmw","chevrolet","dodge1","dodge2","honda1","honda2","isuzu","jaguar","mazda","mercedes","mercury","mitsubishi","nissan1","nissan2","peugot","plymouth","porsche","saab","subaru","toyota1","toyota2","toyota3","toyota4","volkswagen1","volkswagen2","volvo1","volvo2","volvo3"]),a.Column.fromInt32Array("diesel",new Int32Array([0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,1,0,1,1,0,0,0,1])),a.Column.fromInt32Array("turbo",new Int32Array([0,0,0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,1])),a.Column.fromInt32Array("two.doors",new Int32Array([1,0,1,0,1,0,1,0,0,0,0,0,1,1,0,1,0,0,1,0,0,1,0,1,0,1,0,0,0,0])),a.Column.fromInt32Array("hatchback",new Int32Array([1,0,0,0,1,1,1,0,0,0,0,0,1,1,0,0,1,0,0,0,0,1,0,1,0,0,0,0,0,0])),a.Column.fromFloat32Array("wheel.base",new Float32Array([94.5,105.80000305175781,101.19999694824219,94.5,93.69999694824219,93.69999694824219,93.69999694824219,96.5,94.30000305175781,113,93.0999984741211,115.5999984741211,102.69999694824219,93.69999694824219,94.5,94.5,93.69999694824219,114.19999694824219,89.5,99.0999984741211,97.19999694824219,95.69999694824219,95.69999694824219,98.4000015258789,102.4000015258789,97.30000305175781,100.4000015258789,104.30000305175781,109.0999984741211,109.0999984741211])),a.Column.fromFloat32Array("length",new Float32Array([171.1999969482422,192.6999969482422,176.8000030517578,158.8000030517578,157.3000030517578,157.3000030517578,150,175.39999389648438,170.6999969482422,199.60000610351562,166.8000030517578,202.60000610351562,178.39999389648438,157.3000030517578,170.1999969482422,165.3000030517578,157.3000030517578,198.89999389648438,168.89999389648438,186.60000610351562,172,158.6999969482422,166.3000030517578,176.1999969482422,175.60000610351562,171.6999969482422,180.1999969482422,188.8000030517578,188.8000030517578,188.8000030517578])),a.Column.fromFloat32Array("width",new Float32Array([65.5,71.4000015258789,64.80000305175781,63.599998474121094,63.79999923706055,63.79999923706055,64,65.19999694824219,61.79999923706055,69.5999984741211,64.19999694824219,71.69999694824219,68,64.4000015258789,63.79999923706055,63.79999923706055,63.79999923706055,68.4000015258789,65,66.5,65.4000015258789,63.599998474121094,64.4000015258789,65.5999984741211,66.5,65.5,66.9000015258789,67.19999694824219,68.80000305175781,68.9000015258789])),a.Column.fromFloat32Array("height",new Float32Array([52.400001525878906,55.70000076293945,54.29999923706055,52,50.79999923706055,50.599998474121094,52.599998474121094,54.099998474121094,53.5,52.79999923706055,54.099998474121094,56.29999923706055,54.79999923706055,50.79999923706055,53.5,54.5,50.599998474121094,58.70000076293945,51.599998474121094,56.099998474121094,52.5,54.5,53,52,54.900001525878906,55.70000076293945,55.099998474121094,56.20000076293945,55.5,55.5])),a.Column.fromInt32Array("curb.weight",new Int32Array([2823,2844,2395,1909,2128,1967,1956,2304,2337,4066,1950,3770,2910,1918,2024,1951,1967,3430,2800,2695,2190,1985,2275,2551,2480,2261,2661,2912,3049,3217])),a.Column.fromInt32Array("eng.size",new Int32Array([152,136,108,90,98,90,92,110,111,258,91,183,140,92,97,97,90,152,194,121,108,92,110,146,110,97,136,141,141,145])),a.Column.fromInt32Array("horsepower",new Int32Array([154,110,101,70,102,68,76,86,78,176,68,123,175,68,69,69,68,95,207,110,82,62,56,116,73,52,110,114,160,106])),a.Column.fromInt32Array("peak.rpm",new Int32Array([5e3,5500,5800,5400,5500,5500,6e3,5800,4800,4750,5e3,4350,5e3,5500,5200,5200,5500,4150,5900,5250,4400,4800,4500,4800,4500,4800,5500,5400,5300,4800])),a.Column.fromInt32Array("symbol",new Int32Array([1,1,2,0,1,1,1,0,0,0,1,-1,1,2,1,1,1,0,3,2,0,1,0,2,-1,2,0,-2,-1,-1])),a.Column.fromInt32Array("city.mpg",new Int32Array([19,19,23,38,24,31,30,27,24,15,31,22,19,37,31,31,31,25,17,21,28,35,34,24,30,37,19,23,19,26])),a.Column.fromInt32Array("highway.mpg",new Int32Array([26,25,29,43,30,38,34,33,29,19,38,25,24,41,37,37,38,25,25,28,33,39,36,30,33,46,24,28,25,27])),a.Column.fromInt32Array("price",new Int32Array([16500,17710,16430,6575,7957,6229,7129,8845,6785,35550,7395,31600,16503,5389,7349,7299,6229,13860,37028,12170,7775,5348,7898,9989,10698,7775,13295,12940,19045,22470]))])}function nt(e,n,r,o,i,s,l,c){return J(this,void 0,void 0,(function*(){!function(t,e,n,r,a){if(n>=r)throw new Error(O);if(e<V)throw new Error($);if(t<x)throw new Error(H);if(a<R||a>N)throw new Error(W)}(o,i,s,l,c);const u=a.Column.fromList("double","kernelParams",n);let m,d=async function(e,n,r,a,o,i,s){return new Promise(((l,c)=>{const u=new Worker(new URL(t.p+t.u(584),t.b));u.postMessage(L(EDA.generateDataset.arguments,[e,n,r,a,o,i,s])),u.onmessage=function(t){u.terminate(),l(E(EDA.generateDataset,t.data))}}))}(e,u,o,i,s,l,c);yield d.then((t=>{m=t}),(t=>{throw new Error(`Error: ${t}`)})),m[X].name=tt;for(const t of m[Q])t.name=Z+t.name;const h=a.DataFrame.fromColumns(m[Q]);return h.name=r,h.columns.add(m[X]),h}))}var rt=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};const at=0,ot=1,it=2,st=3,lt=4,ct=0,ut=1,mt=2,dt=3,ht=4,pt=5,ft=6,yt=7,vt=0,wt=1,gt=2,_t=3,bt=0,St=0,Ct=1,At=0,kt=1,Dt=0,Ft=0,Pt=0,Lt=0,Et="gamma must be strictly positive.",It="sigma must be strictly positive.",xt="c must be strictly positive.",Vt="d must be strictly positive.",Rt="incorrect kernel.",Nt="Labels",Tt="predicted",Bt="correctness",Mt="Confusion matrix",Ot="mean",$t="std dev",Ht="alpha",Wt="weight",jt="gamma",Gt="kernel",zt="kernel params",Kt="kernel param 1",Ut="kernel param 2",qt="features count",Yt="train samples count",Jt="Train error,%",Qt=["linear","polynomial","RBF","sigmoid"],Xt="positive (P)",Zt="negative (N)",te="predicted positive (PP)",ee="predicted negative (PN)",ne="Sensitivity",re="Specificity",ae="Balanced accuracy",oe="Positive predicitve value",ie="Negative predicitve value",se="Model report",le="Predicted labels",ce="Train labels",ue="Prediction correctness",me="prediction",de=4,he=3,pe=2,fe=0,ye=1,ve=2,we=0,ge=1;function _e(e,n,r){return rt(this,void 0,void 0,(function*(){let o=n.columns,i=o.byName(r);return o.remove(r),yield function(e,n,r){return rt(this,void 0,void 0,(function*(){!function(t){if(t.gamma<=Dt)throw new Error(Et);switch(t.kernel){case at:return;case it:if(t.sigma<=Ft)throw new Error(It);return;case ot:if(t.cParam<=Pt)throw new Error(xt);if(t.dParam<=Lt)throw new Error(Vt);return;case st:return;default:throw new Error(Rt)}}(e);const o=[we,we];switch(e.kernel){case at:break;case it:o[bt]=e.sigma;break;case ot:o[St]=e.cParam,o[Ct]=e.dParam;break;case st:o[At]=e.kappa,o[kt]=e.theta;break;default:throw new Error(Rt)}let i,s=a.Column.fromList("double",zt,o),l=n.toList(),c=l[0].length+ge,u=l.length+ge,m=lt,d=async function(e,n,r,a,o,i,s,l){return new Promise(((c,u)=>{const m=new Worker(new URL(t.p+t.u(111),t.b));m.postMessage(L(EDA.trainAndAnalyzeLSSVM.arguments,[e,n,r,a,o,i,s,l])),m.onmessage=function(t){m.terminate(),c(E(EDA.trainAndAnalyzeLSSVM,t.data))}}))}(e.gamma,e.kernel,s,c,u,m,n,r);yield d.then((t=>{i=t}),(t=>{throw new Error(`Error: ${t}`)})),i[ut].name=Ot,i[mt].name=$t,i[dt].name=Ht,i[ht].name=Wt,i[pt].name=Tt,i[ft].name=Bt,i[yt].name=Mt;let h={trainGamma:e.gamma,kernelType:e.kernel,kernelParams:s,trainLabels:r,normalizedTrainData:a.DataFrame.fromColumns(i[ct]),means:i[ut],stdDevs:i[mt],modelParams:i[dt],modelWeights:i[ht],predictedLabels:i[pt],correctness:i[ft],confusionMatrix:i[yt],trainError:void 0,featuresCount:l.length,trainSamplesCount:l[0].length};return function(t){let e=t.confusionMatrix.getRawData(),n=e[vt],r=e[_t],a=e[gt],o=e[wt],i=n+o,s=a+r,l=n/i,c=r/s,u=n/(n+a),m=r/(r+o),d=(n+r)/(i+s),h=(l+c)/2;t.sensitivity=l,t.specificity=c,t.balancedAccuracy=h,t.positivePredicitveValue=u,t.negativePredicitveValue=m,t.trainError=100*(1-d)}(h),h}))}(e,o,i)}))}function be(t,e){t.name=se,t.columns.add(e.trainLabels),t.columns.add(e.predictedLabels),t.columns.add(e.correctness);let r=n.shell.addTableView(t);r.addViewer(a.Viewer.form(function(t){let e=t.kernelParams.getRawData();return a.DataFrame.fromColumns([a.Column.fromList("double",jt,[t.trainGamma]),a.Column.fromStrings(Gt,[Qt[t.kernelType]]),a.Column.fromList("double",Kt,[e[0]]),a.Column.fromList("double",Ut,[e[1]]),a.Column.fromList("double",qt,[t.featuresCount]),a.Column.fromList("double",Yt,[t.trainSamplesCount]),a.Column.fromList("double",Jt,[t.trainError]),a.Column.fromList("double",ae,[t.balancedAccuracy]),a.Column.fromList("double",ne,[t.sensitivity]),a.Column.fromList("double",re,[t.specificity]),a.Column.fromList("double",oe,[t.positivePredicitveValue]),a.Column.fromList("double",ie,[t.negativePredicitveValue])])}(e))),r.addViewer(a.Viewer.scatterPlot(t,{title:le,color:e.predictedLabels.name})),r.addViewer(a.Viewer.scatterPlot(t,{title:ce,color:e.trainLabels.name})),r.addViewer(a.Viewer.grid(function(t){let e=t.confusionMatrix.getRawData();return a.DataFrame.fromColumns([a.Column.fromStrings("",[Xt,Zt]),a.Column.fromList("int",te,[e[vt],e[gt]]),a.Column.fromList("int",ee,[e[wt],e[_t]])])}(e))),r.addViewer(a.Viewer.scatterPlot(t,{title:ue,color:e.correctness.name}))}function Se(t){let e=t.normalizedTrainData.columns,n=t.trainSamplesCount,r=t.featuresCount,a=new Uint8Array(de*(he+pe+n+r+r+n+ge+r+ge+r*n)),o=a.buffer,i=0,s=new Int32Array(o,i,he);s[fe]=t.kernelType,s[ye]=n,s[ve]=r,i+=he*de;let l=new Float32Array(o,i,pe);l.set(t.kernelParams.getRawData()),i+=pe*de,l=new Float32Array(o,i,n),l.set(t.trainLabels.getRawData()),i+=n*de,l=new Float32Array(o,i,r),l.set(t.means.getRawData()),i+=r*de,l=new Float32Array(o,i,r),l.set(t.stdDevs.getRawData()),i+=r*de,l=new Float32Array(o,i,n+ge),l.set(t.modelParams.getRawData()),i+=(n+ge)*de,l=new Float32Array(o,i,r+ge),l.set(t.modelWeights.getRawData()),i+=(r+ge)*de;for(const t of e)l=new Float32Array(o,i,r),l.set(t.getRawData()),i+=r*de;return a}function Ce(e,n){return rt(this,void 0,void 0,(function*(){let r=function(t){let e=t.buffer,n=0,r=new Int32Array(e,n,he);n+=he*de;let o=r[ye],i=r[ve];const s=a.Column.fromFloat32Array(zt,new Float32Array(e,n,pe));n+=pe*de;const l=a.Column.fromFloat32Array(Nt,new Float32Array(e,n,o));n+=o*de;const c=a.Column.fromFloat32Array(Ot,new Float32Array(e,n,i));n+=i*de;const u=a.Column.fromFloat32Array($t,new Float32Array(e,n,i));n+=i*de;const m=a.Column.fromFloat32Array(Ht,new Float32Array(e,n,o+ge));n+=(o+ge)*de;const d=a.Column.fromFloat32Array(Wt,new Float32Array(e,n,i+ge));n+=(i+ge)*de;let h=[];for(let t=0;t<o;t++)h.push(a.Column.fromFloat32Array(t.toString(),new Float32Array(e,n,i))),n+=i*de;const p=a.DataFrame.fromColumns(h);return{kernelType:r[fe],kernelParams:s,trainLabels:l,means:c,stdDevs:u,modelParams:m,modelWeights:d,normalizedTrainData:p}}(new Uint8Array(n)),o=yield function(e,n){return rt(this,void 0,void 0,(function*(){let r,a=async function(e,n,r,a,o,i,s,l,c){return new Promise(((u,m)=>{const d=new Worker(new URL(t.p+t.u(604),t.b));d.postMessage(L(EDA.predictByLSSVM.arguments,[e,n,r,a,o,i,s,l,c])),d.onmessage=function(t){d.terminate(),u(E(EDA.predictByLSSVM,t.data))}}))}(e.kernelType,e.kernelParams,e.normalizedTrainData.columns,e.trainLabels,e.means,e.stdDevs,e.modelParams,e.modelWeights,n);return yield a.then((t=>{r=t}),(t=>{throw new Error(`Error: ${t}`)})),r}))}(r,e.columns);return o.name=me,a.DataFrame.fromColumns([o])}))}var Ae=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};const ke=new a.Package;function De(){n.shell.info(ke.webRoot)}function Fe(){return Ae(this,void 0,void 0,(function*(){yield async function(){await initEDA()}()}))}function Pe(e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){return function(t){for(const e of t.columns.toList())e.name="PCA"+e.name;return t}(yield function(e,n,r,a,o){return z(this,void 0,void 0,(function*(){G(n,r);let e,i=async function(e,n,r,a,o){return new Promise(((e,i)=>{const s=new Worker(new URL(t.p+t.u(155),t.b));s.postMessage(L(EDA.principalComponentAnalysis.arguments,[n,r,a,o])),s.onmessage=function(t){s.terminate(),e(E(EDA.principalComponentAnalysis,t.data))}}))}(0,n,r,a?1:0,o?1:0);return yield i.then((t=>{e=t}),(t=>{throw new Error(`Error: ${t}`)})),e}))}(0,n,r,a,o))}))}function Le(t,e,r,o,i){return Ae(this,void 0,void 0,(function*(){const s=yield K(0,r,o,i);!function(t,e,r,o,i){let s=n.shell.getTableView(t.name);s.addViewer(U(e,o,i[0])),s.addViewer(q(r,i[1])),s.addViewer(function(t,e){let n=[],r=[];for(let e of t)r.push(e.name);n.push(a.Column.fromStrings("labels",r));for(let t=0;t<e.length;t++)e[t].name=`x.loading.p${t+1}`,n.push(e[t]);let o=a.DataFrame.fromColumns(n);return o.name="Loadings",a.Viewer.scatterPlot(o,{title:o.name,x:e[0].name,y:e[e.length-1].name,markerType:"circle",labels:"labels"})}(r,i[4])),s.addViewer(Y(e,i[2],i[3]))}(t,e,r,o,s)}))}function Ee(){return Ae(this,void 0,void 0,(function*(){const t=new l("Partial least squares regression","Analysis of multidimensional data."),e=et(),a=e.columns.byName("model"),o=e.columns.byName("price"),i=e.columns.remove("price").remove("model"),s=yield K(0,i,o,3),c=et();let u,m;c.name="Cars",yield t.step("Data",(()=>Ae(this,void 0,void 0,(function*(){n.shell.addTableView(c),u=n.shell.getTableView(c.name)}))),{description:"Each car has many features - patterns extraction is complicated.",delay:0}).step("Model",(()=>Ae(this,void 0,void 0,(function*(){m=r.dialog({title:"Multivariate Analysis (PLS)"}).add(r.tableInput("Table",c)).add(r.columnsInput("Features",e,i.toList,{available:void 0,checked:i.names()})).add(r.columnInput("Names",e,a,void 0)).add(r.columnInput("Predict",e,o,void 0)).add(r.intInput("Components",3,void 0)).onOK((()=>{n.shell.info("Multivariate analysis has been already performed.")})).show({x:400,y:140})}))),{description:"Predict car price by its other features.",delay:0}).step("Regression coeffcicients",(()=>Ae(this,void 0,void 0,(function*(){m.close(),u.addViewer(q(i,s[1]))}))),{description:'The feature "diesel" affects the price the most.',delay:0}).step("Scores",(()=>Ae(this,void 0,void 0,(function*(){u.addViewer(Y(a,s[2],s[3]))}))),{description:"Similarities & dissimilarities: alfaromeo and mercedes are different.",delay:0}).step("Prediction",(()=>Ae(this,void 0,void 0,(function*(){u.addViewer(U(a,o,s[0]))}))),{description:"Closer to the line means better price prediction.",delay:0}).start()}))}function Ie(t,e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){return yield nt(at,[0,0],t,e,n,r,a,o)}))}function xe(t,e,n,r,a,o,i){return Ae(this,void 0,void 0,(function*(){return yield nt(it,[e,0],t,n,r,a,o,i)}))}function Ve(t,e,n,r){return Ae(this,void 0,void 0,(function*(){const a=yield _e({gamma:n,kernel:at},t,e);return r&&be(t,a),Se(a)}))}function Re(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}function Ne(t,e,n,r,a){return Ae(this,void 0,void 0,(function*(){const o=yield _e({gamma:n,kernel:it,sigma:r},t,e);return a&&be(t,o),Se(o)}))}function Te(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}function Be(t,e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){const i=yield _e({gamma:n,kernel:ot,cParam:r,dParam:a},t,e);return o&&be(t,i),Se(i)}))}function Me(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}function Oe(t,e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){const i=yield _e({gamma:n,kernel:st,kappa:r,theta:a},t,e);return o&&be(t,i),Se(i)}))}function $e(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}eda=e})();
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package.js","mappings":"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","sources":["webpack://eda/webpack/bootstrap","webpack://eda/webpack/runtime/define property getters","webpack://eda/webpack/runtime/get javascript chunk filename","webpack://eda/webpack/runtime/global","webpack://eda/webpack/runtime/hasOwnProperty shorthand","webpack://eda/webpack/runtime/make namespace object","webpack://eda/webpack/runtime/publicPath","webpack://eda/webpack/runtime/jsonp chunk loading","webpack://eda/external var \"grok\"","webpack://eda/external var \"ui\"","webpack://eda/external var \"DG\"","webpack://eda/./node_modules/@datagrok-libraries/utils/src/test.js","webpack://eda/./node_modules/@datagrok-libraries/tutorials/src/demo-script.js","webpack://eda/./wasm/callWasm.js","webpack://eda/./wasm/callWasmForWebWorker.js","webpack://eda/./src/utils.ts","webpack://eda/./src/EDAtools.ts","webpack://eda/./wasm/EDAAPI.js","webpack://eda/./src/EDAui.ts","webpack://eda/./src/dataGenerators.ts","webpack://eda/./src/svm.ts","webpack://eda/./src/package.ts"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\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) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\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\t359: 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","const __WEBPACK_NAMESPACE_OBJECT__ = grok;","const __WEBPACK_NAMESPACE_OBJECT__ = ui;","const __WEBPACK_NAMESPACE_OBJECT__ = DG;","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';\nexport const tests = {};\nconst autoTestsCatName = 'Auto Tests';\nconst wasRegistered = {};\nexport let currentCategory;\nexport var assure;\n(function (assure) {\n    function notNull(value, name) {\n        if (value == null)\n            throw new Error(`${name == null ? 'Value' : name} not defined`);\n    }\n    assure.notNull = notNull;\n})(assure || (assure = {}));\nexport class TestContext {\n    constructor(catchUnhandled, report) {\n        this.catchUnhandled = true;\n        this.report = false;\n        if (catchUnhandled !== undefined)\n            this.catchUnhandled = catchUnhandled;\n        if (report !== undefined)\n            this.report = report;\n    }\n    ;\n}\nexport class Test {\n    constructor(category, name, test, options) {\n        var _a;\n        this.category = category;\n        this.name = name;\n        options !== null && options !== void 0 ? options : (options = {});\n        (_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);\n        this.options = options;\n        this.test = () => __awaiter(this, void 0, void 0, function* () {\n            return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {\n                let result = '';\n                try {\n                    result = yield test();\n                }\n                catch (e) {\n                    reject(e);\n                }\n                resolve(result);\n            }));\n        });\n    }\n}\nexport function testEvent(event, handler, trigger, ms = 0) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let sub;\n        return new Promise((resolve, reject) => {\n            sub = event.subscribe((args) => {\n                try {\n                    handler(args);\n                }\n                catch (e) {\n                    reject(e);\n                }\n                sub.unsubscribe();\n                resolve('OK');\n            });\n            setTimeout(() => {\n                sub.unsubscribe();\n                // eslint-disable-next-line prefer-promise-reject-errors\n                reject('timeout');\n            }, ms);\n            trigger();\n        });\n    });\n}\nexport function test(name, test, options) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    if (tests[currentCategory].tests == undefined)\n        tests[currentCategory].tests = [];\n    tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));\n}\n/* Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual, expected = true, error) {\n    if (error)\n        error = `${error}, `;\n    else\n        error = '';\n    if (actual !== expected)\n        throw new Error(`${error}Expected \"${expected}\", got \"${actual}\"`);\n}\nexport function expectFloat(actual, expected, tolerance = 0.001, error) {\n    if ((actual === Number.POSITIVE_INFINITY && expected === Number.POSITIVE_INFINITY) ||\n        (actual === Number.NEGATIVE_INFINITY && expected === Number.NEGATIVE_INFINITY) ||\n        (actual === Number.NaN && expected === Number.NaN) || (isNaN(actual) && isNaN(expected)))\n        return;\n    const areEqual = Math.abs(actual - expected) < tolerance;\n    expect(areEqual, true, `${error !== null && error !== void 0 ? error : ''} (tolerance = ${tolerance})`);\n    if (!areEqual)\n        throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);\n}\nexport function expectTable(actual, expected, error) {\n    const expectedRowCount = expected.rowCount;\n    const actualRowCount = actual.rowCount;\n    expect(actualRowCount, expectedRowCount, `${error !== null && error !== void 0 ? error : ''}, row count`);\n    for (const column of expected.columns) {\n        const actualColumn = actual.columns.byName(column.name);\n        if (actualColumn == null)\n            throw new Error(`Column ${column.name} not found`);\n        if (actualColumn.type != column.type)\n            throw new Error(`Column ${column.name} type expected ${column.type} got ${actualColumn.type}`);\n        for (let i = 0; i < expectedRowCount; i++) {\n            const value = column.get(i);\n            const actualValue = actualColumn.get(i);\n            if (column.type == DG.TYPE.FLOAT)\n                expectFloat(actualValue, value, 0.0001, error);\n            else if (column.type == DG.TYPE.DATE_TIME)\n                expect(actualValue.isSame(value), true, error);\n            else\n                expect(actualValue, value, error);\n        }\n    }\n}\nexport function expectObject(actual, expected) {\n    for (const [expectedKey, expectedValue] of Object.entries(expected)) {\n        if (!actual.hasOwnProperty(expectedKey))\n            throw new Error(`Expected property \"${expectedKey}\" not found`);\n        const actualValue = actual[expectedKey];\n        if (actualValue instanceof Array && expectedValue instanceof Array)\n            expectArray(actualValue, expectedValue);\n        else if (actualValue instanceof Object && expectedValue instanceof Object)\n            expectObject(actualValue, expectedValue);\n        else if (Number.isFinite(actualValue) && Number.isFinite(expectedValue))\n            expectFloat(actualValue, expectedValue);\n        else if (actualValue != expectedValue)\n            throw new Error(`Expected (${expectedValue}) for key '${expectedKey}', got (${actualValue})`);\n    }\n}\nexport function expectArray(actual, expected) {\n    const actualLength = actual.length;\n    const expectedLength = expected.length;\n    if (actualLength != expectedLength) {\n        throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +\n            `and expected array length is ${expectedLength}`);\n    }\n    for (let i = 0; i < actualLength; i++) {\n        if (actual[i] instanceof Array && expected[i] instanceof Array)\n            expectArray(actual[i], expected[i]);\n        else if (actual[i] instanceof Object && expected[i] instanceof Object)\n            expectObject(actual[i], expected[i]);\n        else if (actual[i] != expected[i])\n            throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);\n    }\n}\n/* Defines a test suite. */\nexport function category(category, tests) {\n    currentCategory = category;\n    tests();\n}\n/* Defines a function to be executed before the tests in this category are executed. */\nexport function before(before) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].before = before;\n}\n/* Defines a function to be executed after the tests in this category are executed. */\nexport function after(after) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].after = after;\n}\nfunction addNamespace(s, f) {\n    return s.replace(new RegExp(f.name, 'gi'), f.nqName);\n}\nexport function initAutoTests(packageId, module) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (wasRegistered[packageId])\n            return;\n        const moduleTests = module ? module.tests : tests;\n        if (moduleTests[autoTestsCatName] !== undefined) {\n            wasRegistered[packageId] = true;\n            return;\n        }\n        const moduleAutoTests = [];\n        const packFunctions = yield grok.dapi.functions.filter(`package.id = \"${packageId}\"`).list();\n        const reg = new RegExp(/.*\\/\\/\\s*skip[:\\s]*(.*)$/);\n        for (const f of packFunctions) {\n            const tests = f.options['test'];\n            if (!(tests && Array.isArray(tests) && tests.length))\n                continue;\n            for (let i = 0; i < tests.length; i++) {\n                const skipReasons = tests[i].match(reg);\n                let skipReason;\n                if (skipReasons && (skipReasons === null || skipReasons === void 0 ? void 0 : skipReasons.length) > 1)\n                    skipReason = skipReasons[1];\n                moduleAutoTests.push(new Test(autoTestsCatName, tests.length === 1 ? f.name : `${f.name} ${i + 1}`, () => __awaiter(this, void 0, void 0, function* () {\n                    const res = yield grok.functions.eval(addNamespace(tests[i], f));\n                    // eslint-disable-next-line no-throw-literal\n                    if (res !== true)\n                        throw `Failed: ${tests[i]}`;\n                }), { skipReason: skipReason }));\n            }\n        }\n        wasRegistered[packageId] = true;\n        if (!moduleAutoTests.length)\n            return;\n        moduleTests[autoTestsCatName] = { tests: moduleAutoTests };\n    });\n}\nexport function runTests(options) {\n    var _a, _b, _c, _d;\n    var _e;\n    return __awaiter(this, void 0, void 0, function* () {\n        const package_ = (_b = (_a = grok.functions.getCurrentCall()) === null || _a === void 0 ? void 0 : _a.func) === null || _b === void 0 ? void 0 : _b.package;\n        yield initAutoTests(package_.id);\n        const results = [];\n        console.log(`Running tests`);\n        options !== null && options !== void 0 ? options : (options = {});\n        (_c = (_e = options).testContext) !== null && _c !== void 0 ? _c : (_e.testContext = new TestContext());\n        grok.shell.lastError = '';\n        for (const [key, value] of Object.entries(tests)) {\n            if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {\n                if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))\n                    continue;\n            }\n            console.log(`Started ${key} category`);\n            try {\n                if (value.before)\n                    yield value.before();\n            }\n            catch (x) {\n                value.beforeStatus = x.toString();\n            }\n            const t = (_d = value.tests) !== null && _d !== void 0 ? _d : [];\n            const res = [];\n            for (let i = 0; i < t.length; i++)\n                res.push(yield execTest(t[i], options === null || options === void 0 ? void 0 : options.test));\n            const data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');\n            try {\n                if (value.after)\n                    yield value.after();\n            }\n            catch (x) {\n                value.afterStatus = x.toString();\n            }\n            if (value.afterStatus)\n                data.push({ category: key, name: 'init', result: value.afterStatus, success: false, ms: 0, skipped: false });\n            if (value.beforeStatus)\n                data.push({ category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0, skipped: false });\n            results.push(...data);\n        }\n        if (options.testContext.catchUnhandled) {\n            yield delay(1000);\n            if (grok.shell.lastError.length > 0) {\n                results.push({\n                    category: 'Unhandled exceptions',\n                    name: 'exceptions',\n                    result: grok.shell.lastError, success: false, ms: 0, skipped: false\n                });\n            }\n        }\n        if (options.testContext.report) {\n            const logger = new DG.Logger();\n            const successful = results.filter((r) => r.success).length;\n            const skipped = results.filter((r) => r.skipped).length;\n            const failed = results.filter((r) => !r.success);\n            const description = 'Package @package tested: @successful successful, @skipped skipped, @failed failed tests';\n            const params = {\n                successful: successful,\n                skipped: skipped,\n                failed: failed.length,\n                package: package_\n            };\n            for (const r of failed)\n                Object.assign(params, { [`${r.category} | ${r.name}`]: r.result });\n            logger.log(description, params, 'package-tested');\n        }\n        return results;\n    });\n}\nfunction execTest(t, predicate) {\n    var _a, _b, _c;\n    return __awaiter(this, void 0, void 0, function* () {\n        let r;\n        const filter = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));\n        const skip = ((_a = t.options) === null || _a === void 0 ? void 0 : _a.skipReason) || filter;\n        const skipReason = filter ? 'skipped' : (_b = t.options) === null || _b === void 0 ? void 0 : _b.skipReason;\n        if (!skip)\n            console.log(`Started ${t.category} ${t.name}`);\n        const start = new Date();\n        try {\n            if (skip)\n                r = { success: true, result: skipReason, ms: 0, skipped: true };\n            else\n                r = { success: true, result: (_c = yield t.test()) !== null && _c !== void 0 ? _c : 'OK', ms: 0, skipped: false };\n        }\n        catch (x) {\n            r = { success: false, result: x.toString(), ms: 0, skipped: false };\n        }\n        const stop = new Date();\n        // @ts-ignore\n        r.ms = stop - start;\n        if (!skip)\n            console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);\n        r.category = t.category;\n        r.name = t.name;\n        return r;\n    });\n}\n/* Waits [ms] milliseconds */\nexport function delay(ms) {\n    return __awaiter(this, void 0, void 0, function* () {\n        yield new Promise((r) => setTimeout(r, ms));\n    });\n}\nexport function awaitCheck(checkHandler, error = 'Timeout exceeded', wait = 500, interval = 50) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return new Promise((resolve, reject) => {\n            setTimeout(() => {\n                clearInterval(intervalId);\n                reject(new Error(error));\n            }, wait);\n            // @ts-ignore\n            const intervalId = setInterval(() => {\n                if (checkHandler()) {\n                    clearInterval(intervalId);\n                    resolve();\n                }\n            }, interval);\n        });\n    });\n}\nexport function isDialogPresent(dialogTitle) {\n    const dialogs = DG.Dialog.getOpenDialogs();\n    for (let i = 0; i < dialogs.length; i++) {\n        if (dialogs[i].title == dialogTitle)\n            return true;\n    }\n    return false;\n}\nexport function testViewer(v, df, detectSemanticTypes = false) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (detectSemanticTypes)\n            yield grok.data.detectSemanticTypes(df);\n        const tv = grok.shell.addTableView(df);\n        const viewerName = `[name=viewer-${v.replace(/\\s+/g, '-')} i]`;\n        const selector = `${viewerName} canvas,${viewerName} svg,${viewerName} img,\n    ${viewerName} input,${viewerName} h1,${viewerName} a`;\n        const res = [];\n        try {\n            let viewer = tv.addViewer(v);\n            yield awaitCheck(() => document.querySelector(selector) !== null, 'cannot load viewer', 3000);\n            res.push(Array.from(tv.viewers).length);\n            Array.from(df.row(0).cells).forEach((c) => c.value = null);\n            df.rows.select((row) => row.idx > 1 && row.idx < 7);\n            for (let i = 7; i < 12; i++)\n                df.filter.set(i, false);\n            df.currentRowIdx = 1;\n            const props = viewer.getOptions(true).look;\n            const newProps = {};\n            Object.keys(props).filter((k) => typeof props[k] === 'boolean').forEach((k) => newProps[k] = !props[k]);\n            viewer.setOptions(newProps);\n            yield delay(250);\n            const layout = tv.saveLayout();\n            const oldProps = viewer.getOptions().look;\n            tv.resetLayout();\n            res.push(Array.from(tv.viewers).length);\n            tv.loadLayout(layout);\n            yield awaitCheck(() => document.querySelector(selector) !== null, 'cannot load viewer from layout', 3000);\n            yield delay(250);\n            res.push(Array.from(tv.viewers).length);\n            viewer = Array.from(tv.viewers).find((v) => v.type !== 'Grid');\n            expectArray(res, [2, 1, 2]);\n            expect(JSON.stringify(viewer.getOptions().look), JSON.stringify(oldProps));\n        }\n        finally {\n            tv.close();\n            grok.shell.closeTable(df);\n        }\n    });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport {Observable, Subscription} from 'rxjs';\nimport Timeout = NodeJS.Timeout;\nimport {DataFrame} from 'datagrok-api/dg';\n\nexport const tests: {\n  [key: string]: {\n    tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>,\n    beforeStatus?: string, afterStatus?: string\n  }\n} = {};\n\nconst autoTestsCatName = 'Auto Tests';\nconst wasRegistered: {[key: string]: boolean} = {};\nexport let currentCategory: string;\n\nexport namespace assure {\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw new Error(`${name == null ? 'Value' : name} not defined`);\n  }\n}\n\nexport interface TestOptions {\n  timeout?: number;\n  unhandledExceptionTimeout?: number;\n  skipReason?: string;\n}\n\nexport class TestContext {\n  catchUnhandled = true;\n  report = false;\n\n  constructor(catchUnhandled?: boolean, report?: boolean) {\n    if (catchUnhandled !== undefined) this.catchUnhandled = catchUnhandled;\n    if (report !== undefined) this.report = report;\n  };\n}\n\nexport class Test {\n  test: () => Promise<any>;\n  name: string;\n  category: string;\n  options?: TestOptions;\n\n  constructor(category: string, name: string, test: () => Promise<any>, options?: TestOptions) {\n    this.category = category;\n    this.name = name;\n    options ??= {};\n    options.timeout ??= 30000;\n    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport async function testEvent<T>(event: Observable<T>,\n  handler: (args: T) => void, trigger: () => void, ms: number = 0): Promise<string> {\n  let sub: Subscription;\n  return new Promise((resolve, reject) => {\n    sub = event.subscribe((args) => {\n      try {\n        handler(args);\n      } catch (e) {\n        reject(e);\n      }\n      sub.unsubscribe();\n      resolve('OK');\n    });\n    setTimeout(() => {\n      sub.unsubscribe();\n      // eslint-disable-next-line prefer-promise-reject-errors\n      reject('timeout');\n    }, ms);\n    trigger();\n  });\n}\n\nexport function test(name: string, test: () => Promise<any>, options?: TestOptions): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  if (tests[currentCategory].tests == undefined)\n    tests[currentCategory].tests = [];\n  tests[currentCategory].tests!.push(new Test(currentCategory, name, test, options));\n}\n\n/* Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual: any, expected: any = true, error?: string): void {\n  if (error)\n    error = `${error}, `;\n  else error = '';\n  if (actual !== expected)\n    throw new Error(`${error}Expected \"${expected}\", got \"${actual}\"`);\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001, error?: string): void {\n  if ((actual === Number.POSITIVE_INFINITY && expected === Number.POSITIVE_INFINITY) ||\n      (actual === Number.NEGATIVE_INFINITY && expected === Number.NEGATIVE_INFINITY) ||\n      (actual === Number.NaN && expected === Number.NaN) || (isNaN(actual) && isNaN(expected)))\n    return;\n  const areEqual = Math.abs(actual - expected) < tolerance;\n  expect(areEqual, true, `${error ?? ''} (tolerance = ${tolerance})`);\n  if (!areEqual)\n    throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);\n}\n\nexport function expectTable(actual: DataFrame, expected: DataFrame, error?: string): void {\n  const expectedRowCount = expected.rowCount;\n  const actualRowCount = actual.rowCount;\n  expect(actualRowCount, expectedRowCount, `${error ?? ''}, row count`);\n\n  for (const column of expected.columns) {\n    const actualColumn = actual.columns.byName(column.name);\n    if (actualColumn == null)\n      throw new Error(`Column ${column.name} not found`);\n    if (actualColumn.type != column.type)\n      throw new Error(`Column ${column.name} type expected ${column.type} got ${actualColumn.type}`);\n    for (let i = 0; i < expectedRowCount; i++) {\n      const value = column.get(i);\n      const actualValue = actualColumn.get(i);\n      if (column.type == DG.TYPE.FLOAT)\n        expectFloat(actualValue, value, 0.0001, error);\n      else if (column.type == DG.TYPE.DATE_TIME)\n        expect(actualValue.isSame(value), true, error);\n      else\n        expect(actualValue, value, error);\n    }\n  }\n}\n\nexport function expectObject(actual: { [key: string]: any }, expected: { [key: string]: any }) {\n  for (const [expectedKey, expectedValue] of Object.entries(expected)) {\n    if (!actual.hasOwnProperty(expectedKey))\n      throw new Error(`Expected property \"${expectedKey}\" not found`);\n\n    const actualValue = actual[expectedKey];\n    if (actualValue instanceof Array && expectedValue instanceof Array)\n      expectArray(actualValue, expectedValue);\n    else if (actualValue instanceof Object && expectedValue instanceof Object)\n      expectObject(actualValue, expectedValue);\n    else if (Number.isFinite(actualValue) && Number.isFinite(expectedValue))\n      expectFloat(actualValue, expectedValue);\n    else if (actualValue != expectedValue)\n      throw new Error(`Expected (${expectedValue}) for key '${expectedKey}', got (${actualValue})`);\n  }\n}\n\nexport function expectArray(actual: ArrayLike<any>, expected: ArrayLike<any>) {\n  const actualLength = actual.length;\n  const expectedLength = expected.length;\n\n  if (actualLength != expectedLength) {\n    throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +\n      `and expected array length is ${expectedLength}`);\n  }\n\n  for (let i = 0; i < actualLength; i++) {\n    if (actual[i] instanceof Array && expected[i] instanceof Array)\n      expectArray(actual[i], expected[i]);\n    else if (actual[i] instanceof Object && expected[i] instanceof Object)\n      expectObject(actual[i], expected[i]);\n    else if (actual[i] != expected[i])\n      throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);\n  }\n}\n\n/* Defines a test suite. */\nexport function category(category: string, tests: () => void): void {\n  currentCategory = category;\n  tests();\n}\n\n/* Defines a function to be executed before the tests in this category are executed. */\nexport function before(before: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].before = before;\n}\n\n/* Defines a function to be executed after the tests in this category are executed. */\nexport function after(after: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].after = after;\n}\n\nfunction addNamespace(s: string, f: DG.Func): string {\n  return s.replace(new RegExp(f.name, 'gi'), f.nqName);\n}\n\nexport async function initAutoTests(packageId: string, module?: any) {\n  if (wasRegistered[packageId]) return;\n  const moduleTests = module ? module.tests : tests;\n  if (moduleTests[autoTestsCatName] !== undefined) {\n    wasRegistered[packageId] = true;\n    return;\n  }\n  const moduleAutoTests = [];\n  const packFunctions = await grok.dapi.functions.filter(`package.id = \"${packageId}\"`).list();\n  const reg = new RegExp(/.*\\/\\/\\s*skip[:\\s]*(.*)$/);\n  for (const f of packFunctions) {\n    const tests = f.options['test'];\n    if (!(tests && Array.isArray(tests) && tests.length)) continue;\n    for (let i = 0; i < tests.length; i++) {\n      const skipReasons = (tests[i] as string).match(reg);\n      let skipReason;\n      if (skipReasons && skipReasons?.length > 1) skipReason = skipReasons[1];\n      moduleAutoTests.push(new Test(autoTestsCatName, tests.length === 1 ? f.name : `${f.name} ${i + 1}`, async () => {\n        const res = await grok.functions.eval(addNamespace(tests[i], f));\n        // eslint-disable-next-line no-throw-literal\n        if (res !== true) throw `Failed: ${tests[i]}`;\n      }, {skipReason: skipReason}));\n    }\n  }\n  wasRegistered[packageId] = true;\n  if (!moduleAutoTests.length) return;\n  moduleTests[autoTestsCatName] = {tests: moduleAutoTests};\n}\n\nexport async function runTests(options?: {category?: string, test?: string, testContext?: TestContext}) {\n  const package_ = grok.functions.getCurrentCall()?.func?.package;\n  await initAutoTests(package_.id);\n  const results: { category?: string, name?: string, success: boolean,\n                   result: string, ms: number, skipped: boolean }[] = [];\n  console.log(`Running tests`);\n  options ??= {};\n  options!.testContext ??= new TestContext();\n  grok.shell.lastError = '';\n  for (const [key, value] of Object.entries(tests)) {\n    if (options?.category != undefined) {\n      if (!key.toLowerCase().startsWith(options?.category.toLowerCase()))\n        continue;\n    }\n    console.log(`Started ${key} category`);\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    const t = value.tests ?? [];\n    const res = [];\n    for (let i = 0; i < t.length; i++)\n      res.push(await execTest(t[i], options?.test));\n    const data = (await Promise.all(res)).filter((d) => d.result != 'skipped');\n    try {\n      if (value.after)\n        await value.after();\n    } catch (x: any) {\n      value.afterStatus = x.toString();\n    }\n    if (value.afterStatus)\n      data.push({category: key, name: 'init', result: value.afterStatus, success: false, ms: 0, skipped: false});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0, skipped: false});\n    results.push(...data);\n  }\n  if (options.testContext.catchUnhandled) {\n    await delay(1000);\n    if (grok.shell.lastError.length > 0) {\n      results.push({\n        category: 'Unhandled exceptions',\n        name: 'exceptions',\n        result: grok.shell.lastError, success: false, ms: 0, skipped: false\n      });\n    }\n  }\n  if (options.testContext.report) {\n    const logger = new DG.Logger();\n    const successful = results.filter((r) => r.success).length;\n    const skipped = results.filter((r) => r.skipped).length;\n    const failed = results.filter((r) => !r.success);\n    const description = 'Package @package tested: @successful successful, @skipped skipped, @failed failed tests';\n    const params = {\n      successful: successful,\n      skipped: skipped,\n      failed: failed.length,\n      package: package_\n    };\n    for (const r of failed) Object.assign(params, {[`${r.category} | ${r.name}`]: r.result});\n    logger.log(description, params, 'package-tested');\n  }\n  return results;\n}\n\nasync function execTest(t: Test, predicate: string | undefined) {\n  let r: { category?: string, name?: string, success: boolean, result: string, ms: number, skipped: boolean };\n  const filter = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));\n  const skip = t.options?.skipReason || filter;\n  const skipReason = filter ? 'skipped' : t.options?.skipReason;\n  if (!skip)\n    console.log(`Started ${t.category} ${t.name}`);\n  const start = new Date();\n  try {\n    if (skip)\n      r = {success: true, result: skipReason!, ms: 0, skipped: true};\n    else\n      r = {success: true, result: await t.test() ?? 'OK', ms: 0, skipped: false};\n  } catch (x: any) {\n    r = {success: false, result: x.toString(), ms: 0, skipped: false};\n  }\n  const stop = new Date();\n  // @ts-ignore\n  r.ms = stop - start;\n  if (!skip)\n    console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\n/* Waits [ms] milliseconds */\nexport async function delay(ms: number) {\n  await new Promise((r) => setTimeout(r, ms));\n}\n\nexport async function awaitCheck(checkHandler: () => boolean,\n  error: string = 'Timeout exceeded', wait: number = 500, interval: number = 50): Promise<void> {\n  return new Promise((resolve, reject) => {\n    setTimeout(() => {\n      clearInterval(intervalId);\n      reject(new Error(error));\n    }, wait);\n    // @ts-ignore\n    const intervalId: Timeout = setInterval(() => {\n      if (checkHandler()) {\n        clearInterval(intervalId);\n        resolve();\n      }\n    }, interval);\n  });\n}\n\nexport function isDialogPresent(dialogTitle: string): boolean {\n  const dialogs = DG.Dialog.getOpenDialogs();\n  for (let i = 0; i < dialogs.length; i++) {\n    if (dialogs[i].title == dialogTitle)\n      return true;\n  }\n  return false;\n}\n\nexport async function testViewer(v: string, df: DG.DataFrame, detectSemanticTypes: boolean = false): Promise<void> {\n  if (detectSemanticTypes) await grok.data.detectSemanticTypes(df);\n  const tv = grok.shell.addTableView(df);\n  const viewerName = `[name=viewer-${v.replace(/\\s+/g, '-')} i]`;\n  const selector = `${viewerName} canvas,${viewerName} svg,${viewerName} img,\n    ${viewerName} input,${viewerName} h1,${viewerName} a`;\n  const res = [];\n  try {\n    let viewer = tv.addViewer(v);\n    await awaitCheck(() => document.querySelector(selector) !== null,\n      'cannot load viewer', 3000);\n    res.push(Array.from(tv.viewers).length);\n    Array.from(df.row(0).cells).forEach((c) => c.value = null);\n    df.rows.select((row) => row.idx > 1 && row.idx < 7);\n    for (let i = 7; i < 12; i++) df.filter.set(i, false);\n    df.currentRowIdx = 1;\n    const props = viewer.getOptions(true).look;\n    const newProps: Record<string, boolean> = {};\n    Object.keys(props).filter((k) => typeof props[k] === 'boolean').forEach((k) => newProps[k] = !props[k]);\n    viewer.setOptions(newProps);\n    await delay(250);\n    const layout = tv.saveLayout();\n    const oldProps = viewer.getOptions().look;\n    tv.resetLayout();\n    res.push(Array.from(tv.viewers).length);\n    tv.loadLayout(layout);\n    await awaitCheck(() => document.querySelector(selector) !== null,\n      'cannot load viewer from layout', 3000);\n    await delay(250);\n    res.push(Array.from(tv.viewers).length);\n    viewer = Array.from(tv.viewers).find((v) => v.type !== 'Grid')!;\n    expectArray(res, [2, 1, 2]);\n    expect(JSON.stringify(viewer.getOptions().look), JSON.stringify(oldProps));\n  } finally {\n    tv.close();\n    grok.shell.closeTable(df);\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 * as grok from 'datagrok-api/grok';\nimport { delay } from '@datagrok-libraries/utils/src/test';\n/** Demo script class. Could be used for creating demo scripts to show the platform capabilities */\nexport class DemoScript {\n    constructor(name, description, isAutomatic = false, options) {\n        var _a;\n        this.name = '';\n        this.description = '';\n        this._isAutomatic = false;\n        this._autoStartFirstStep = false;\n        this._currentStep = 0;\n        this._isStopped = false;\n        this._isCancelled = false;\n        this._isStepProcessed = false;\n        this._root = ui.div([], { id: 'demo-script',\n            classes: 'tutorials-root tutorials-track demo-app-script' });\n        this._steps = [];\n        this._mainHeader = ui.panel([], 'tutorials-main-header');\n        this._header = ui.h2('');\n        this._headerDiv = ui.divH([], 'tutorials-root-header');\n        this._stopStartBtn = ui.button(ui.iconFA('pause'), () => this._changeStopState(), 'Play / pause');\n        this._restartBtn = ui.button(ui.iconFA('redo'), () => this._restartScript(), 'Restart');\n        this._nextStepBtn = ui.button(ui.iconFA('play'), () => {\n            if (!this._isStepProcessed)\n                this._nextStep();\n        }, 'Next step');\n        this._activity = ui.panel([], 'tutorials-root-description');\n        this._progressDiv = ui.divV([], 'tutorials-root-progress');\n        this._progress = ui.element('progress');\n        this._progressSteps = ui.divText('');\n        this._closeBtn = ui.button(ui.iconFA('chevron-left'), () => this._closeDock(), 'Back to demo');\n        this.name = name;\n        this.description = description;\n        this._isAutomatic = isAutomatic;\n        this._autoStartFirstStep = (_a = options === null || options === void 0 ? void 0 : options.autoStartFirstStep) !== null && _a !== void 0 ? _a : false;\n        this._progress.max = 0;\n        this._progress.value = 1;\n        DemoScript.currentObject = this;\n    }\n    /** Returns demo script steps */\n    get steps() {\n        return this._steps;\n    }\n    /** Returns the amount of demo script steps */\n    get stepNumber() {\n        return this._steps.length;\n    }\n    /** Adds script header */\n    _addHeader() {\n        this._createHeaderDiv();\n        this._createProgressDiv();\n        this._mainHeader.append(this._headerDiv, this._progressDiv);\n    }\n    /** Creates script header div */\n    _createHeaderDiv() {\n        this._header.innerText = this.name;\n        this._headerDiv.append(this._closeBtn);\n        this._headerDiv.append(this._header);\n        this._nextStepBtn.firstChild.className = 'grok-icon fas fa-play';\n        this._headerDiv.append(this._isAutomatic ? this._stopStartBtn : this._nextStepBtn);\n    }\n    /** Creates script progress div */\n    _createProgressDiv() {\n        this._progress.max = this.stepNumber;\n        this._progressDiv.append(this._progress);\n        this._progressSteps = ui.divText(`Step: ${this._progress.value} of ${this.stepNumber}`);\n        this._progressDiv.append(this._progressSteps);\n    }\n    /** Adds description of the script */\n    _addDescription() {\n        var _a;\n        this._activity.append(ui.div(this.description, 'tutorials-root-description'));\n        for (let i = 0; i < this.stepNumber; i++) {\n            let instructionIndicator = ui.iconFA('clock');\n            if (!this._isAutomatic) {\n                if (i === 0) {\n                    instructionIndicator = ui.iconFA('play', () => this._nextStep(), 'Next step');\n                    instructionIndicator.className = 'grok-icon fas fa-play';\n                }\n            }\n            const instructionDiv = ui.div(this._steps[i].name, 'grok-tutorial-entry-instruction');\n            const currentStepDescription = ui.div((_a = this._steps[i].options) === null || _a === void 0 ? void 0 : _a.description, 'grok-tutorial-step-description hidden');\n            const entry = ui.divH([\n                instructionIndicator,\n                instructionDiv,\n            ], 'grok-tutorial-entry');\n            this._activity.append(entry, currentStepDescription);\n        }\n    }\n    /** Initializes the root of the demo script */\n    _initRoot() {\n        var _a, _b, _c;\n        grok.shell.windows.showContextPanel = true;\n        grok.shell.windows.showHelp = false;\n        const scriptDockNode = Array.from(grok.shell.dockManager.rootNode.children)[0];\n        this._node = grok.shell.dockManager.dock(this._root, DG.DOCK_TYPE.FILL, scriptDockNode, '');\n        if ((_b = (_a = scriptDockNode.parent.container.containerElement.firstElementChild) === null || _a === void 0 ? void 0 : _a.lastElementChild) === null || _b === void 0 ? void 0 : _b.classList.contains('tab-handle-list-container'))\n            (_c = scriptDockNode.parent.container.containerElement.firstElementChild) === null || _c === void 0 ? void 0 : _c.lastElementChild.remove();\n        this._node.container.containerElement.classList.add('tutorials-demo-script-container');\n        this._addHeader();\n        this._root.append(this._mainHeader);\n        this._addDescription();\n        this._root.append(this._activity);\n    }\n    /** Processes next step */\n    _nextStep() {\n        var _a, _b;\n        return __awaiter(this, void 0, void 0, function* () {\n            this._isStepProcessed = true;\n            if (!this._isAutomatic) {\n                this._nextStepBtn.classList.add('disabled');\n                this._nextStepBtn.firstChild.classList.add('fa-disabled');\n            }\n            const entry = this._activity.getElementsByClassName('grok-tutorial-entry')[this._currentStep];\n            const entryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n            const entryInstruction = this._activity.getElementsByClassName('grok-tutorial-step-description')[this._currentStep];\n            entryIndicator.className = 'grok-icon far fa-spinner-third fa-spin';\n            entryInstruction.classList.remove('hidden');\n            entryInstruction.classList.add('visible');\n            const currentStep = entry;\n            const stepDelay = ((_a = this._steps[this._currentStep].options) === null || _a === void 0 ? void 0 : _a.delay) ?\n                (_b = this._steps[this._currentStep].options) === null || _b === void 0 ? void 0 : _b.delay : 2000;\n            yield this._steps[this._currentStep].func();\n            this._scrollTo(this._root, currentStep.offsetTop - this._mainHeader.offsetHeight);\n            yield this._countdown(entry, entryIndicator, stepDelay);\n            yield delay(stepDelay);\n            const newEntryIndicator = ui.iconFA('check');\n            entryIndicator.replaceWith(newEntryIndicator);\n            newEntryIndicator.className = 'grok-icon far fa-check';\n            this._progress.value++;\n            this._progressSteps.innerText = `Step: ${this._progress.value} of ${this.stepNumber}`;\n            this._currentStep++;\n            this._isStepProcessed = false;\n            if (this._currentStep === this.stepNumber) {\n                this._isAutomatic ? this._stopStartBtn.replaceWith(this._restartBtn) :\n                    this._nextStepBtn.replaceWith(this._restartBtn);\n                return;\n            }\n            if (!this._isAutomatic) {\n                const nextStepEntryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n                const startNextStepIcon = ui.iconFA('play', () => this._nextStep(), 'Next step');\n                startNextStepIcon.className = 'grok-icon fas fa-play';\n                nextStepEntryIndicator.replaceWith(startNextStepIcon);\n                this._nextStepBtn.classList.remove('disabled');\n                this._nextStepBtn.firstChild.classList.remove('fa-disabled');\n            }\n        });\n    }\n    /** Starts the demo script actions */\n    _startScript() {\n        return __awaiter(this, void 0, void 0, function* () {\n            for (let i = this._currentStep; i < this.stepNumber; i++) {\n                if (this._isStopped || this._isCancelled)\n                    break;\n                yield this._nextStep();\n            }\n        });\n    }\n    /**\n     * Scrolls to the current step\n     * @param element - Current step element in root\n     * @param y - y coordinate of the element\n     */\n    _scrollTo(element, y) {\n        element.focus();\n        element.scrollTop = y;\n    }\n    /**\n     * Adds an interactive delay indicator\n     * @param element - Current step element\n     * @param indicator - Current step indicator\n     * @param time - Indicator animation time\n     */\n    _countdown(element, indicator, time) {\n        return __awaiter(this, void 0, void 0, function* () {\n            const countdownDiv = ui.div([], 'demo-script-countdown');\n            indicator.classList.add('hidden');\n            let countdown = time / 1000;\n            const svg = this._createSVGIndicator(countdown);\n            countdownDiv.append(svg);\n            element.prepend(countdownDiv);\n            const interval = setInterval(() => {\n                countdown--;\n                if (countdown === 0) {\n                    clearInterval(interval);\n                    countdownDiv.remove();\n                    indicator.classList.remove('hidden');\n                    indicator.classList.add('visible');\n                }\n            }, 1000);\n        });\n    }\n    /**\n     * Creates SVG with countdown circle\n     * @param countdown - countdown time\n     * @returns SVG countdown indicator\n     */\n    _createSVGIndicator(countdown) {\n        const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n        const circle = document.createElementNS('http://www.w3.org/2000/svg', 'circle');\n        circle.setAttributeNS(null, 'cx', '7');\n        circle.setAttributeNS(null, 'cy', '7');\n        circle.setAttributeNS(null, 'r', '6');\n        circle.setAttributeNS(null, 'style', `animation: countdown ${countdown}s linear infinite forwards`);\n        svg.append(circle);\n        return svg;\n    }\n    /** Changes the state of the demo script (stop/play) */\n    _changeStopState() {\n        const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n        icon[0].className = 'grok-icon fas fa-play';\n        this._isStopped = !this._isStopped;\n        if (!this._isStopped) {\n            icon[0].className = 'grok-icon fal fa-pause';\n            if (!this._isStepProcessed)\n                this._startScript();\n        }\n    }\n    /** Restarts the script */\n    _restartScript() {\n        grok.shell.dockManager.close(this._node);\n        grok.shell.closeAll();\n        this._clearRoot();\n        this._setInitParams();\n        this.start();\n    }\n    /** Clears the root element */\n    _clearRoot() {\n        this._root = ui.div([], { id: 'demo-script', classes: 'tutorials-root tutorials-track demo-app-script' });\n        this._mainHeader = ui.panel([], 'tutorials-main-header');\n        this._header = ui.h2('');\n        this._headerDiv = ui.divH([], 'tutorials-root-header');\n        this._activity = ui.panel([], 'tutorials-root-description');\n        this._progressDiv = ui.divV([], 'tutorials-root-progress');\n        this._progress = ui.element('progress');\n        this._progressSteps = ui.divText('');\n        this._progress.max = 0;\n        this._progress.value = 1;\n    }\n    /** Sets initial parameters */\n    _setInitParams() {\n        this._currentStep = 0;\n        this._isStopped = false;\n        this._isCancelled = false;\n        const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n        icon[0].className = 'grok-icon fal fa-pause';\n        this._nextStepBtn.classList.remove('disabled');\n    }\n    /** Closes demo script dock */\n    _closeDock() {\n        grok.shell.dockManager.close(this._node);\n        this.cancelScript();\n    }\n    /** Cancels the script */\n    cancelScript() {\n        this._isCancelled = true;\n        DemoScript.currentObject = null;\n    }\n    /**\n     * Adds a new step to script\n     * @param name - Step name\n     * @param func - Step function\n     * @param options - Step options (description and delay after step ends)\n     * @returns Returns the current demo script object\n     */\n    step(name, func, options) {\n        this._steps[this.steps.length] = {\n            name: name,\n            func: func,\n            options: options,\n        };\n        return this;\n    }\n    /** Starts the demo script */\n    start() {\n        return __awaiter(this, void 0, void 0, function* () {\n            this._initRoot();\n            grok.shell.newView(this.name);\n            if (this._isAutomatic) {\n                this._startScript();\n                return;\n            }\n            if (this._autoStartFirstStep)\n                yield this._nextStep();\n        });\n    }\n}\nDemoScript.currentObject = null;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo-script.js","sourceRoot":"","sources":["demo-script.ts"],"names":[],"mappings":"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","sourcesContent":["import * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport * as grok from 'datagrok-api/grok';\n\nimport {delay} from '@datagrok-libraries/utils/src/test';\n\n\n/** Type for {@link DemoScript} step */\nexport type Step = {\n  name: string;\n  func: () => Promise<void>;\n\n  /** Step options: description and delay (in ms) after function ends */\n  options?: {\n    description?: string;\n    delay?: number;\n  }\n};\n\n/** Demo script class. Could be used for creating demo scripts to show the platform capabilities */\nexport class DemoScript {\n  name: string = '';\n  description: string = '';\n\n  static currentObject: DemoScript | null = null;\n\n  private _isAutomatic: boolean = false;\n  private _autoStartFirstStep: boolean = false;\n  private _currentStep: number = 0;\n  private _isStopped: boolean = false;\n  private _isCancelled: boolean = false;\n  private _isStepProcessed: boolean = false;\n\n  private _root: HTMLDivElement = ui.div([], {id: 'demo-script',\n    classes: 'tutorials-root tutorials-track demo-app-script'});\n\n  private _steps: Step[] = [];\n\n  private _mainHeader: HTMLDivElement = ui.panel([], 'tutorials-main-header');\n  private _header: HTMLHeadingElement = ui.h2('');\n  private _headerDiv: HTMLDivElement = ui.divH([], 'tutorials-root-header');\n  private _stopStartBtn: HTMLButtonElement = ui.button(ui.iconFA('pause'),\n    () => this._changeStopState(), 'Play / pause');\n  private _restartBtn: HTMLButtonElement = ui.button(ui.iconFA('redo'), () => this._restartScript(), 'Restart');\n  private _nextStepBtn: HTMLButtonElement = ui.button(ui.iconFA('play'), () => {\n    if (!this._isStepProcessed)\n      this._nextStep();\n  }, 'Next step');\n\n  private _activity: HTMLDivElement = ui.panel([], 'tutorials-root-description');\n\n  private _progressDiv: HTMLDivElement = ui.divV([], 'tutorials-root-progress');\n  private _progress: HTMLProgressElement = ui.element('progress');\n  private _progressSteps: HTMLDivElement = ui.divText('');\n\n  private _node?: DG.DockNode;\n  private _closeBtn: HTMLButtonElement = ui.button(ui.iconFA('chevron-left'), () => this._closeDock(), 'Back to demo');\n\n\n  constructor(name: string, description: string, isAutomatic: boolean = false,\n    options?: {autoStartFirstStep?: boolean}) {\n    this.name = name;\n    this.description = description;\n    this._isAutomatic = isAutomatic;\n    this._autoStartFirstStep = options?.autoStartFirstStep ?? false;\n\n    this._progress.max = 0;\n    this._progress.value = 1;\n\n    DemoScript.currentObject = this;\n  }\n\n  /** Returns demo script steps */\n  get steps(): Step[] {\n    return this._steps;\n  }\n\n  /** Returns the amount of demo script steps */\n  get stepNumber(): number {\n    return this._steps.length;\n  }\n\n\n  /** Adds script header */\n  private _addHeader(): void {\n    this._createHeaderDiv();\n    this._createProgressDiv();\n    this._mainHeader.append(this._headerDiv, this._progressDiv);\n  }\n\n  /** Creates script header div */\n  private _createHeaderDiv(): void {\n    this._header.innerText = this.name;\n    this._headerDiv.append(this._closeBtn);\n    this._headerDiv.append(this._header);\n\n    (this._nextStepBtn.firstChild as HTMLElement).className = 'grok-icon fas fa-play';\n\n    this._headerDiv.append(this._isAutomatic ? this._stopStartBtn : this._nextStepBtn);\n  }\n\n  /** Creates script progress div */\n  private _createProgressDiv(): void {\n    this._progress.max = this.stepNumber;\n    this._progressDiv.append(this._progress);\n    this._progressSteps = ui.divText(`Step: ${this._progress.value} of ${this.stepNumber}`);\n\n    this._progressDiv.append(this._progressSteps);\n  }\n\n  /** Adds description of the script */\n  private _addDescription(): void {\n    this._activity.append(ui.div(this.description, 'tutorials-root-description'));\n\n    for (let i = 0; i < this.stepNumber; i++) {\n      let instructionIndicator = ui.iconFA('clock');\n      if (!this._isAutomatic) {\n        if (i === 0) {\n          instructionIndicator = ui.iconFA('play', () => this._nextStep(), 'Next step');\n          instructionIndicator.className = 'grok-icon fas fa-play';\n        }\n      }\n      const instructionDiv = ui.div(this._steps[i].name, 'grok-tutorial-entry-instruction');\n      const currentStepDescription = ui.div(this._steps[i].options?.description,\n        'grok-tutorial-step-description hidden');\n      const entry = ui.divH([\n        instructionIndicator,\n        instructionDiv,\n      ], 'grok-tutorial-entry');\n\n      this._activity.append(entry, currentStepDescription);\n    }\n  }\n\n  /** Initializes the root of the demo script */\n  private _initRoot(): void {\n    grok.shell.windows.showContextPanel = true;\n    grok.shell.windows.showHelp = false;\n\n    const scriptDockNode = Array.from(grok.shell.dockManager.rootNode.children)[0];\n\n    this._node = grok.shell.dockManager.dock(this._root, DG.DOCK_TYPE.FILL, scriptDockNode, '');\n\n    if (scriptDockNode.parent.container.containerElement.firstElementChild?.lastElementChild?.\n      classList.contains('tab-handle-list-container'))\n      scriptDockNode.parent.container.containerElement.firstElementChild?.lastElementChild.remove();\n\n    this._node.container.containerElement.classList.add('tutorials-demo-script-container');\n\n    this._addHeader();\n    this._root.append(this._mainHeader);\n\n    this._addDescription();\n    this._root.append(this._activity);\n  }\n\n  /** Processes next step */\n  private async _nextStep(): Promise<void> {\n    this._isStepProcessed = true;\n    if (!this._isAutomatic) {\n      this._nextStepBtn.classList.add('disabled');\n      (this._nextStepBtn.firstChild as HTMLElement).classList.add('fa-disabled');\n    }\n\n    const entry = this._activity.getElementsByClassName('grok-tutorial-entry')[this._currentStep];\n    const entryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n    const entryInstruction = this._activity.getElementsByClassName('grok-tutorial-step-description')[this._currentStep];\n\n    entryIndicator.className = 'grok-icon far fa-spinner-third fa-spin';\n    entryInstruction.classList.remove('hidden');\n    entryInstruction.classList.add('visible');\n\n    const currentStep = entry as HTMLDivElement;\n    const stepDelay = this._steps[this._currentStep].options?.delay ?\n      this._steps[this._currentStep].options?.delay! : 2000;\n\n    await this._steps[this._currentStep].func();\n    this._scrollTo(this._root, currentStep.offsetTop - this._mainHeader.offsetHeight);\n    await this._countdown(entry as HTMLElement, entryIndicator as HTMLElement, stepDelay);\n    await delay(stepDelay);\n\n    const newEntryIndicator = ui.iconFA('check');\n    entryIndicator.replaceWith(newEntryIndicator);\n    newEntryIndicator.className = 'grok-icon far fa-check';\n\n    this._progress.value++;\n    this._progressSteps.innerText = `Step: ${this._progress.value} of ${this.stepNumber}`;\n\n    this._currentStep++;\n    this._isStepProcessed = false;\n\n    if (this._currentStep === this.stepNumber) {\n      this._isAutomatic ? this._stopStartBtn.replaceWith(this._restartBtn) :\n        this._nextStepBtn.replaceWith(this._restartBtn);\n      return;\n    }\n\n    if (!this._isAutomatic) {\n      const nextStepEntryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n      const startNextStepIcon = ui.iconFA('play', () => this._nextStep(), 'Next step');\n      startNextStepIcon.className = 'grok-icon fas fa-play';\n      nextStepEntryIndicator.replaceWith(startNextStepIcon);\n      this._nextStepBtn.classList.remove('disabled');\n      (this._nextStepBtn.firstChild as HTMLElement).classList.remove('fa-disabled');\n    }\n  }\n\n  /** Starts the demo script actions */\n  private async _startScript(): Promise<void> {\n    for (let i = this._currentStep; i < this.stepNumber; i++) {\n      if (this._isStopped || this._isCancelled)\n        break;\n\n      await this._nextStep();\n    }\n  }\n\n  /**\n   * Scrolls to the current step\n   * @param element - Current step element in root\n   * @param y - y coordinate of the element\n   */\n  private _scrollTo(element: HTMLDivElement, y: number): void {\n    element.focus();\n    element.scrollTop = y;\n  }\n\n  /**\n   * Adds an interactive delay indicator\n   * @param element - Current step element\n   * @param indicator - Current step indicator\n   * @param time - Indicator animation time\n   */\n  private async _countdown(element: HTMLElement, indicator: HTMLElement, time: number): Promise<void> {\n    const countdownDiv: HTMLDivElement = ui.div([], 'demo-script-countdown');\n\n    indicator.classList.add('hidden');\n\n    let countdown = time / 1000;\n    const svg = this._createSVGIndicator(countdown);\n\n    countdownDiv.append(svg);\n    element.prepend(countdownDiv);\n\n    const interval = setInterval(() => {\n      countdown--;\n      if (countdown === 0) {\n        clearInterval(interval);\n        countdownDiv.remove();\n\n        indicator.classList.remove('hidden');\n        indicator.classList.add('visible');\n      }\n    }, 1000);\n  }\n\n  /**\n   * Creates SVG with countdown circle\n   * @param countdown - countdown time\n   * @returns SVG countdown indicator\n   */\n  private _createSVGIndicator(countdown: number): SVGSVGElement {\n    const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n    const circle = document.createElementNS('http://www.w3.org/2000/svg', 'circle');\n    circle.setAttributeNS(null, 'cx', '7');\n    circle.setAttributeNS(null, 'cy', '7');\n    circle.setAttributeNS(null, 'r', '6');\n    circle.setAttributeNS(null, 'style', `animation: countdown ${countdown}s linear infinite forwards`);\n    svg.append(circle);\n\n    return svg;\n  }\n\n  /** Changes the state of the demo script (stop/play) */\n  private _changeStopState(): void {\n    const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n    icon[0].className = 'grok-icon fas fa-play';\n    this._isStopped = !this._isStopped;\n\n    if (!this._isStopped) {\n      icon[0].className = 'grok-icon fal fa-pause';\n      if (!this._isStepProcessed)\n        this._startScript();\n    }\n  }\n\n  /** Restarts the script */\n  private _restartScript(): void {\n    grok.shell.dockManager.close(this._node!);\n    grok.shell.closeAll();\n    this._clearRoot();\n    this._setInitParams();\n    this.start();\n  }\n\n  /** Clears the root element */\n  private _clearRoot(): void {\n    this._root = ui.div([], {id: 'demo-script', classes: 'tutorials-root tutorials-track demo-app-script'});\n\n    this._mainHeader = ui.panel([], 'tutorials-main-header');\n    this._header = ui.h2('');\n    this._headerDiv = ui.divH([], 'tutorials-root-header');\n\n    this._activity = ui.panel([], 'tutorials-root-description');\n\n    this._progressDiv = ui.divV([], 'tutorials-root-progress');\n    this._progress = ui.element('progress');\n    this._progressSteps = ui.divText('');\n\n    this._progress.max = 0;\n    this._progress.value = 1;\n  }\n\n  /** Sets initial parameters */\n  private _setInitParams(): void {\n    this._currentStep = 0;\n    this._isStopped = false;\n    this._isCancelled = false;\n\n    const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n    icon[0].className = 'grok-icon fal fa-pause';\n    this._nextStepBtn.classList.remove('disabled');\n  }\n\n  /** Closes demo script dock */\n  private _closeDock(): void {\n    grok.shell.dockManager.close(this._node!);\n    this.cancelScript();\n  }\n\n  /** Cancels the script */\n  cancelScript(): void {\n    this._isCancelled = true;\n    DemoScript.currentObject = null;\n  }\n\n  /**\n   * Adds a new step to script\n   * @param name - Step name\n   * @param func - Step function\n   * @param options - Step options (description and delay after step ends)\n   * @returns Returns the current demo script object\n   */\n  step(name: string, func: () => Promise<void>, options?: {description?: string, delay?: number}): this {\n    this._steps[this.steps.length] = {\n      name: name,\n      func: func,\n      options: options,\n    };\n    return this;\n  }\n\n  /** Starts the demo script */\n  async start(): Promise<void> {\n    this._initRoot();\n    grok.shell.newView(this.name);\n\n    if (this._isAutomatic) {\n      this._startScript();\n      return;\n    }\n\n    if (this._autoStartFirstStep)\n      await this._nextStep();\n  }\n}\n"]}","// Runtime system for exported C/C++-functions call.\n// It was previousely developed and does NOT provide call wasm-functions in WebWorkers.\n\n// type-to-heap correspondence\nconst heapMap = {\"i32\": \"HEAP32\", // Int32Array\n                 \"f32\": \"HEAPF32\" // Float32Array\n                };\n\n// type signature to typed array ,app\nconst typeMap = {\"i32\": Int32Array, // Int32Array\n                 \"f32\": Float32Array // Float32Array\n                }; \n \n// type-to-shift map\nconst shiftMap = {\"i32\": 2, // Int32Array\n                  \"f32\": 2 // Float32Array\n                 };\n\n// type-to-column_creator map\nconst typeToColumnCreatorMap = {\"i32\": DG.Column.fromInt32Array,\n                                \"f32\": DG.Column.fromFloat32Array};\n \n\n// CLASSES THAT ARE USED BY CPP-WRAPPER\n\n// simple argument: a number \nclass Arg{\n\n    constructor(data) {\n        this.data = data;        \n    }\n\n    complementArrOfParams(arrOfParams) {\n        arrOfParams.push(this.data);\n    }\n\n    complementArrOfTypes(arrOfTypes) {\n        arrOfTypes.push('number');        \n    }\n\n    allocateMemoryForBuffer(module) {}\n\n    isMemoryForBufferAllocated(){\n        return true;\n    }\n\n    putDataToBuffer(module) {}\n\n    getDataFromBuffer(module) {}\n\n    freeBuffer(module) {}\n}\n\n// column argument\nclass ArgColumn extends Arg {\n\n    constructor(data, targetType, toUpdate = false) {\n        super(data);\n        this.type = targetType;\n        this.toUpdate = toUpdate;\n        this.buf = 0;    \n        this.numOfRows = data.length;\n    }\n\n    complementArrOfParams(arrOfParams) {\n        arrOfParams.push(this.buf);\n        arrOfParams.push(this.numOfRows);\n    }\n\n    complementArrOfTypes(arrOfTypes) {\n        arrOfTypes.push('number');\n        arrOfTypes.push('number');        \n    }\n\n    allocateMemoryForBuffer(module) {\n        this.buf = module._malloc(this.numOfRows * typeMap[this.type].BYTES_PER_ELEMENT);\n    }\n\n    isMemoryForBufferAllocated(){\n        return (this.buf != 0);\n    }\n\n    putDataToBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let shift = shiftMap[type];\n            let heap = module[heapMap[type]];            \n            let array = null;\n            let col = this.data;\n\n            if(((col.type == 'int') && (type == 'i32')) \n               || ((col.type == 'double') && (type == 'f32')))\n              array = col.getRawData();\n            else\n              array = new typeMap[type](col.getRawData());\n\n            if(array) \n              heap.set(array, this.buf >> shift);\n        }\n    }\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let buffer = this.buf;\n            let bytes = typeMap[type].BYTES_PER_ELEMENT;\n            let array = this.data.getRawData();\n\n            for(let i = 0; i < this.numOfRows; i++)\n                array[i] = heap[buffer / bytes + i];\n        }\n    }\n\n    freeBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n           module._free(this.buf);\n           this.buf = 0;\n        }\n    }\n\n}\n\n// new column argument: a new column is created\nclass ArgNewColumn extends ArgColumn {\n    constructor(targetType, numOfRows) {\n        super([], targetType, true);\n        this.numOfRows = numOfRows;\n    }\n\n    putDataToBuffer(module) {}\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let buf = this.buf;\n            \n            let columnCreator = typeToColumnCreatorMap[type];   \n            \n            let arr = new typeMap[type](this.numOfRows);            \n\n            for(let i = 0; i < arr.length; i++)\n                arr[i] = heap[buf / arr.BYTES_PER_ELEMENT + i];\n\n            this.data = columnCreator('name', arr);\n\n            //console.log(arr);\n            \n            // This makes mistake, when this.numOfRows = 5 (TODO: investigate why)\n            //this.data = columnCreator('name', new typeMap[type](heap.buffer, this.buf, this.numOfRows));\n\n            //console.log(this.data.getRawData());\n        }\n    }\n}\n\n// an array of columns argument\nclass ArgColumns extends Arg {\n\n    constructor(data, targetType, toUpdate = false) {\n        super(data);\n        this.type = targetType;\n        this.toUpdate = toUpdate;\n        this.buf = 0;    \n        this.numOfColumns = data.length;\n        this.numOfRows = data[0].length;\n    }\n\n    complementArrOfParams(arrOfParams) {\n        arrOfParams.push(this.buf);\n        arrOfParams.push(this.numOfRows);\n        arrOfParams.push(this.numOfColumns);\n    }\n\n    complementArrOfTypes(arrOfTypes) {\n        arrOfTypes.push('number');\n        arrOfTypes.push('number');\n        arrOfTypes.push('number');        \n    }\n\n    allocateMemoryForBuffer(module) {\n        this.buf = module._malloc(this.numOfRows * this.numOfColumns \n                                  * typeMap[this.type].BYTES_PER_ELEMENT);\n    }\n\n    isMemoryForBufferAllocated(){\n        return (this.buf != 0);\n    }\n\n    putDataToBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let shift = shiftMap[type];\n            let heap = module[heapMap[type]];\n            let numOfBytes = typeMap[type].BYTES_PER_ELEMENT;\n            \n            // put columns data to buffer\n            for(let i = 0; i < this.numOfColumns; i++) {\n                let array = null;\n                let col = this.data[i];\n\n                if(((col.type == 'int') && (type == 'i32')) \n                   || ((col.type == 'double') && (type == 'f32')))\n                     array = col.getRawData();\n                else\n                     array = new typeMap[type](col.getRawData());\n\n                // check data array\n                if(array != null) \n                    heap.set(array, (this.buf + i * this.numOfRows * numOfBytes) >> shift);                                   \n            }\n        }\n    }\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let numOfRows = this.numOfRows;\n            let numOfCols = this.numOfColumns;                 \n            let arr = new typeMap[type](heap.buffer, this.buf, numOfRows * numOfCols);\n       \n            for(let i = 0; i < numOfCols; i++) {\n                let colData = this.data[i].getRawData();\n                for(let j = 0; j < numOfRows; j++)\n                  colData[j] = arr[j + i * numOfRows];                    \n            }\n        }\n    }\n\n    freeBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n           module._free(this.buf);\n           this.buf = 0;\n        }\n    }\n\n}\n\n// an array of new columns: new columns are created\nclass ArgNewColumns extends ArgColumns {\n\n    constructor(targetType, numOfRows, numOfColumns) {\n        super([[]], targetType, true);  \n        this.data = [];        \n        this.numOfColumns = numOfColumns;\n        this.numOfRows = numOfRows;\n    }\n\n    putDataToBuffer(module) { }\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let numOfRows = this.numOfRows;\n            let numOfCols = this.numOfColumns;\n            let numOfBytes = typeMap[type].BYTES_PER_ELEMENT;                       \n            let columnCreator = typeToColumnCreatorMap[type];\n            let buf = this.buf;\n\n            for(let i = 0; i < numOfCols; i++) {\n                let arr = new typeMap[type](numOfRows);\n\n                for(let j = 0; j < numOfRows; j++)\n                    arr[j] = heap[buf / numOfBytes + j + i * numOfRows];\n                \n                this.data.push(columnCreator((i + 1).toString(), arr));\n            }\n\n            // create columns: here, may be a problem when numOfRows = 5            \n            /*for(let i = 0; i < numOfCols; i++)\n                this.data.push(columnCreator((i + 1).toString(), new typeMap[type](heap.buffer, \n                    this.buf + i * numOfRows * numOfBytes, numOfRows)));*/\n        }\n    }\n}\n\n// a wrapper for exported C/C++-function call\nfunction cppFuncWrapper(module, cFuncName, returnType, args)\n{\n    let result;\n\n    // allocate memory for buffers\n    for(let arg of args)         \n        arg.allocateMemoryForBuffer(module);\n    \n    let isEnoughOfMemoryAllocated = true;\n\n    // check memory allocation\n    for(let arg of args)\n        isEnoughOfMemoryAllocated &= arg.isMemoryForBufferAllocated();  \n    \n    // run exported function if enough of memory is allocated\n    if(isEnoughOfMemoryAllocated) {\n\n        let params = []; // arguments that are put to the exported function\n        let types = []; // their types\n\n        // prepare data that is put to exported function\n        for(let arg of args) {\n            arg.complementArrOfParams(params);\n            arg.complementArrOfTypes(types);\n            arg.putDataToBuffer(module);\n        }\n\n        let extendedTypeOfReturn = (returnType == 'num') ? 'number' : null;   \n        \n        // call exported function\n        if(extendedTypeOfReturn)\n            result = module.ccall(cFuncName, extendedTypeOfReturn, types, params);\n        else\n            result = module.ccall(cFuncName, extendedTypeOfReturn, types, params);\n                    \n        // update and get data from buffers if required\n        for(let arg of args)\n            arg.getDataFromBuffer(module);       \n    }\n\n    // clear buffers\n    for(let arg of args)         \n        arg.freeBuffer(module);\n\n    if(result != undefined)\n        return result;    \n} // cppFuncWrapper\n\n\n// A LAYER BETWEEN JS AND CPP-WRAPPER\n\n// Parameters creator\nlet Param = {\n    intColumn (column) {\n        return new ArgColumn(column, 'i32');\n    },\n    \n    newIntColumn (numOfRows) {\n        return new ArgNewColumn('i32', numOfRows);\n    },\n\n    intColumns(columns){\n        return new ArgColumns(columns.toList(), 'i32');\n    },\n\n    newIntColumns(numOfRows, numOfColumns) {\n        return new ArgNewColumns('i32', numOfRows, numOfColumns);\n    },\n\n    floatColumn (column) {\n        return new ArgColumn(column, 'f32');\n    },\n\n    newFloatColumn (numOfRows) {\n        return new ArgNewColumn('f32', numOfRows);\n    },\n\n    floatColumns(columns){\n        return new ArgColumns(columns.toList(), 'f32');\n    },\n\n    newFloatColumns(numOfRows, numOfColumns) {\n        return new ArgNewColumns('f32', numOfRows, numOfColumns);\n    },\n\n    int(number) {\n        return new Arg(number);\n    },\n\n    num(number) {\n        return new Arg(number);\n    }\n};\n\n// Return value creator\nlet Return = {\n    tableFromColumns(argColumns) {\n        return DG.DataFrame.fromColumns(argColumns.data);\n    },\n\n    num(number) {\n        return number;\n    },\n\n    int(number) {\n        return number;\n    },\n\n    double(number) {\n        return number;\n    },\n\n    column(argColumn) {\n        return argColumn.data;\n    }\n};\n\n// The main tool that combines all together\nexport function callWasm(module, funcName, inputs) {\n\n    let start = new Date().getTime();\n\n    // get specification of exported C/C++-function\n    let funcSpecification = module[funcName];\n\n    // get argumnets\n    let args = funcSpecification.arguments; \n\n    // array of arguments that further are used by cpp-wrapper\n    let cppFuncInput = [];\n\n    // complete an input for cpp\n    let i = 0;\n    for(let key in args){\n        let arg = args[key]; \n        \n        // skip auxiliry element\n        if(key == '_callResult')             \n            continue;\n\n        // create an argument\n        switch(arg.type){\n            case 'floatColumns':\n            case 'int':\n            case 'num':\n            case 'floatColumn':\n            case 'intColumn':\n            case 'intColumns':\n                arg.data = Param[arg.type](inputs[i]);\n                i++;\n                break;\n            case 'newFloatColumns':\n            case 'newIntColumns':\n                let val1 = args[ arg['numOfRows']['ref'] ].data[arg['numOfRows']['value']];\n                let val2 = args[ arg['numOfColumns']['ref'] ].data[arg['numOfColumns']['value']];\n                arg.data = Param[arg.type](val1, val2);\n                break;\n            case 'newFloatColumn':\n            case 'newIntColumn':\n                let val = args[ arg['numOfRows']['ref'] ].data[arg['numOfRows']['value']];\n                arg.data = Param[arg.type](val);\n                break;\n            } // switch\n\n        cppFuncInput.push(args[key].data);\n\n    } // for key    \n\n    // CALL EXPORTED CPP-FUNCTION\n    let callResult = cppFuncWrapper(module, funcName, 'num', cppFuncInput);\n\n    console.log('C++-function call result: ' + callResult);\n\n    // store result that is returned by exported cpp-function\n    args._callResult = Param.num(callResult);\n\n    // create output\n    let output = funcSpecification.output;\n\n    let finish = new Date().getTime();\n\n    console.log(`Time for C/C++-function is ${finish - start} ms.`)\n\n    // if a single object must be returned\n    if(output['type'] != 'objects')\n      return Return[output['type']](args[output['source']].data);\n\n    let arrayToReturn = [];\n\n    // push data of the required arguments\n    for(let name of output['source'])\n      arrayToReturn.push(args[name].data.data);\n\n    return arrayToReturn;\n  } // callWasm","// Utilities for calling wasm-functions via webworker.\n\n// We use an approach that is well described here:\n// https://becominghuman.ai/passing-and-returning-webassembly-array-parameters-a0f572c65d97\n// It has been modified for usage in DATAGROK.\n\n// Constants for wasm-functions in webworkers runtime system\nconst TYPE = 'type';\nconst NUM_TYPE = 'num';\nconst FLOAT_COLUMN_TYPE = 'floatColumn';\nconst INT_COLUMN_TYPE = 'intColumn';\nconst FLOAT_COLUMNS_TYPE = 'floatColumns';\nconst NEW_FLOAT_COLUMNS_TYPE = 'newFloatColumns';\nconst INT_COLUMNS_TYPE = 'intColumns';\nconst NEW_INT_COLUMNS_TYPE = 'newIntColumns';\nconst NEW_FLOAT_COLUMN_TYPE = 'newFloatColumn';\nconst NEW_INT_COLUMN_TYPE = 'newIntColumn';\nconst COLUMN = 'column';\nconst CALL_RESULT = '_callResult';\nconst NUM_OF_ROWS = 'numOfRows';\nconst NUM_OF_COLUMNS = 'numOfColumns';\nconst REF = 'ref';\nconst VALUE = 'value';\nconst TABLE_OF_COLUMNS = 'tableFromColumns';\nconst OBJECTS = 'objects';\nconst INT_TYPE = 'int';\nconst DOUBLE_TYPE = 'double';\nconst NUMBER = 'number';\n\n// Type-to-heap correspondence.\n// It is required for JS-module generated by Emscripten,\n// and it is used, when passing array data to/from wasm-functions.\n// More info can be found at the following link:\n// https://becominghuman.ai/passing-and-returning-webassembly-array-parameters-a0f572c65d97\nconst heapMap = {\n                 'intColumn': \"HEAP32\",\n                 'floatColumn': \"HEAPF32\",\n                 'floatColumns': \"HEAPF32\",\n                 'newFloatColumns': \"HEAPF32\",\n                 'intColumns': \"HEAP32\",\n                 'newIntColumns': \"HEAP32\",\n                 'newFloatColumn': \"HEAPF32\",\n                 'newIntColumn': \"HEAP32\"\n                };\n\n// Type signature to typed array map.\n// It is used, when manipulating column(s).\nconst typeMap = {\n                 'intColumn': Int32Array,\n                 'floatColumn': Float32Array,\n                 'floatColumns': Float32Array,\n                 'newFloatColumns': Float32Array,\n                 'intColumns': Int32Array,  \n                 'newIntColumns': Int32Array,\n                 'newFloatColumn': Float32Array,\n                 'newIntColumn': Int32Array\n                }; \n\n// Type-to-shift map.\n// It is used, when passing array to/from wasm-functions.\n// More info can be found at the following link:\n// https://becominghuman.ai/passing-and-returning-webassembly-array-parameters-a0f572c65d97 \nconst shiftMap = {'intColumn': 2, \n                  'floatColumn': 2, \n                  'floatColumns': 2,  \n                  'newFloatColumns': 2, \n                  'intColumns': 2,  \n                  'newIntColumns': 2,\n                  'newFloatColumn': 2,\n                  'newIntColumn': 2\n                 };         \n\n// Get input for C++-function.\n// This function takes specification of arguments (argsSpecification) & input data (inputVals)\n// and returns input that will be further used in cpp/wasm-function.\nexport function getCppInput(argsSpecification, inputVals) {\n    let cppFuncInput = [];\n    let ref;\n\n    // complete an input for cpp\n    let i = 0;\n    for(const key in argsSpecification) {\n        const arg = argsSpecification[key]; \n        const type = arg.type;\n        \n        // skip auxiliry element\n        if(key === CALL_RESULT)             \n            continue;\n\n        // here, we consider each type of input\n        switch(type) {           \n \n            // numbers\n            case NUM_TYPE:                \n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                arg.data = inputVals[i];\n                i++;\n                break;\n\n            // column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n\n                let array;\n\n                // this is OK if type of column and target type coinside\n                //array = inputVals[i].getRawData();\n\n                let col = inputVals[i];\n\n                // here, we check types and perform an appropriate transform\n                if( ( (col.type === INT_TYPE) && (type === INT_COLUMN_TYPE) ) \n                   || ( (col.type === DOUBLE_TYPE) && (type === FLOAT_COLUMN_TYPE) ) )\n                     array = col.getRawData();\n                else\n                     array = new typeMap[type](col.getRawData());\n\n                /*if(((col.type == 'int') && (type == INT_COLUMN_TYPE)) \n                     || ((col.type == 'double') && (type == FLOAT_COLUMN_TYPE)))\n                       array = col.getRawData();\n                else\n                       array = new typeMap[type](col.getRawData());*/\n\n                // check types\n                arg.data = { 'array': array,\n                             'numOfRows': array.length};                             \n               \n                i++;\n                break;\n\n            // new column \n            case NEW_INT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n                let val = 0;                \n\n                ref = arg[NUM_OF_ROWS][REF];\n\n                if (argsSpecification[ref].type === NUM_TYPE)\n                    val = argsSpecification[ref].data;\n                else\n                    val = argsSpecification[ref].data[arg[NUM_OF_ROWS][VALUE]];                                \n\n                arg.data = {'numOfRows': val};\n\n                i++;\n                break;\n\n            // columns or column_list\n            case INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:                \n                let arrays = [];                \n\n                // this is OK if type of columns and target type coinside\n                //for(let col of inputVals[i].toList())\n                //  arrays.push(col.getRawData());\n\n                // here, we check types and perform an appropriate transform\n                for(let col of inputVals[i].toList())\n                  if( ( (col.type === INT_TYPE) && (type === INT_COLUMN_TYPE) ) \n                    || ( (col.type === DOUBLE_TYPE) && (type === FLOAT_COLUMN_TYPE) ) )\n                    arrays.push(col.getRawData());\n                  else\n                    arrays.push(new typeMap[type](col.getRawData()));\n                \n                /*for(let col of inputVals[i].toList())\n                    if(((col.type == 'int') && (type == INT_COLUMN_TYPE)) \n                      || ((col.type == 'double') && (type == FLOAT_COLUMN_TYPE)))\n                      arrays.push(col.getRawData());\n                    else\n                      arrays.push(new typeMap[type](col.getRawData()));*/\n\n                arg.data = { 'arrays': arrays,\n                    'numOfRows': arrays[0].length,\n                    'numOfColumns': arrays.length};\n\n                i++;  \n                break;\n\n            // new columns or new column_list\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                let val1 = 0;\n                let val2 = 0;\n\n                ref = arg[NUM_OF_ROWS][REF];\n\n                if (argsSpecification[ref].type === NUM_TYPE)\n                    val1 = argsSpecification[ref].data;\n                else\n                    val1 = argsSpecification[ref].data[arg[NUM_OF_ROWS][VALUE]];\n\n                ref = arg[NUM_OF_COLUMNS][REF];\n\n                //console.log('Ref:');\n                //console.log(ref);\n                //console.log(argsSpecification[ref].data);\n\n                if (argsSpecification[ref].type === NUM_TYPE)\n                    val2 = argsSpecification[ref].data;\n                else\n                    val2 = argsSpecification[ref].data[arg[NUM_OF_COLUMNS][VALUE]];                \n\n                arg.data = {'numOfRows': val1,\n                  'numOfColumns': val2};\n\n                i++;\n                break;            \n\n            default: \n                return; // TODO: specify behaviour           \n            } // switch        \n\n        cppFuncInput.push(arg);\n    } // for key\n\n    //console.log('cppFuncInput:');\n    //console.log(cppFuncInput);\n\n    return cppFuncInput;\n} // getCppInput\n\n// Allocate memory for buffers for array data\nfunction allocateMemoryForBuffer(module, inputs) {\n    for(const arg of inputs) { \n        const type = arg.type;\n\n        switch(type) { // Process each type of input\n\n            // numbers\n            case NUM_TYPE: \n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // column & new column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                arg.data.buf = module._malloc(arg.data.numOfRows * typeMap[type].BYTES_PER_ELEMENT);\n                break;\n\n            // columns & new columns\n            case INT_COLUMNS_TYPE:             \n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:             \n            case NEW_FLOAT_COLUMNS_TYPE: // allocation memory for columns that are created\n                arg.data.buf = module._malloc(arg.data.numOfRows * arg.data.numOfColumns \n                    * typeMap[type].BYTES_PER_ELEMENT);\n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break; \n        }  \n    }\n    \n    //console.log('inputs after memory allocation:');\n    //console.log(inputs);\n} // allocateMemoryForBuffer\n\n// Get array of values that are put to wasm-function.\nfunction getArrOfWasmParams(inputs) {\n    let params = [];\n\n    // Process each type of input\n    for(const arg of inputs) {\n        switch (arg.type) {\n\n            // numbers\n            case NUM_TYPE:            \n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                params.push(arg.data);\n                break;\n\n            // column & new column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                params.push(arg.data.buf);                \n                params.push(arg.data.numOfRows);\n                break;\n            \n            // columns & new columns\n            case INT_COLUMNS_TYPE:\n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE: \n                params.push(arg.data.buf);\n                params.push(arg.data.numOfRows);\n                params.push(arg.data.numOfColumns);\n                break;\n        \n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n\n    return params;\n} // getArrOfWasmParams\n\n// Get array of types that are put to wasm-function.\nfunction getArrOfWasmTypes(inputs) {\n    let types = [];\n\n    for(const arg of inputs) {\n        switch (arg.type) { // Process each type of input\n\n            // numbers\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                types.push(NUMBER);\n                break;\n\n            // column & new column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                types.push(NUMBER);                \n                types.push(NUMBER);\n                break;\n            \n            // columns & new columns\n            case INT_COLUMNS_TYPE:\n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                types.push(NUMBER);\n                types.push(NUMBER);\n                types.push(NUMBER);\n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n\n    return types;\n} // getArrOfWasmTypes\n\n// Put array data to buffer\nfunction putDataToBuffer(module, inputs) {\n    let shift;\n    let heap;    \n    \n    for(const arg of inputs) {\n        const type = arg.type;\n\n        switch (type) { // Process each type of input\n\n            // numbers\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:                \n                break;\n                \n            // column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:                \n                shift = shiftMap[type];\n                heap = module[heapMap[type]];  \n                heap.set(arg.data.array, arg.data.buf >> shift);\n                break;\n            \n            // columns\n            case INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n                shift = shiftMap[type];\n                heap = module[heapMap[type]];\n                let numOfBytes = typeMap[type].BYTES_PER_ELEMENT;\n                let buf = arg.data.buf;\n                let numOfColumns = arg.data.numOfColumns;\n                let numOfRows = arg.data.numOfRows;\n                let arrays = arg.data.arrays;\n\n                for(let i = 0; i < numOfColumns; i++)\n                    heap.set(arrays[i], (buf + i * numOfRows * numOfBytes) >> shift);\n                                \n                break;\n\n            // new column(s)\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:                \n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n} // putDataToBuffer\n\n// Get array data from buffer.\nfunction getDataFromBuffer(module, inputs) {\n\n    let heap;\n    let numOfRows;\n    let numOfCols;\n    let numOfBytes;    \n    let buf;\n\n    for(const arg of inputs) {\n        const type = arg.type;\n\n        switch (type) { // Process each type of input\n            \n            // number\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // column(s)\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case FLOAT_COLUMNS_TYPE:  \n            case INT_COLUMNS_TYPE:          \n                break;\n\n            // new column\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                heap = module[heapMap[type]];\n                numOfRows = arg.data.numOfRows;\n                numOfBytes = typeMap[type].BYTES_PER_ELEMENT;    \n                buf = arg.data.buf;\n                let array = new typeMap[type](numOfRows);\n\n                for(let j = 0; j < numOfRows; j++)\n                    array[j] = heap[buf / numOfBytes + j];\n\n                arg.array = array;\n\n                break;\n\n            // new columns\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE: \n                heap = module[heapMap[type]];\n                numOfRows = arg.data.numOfRows;\n                numOfCols = arg.data.numOfColumns;\n                numOfBytes = typeMap[type].BYTES_PER_ELEMENT;    \n                buf = arg.data.buf;\n                let arrays = [];\n\n                for(let i = 0; i < numOfCols; i++) {\n                   let arr = new typeMap[type](numOfRows);\n\n                   for(let j = 0; j < numOfRows; j++)\n                      arr[j] = heap[buf / numOfBytes + j + i * numOfRows];               \n                \n                   arrays.push(arr);\n                }\n\n                arg.arrays = arrays;\n                \n                break;\n        \n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }            \n} // getDataFromBuffer\n\n// Clear memory allocated for array data\nfunction clearMemoryForBuffer(module, inputs) {\n    for(const arg of inputs) \n        switch(arg.type) { // process each type of input\n\n            // number\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // each non-number case\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:                \n            case INT_COLUMNS_TYPE:\n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                module._free(arg.data.buf);\n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break; \n        }    \n} // clearMemoryForBuffer\n\n// Extract newly created data: new column(s) are created\nfunction extractNewlyCreatedData(funcSpecificationArgs, argsAfterWasmCall) {\n    // type-to-column_creator map\n    const typeToColumnCreatorMap = {'newFloatColumns': DG.Column.fromFloat32Array,\n                                    'newIntColumns': DG.Column.fromInt32Array,\n                                    'newFloatColumn': DG.Column.fromFloat32Array,\n                                    'newIntColumn': DG.Column.fromInt32Array};\n\n    let i = 0;\n\n    for(const key in funcSpecificationArgs) \n    {\n        const arg = funcSpecificationArgs[key];\n\n        switch(arg.type){ // Process each type\n\n            // number\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // column(s)\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case INT_COLUMNS_TYPE:\n                break;\n\n            // new column\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                let name;\n\n                // specify name for column\n                if(arg.name == undefined)\n                    name = (0).toString();\n                else \n                    names = arg.name;\n\n                arg.column = typeToColumnCreatorMap[arg.type](name,\n                    argsAfterWasmCall[i].array);\n                break;\n\n            // new columns\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                let columns = [];\n                let length = argsAfterWasmCall[i].arrays.length;\n\n                let names = [];\n\n                // specify name for column\n                if(arg.names == undefined)\n                    for(let k = 1; k <= length; k++)\n                        names.push((k).toString());\n                else names = arg.names;\n\n                for(let j = 0; j < length; j++)\n                    columns.push(typeToColumnCreatorMap[arg.type](names[j],\n                        argsAfterWasmCall[i].arrays[j]));\n\n                arg.columns = columns;\n                \n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n\n        i++;\n    }\n} // extractNewlyCreatedData\n\n// Get output data: overall output is created\nfunction getOutput(funcSpecification) {  \n    let output = funcSpecification.output;\n    \n    const typeToDataFieldMap = {'newFloatColumns': 'columns',\n                                'newIntColumns': 'columns',\n                                'newFloatColumn': 'column',\n                                'newIntColumn': 'column'};\n\n    switch(output.type) {\n\n        case NUM_TYPE:\n        case INT_TYPE:\n        case DOUBLE_TYPE:\n            return funcSpecification.arguments[output.source];\n            break;\n\n        case COLUMN:\n            return funcSpecification.arguments[output.source].column;\n            break;\n\n        case TABLE_OF_COLUMNS:\n            return DG.DataFrame.fromColumns(funcSpecification.arguments[output.source].columns);\n            break;\n\n        case OBJECTS:\n            let arrayToReturn = [];\n            \n            // push data of the required arguments\n            for(let name of output.source) {\n                let arg = funcSpecification.arguments[name];\n                arrayToReturn.push(arg[typeToDataFieldMap[arg.type]]);\n            }                \n\n            return arrayToReturn;\n            break;\n\n        // TODO: process other cases and mistakes\n        default:\n            break;\n    }\n\n} // getOutput\n\n// Clear newly created data fields (new column(s))\nfunction clearNewlyCreatedData(funcSpecificationArgs) { \n    for(const key in funcSpecificationArgs) {\n        const arg = funcSpecificationArgs[key];\n\n        switch (arg.type) {\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:            \n            case INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n                break;\n\n            case NEW_INT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n                arg.column = null;                \n                break;\n\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                arg.columns = null;\n                break;\n        \n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n} // clearNewlyCreatedData\n\n// THE MAIN FUNCTION: a wrapper for C++-function call\nexport function cppWrapper(module, args, cppFuncName, returnType) {\n    // allocate memory for arrays that are passed to C++-function\n    allocateMemoryForBuffer(module, args);\n\n    // put data (just column(s)) to allocated buffers\n    putDataToBuffer(module, args);\n\n    // create array of parameters that are passed to C++-function\n    let params = getArrOfWasmParams(args);\n\n    //console.log('params:');\n    //console.log(params);\n\n    // create array of parameters' types that are passed to C++-function\n    let types = getArrOfWasmTypes(args);\n    \n    //console.log('types:');\n    //console.log(types);\n\n    // call wasm-function\n    let result = module.ccall(cppFuncName, returnType, types, params);\n    \n    //console.log(result);\n\n    // get data from buffers (just column(s))\n    getDataFromBuffer(module, args);        \n\n    // clear memory that was previousely allocated\n    clearMemoryForBuffer(module, args);\n\n    //console.log('done');\n\n    return result;\n}\n\n// Get the required output.\n// It takes a specification of the function and the data computed\n// and extracts the required results.\nexport function getResult(funcSpecification, dataFromWebWorker) {\n    funcSpecification.arguments._callResult = dataFromWebWorker.callResult;  \n\n    extractNewlyCreatedData(funcSpecification.arguments, dataFromWebWorker.args);    \n\n    let outPut = getOutput(funcSpecification);\n\n    // Below, we remove newly created column(s), which are created at the extraction-step.\n    // It is especially required, when multiple call of wasm-functions in webworker.\n    clearNewlyCreatedData(funcSpecification.arguments);\n\n    return outPut;\n}","// Inputs correctness check tools\n//Limitation constants\nconst COMP_MIN = 1;\nconst SAMPLES_COUNT_MIN = 1;\nconst FEATURES_COUNT_MIN = 1;\nconst PERCENTAGE_MIN = 0;\nconst PERCENTAGE_MAX = 100;\nconst MAX_ELEMENTS_COUNT = 100000000;\n// Error messages\nconst COMP_POSITVE_MES = 'components must be positive.';\nconst COMP_EXCESS = 'components must not be greater than feautures count.';\nconst INCORERRECT_MIN_MAX_MES = 'min must be less than max.';\nconst INCORERRECT_FEATURES_MES = 'features must be positive.';\nconst INCORERRECT_SAMPLES_MES = 'samples must be positive.';\nconst INCORERRECT_PERCENTAGE_MES = 'violators percentage must be from the range from 0 to 100.';\nconst DATAFRAME_IS_TOO_BIG_MES = 'dataframe is too big.';\n// Check components count (PCA, PLS)\nexport function checkComponenets(features, components) {\n    if (components < COMP_MIN)\n        throw new Error(COMP_POSITVE_MES);\n    if (components > features.length)\n        throw new Error(COMP_EXCESS);\n    if (features.length * features.byIndex(0).length > MAX_ELEMENTS_COUNT)\n        throw new Error(DATAFRAME_IS_TOO_BIG_MES);\n}\n// Check inputs of data for SVM testing generator\nexport function checkGeneratorSVMinputs(samplesCount, featuresCount, min, max, violatorsPercentage) {\n    if (min >= max)\n        throw new Error(INCORERRECT_MIN_MAX_MES);\n    if (featuresCount < FEATURES_COUNT_MIN)\n        throw new Error(INCORERRECT_FEATURES_MES);\n    if (samplesCount < SAMPLES_COUNT_MIN)\n        throw new Error(INCORERRECT_SAMPLES_MES);\n    if ((violatorsPercentage < PERCENTAGE_MIN) || (violatorsPercentage > PERCENTAGE_MAX))\n        throw new Error(INCORERRECT_PERCENTAGE_MES);\n}\n","// Exploratory data analysis (EDA) tools\nvar __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 { _principalComponentAnalysisInWebWorker, _partialLeastSquareRegressionInWebWorker } from '../wasm/EDAAPI';\nimport { checkComponenets } from './utils';\n// Principal components analysis (PCA)\nexport function computePCA(table, features, components, center, scale) {\n    return __awaiter(this, void 0, void 0, function* () {\n        checkComponenets(features, components);\n        const centerNum = center ? 1 : 0;\n        const scaleNum = scale ? 1 : 0;\n        let _output;\n        let _promise = _principalComponentAnalysisInWebWorker(table, features, components, centerNum, scaleNum);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        return _output;\n    });\n}\n// Partial least square regression (PLS)\nexport function computePLS(table, features, predict, components) {\n    return __awaiter(this, void 0, void 0, function* () {\n        checkComponenets(features, components);\n        let _output;\n        let _promise = _partialLeastSquareRegressionInWebWorker(table, features, predict, components);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        return _output;\n    });\n}\n","// The following code is generated automatically.\n// JavaScript API for call wasm-functions from the module EDA\n\n// Imports for call wasm runtime-system: in the main stream and in webworkers\nimport {callWasm} from '../wasm/callWasm';\nimport {getCppInput, getResult} from '../wasm/callWasmForWebWorker';\n\nexport async function _initEDAAPI() {\n  await initEDA();\n}\n\nexport function _principalComponentAnalysis(table, columns, componentsCount, centerNum, scaleNum) {\n  return callWasm(EDA, 'principalComponentAnalysis', [columns, componentsCount, centerNum, scaleNum]);\n}\n\nexport async function _principalComponentAnalysisInWebWorker(table, columns, componentsCount, centerNum, scaleNum) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/principalComponentAnalysisWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['principalComponentAnalysis'].arguments,[columns, componentsCount, centerNum, scaleNum]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['principalComponentAnalysis'], e.data));\n    }\n  });\n}\n\nexport function _error(df, col1, col2) {\n  return callWasm(EDA, 'error', [col1, col2]);\n}\n\nexport async function _errorInWebWorker(df, col1, col2) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/errorWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['error'].arguments,[col1, col2]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['error'], e.data));\n    }\n  });\n}\n\nexport function _partialLeastSquareRegression(table, features, predict, componentsCount) {\n  return callWasm(EDA, 'partialLeastSquareRegression', [features, predict, componentsCount]);\n}\n\nexport async function _partialLeastSquareRegressionInWebWorker(table, features, predict, componentsCount) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/partialLeastSquareRegressionWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['partialLeastSquareRegression'].arguments,[features, predict, componentsCount]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['partialLeastSquareRegression'], e.data));\n    }\n  });\n}\n\nexport function _generateDataset(kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage) {\n  return callWasm(EDA, 'generateDataset', [kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage]);\n}\n\nexport async function _generateDatasetInWebWorker(kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/generateDatasetWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['generateDataset'].arguments,[kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['generateDataset'], e.data));\n    }\n  });\n}\n\nexport function _normalizeDataset(data) {\n  return callWasm(EDA, 'normalizeDataset', [data]);\n}\n\nexport async function _normalizeDatasetInWebWorker(data) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/normalizeDatasetWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['normalizeDataset'].arguments,[data]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['normalizeDataset'], e.data));\n    }\n  });\n}\n\nexport function _trainLSSVM(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels) {\n  return callWasm(EDA, 'trainLSSVM', [gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels]);\n}\n\nexport async function _trainLSSVMInWebWorker(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/trainLSSVMWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['trainLSSVM'].arguments,[gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['trainLSSVM'], e.data));\n    }\n  });\n}\n\nexport function _predictByLSSVM(kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData) {\n  return callWasm(EDA, 'predictByLSSVM', [kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData]);\n}\n\nexport async function _predictByLSSVMInWebWorker(kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/predictByLSSVMWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['predictByLSSVM'].arguments,[kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['predictByLSSVM'], e.data));\n    }\n  });\n}\n\nexport function _trainAndAnalyzeLSSVM(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels) {\n  return callWasm(EDA, 'trainAndAnalyzeLSSVM', [gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels]);\n}\n\nexport async function _trainAndAnalyzeLSSVMInWebWorker(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/trainAndAnalyzeLSSVMWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['trainAndAnalyzeLSSVM'].arguments,[gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['trainAndAnalyzeLSSVM'], e.data));\n    }\n  });\n}\n\n","// Custom UI for Exploratory data analysis (EDA) tools\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\n// Rename PCA columns\nexport function renamePCAcolumns(pcaTable) {\n    for (const col of pcaTable.columns.toList())\n        col.name = 'PCA' + col.name;\n    return pcaTable;\n}\n// Predicted vs Reference scatter plot\nexport function predictedVersusReferenceScatterPlot(samplesNames, reference, prediction) {\n    prediction.name = reference.name + '(predicted)';\n    let dfReferencePrediction = DG.DataFrame.fromColumns([samplesNames, reference, prediction]);\n    dfReferencePrediction.name = 'Reference vs. Predicted';\n    return DG.Viewer.scatterPlot(dfReferencePrediction, { title: dfReferencePrediction.name,\n        x: reference.name,\n        y: prediction.name,\n        showRegressionLine: true,\n        markerType: 'circle',\n        labels: samplesNames.name\n    });\n}\n// Regression Coefficients Bar Chart\nexport function regressionCoefficientsBarChart(features, regressionCoeffs) {\n    regressionCoeffs.name = 'regression coefficient';\n    let namesOfPredictors = [];\n    for (const col of features)\n        namesOfPredictors.push(col.name);\n    let predictorNamesColumn = DG.Column.fromStrings('feature', namesOfPredictors);\n    let dfRegrCoefs = DG.DataFrame.fromColumns([predictorNamesColumn, regressionCoeffs]);\n    dfRegrCoefs.name = 'Regression Coefficients';\n    return DG.Viewer.barChart(dfRegrCoefs, { title: dfRegrCoefs.name, split: 'feature',\n        value: 'regression coefficient', valueAggrType: 'avg' });\n}\n// Scores Scatter Plot\nexport function scoresScatterPlot(samplesNames, xScores, yScores) {\n    let scoresColumns = [samplesNames];\n    for (let i = 0; i < xScores.length; i++) {\n        xScores[i].name = `x.score.t${i + 1}`;\n        scoresColumns.push(xScores[i]);\n    }\n    for (let i = 0; i < yScores.length; i++) {\n        yScores[i].name = `y.score.u${i + 1}`;\n        scoresColumns.push(yScores[i]);\n    }\n    let scores = DG.DataFrame.fromColumns(scoresColumns);\n    scores.name = 'Scores';\n    //grok.shell.addTableView(scores);\n    const index = xScores.length > 1 ? 1 : 0;\n    return DG.Viewer.scatterPlot(scores, { title: scores.name,\n        x: xScores[0].name,\n        y: xScores[index].name,\n        markerType: 'circle',\n        labels: samplesNames.name\n    });\n}\n// Loading Scatter Plot\nexport function loadingScatterPlot(features, xLoadings) {\n    let loadingCols = [];\n    let loadingLabels = [];\n    for (let col of features)\n        loadingLabels.push(col.name);\n    loadingCols.push(DG.Column.fromStrings('labels', loadingLabels));\n    for (let i = 0; i < xLoadings.length; i++) {\n        xLoadings[i].name = `x.loading.p${i + 1}`;\n        loadingCols.push(xLoadings[i]);\n    }\n    let dfLoadings = DG.DataFrame.fromColumns(loadingCols);\n    dfLoadings.name = 'Loadings';\n    return DG.Viewer.scatterPlot(dfLoadings, { title: dfLoadings.name,\n        x: xLoadings[0].name,\n        y: xLoadings[xLoadings.length - 1].name,\n        markerType: 'circle',\n        labels: 'labels'\n    });\n}\n// Add PLS visualization\nexport function addPLSvisualization(table, samplesNames, features, predict, plsOutput) {\n    let view = grok.shell.getTableView(table.name);\n    // 1. Predicted vs Reference scatter plot\n    view.addViewer(predictedVersusReferenceScatterPlot(samplesNames, predict, plsOutput[0]));\n    // 2. Regression Coefficients Bar Chart\n    view.addViewer(regressionCoefficientsBarChart(features, plsOutput[1]));\n    // 3. Loading Scatter Plot\n    view.addViewer(loadingScatterPlot(features, plsOutput[4]));\n    // 4. Scores Scatter Plot\n    view.addViewer(scoresScatterPlot(samplesNames, plsOutput[2], plsOutput[3]));\n}\n","// Test data generation tools\nvar __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 { checkGeneratorSVMinputs } from './utils';\nimport { _generateDatasetInWebWorker } from '../wasm/EDAAPI';\nconst SVM_GEN_FEATURES_INDEX = 0;\nconst SVM_GEN_LABELS_INDEX = 1;\nconst SVM_FEATURE_NAME = 'Feature #';\nconst SVM_LABEL_NAME = 'Label';\n// Returns the dataframe \"cars\"\nexport function carsDataframe() {\n    return DG.DataFrame.fromColumns([\n        DG.Column.fromStrings('model', ['alfaromeo', 'audi', 'bmw', 'chevrolet', 'dodge1', 'dodge2', 'honda1', 'honda2', 'isuzu', 'jaguar', 'mazda', 'mercedes', 'mercury', 'mitsubishi', 'nissan1', 'nissan2', 'peugot', 'plymouth', 'porsche', 'saab', 'subaru', 'toyota1', 'toyota2', 'toyota3', 'toyota4', 'volkswagen1', 'volkswagen2', 'volvo1', 'volvo2', 'volvo3']),\n        DG.Column.fromInt32Array('diesel', new Int32Array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 1])),\n        DG.Column.fromInt32Array('turbo', new Int32Array([0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1])),\n        DG.Column.fromInt32Array('two.doors', new Int32Array([1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0])),\n        DG.Column.fromInt32Array('hatchback', new Int32Array([1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0])),\n        DG.Column.fromFloat32Array('wheel.base', new Float32Array([94.5, 105.80000305175781, 101.19999694824219, 94.5, 93.69999694824219, 93.69999694824219, 93.69999694824219, 96.5, 94.30000305175781, 113, 93.0999984741211, 115.5999984741211, 102.69999694824219, 93.69999694824219, 94.5, 94.5, 93.69999694824219, 114.19999694824219, 89.5, 99.0999984741211, 97.19999694824219, 95.69999694824219, 95.69999694824219, 98.4000015258789, 102.4000015258789, 97.30000305175781, 100.4000015258789, 104.30000305175781, 109.0999984741211, 109.0999984741211])),\n        DG.Column.fromFloat32Array('length', new Float32Array([171.1999969482422, 192.6999969482422, 176.8000030517578, 158.8000030517578, 157.3000030517578, 157.3000030517578, 150, 175.39999389648438, 170.6999969482422, 199.60000610351562, 166.8000030517578, 202.60000610351562, 178.39999389648438, 157.3000030517578, 170.1999969482422, 165.3000030517578, 157.3000030517578, 198.89999389648438, 168.89999389648438, 186.60000610351562, 172, 158.6999969482422, 166.3000030517578, 176.1999969482422, 175.60000610351562, 171.6999969482422, 180.1999969482422, 188.8000030517578, 188.8000030517578, 188.8000030517578])),\n        DG.Column.fromFloat32Array('width', new Float32Array([65.5, 71.4000015258789, 64.80000305175781, 63.599998474121094, 63.79999923706055, 63.79999923706055, 64, 65.19999694824219, 61.79999923706055, 69.5999984741211, 64.19999694824219, 71.69999694824219, 68, 64.4000015258789, 63.79999923706055, 63.79999923706055, 63.79999923706055, 68.4000015258789, 65, 66.5, 65.4000015258789, 63.599998474121094, 64.4000015258789, 65.5999984741211, 66.5, 65.5, 66.9000015258789, 67.19999694824219, 68.80000305175781, 68.9000015258789])),\n        DG.Column.fromFloat32Array('height', new Float32Array([52.400001525878906, 55.70000076293945, 54.29999923706055, 52, 50.79999923706055, 50.599998474121094, 52.599998474121094, 54.099998474121094, 53.5, 52.79999923706055, 54.099998474121094, 56.29999923706055, 54.79999923706055, 50.79999923706055, 53.5, 54.5, 50.599998474121094, 58.70000076293945, 51.599998474121094, 56.099998474121094, 52.5, 54.5, 53, 52, 54.900001525878906, 55.70000076293945, 55.099998474121094, 56.20000076293945, 55.5, 55.5])),\n        DG.Column.fromInt32Array('curb.weight', new Int32Array([2823, 2844, 2395, 1909, 2128, 1967, 1956, 2304, 2337, 4066, 1950, 3770, 2910, 1918, 2024, 1951, 1967, 3430, 2800, 2695, 2190, 1985, 2275, 2551, 2480, 2261, 2661, 2912, 3049, 3217])),\n        DG.Column.fromInt32Array('eng.size', new Int32Array([152, 136, 108, 90, 98, 90, 92, 110, 111, 258, 91, 183, 140, 92, 97, 97, 90, 152, 194, 121, 108, 92, 110, 146, 110, 97, 136, 141, 141, 145])),\n        DG.Column.fromInt32Array('horsepower', new Int32Array([154, 110, 101, 70, 102, 68, 76, 86, 78, 176, 68, 123, 175, 68, 69, 69, 68, 95, 207, 110, 82, 62, 56, 116, 73, 52, 110, 114, 160, 106])),\n        DG.Column.fromInt32Array('peak.rpm', new Int32Array([5000, 5500, 5800, 5400, 5500, 5500, 6000, 5800, 4800, 4750, 5000, 4350, 5000, 5500, 5200, 5200, 5500, 4150, 5900, 5250, 4400, 4800, 4500, 4800, 4500, 4800, 5500, 5400, 5300, 4800])),\n        DG.Column.fromInt32Array('symbol', new Int32Array([1, 1, 2, 0, 1, 1, 1, 0, 0, 0, 1, -1, 1, 2, 1, 1, 1, 0, 3, 2, 0, 1, 0, 2, -1, 2, 0, -2, -1, -1])),\n        DG.Column.fromInt32Array('city.mpg', new Int32Array([19, 19, 23, 38, 24, 31, 30, 27, 24, 15, 31, 22, 19, 37, 31, 31, 31, 25, 17, 21, 28, 35, 34, 24, 30, 37, 19, 23, 19, 26])),\n        DG.Column.fromInt32Array('highway.mpg', new Int32Array([26, 25, 29, 43, 30, 38, 34, 33, 29, 19, 38, 25, 24, 41, 37, 37, 38, 25, 25, 28, 33, 39, 36, 30, 33, 46, 24, 28, 25, 27])),\n        DG.Column.fromInt32Array('price', new Int32Array([16500, 17710, 16430, 6575, 7957, 6229, 7129, 8845, 6785, 35550, 7395, 31600, 16503, 5389, 7349, 7299, 6229, 13860, 37028, 12170, 7775, 5348, 7898, 9989, 10698, 7775, 13295, 12940, 19045, 22470])),\n    ]);\n} // carsDataframe\n// Generate dataset for testing binary classifiers\nexport function testDataForBinaryClassification(kernel, kernelParams, name, samplesCount, featuresCount, min, max, violatorsPercentage) {\n    return __awaiter(this, void 0, void 0, function* () {\n        // check inputs\n        checkGeneratorSVMinputs(samplesCount, featuresCount, min, max, violatorsPercentage);\n        // kernel params column\n        const kernelParamsCol = DG.Column.fromList('double', 'kernelParams', kernelParams);\n        // CALL WASM-COMPUTATIONS  \n        let _output;\n        let _promise = _generateDatasetInWebWorker(kernel, kernelParamsCol, samplesCount, featuresCount, min, max, violatorsPercentage);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        // Rename labels column\n        _output[SVM_GEN_LABELS_INDEX].name = SVM_LABEL_NAME;\n        // Rename feature columns\n        for (const col of _output[SVM_GEN_FEATURES_INDEX])\n            col.name = SVM_FEATURE_NAME + col.name;\n        // Create dataframe\n        const df = DG.DataFrame.fromColumns(_output[SVM_GEN_FEATURES_INDEX]);\n        df.name = name;\n        df.columns.add(_output[SVM_GEN_LABELS_INDEX]);\n        return df;\n    });\n} // testDataForMachineLearning\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};\n/* Support vector machine (SVM) tools.\n   It's developed for applying in combination with DATAGROK predictive tools.\n\n   Training & predicting are provided by wasm-computations.\n\n   Least square support vector machine (LS-SVM) is implemented:\n     [1] Suykens, J., Vandewalle, J. \"Least Squares Support Vector Machine Classifiers\",\n           Neural Processing Letters 9, 293-300 (1999). https://doi.org/10.1023/A:1018628609742\n*/\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport { _trainAndAnalyzeLSSVMInWebWorker, _predictByLSSVMInWebWorker } from '../wasm/EDAAPI';\n// 1. CONSTANTS\n// kernel types\nexport const LINEAR = 0;\nexport const POLYNOMIAL = 1;\nexport const RBF = 2;\nexport const SIGMOID = 3;\n// output-related\nconst CONFUSION_MATR_SIZE = 4;\nconst NORMALIZED_DATA_INDEX = 0;\nconst MEANS_INDEX = 1;\nconst STD_DEVS_INDEX = 2;\nconst MODEL_PARAMS_INDEX = 3;\nconst MODEL_WEIGHTS_INDEX = 4;\nconst PREDICTED_LABELS_INDEX = 5;\nconst CORRECTNESS_INDEX = 6;\nconst CONFUSION_MATRIX_INDEX = 7;\nconst TRUE_POSITIVE_INDEX = 0;\nconst FALSE_NEGATIVE_INDEX = 1;\nconst FALSE_POSITIVE_INDEX = 2;\nconst TRUE_NEGATIVE_INDEX = 3;\n// kernel parameters indeces\nconst RBF_SIGMA_INDEX = 0;\nconst POLYNOMIAL_C_INDEX = 0;\nconst POLYNOMIAL_D_INDEX = 1;\nconst SIGMOID_KAPPA_INDEX = 0;\nconst SIGMOID_THETA_INDEX = 1;\n// hyperparameters limits\nconst GAMMA_INFIMUM_LIMIT = 0;\nconst RBF_SIGMA_INFIMUM_LIMIT = 0;\nconst POLYNOMIAL_C_INFIMUM_LIMIT = 0;\nconst POLYNOMIAL_D_INFIMUM_LIMIT = 0;\n// error messages\nconst WRONG_GAMMA_MESSAGE = 'gamma must be strictly positive.';\nconst WRONG_RBF_SIGMA_MESSAGE = 'sigma must be strictly positive.';\nconst WRONG_POLYNOMIAL_C_MESSAGE = 'c must be strictly positive.';\nconst WRONG_POLYNOMIAL_D_MESSAGE = 'd must be strictly positive.';\nconst WRONG_KERNEL_MESSAGE = 'incorrect kernel.';\n// names\nconst LABELS = 'Labels';\nconst PREDICTED = 'predicted';\nconst CORRECTNESS = 'correctness';\nconst CONFUSION_MATRIX_NAME = 'Confusion matrix';\nconst MEAN = 'mean';\nconst STD_DEV = 'std dev';\nconst MODEL_PARAMS_NAME = 'alpha';\nconst MODEL_WEIGHTS_NAME = 'weight';\nconst GAMMA = 'gamma';\nconst KERNEL = 'kernel';\nconst KERNEL_PARAMS = 'kernel params';\nconst KERNEL_PARAM_1 = 'kernel param 1';\nconst KERNEL_PARAM_2 = 'kernel param 2';\nconst FEATURES_COUNT_NAME = 'features count';\nconst TRAIN_SAMPLES_COUNT_NAME = 'train samples count';\nconst TRAIN_ERROR = 'Train error,%';\nconst KERNEL_TYPE_TO_NAME_MAP = ['linear', 'polynomial', 'RBF', 'sigmoid'];\nconst POSITIVE_NAME = 'positive (P)';\nconst NEGATIVE_NAME = 'negative (N)';\nconst PREDICTED_POSITIVE_NAME = 'predicted positive (PP)';\nconst PREDICTED_NEGATIVE_NAME = 'predicted negative (PN)';\nconst SENSITIVITY = 'Sensitivity';\nconst SPECIFICITY = 'Specificity';\nconst BALANCED_ACCURACY = 'Balanced accuracy';\nconst POSITIVE_PREDICTIVE_VALUE = 'Positive predicitve value';\nconst NEGATIVE_PREDICTIVE_VALUE = 'Negative predicitve value';\nconst ML_REPORT = 'Model report';\nconst ML_REPORT_PREDICTED_LABELS = 'Predicted labels';\nconst ML_REPORT_TRAIN_LABELS = 'Train labels';\nconst ML_REPORT_CORRECTNESS = 'Prediction correctness';\nconst PREDICTION = 'prediction';\n// Pack/unpack constants\nconst BYTES = 4;\nconst INTS_COUNT = 3;\nconst KER_PARAMS_COUNT = 2;\nconst MODEL_KERNEL_INDEX = 0;\nconst SAMPLES_COUNT_INDEX = 1;\nconst FEATURES_COUNT_INDEX = 2;\n// misc\nconst INIT_VALUE = 0; // any number can be used\nconst LS_SVM_ADD_CONST = 1; // see [1] for more details\n// 2. TOOLS\n// Check LS-SVM learning hyperparameters\nfunction checkHyperparameters(hyperparameters) {\n    // check gamma\n    if (hyperparameters.gamma <= GAMMA_INFIMUM_LIMIT)\n        throw new Error(WRONG_GAMMA_MESSAGE);\n    // check kernel & its parameters\n    switch (hyperparameters.kernel) {\n        case LINEAR: // the case of linear kernel\n            return;\n        case RBF: // the case of RBF kernel\n            if (hyperparameters.sigma <= RBF_SIGMA_INFIMUM_LIMIT)\n                throw new Error(WRONG_RBF_SIGMA_MESSAGE);\n            return;\n        case POLYNOMIAL: // the case of polynomial kernel\n            // check c\n            if (hyperparameters.cParam <= POLYNOMIAL_C_INFIMUM_LIMIT)\n                throw new Error(WRONG_POLYNOMIAL_C_MESSAGE);\n            // check d\n            if (hyperparameters.dParam <= POLYNOMIAL_D_INFIMUM_LIMIT)\n                throw new Error(WRONG_POLYNOMIAL_D_MESSAGE);\n            return;\n        case SIGMOID: // the case of polynomial kernel\n            return;\n        default: // incorrect kernel\n            throw new Error(WRONG_KERNEL_MESSAGE);\n    } // switch    \n} // checkHyperparameters\n// Returnes labels predicted by the model specified\nfunction predict(model, dataset) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let _output;\n        let _promise = _predictByLSSVMInWebWorker(model.kernelType, model.kernelParams, model.normalizedTrainData.columns, model.trainLabels, model.means, model.stdDevs, model.modelParams, model.modelWeights, dataset);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        return _output;\n    });\n} // predict\n// Evaluate accuracy of the model\nfunction evaluateAccuracy(model) {\n    let data = model.confusionMatrix.getRawData();\n    // here, the classic notation is used (see https://en.wikipedia.org/wiki/Sensitivity_and_specificity)\n    let TP = data[TRUE_POSITIVE_INDEX]; // true positive\n    let TN = data[TRUE_NEGATIVE_INDEX]; // true negative\n    let FP = data[FALSE_POSITIVE_INDEX]; // false positive\n    let FN = data[FALSE_NEGATIVE_INDEX]; // false negative\n    let P = TP + FN; // positive\n    let N = FP + TN; // negative\n    let TPR = TP / P; // true positive rate\n    let TNR = TN / N; // true negative rate\n    let PPV = TP / (TP + FP); // positive predicitve value\n    let NPV = TN / (TN + FN); // negative predicitve value\n    let ACC = (TP + TN) / (P + N); // accuracy\n    let BA = (TPR + TNR) / 2; // balanced accuracy\n    model.sensitivity = TPR;\n    model.specificity = TNR;\n    model.balancedAccuracy = BA;\n    model.positivePredicitveValue = PPV;\n    model.negativePredicitveValue = NPV;\n    model.trainError = (1 - ACC) * 100; // train error, %\n} // evaluateAccuracy\n// Returns trained LS-SVM model.\nfunction trainAndAnalyzeModel(hyperparameters, dataset, labels) {\n    return __awaiter(this, void 0, void 0, function* () {\n        // check correctness of hyperparameter gamma\n        checkHyperparameters(hyperparameters);\n        // create default kernel params array\n        const kernelParamsArray = [INIT_VALUE, INIT_VALUE];\n        // fill kernelParams\n        switch (hyperparameters.kernel) {\n            case LINEAR: // no kernel parameters in the case of linear kernel\n                break;\n            case RBF: // sigma parameter in the case of RBF-kernel\n                kernelParamsArray[RBF_SIGMA_INDEX] = hyperparameters.sigma;\n                break;\n            case POLYNOMIAL: // sigma parameter in the case of polynomial kernel\n                kernelParamsArray[POLYNOMIAL_C_INDEX] = hyperparameters.cParam;\n                kernelParamsArray[POLYNOMIAL_D_INDEX] = hyperparameters.dParam;\n                break;\n            case SIGMOID: // sigma parameter in the case of sigmoid kernel\n                kernelParamsArray[SIGMOID_KAPPA_INDEX] = hyperparameters.kappa;\n                kernelParamsArray[SIGMOID_THETA_INDEX] = hyperparameters.theta;\n                break;\n            default: // incorrect kernel \n                throw new Error(WRONG_KERNEL_MESSAGE);\n        }\n        ;\n        // create kernel params column\n        let kernelParams = DG.Column.fromList('double', KERNEL_PARAMS, kernelParamsArray);\n        // compute size of model params & precomputed weigths\n        let trainCols = dataset.toList();\n        let modelParamsCount = trainCols[0].length + LS_SVM_ADD_CONST;\n        let precomputedWeightsCount = trainCols.length + LS_SVM_ADD_CONST;\n        let confusionMatrixElementsCount = CONFUSION_MATR_SIZE;\n        // call webassembly training function\n        let output;\n        let _promise = _trainAndAnalyzeLSSVMInWebWorker(hyperparameters.gamma, hyperparameters.kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels);\n        yield _promise.then(_result => { output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        // rename output columns\n        output[MEANS_INDEX].name = MEAN;\n        output[STD_DEVS_INDEX].name = STD_DEV;\n        output[MODEL_PARAMS_INDEX].name = MODEL_PARAMS_NAME;\n        output[MODEL_WEIGHTS_INDEX].name = MODEL_WEIGHTS_NAME;\n        output[PREDICTED_LABELS_INDEX].name = PREDICTED;\n        output[CORRECTNESS_INDEX].name = CORRECTNESS;\n        output[CONFUSION_MATRIX_INDEX].name = CONFUSION_MATRIX_NAME;\n        // complete model\n        let model = {\n            trainGamma: hyperparameters.gamma,\n            kernelType: hyperparameters.kernel,\n            kernelParams: kernelParams,\n            trainLabels: labels,\n            normalizedTrainData: DG.DataFrame.fromColumns(output[NORMALIZED_DATA_INDEX]),\n            means: output[MEANS_INDEX],\n            stdDevs: output[STD_DEVS_INDEX],\n            modelParams: output[MODEL_PARAMS_INDEX],\n            modelWeights: output[MODEL_WEIGHTS_INDEX],\n            predictedLabels: output[PREDICTED_LABELS_INDEX],\n            correctness: output[CORRECTNESS_INDEX],\n            confusionMatrix: output[CONFUSION_MATRIX_INDEX],\n            trainError: undefined,\n            featuresCount: trainCols.length,\n            trainSamplesCount: trainCols[0].length\n        };\n        evaluateAccuracy(model);\n        return model;\n    });\n} // trainAndAnalyzeModel\n// Wrapper for combining the function \"trainAndAnalyzeModel\" with Datagrok predicitve tools\nexport function getTrainedModel(hyperparameters, df, predict_column) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let columns = df.columns;\n        let labels = columns.byName(predict_column);\n        columns.remove(predict_column);\n        return yield trainAndAnalyzeModel(hyperparameters, columns, labels);\n    });\n}\n// Returns dataframe with short info about model\nfunction getModelInfo(model) {\n    let kernelParams = model.kernelParams.getRawData();\n    return DG.DataFrame.fromColumns([\n        DG.Column.fromList('double', GAMMA, [model.trainGamma]),\n        DG.Column.fromStrings(KERNEL, [KERNEL_TYPE_TO_NAME_MAP[model.kernelType]]),\n        DG.Column.fromList('double', KERNEL_PARAM_1, [kernelParams[0]]),\n        DG.Column.fromList('double', KERNEL_PARAM_2, [kernelParams[1]]),\n        DG.Column.fromList('double', FEATURES_COUNT_NAME, [model.featuresCount]),\n        DG.Column.fromList('double', TRAIN_SAMPLES_COUNT_NAME, [model.trainSamplesCount]),\n        DG.Column.fromList('double', TRAIN_ERROR, [model.trainError]),\n        DG.Column.fromList('double', BALANCED_ACCURACY, [model.balancedAccuracy]),\n        DG.Column.fromList('double', SENSITIVITY, [model.sensitivity]),\n        DG.Column.fromList('double', SPECIFICITY, [model.specificity]),\n        DG.Column.fromList('double', POSITIVE_PREDICTIVE_VALUE, [model.positivePredicitveValue]),\n        DG.Column.fromList('double', NEGATIVE_PREDICTIVE_VALUE, [model.negativePredicitveValue])\n    ]);\n}\n// Get dataframe with confusion matrix\nfunction getConfusionMatrixDF(model) {\n    let data = model.confusionMatrix.getRawData();\n    return DG.DataFrame.fromColumns([\n        DG.Column.fromStrings('', [POSITIVE_NAME, NEGATIVE_NAME]),\n        DG.Column.fromList('int', PREDICTED_POSITIVE_NAME, [data[TRUE_POSITIVE_INDEX], data[FALSE_POSITIVE_INDEX]]),\n        DG.Column.fromList('int', PREDICTED_NEGATIVE_NAME, [data[FALSE_NEGATIVE_INDEX], data[TRUE_NEGATIVE_INDEX]])\n    ]);\n}\n// Show training report\nexport function showTrainReport(df, model) {\n    df.name = ML_REPORT;\n    df.columns.add(model.trainLabels);\n    df.columns.add(model.predictedLabels);\n    df.columns.add(model.correctness);\n    let dfView = grok.shell.addTableView(df);\n    dfView.addViewer(DG.Viewer.form(getModelInfo(model)));\n    dfView.addViewer(DG.Viewer.scatterPlot(df, { title: ML_REPORT_PREDICTED_LABELS,\n        color: model.predictedLabels.name\n    }));\n    dfView.addViewer(DG.Viewer.scatterPlot(df, { title: ML_REPORT_TRAIN_LABELS,\n        color: model.trainLabels.name\n    }));\n    dfView.addViewer(DG.Viewer.grid(getConfusionMatrixDF(model)));\n    dfView.addViewer(DG.Viewer.scatterPlot(df, { title: ML_REPORT_CORRECTNESS,\n        color: model.correctness.name\n    }));\n} // showTrainReport\n// Returns trained model packed into UInt8Array\nexport function getPackedModel(model) {\n    // get principal data\n    let dataCols = model.normalizedTrainData.columns;\n    let samplesCount = model.trainSamplesCount;\n    let featuresCount = model.featuresCount;\n    /*let bufferSize = BYTES * (7 + featuresCount * samplesCount\n      + 3 * featuresCount + 2 * samplesCount);*/\n    // compute size of packed model\n    let bufferSize = BYTES * (INTS_COUNT + KER_PARAMS_COUNT +\n        samplesCount + featuresCount + featuresCount + samplesCount + LS_SVM_ADD_CONST\n        + featuresCount + LS_SVM_ADD_CONST + featuresCount * samplesCount);\n    // packed model\n    let result = new Uint8Array(bufferSize);\n    let buffer = result.buffer;\n    let offset = 0;\n    // pack kernel type and sizes\n    let ints = new Int32Array(buffer, offset, INTS_COUNT);\n    ints[MODEL_KERNEL_INDEX] = model.kernelType;\n    ints[SAMPLES_COUNT_INDEX] = samplesCount;\n    ints[FEATURES_COUNT_INDEX] = featuresCount;\n    offset += INTS_COUNT * BYTES;\n    // pack kernel parameters\n    let floats = new Float32Array(buffer, offset, KER_PARAMS_COUNT);\n    floats.set(model.kernelParams.getRawData());\n    offset += KER_PARAMS_COUNT * BYTES;\n    // pack pack labels of training data\n    floats = new Float32Array(buffer, offset, samplesCount);\n    floats.set(model.trainLabels.getRawData());\n    offset += samplesCount * BYTES;\n    // pack mean values of training data\n    floats = new Float32Array(buffer, offset, featuresCount);\n    floats.set(model.means.getRawData());\n    offset += featuresCount * BYTES;\n    // pack standard deviations of training data\n    floats = new Float32Array(buffer, offset, featuresCount);\n    floats.set(model.stdDevs.getRawData());\n    offset += featuresCount * BYTES;\n    // pack model paramters\n    floats = new Float32Array(buffer, offset, samplesCount + LS_SVM_ADD_CONST);\n    floats.set(model.modelParams.getRawData());\n    offset += (samplesCount + LS_SVM_ADD_CONST) * BYTES;\n    // pack model's precomputed weights\n    floats = new Float32Array(buffer, offset, featuresCount + LS_SVM_ADD_CONST);\n    floats.set(model.modelWeights.getRawData());\n    offset += (featuresCount + LS_SVM_ADD_CONST) * BYTES;\n    // pack training dataset\n    for (const col of dataCols) {\n        floats = new Float32Array(buffer, offset, featuresCount);\n        floats.set(col.getRawData());\n        offset += featuresCount * BYTES;\n    }\n    return result;\n} // getPackedModel\n// Returns unpacked model\nfunction getUnpackedModel(packedModel) {\n    let modelBytes = packedModel.buffer;\n    let offset = 0;\n    // extract kernel type and sizes\n    let header = new Int32Array(modelBytes, offset, INTS_COUNT);\n    offset += INTS_COUNT * BYTES;\n    let samplesCount = header[SAMPLES_COUNT_INDEX];\n    let featuresCount = header[FEATURES_COUNT_INDEX];\n    // extract parameters of kernel\n    const kernelParams = DG.Column.fromFloat32Array(KERNEL_PARAMS, new Float32Array(modelBytes, offset, KER_PARAMS_COUNT));\n    offset += KER_PARAMS_COUNT * BYTES;\n    // extract training labels\n    const trainLabels = DG.Column.fromFloat32Array(LABELS, new Float32Array(modelBytes, offset, samplesCount));\n    offset += samplesCount * BYTES;\n    // extract mean values of training data\n    const means = DG.Column.fromFloat32Array(MEAN, new Float32Array(modelBytes, offset, featuresCount));\n    offset += featuresCount * BYTES;\n    // extract standard deviations of training data\n    const stdDevs = DG.Column.fromFloat32Array(STD_DEV, new Float32Array(modelBytes, offset, featuresCount));\n    offset += featuresCount * BYTES;\n    // extract parameters of model\n    const modelParams = DG.Column.fromFloat32Array(MODEL_PARAMS_NAME, new Float32Array(modelBytes, offset, samplesCount + LS_SVM_ADD_CONST));\n    offset += (samplesCount + LS_SVM_ADD_CONST) * BYTES;\n    // extract model's precomputed weights\n    const modelWeights = DG.Column.fromFloat32Array(MODEL_WEIGHTS_NAME, new Float32Array(modelBytes, offset, featuresCount + LS_SVM_ADD_CONST));\n    offset += (featuresCount + LS_SVM_ADD_CONST) * BYTES;\n    // extract training data columns\n    let dataCols = [];\n    for (let i = 0; i < samplesCount; i++) {\n        dataCols.push(DG.Column.fromFloat32Array(i.toString(), new Float32Array(modelBytes, offset, featuresCount)));\n        offset += featuresCount * BYTES;\n    }\n    const normalizedTrainData = DG.DataFrame.fromColumns(dataCols);\n    let model = { kernelType: header[MODEL_KERNEL_INDEX],\n        kernelParams: kernelParams,\n        trainLabels: trainLabels,\n        means: means,\n        stdDevs: stdDevs,\n        modelParams: modelParams,\n        modelWeights: modelWeights,\n        normalizedTrainData: normalizedTrainData\n    };\n    return model;\n} // getUnpackedModel\n// Wrapper for combining the function \"predict\" with Datagrok predicitve tools\nexport function getPrediction(df, packedModel) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let model = getUnpackedModel(new Uint8Array(packedModel));\n        let res = yield predict(model, df.columns);\n        res.name = PREDICTION;\n        return DG.DataFrame.fromColumns([res]);\n    });\n} // getPrediction\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};\n/* Do not change these import lines to match external modules in webpack configuration */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { DemoScript } from '@datagrok-libraries/tutorials/src/demo-script';\nimport { _initEDAAPI } from '../wasm/EDAAPI';\nimport { computePCA, computePLS } from './EDAtools';\nimport { renamePCAcolumns, addPLSvisualization, regressionCoefficientsBarChart, scoresScatterPlot, predictedVersusReferenceScatterPlot } from './EDAui';\nimport { carsDataframe, testDataForBinaryClassification } from './dataGenerators';\nimport { LINEAR, RBF, POLYNOMIAL, SIGMOID, getTrainedModel, getPrediction, showTrainReport, getPackedModel } from './svm';\nexport const _package = new DG.Package();\n//name: info\nexport function info() {\n    grok.shell.info(_package.webRoot);\n}\n//tags: init\nexport function init() {\n    return __awaiter(this, void 0, void 0, function* () {\n        yield _initEDAAPI();\n    });\n}\n//top-menu: Tools | Data Science | Principal Component Analysis...\n//name: PCA\n//description: Principal component analysis (PCA).\n//input: dataframe table\n//input: column_list features\n//input: int components = 2\n//input: bool center = true\n//input: bool scale = true\n//output: dataframe result {action:join(table)}\nexport function PCA(table, features, components, center, scale) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return renamePCAcolumns(yield computePCA(table, features, components, center, scale));\n    });\n}\n//top-menu: Tools | Data Science | Multivariate Analysis (PLS)...\n//name: Multivariate Analysis (PLS)\n//description: Partial least square regression (PLS).\n//input: dataframe table\n//input: column names\n//input: column_list features\n//input: column predict\n//input: int components = 3\nexport function PLS(table, names, features, predict, components) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const plsResults = yield computePLS(table, features, predict, components);\n        addPLSvisualization(table, names, features, predict, plsResults);\n    });\n}\n//name: MVA demo\n//description: Multidimensional data analysis using partial least squares (PLS) regression. It reduces the predictors to a smaller set of uncorrelated components and performs least squares regression on them.\n//meta.demoPath: Compute | Multivariate analysis\n//meta.isDemoScript: True\nexport function demoMultivariateAnalysis() {\n    return __awaiter(this, void 0, void 0, function* () {\n        const demoScript = new DemoScript('Partial least squares regression', 'Analysis of multidimensional data.');\n        const cars = carsDataframe();\n        const components = 3;\n        const names = cars.columns.byName('model');\n        const predict = cars.columns.byName('price');\n        const features = cars.columns.remove('price').remove('model');\n        const plsOutput = yield computePLS(cars, features, predict, components);\n        const sourceCars = carsDataframe();\n        sourceCars.name = 'Cars';\n        let view;\n        let dialog;\n        yield demoScript\n            .step('Data', () => __awaiter(this, void 0, void 0, function* () {\n            grok.shell.addTableView(sourceCars);\n            view = grok.shell.getTableView(sourceCars.name);\n        }), { description: 'Each car has many features - patterns extraction is complicated.', delay: 0 })\n            .step('Model', () => __awaiter(this, void 0, void 0, function* () {\n            dialog = ui.dialog({ title: 'Multivariate Analysis (PLS)' })\n                .add(ui.tableInput('Table', sourceCars))\n                .add(ui.columnsInput('Features', cars, features.toList, { available: undefined, checked: features.names() }))\n                .add(ui.columnInput('Names', cars, names, undefined))\n                .add(ui.columnInput('Predict', cars, predict, undefined))\n                .add(ui.intInput('Components', components, undefined))\n                .onOK(() => {\n                grok.shell.info('Multivariate analysis has been already performed.');\n            })\n                .show({ x: 400, y: 140 });\n        }), { description: 'Predict car price by its other features.', delay: 0 })\n            .step('Regression coeffcicients', () => __awaiter(this, void 0, void 0, function* () {\n            dialog.close();\n            view.addViewer(regressionCoefficientsBarChart(features, plsOutput[1]));\n        }), { description: 'The feature \"diesel\" affects the price the most.', delay: 0 })\n            .step('Scores', () => __awaiter(this, void 0, void 0, function* () { view.addViewer(scoresScatterPlot(names, plsOutput[2], plsOutput[3])); }), { description: 'Similarities & dissimilarities: alfaromeo and mercedes are different.', delay: 0 })\n            .step('Prediction', () => __awaiter(this, void 0, void 0, function* () { view.addViewer(predictedVersusReferenceScatterPlot(names, predict, plsOutput[0])); }), { description: 'Closer to the line means better price prediction.', delay: 0 })\n            .start();\n    });\n}\n//name: Generate linear separable dataset\n//description: Generates linear separble dataset for testing binary classificators.\n//input: string name = 'Data' {caption: name; category: Dataset}\n//input: int samplesCount = 1000 {caption: samples; category: Size}\n//input: int featuresCount = 2 {caption: features; category: Size}\n//input: double min = -39 {caption: min; category: Range}\n//input: double max = 173 {caption: max; category: Range}\n//input: double violatorsPercentage = 5 {caption: violators; units: %; category: Dataset}\n//output: dataframe df\nexport function testDataLinearSeparable(name, samplesCount, featuresCount, min, max, violatorsPercentage) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield testDataForBinaryClassification(LINEAR, [0, 0], name, samplesCount, featuresCount, min, max, violatorsPercentage);\n    });\n}\n//name: Generate linear non-separable dataset\n//description: Generates linear non-separble dataset for testing binary classificators.\n//input: string name = 'Data' {caption: name; category: Dataset}\n//input: double sigma = 90  {caption: sigma; category: Hyperparameters} [RBF-kernel paramater]\n//input: int samplesCount = 1000 {caption: samples; category: Size}\n//input: int featuresCount = 2 {caption: features; category: Size}\n//input: double min = -39 {caption: min; category: Range}\n//input: double max = 173 {caption: max; category: Range}\n//input: double violatorsPercentage = 5 {caption: violators; units: %; category: Dataset}\n//output: dataframe df\nexport function testDataLinearNonSeparable(name, sigma, samplesCount, featuresCount, min, max, violatorsPercentage) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield testDataForBinaryClassification(RBF, [sigma, 0], name, samplesCount, featuresCount, min, max, violatorsPercentage);\n    });\n}\n//name: trainLinearKernelSVM\n//meta.mlname: linear kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainLinearKernelSVM(df, predict_column, gamma, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: LINEAR }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n}\n//name: applyLinearKernelSVM\n//meta.mlname: linear kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applyLinearKernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n//name: trainRBFkernelSVM\n//meta.mlname: RBF-kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: double sigma = 1.5 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainRBFkernelSVM(df, predict_column, gamma, sigma, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: RBF, sigma: sigma }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n}\n//name: applyRBFkernelSVM\n//meta.mlname: RBF-kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applyRBFkernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n//name: trainPolynomialKernelSVM\n//meta.mlname: polynomial kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: double c = 1 {category: Hyperparameters}\n//input: double d = 2 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainPolynomialKernelSVM(df, predict_column, gamma, c, d, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: POLYNOMIAL, cParam: c, dParam: d }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n} // trainPolynomialKernelSVM\n//name: applyPolynomialKernelSVM\n//meta.mlname: polynomial kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applyPolynomialKernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n//name: trainSigmoidKernelSVM\n//meta.mlname: sigmoid kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: double kappa = 1 {category: Hyperparameters}\n//input: double theta = 1 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainSigmoidKernelSVM(df, predict_column, gamma, kappa, theta, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: SIGMOID, kappa: kappa, theta: theta }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n} // trainSigmoidKernelSVM\n//name: applySigmoidKernelSVM\n//meta.mlname: sigmoid kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applySigmoidKernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n"],"names":["__webpack_require__","exports","definition","key","o","Object","defineProperty","enumerable","get","chunkId","g","globalThis","this","Function","e","window","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","scriptUrl","importScripts","location","document","currentScript","src","scripts","getElementsByTagName","length","i","Error","replace","p","b","baseURI","self","href","grok","ui","DG","assure","delay","ms","thisArg","_arguments","generator","Promise","setTimeout","P","resolve","reject","fulfilled","step","next","rejected","result","done","then","apply","notNull","name","DemoScript","constructor","description","isAutomatic","options","_a","_isAutomatic","_autoStartFirstStep","_currentStep","_isStopped","_isCancelled","_isStepProcessed","_root","id","classes","_steps","_mainHeader","_header","_headerDiv","_stopStartBtn","_changeStopState","_restartBtn","_restartScript","_nextStepBtn","_nextStep","_activity","_progressDiv","_progress","_progressSteps","_closeBtn","_closeDock","autoStartFirstStep","max","currentObject","steps","stepNumber","_addHeader","_createHeaderDiv","_createProgressDiv","append","innerText","firstChild","className","_addDescription","instructionIndicator","instructionDiv","currentStepDescription","entry","_initRoot","_b","_c","scriptDockNode","Array","from","_node","parent","container","containerElement","firstElementChild","lastElementChild","classList","contains","remove","add","getElementsByClassName","entryIndicator","entryInstruction","currentStep","stepDelay","func","_scrollTo","offsetTop","offsetHeight","_countdown","newEntryIndicator","replaceWith","nextStepEntryIndicator","startNextStepIcon","_startScript","element","y","focus","scrollTop","indicator","time","countdownDiv","countdown","svg","_createSVGIndicator","prepend","interval","setInterval","clearInterval","createElementNS","circle","setAttributeNS","icon","_clearRoot","_setInitParams","start","cancelScript","Int32Array","Float32Array","Column","fromInt32Array","fromFloat32Array","NUM_TYPE","FLOAT_COLUMN_TYPE","INT_COLUMN_TYPE","FLOAT_COLUMNS_TYPE","NEW_FLOAT_COLUMNS_TYPE","INT_COLUMNS_TYPE","NEW_INT_COLUMNS_TYPE","NEW_FLOAT_COLUMN_TYPE","NEW_INT_COLUMN_TYPE","COLUMN","CALL_RESULT","NUM_OF_ROWS","NUM_OF_COLUMNS","REF","VALUE","TABLE_OF_COLUMNS","OBJECTS","INT_TYPE","DOUBLE_TYPE","argsSpecification","inputVals","ref","cppFuncInput","arg","type","data","array","col","getRawData","val","arrays","toList","push","val1","val2","funcSpecification","dataFromWebWorker","arguments","_callResult","callResult","funcSpecificationArgs","argsAfterWasmCall","typeToColumnCreatorMap","undefined","toString","names","column","columns","k","j","extractNewlyCreatedData","args","outPut","output","typeToDataFieldMap","source","DataFrame","fromColumns","arrayToReturn","getOutput","clearNewlyCreatedData","COMP_MIN","SAMPLES_COUNT_MIN","FEATURES_COUNT_MIN","PERCENTAGE_MIN","PERCENTAGE_MAX","MAX_ELEMENTS_COUNT","COMP_POSITVE_MES","COMP_EXCESS","INCORERRECT_MIN_MAX_MES","INCORERRECT_FEATURES_MES","INCORERRECT_SAMPLES_MES","INCORERRECT_PERCENTAGE_MES","DATAFRAME_IS_TOO_BIG_MES","checkComponenets","features","components","byIndex","computePLS","table","predict","_output","_promise","async","componentsCount","worker","Worker","URL","postMessage","EDA","onmessage","terminate","_partialLeastSquareRegressionInWebWorker","_result","_error","predictedVersusReferenceScatterPlot","samplesNames","reference","prediction","dfReferencePrediction","title","x","showRegressionLine","markerType","labels","regressionCoefficientsBarChart","regressionCoeffs","namesOfPredictors","predictorNamesColumn","dfRegrCoefs","split","valueAggrType","scoresScatterPlot","xScores","yScores","scoresColumns","scores","index","SVM_GEN_FEATURES_INDEX","SVM_GEN_LABELS_INDEX","SVM_FEATURE_NAME","SVM_LABEL_NAME","carsDataframe","testDataForBinaryClassification","kernel","kernelParams","samplesCount","featuresCount","min","violatorsPercentage","checkGeneratorSVMinputs","kernelParamsCol","_generateDatasetInWebWorker","df","LINEAR","POLYNOMIAL","RBF","SIGMOID","CONFUSION_MATR_SIZE","NORMALIZED_DATA_INDEX","MEANS_INDEX","STD_DEVS_INDEX","MODEL_PARAMS_INDEX","MODEL_WEIGHTS_INDEX","PREDICTED_LABELS_INDEX","CORRECTNESS_INDEX","CONFUSION_MATRIX_INDEX","TRUE_POSITIVE_INDEX","FALSE_NEGATIVE_INDEX","FALSE_POSITIVE_INDEX","TRUE_NEGATIVE_INDEX","RBF_SIGMA_INDEX","POLYNOMIAL_C_INDEX","POLYNOMIAL_D_INDEX","SIGMOID_KAPPA_INDEX","SIGMOID_THETA_INDEX","GAMMA_INFIMUM_LIMIT","RBF_SIGMA_INFIMUM_LIMIT","POLYNOMIAL_C_INFIMUM_LIMIT","POLYNOMIAL_D_INFIMUM_LIMIT","WRONG_GAMMA_MESSAGE","WRONG_RBF_SIGMA_MESSAGE","WRONG_POLYNOMIAL_C_MESSAGE","WRONG_POLYNOMIAL_D_MESSAGE","WRONG_KERNEL_MESSAGE","LABELS","PREDICTED","CORRECTNESS","CONFUSION_MATRIX_NAME","MEAN","STD_DEV","MODEL_PARAMS_NAME","MODEL_WEIGHTS_NAME","GAMMA","KERNEL","KERNEL_PARAMS","KERNEL_PARAM_1","KERNEL_PARAM_2","FEATURES_COUNT_NAME","TRAIN_SAMPLES_COUNT_NAME","TRAIN_ERROR","KERNEL_TYPE_TO_NAME_MAP","POSITIVE_NAME","NEGATIVE_NAME","PREDICTED_POSITIVE_NAME","PREDICTED_NEGATIVE_NAME","SENSITIVITY","SPECIFICITY","BALANCED_ACCURACY","POSITIVE_PREDICTIVE_VALUE","NEGATIVE_PREDICTIVE_VALUE","ML_REPORT","ML_REPORT_PREDICTED_LABELS","ML_REPORT_TRAIN_LABELS","ML_REPORT_CORRECTNESS","PREDICTION","BYTES","INTS_COUNT","KER_PARAMS_COUNT","MODEL_KERNEL_INDEX","SAMPLES_COUNT_INDEX","FEATURES_COUNT_INDEX","INIT_VALUE","LS_SVM_ADD_CONST","getTrainedModel","hyperparameters","predict_column","byName","dataset","gamma","sigma","cParam","dParam","checkHyperparameters","kernelParamsArray","kappa","theta","trainCols","modelParamsCount","precomputedWeightsCount","confusionMatrixElementsCount","_trainAndAnalyzeLSSVMInWebWorker","model","trainGamma","kernelType","trainLabels","normalizedTrainData","means","stdDevs","modelParams","modelWeights","predictedLabels","correctness","confusionMatrix","trainError","trainSamplesCount","TP","TN","FP","FN","N","TPR","TNR","PPV","NPV","ACC","BA","sensitivity","specificity","balancedAccuracy","positivePredicitveValue","negativePredicitveValue","evaluateAccuracy","trainAndAnalyzeModel","showTrainReport","dfView","addViewer","getModelInfo","color","getConfusionMatrixDF","getPackedModel","dataCols","Uint8Array","buffer","offset","ints","floats","set","getPrediction","packedModel","modelBytes","header","getUnpackedModel","res","normalizedData","precomputedWeights","targetData","_predictByLSSVMInWebWorker","_package","info","webRoot","init","initEDA","_initEDAAPI","PCA","center","scale","pcaTable","renamePCAcolumns","centerNum","scaleNum","_principalComponentAnalysisInWebWorker","computePCA","PLS","plsResults","plsOutput","view","xLoadings","loadingCols","loadingLabels","dfLoadings","loadingScatterPlot","addPLSvisualization","demoMultivariateAnalysis","demoScript","cars","sourceCars","dialog","available","checked","onOK","show","close","testDataLinearSeparable","testDataLinearNonSeparable","trainLinearKernelSVM","toShowReport","trainedModel","applyLinearKernelSVM","trainRBFkernelSVM","applyRBFkernelSVM","trainPolynomialKernelSVM","c","d","applyPolynomialKernelSVM","trainSigmoidKernelSVM","applySigmoidKernelSVM"],"sourceRoot":""}
1
+ var eda;(()=>{"use strict";var t={m:{},d:(e,n)=>{for(var r in n)t.o(n,r)&&!t.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:n[r]})},u:t=>t+".js"};t.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}(),t.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),t.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},(()=>{var e;t.g.importScripts&&(e=t.g.location+"");var n=t.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var r=n.getElementsByTagName("script");if(r.length)for(var a=r.length-1;a>-1&&!e;)e=r[a--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),t.p=e})(),t.b=document.baseURI||self.location.href;var e={};t.r(e),t.d(e,{PCA:()=>Pe,PLS:()=>Le,_package:()=>ke,applyLinearKernelSVM:()=>Re,applyPolynomialKernelSVM:()=>Me,applyRBFkernelSVM:()=>Te,applySigmoidKernelSVM:()=>$e,demoMultivariateAnalysis:()=>Ee,info:()=>De,init:()=>Fe,testDataLinearNonSeparable:()=>xe,testDataLinearSeparable:()=>Ie,trainLinearKernelSVM:()=>Ve,trainPolynomialKernelSVM:()=>Be,trainRBFkernelSVM:()=>Ne,trainSigmoidKernelSVM:()=>Oe});const n=grok,r=ui,a=DG;var o;function i(t){return e=this,n=void 0,a=function*(){yield new Promise((e=>setTimeout(e,t)))},new((r=void 0)||(r=Promise))((function(t,o){function i(t){try{l(a.next(t))}catch(t){o(t)}}function s(t){try{l(a.throw(t))}catch(t){o(t)}}function l(e){var n;e.done?t(e.value):(n=e.value,n instanceof r?n:new r((function(t){t(n)}))).then(i,s)}l((a=a.apply(e,n||[])).next())}));var e,n,r,a}!function(t){t.notNull=function(t,e){if(null==t)throw new Error(`${null==e?"Value":e} not defined`)}}(o||(o={}));var s=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};class l{constructor(t,e,n=!1,a){var o;this.name="",this.description="",this._isAutomatic=!1,this._autoStartFirstStep=!1,this._currentStep=0,this._isStopped=!1,this._isCancelled=!1,this._isStepProcessed=!1,this._root=r.div([],{id:"demo-script",classes:"tutorials-root tutorials-track demo-app-script"}),this._steps=[],this._mainHeader=r.panel([],"tutorials-main-header"),this._header=r.h2(""),this._headerDiv=r.divH([],"tutorials-root-header"),this._stopStartBtn=r.button(r.iconFA("pause"),(()=>this._changeStopState()),"Play / pause"),this._restartBtn=r.button(r.iconFA("redo"),(()=>this._restartScript()),"Restart"),this._nextStepBtn=r.button(r.iconFA("play"),(()=>{this._isStepProcessed||this._nextStep()}),"Next step"),this._activity=r.panel([],"tutorials-root-description"),this._progressDiv=r.divV([],"tutorials-root-progress"),this._progress=r.element("progress"),this._progressSteps=r.divText(""),this._closeBtn=r.button(r.iconFA("chevron-left"),(()=>this._closeDock()),"Back to demo"),this.name=t,this.description=e,this._isAutomatic=n,this._autoStartFirstStep=null!==(o=null==a?void 0:a.autoStartFirstStep)&&void 0!==o&&o,this._progress.max=0,this._progress.value=1,l.currentObject=this}get steps(){return this._steps}get stepNumber(){return this._steps.length}_addHeader(){this._createHeaderDiv(),this._createProgressDiv(),this._mainHeader.append(this._headerDiv,this._progressDiv)}_createHeaderDiv(){this._header.innerText=this.name,this._headerDiv.append(this._closeBtn),this._headerDiv.append(this._header),this._nextStepBtn.firstChild.className="grok-icon fas fa-play",this._headerDiv.append(this._isAutomatic?this._stopStartBtn:this._nextStepBtn)}_createProgressDiv(){this._progress.max=this.stepNumber,this._progressDiv.append(this._progress),this._progressSteps=r.divText(`Step: ${this._progress.value} of ${this.stepNumber}`),this._progressDiv.append(this._progressSteps)}_addDescription(){var t;this._activity.append(r.div(this.description,"tutorials-root-description"));for(let e=0;e<this.stepNumber;e++){let n=r.iconFA("clock");this._isAutomatic||0===e&&(n=r.iconFA("play",(()=>this._nextStep()),"Next step"),n.className="grok-icon fas fa-play");const a=r.div(this._steps[e].name,"grok-tutorial-entry-instruction"),o=r.div(null===(t=this._steps[e].options)||void 0===t?void 0:t.description,"grok-tutorial-step-description hidden"),i=r.divH([n,a],"grok-tutorial-entry");this._activity.append(i,o)}}_initRoot(){var t,e,r;n.shell.windows.showContextPanel=!0,n.shell.windows.showHelp=!1;const o=Array.from(n.shell.dockManager.rootNode.children)[0];this._node=n.shell.dockManager.dock(this._root,a.DOCK_TYPE.FILL,o,""),(null===(e=null===(t=o.parent.container.containerElement.firstElementChild)||void 0===t?void 0:t.lastElementChild)||void 0===e?void 0:e.classList.contains("tab-handle-list-container"))&&(null===(r=o.parent.container.containerElement.firstElementChild)||void 0===r||r.lastElementChild.remove()),this._node.container.containerElement.classList.add("tutorials-demo-script-container"),this._addHeader(),this._root.append(this._mainHeader),this._addDescription(),this._root.append(this._activity)}_nextStep(){var t,e;return s(this,void 0,void 0,(function*(){this._isStepProcessed=!0,this._isAutomatic||(this._nextStepBtn.classList.add("disabled"),this._nextStepBtn.firstChild.classList.add("fa-disabled"));const n=this._activity.getElementsByClassName("grok-tutorial-entry")[this._currentStep],a=this._activity.getElementsByClassName("grok-icon")[this._currentStep],o=this._activity.getElementsByClassName("grok-tutorial-step-description")[this._currentStep];a.className="grok-icon far fa-spinner-third fa-spin",o.classList.remove("hidden"),o.classList.add("visible");const s=n,l=(null===(t=this._steps[this._currentStep].options)||void 0===t?void 0:t.delay)?null===(e=this._steps[this._currentStep].options)||void 0===e?void 0:e.delay:2e3;yield this._steps[this._currentStep].func(),this._scrollTo(this._root,s.offsetTop-this._mainHeader.offsetHeight),this._isAutomatic&&(yield this._countdown(n,a,l),yield i(l));const c=r.iconFA("check");if(a.replaceWith(c),c.className="grok-icon far fa-check",this._progress.value++,this._progressSteps.innerText=`Step: ${this._progress.value} of ${this.stepNumber}`,this._currentStep++,this._isStepProcessed=!1,this._currentStep!==this.stepNumber){if(!this._isAutomatic){const t=this._activity.getElementsByClassName("grok-icon")[this._currentStep],e=r.iconFA("play",(()=>this._nextStep()),"Next step");e.className="grok-icon fas fa-play",t.replaceWith(e),this._nextStepBtn.classList.remove("disabled"),this._nextStepBtn.firstChild.classList.remove("fa-disabled")}}else this._isAutomatic?this._stopStartBtn.replaceWith(this._restartBtn):this._nextStepBtn.replaceWith(this._restartBtn)}))}_startScript(){return s(this,void 0,void 0,(function*(){for(let t=this._currentStep;t<this.stepNumber&&!this._isStopped&&!this._isCancelled;t++)yield this._nextStep()}))}_scrollTo(t,e){t.focus(),t.scrollTop=e}_countdown(t,e,n){return s(this,void 0,void 0,(function*(){const a=r.div([],"demo-script-countdown");e.classList.add("hidden");let o=n/1e3;const i=this._createSVGIndicator(o);a.append(i),t.prepend(a);const s=setInterval((()=>{o--,0===o&&(clearInterval(s),a.remove(),e.classList.remove("hidden"),e.classList.add("visible"))}),1e3)}))}_createSVGIndicator(t){const e=document.createElementNS("http://www.w3.org/2000/svg","svg"),n=document.createElementNS("http://www.w3.org/2000/svg","circle");return n.setAttributeNS(null,"cx","7"),n.setAttributeNS(null,"cy","7"),n.setAttributeNS(null,"r","6"),n.setAttributeNS(null,"style",`animation: countdown ${t}s linear infinite forwards`),e.append(n),e}_changeStopState(){const t=this._stopStartBtn.getElementsByClassName("grok-icon");t[0].className="grok-icon fas fa-play",this._isStopped=!this._isStopped,this._isStopped||(t[0].className="grok-icon fal fa-pause",this._isStepProcessed||this._startScript())}_restartScript(){n.shell.dockManager.close(this._node),n.shell.closeAll(),this._clearRoot(),this._setInitParams(),this.start()}_clearRoot(){this._root=r.div([],{id:"demo-script",classes:"tutorials-root tutorials-track demo-app-script"}),this._mainHeader=r.panel([],"tutorials-main-header"),this._header=r.h2(""),this._headerDiv=r.divH([],"tutorials-root-header"),this._activity=r.panel([],"tutorials-root-description"),this._progressDiv=r.divV([],"tutorials-root-progress"),this._progress=r.element("progress"),this._progressSteps=r.divText(""),this._progress.max=0,this._progress.value=1}_setInitParams(){this._currentStep=0,this._isStopped=!1,this._isCancelled=!1,this._stopStartBtn.getElementsByClassName("grok-icon")[0].className="grok-icon fal fa-pause",this._nextStepBtn.classList.remove("disabled")}_closeDock(){n.shell.dockManager.close(this._node),this.cancelScript()}cancelScript(){this._isCancelled=!0,l.currentObject=null}step(t,e,n){return this._steps[this.steps.length]={name:t,func:e,options:n},this}start(){return s(this,void 0,void 0,(function*(){this._initRoot(),n.shell.newView(this.name),this._isAutomatic?this._startScript():this._autoStartFirstStep&&(yield this._nextStep())}))}}l.currentObject=null,Int32Array,Float32Array,DG.Column.fromInt32Array,DG.Column.fromFloat32Array;const c="num",u="floatColumn",m="intColumn",d="floatColumns",h="newFloatColumns",p="intColumns",f="newIntColumns",y="newFloatColumn",v="newIntColumn",w="column",g="_callResult",_="numOfRows",b="numOfColumns",S="ref",C="value",A="tableFromColumns",k="objects",D="int",F="double",P={intColumn:Int32Array,floatColumn:Float32Array,floatColumns:Float32Array,newFloatColumns:Float32Array,intColumns:Int32Array,newIntColumns:Int32Array,newFloatColumn:Float32Array,newIntColumn:Int32Array};function L(t,e){let n,r=[],a=0;for(const o in t){const i=t[o],s=i.type;if(o!==g){switch(s){case c:case D:case F:i.data=e[a],a++;break;case m:case u:let r,o=e[a];r=o.type===D&&s===m||o.type===F&&s===u?o.getRawData():new P[s](o.getRawData()),i.data={array:r,numOfRows:r.length},a++;break;case v:case y:let l=0;n=i[_][S],l=t[n].type===c?t[n].data:t[n].data[i[_][C]],i.data={numOfRows:l},a++;break;case p:case d:let w=[];for(let t of e[a].toList())t.type===D&&s===m||t.type===F&&s===u?w.push(t.getRawData()):w.push(new P[s](t.getRawData()));i.data={arrays:w,numOfRows:w[0].length,numOfColumns:w.length},a++;break;case f:case h:let g=0,A=0;n=i[_][S],g=t[n].type===c?t[n].data:t[n].data[i[_][C]],n=i[b][S],A=t[n].type===c?t[n].data:t[n].data[i[b][C]],i.data={numOfRows:g,numOfColumns:A},a++;break;default:return}r.push(i)}}return r}function E(t,e){t.arguments._callResult=e.callResult,function(t,e){const n={newFloatColumns:DG.Column.fromFloat32Array,newIntColumns:DG.Column.fromInt32Array,newFloatColumn:DG.Column.fromFloat32Array,newIntColumn:DG.Column.fromInt32Array};let r=0;for(const a in t){const o=t[a];switch(o.type){case c:case D:case F:case m:case u:case d:case p:break;case y:case v:let t;null==o.name?t=(0).toString():s=o.name,o.column=n[o.type](t,e[r].array);break;case f:case h:let a=[],i=e[r].arrays.length,s=[];if(null==o.names)for(let t=1;t<=i;t++)s.push(t.toString());else s=o.names;for(let t=0;t<i;t++)a.push(n[o.type](s[t],e[r].arrays[t]));o.columns=a}r++}}(t.arguments,e.args);let n=function(t){let e=t.output;const n={newFloatColumns:"columns",newIntColumns:"columns",newFloatColumn:"column",newIntColumn:"column"};switch(e.type){case c:case D:case F:return t.arguments[e.source];case w:return t.arguments[e.source].column;case A:return DG.DataFrame.fromColumns(t.arguments[e.source].columns);case k:let r=[];for(let a of e.source){let e=t.arguments[a];r.push(e[n[e.type]])}return r}}(t);return function(t){for(const e in t){const n=t[e];switch(n.type){case c:case D:case F:case m:case u:case p:case d:break;case v:case y:n.column=null;break;case f:case h:n.columns=null}}}(t.arguments),n}const I=1,x=1,V=1,R=0,N=100,T=1e8,B="components must be positive.",M="components must not be greater than feautures count.",O="min must be less than max.",$="features must be positive.",H="samples must be positive.",W="violators percentage must be from the range from 0 to 100.",j="dataframe is too big.";function G(t,e){if(e<I)throw new Error(B);if(e>t.length)throw new Error(M);if(t.length*t.byIndex(0).length>T)throw new Error(j)}var z=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};function K(e,n,r,a){return z(this,void 0,void 0,(function*(){let e;G(n,a);let o=async function(e,n,r,a){return new Promise(((e,o)=>{const i=new Worker(new URL(t.p+t.u(93),t.b));i.postMessage(L(EDA.partialLeastSquareRegression.arguments,[n,r,a])),i.onmessage=function(t){i.terminate(),e(E(EDA.partialLeastSquareRegression,t.data))}}))}(0,n,r,a);return yield o.then((t=>{e=t}),(t=>{throw new Error(`Error: ${t}`)})),e}))}function U(t,e,n){n.name=e.name+"(predicted)";let r=a.DataFrame.fromColumns([t,e,n]);return r.name="Reference vs. Predicted",a.Viewer.scatterPlot(r,{title:r.name,x:e.name,y:n.name,showRegressionLine:!0,markerType:"circle",labels:t.name})}function q(t,e){e.name="regression coefficient";let n=[];for(const e of t)n.push(e.name);let r=a.Column.fromStrings("feature",n),o=a.DataFrame.fromColumns([r,e]);return o.name="Regression Coefficients",a.Viewer.barChart(o,{title:o.name,split:"feature",value:"regression coefficient",valueAggrType:"avg"})}function Y(t,e,n){let r=[t];for(let t=0;t<e.length;t++)e[t].name=`x.score.t${t+1}`,r.push(e[t]);for(let t=0;t<n.length;t++)n[t].name=`y.score.u${t+1}`,r.push(n[t]);let o=a.DataFrame.fromColumns(r);o.name="Scores";const i=e.length>1?1:0;return a.Viewer.scatterPlot(o,{title:o.name,x:e[0].name,y:e[i].name,markerType:"circle",labels:t.name})}var J=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};const Q=0,X=1,Z="Feature #",tt="Label";function et(){return a.DataFrame.fromColumns([a.Column.fromStrings("model",["alfaromeo","audi","bmw","chevrolet","dodge1","dodge2","honda1","honda2","isuzu","jaguar","mazda","mercedes","mercury","mitsubishi","nissan1","nissan2","peugot","plymouth","porsche","saab","subaru","toyota1","toyota2","toyota3","toyota4","volkswagen1","volkswagen2","volvo1","volvo2","volvo3"]),a.Column.fromInt32Array("diesel",new Int32Array([0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,1,0,1,1,0,0,0,1])),a.Column.fromInt32Array("turbo",new Int32Array([0,0,0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,1])),a.Column.fromInt32Array("two.doors",new Int32Array([1,0,1,0,1,0,1,0,0,0,0,0,1,1,0,1,0,0,1,0,0,1,0,1,0,1,0,0,0,0])),a.Column.fromInt32Array("hatchback",new Int32Array([1,0,0,0,1,1,1,0,0,0,0,0,1,1,0,0,1,0,0,0,0,1,0,1,0,0,0,0,0,0])),a.Column.fromFloat32Array("wheel.base",new Float32Array([94.5,105.80000305175781,101.19999694824219,94.5,93.69999694824219,93.69999694824219,93.69999694824219,96.5,94.30000305175781,113,93.0999984741211,115.5999984741211,102.69999694824219,93.69999694824219,94.5,94.5,93.69999694824219,114.19999694824219,89.5,99.0999984741211,97.19999694824219,95.69999694824219,95.69999694824219,98.4000015258789,102.4000015258789,97.30000305175781,100.4000015258789,104.30000305175781,109.0999984741211,109.0999984741211])),a.Column.fromFloat32Array("length",new Float32Array([171.1999969482422,192.6999969482422,176.8000030517578,158.8000030517578,157.3000030517578,157.3000030517578,150,175.39999389648438,170.6999969482422,199.60000610351562,166.8000030517578,202.60000610351562,178.39999389648438,157.3000030517578,170.1999969482422,165.3000030517578,157.3000030517578,198.89999389648438,168.89999389648438,186.60000610351562,172,158.6999969482422,166.3000030517578,176.1999969482422,175.60000610351562,171.6999969482422,180.1999969482422,188.8000030517578,188.8000030517578,188.8000030517578])),a.Column.fromFloat32Array("width",new Float32Array([65.5,71.4000015258789,64.80000305175781,63.599998474121094,63.79999923706055,63.79999923706055,64,65.19999694824219,61.79999923706055,69.5999984741211,64.19999694824219,71.69999694824219,68,64.4000015258789,63.79999923706055,63.79999923706055,63.79999923706055,68.4000015258789,65,66.5,65.4000015258789,63.599998474121094,64.4000015258789,65.5999984741211,66.5,65.5,66.9000015258789,67.19999694824219,68.80000305175781,68.9000015258789])),a.Column.fromFloat32Array("height",new Float32Array([52.400001525878906,55.70000076293945,54.29999923706055,52,50.79999923706055,50.599998474121094,52.599998474121094,54.099998474121094,53.5,52.79999923706055,54.099998474121094,56.29999923706055,54.79999923706055,50.79999923706055,53.5,54.5,50.599998474121094,58.70000076293945,51.599998474121094,56.099998474121094,52.5,54.5,53,52,54.900001525878906,55.70000076293945,55.099998474121094,56.20000076293945,55.5,55.5])),a.Column.fromInt32Array("curb.weight",new Int32Array([2823,2844,2395,1909,2128,1967,1956,2304,2337,4066,1950,3770,2910,1918,2024,1951,1967,3430,2800,2695,2190,1985,2275,2551,2480,2261,2661,2912,3049,3217])),a.Column.fromInt32Array("eng.size",new Int32Array([152,136,108,90,98,90,92,110,111,258,91,183,140,92,97,97,90,152,194,121,108,92,110,146,110,97,136,141,141,145])),a.Column.fromInt32Array("horsepower",new Int32Array([154,110,101,70,102,68,76,86,78,176,68,123,175,68,69,69,68,95,207,110,82,62,56,116,73,52,110,114,160,106])),a.Column.fromInt32Array("peak.rpm",new Int32Array([5e3,5500,5800,5400,5500,5500,6e3,5800,4800,4750,5e3,4350,5e3,5500,5200,5200,5500,4150,5900,5250,4400,4800,4500,4800,4500,4800,5500,5400,5300,4800])),a.Column.fromInt32Array("symbol",new Int32Array([1,1,2,0,1,1,1,0,0,0,1,-1,1,2,1,1,1,0,3,2,0,1,0,2,-1,2,0,-2,-1,-1])),a.Column.fromInt32Array("city.mpg",new Int32Array([19,19,23,38,24,31,30,27,24,15,31,22,19,37,31,31,31,25,17,21,28,35,34,24,30,37,19,23,19,26])),a.Column.fromInt32Array("highway.mpg",new Int32Array([26,25,29,43,30,38,34,33,29,19,38,25,24,41,37,37,38,25,25,28,33,39,36,30,33,46,24,28,25,27])),a.Column.fromInt32Array("price",new Int32Array([16500,17710,16430,6575,7957,6229,7129,8845,6785,35550,7395,31600,16503,5389,7349,7299,6229,13860,37028,12170,7775,5348,7898,9989,10698,7775,13295,12940,19045,22470]))])}function nt(e,n,r,o,i,s,l,c){return J(this,void 0,void 0,(function*(){!function(t,e,n,r,a){if(n>=r)throw new Error(O);if(e<V)throw new Error($);if(t<x)throw new Error(H);if(a<R||a>N)throw new Error(W)}(o,i,s,l,c);const u=a.Column.fromList("double","kernelParams",n);let m,d=async function(e,n,r,a,o,i,s){return new Promise(((l,c)=>{const u=new Worker(new URL(t.p+t.u(584),t.b));u.postMessage(L(EDA.generateDataset.arguments,[e,n,r,a,o,i,s])),u.onmessage=function(t){u.terminate(),l(E(EDA.generateDataset,t.data))}}))}(e,u,o,i,s,l,c);yield d.then((t=>{m=t}),(t=>{throw new Error(`Error: ${t}`)})),m[X].name=tt;for(const t of m[Q])t.name=Z+t.name;const h=a.DataFrame.fromColumns(m[Q]);return h.name=r,h.columns.add(m[X]),h}))}var rt=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};const at=0,ot=1,it=2,st=3,lt=4,ct=0,ut=1,mt=2,dt=3,ht=4,pt=5,ft=6,yt=7,vt=0,wt=1,gt=2,_t=3,bt=0,St=0,Ct=1,At=0,kt=1,Dt=0,Ft=0,Pt=0,Lt=0,Et="gamma must be strictly positive.",It="sigma must be strictly positive.",xt="c must be strictly positive.",Vt="d must be strictly positive.",Rt="incorrect kernel.",Nt="Labels",Tt="predicted",Bt="correctness",Mt="Confusion matrix",Ot="mean",$t="std dev",Ht="alpha",Wt="weight",jt="gamma",Gt="kernel",zt="kernel params",Kt="kernel param 1",Ut="kernel param 2",qt="features count",Yt="train samples count",Jt="Train error,%",Qt=["linear","polynomial","RBF","sigmoid"],Xt="positive (P)",Zt="negative (N)",te="predicted positive (PP)",ee="predicted negative (PN)",ne="Sensitivity",re="Specificity",ae="Balanced accuracy",oe="Positive predicitve value",ie="Negative predicitve value",se="Model report",le="Predicted labels",ce="Train labels",ue="Prediction correctness",me="prediction",de=4,he=3,pe=2,fe=0,ye=1,ve=2,we=0,ge=1;function _e(e,n,r){return rt(this,void 0,void 0,(function*(){let o=n.columns,i=o.byName(r);return o.remove(r),yield function(e,n,r){return rt(this,void 0,void 0,(function*(){!function(t){if(t.gamma<=Dt)throw new Error(Et);switch(t.kernel){case at:return;case it:if(t.sigma<=Ft)throw new Error(It);return;case ot:if(t.cParam<=Pt)throw new Error(xt);if(t.dParam<=Lt)throw new Error(Vt);return;case st:return;default:throw new Error(Rt)}}(e);const o=[we,we];switch(e.kernel){case at:break;case it:o[bt]=e.sigma;break;case ot:o[St]=e.cParam,o[Ct]=e.dParam;break;case st:o[At]=e.kappa,o[kt]=e.theta;break;default:throw new Error(Rt)}let i,s=a.Column.fromList("double",zt,o),l=n.toList(),c=l[0].length+ge,u=l.length+ge,m=lt,d=async function(e,n,r,a,o,i,s,l){return new Promise(((c,u)=>{const m=new Worker(new URL(t.p+t.u(111),t.b));m.postMessage(L(EDA.trainAndAnalyzeLSSVM.arguments,[e,n,r,a,o,i,s,l])),m.onmessage=function(t){m.terminate(),c(E(EDA.trainAndAnalyzeLSSVM,t.data))}}))}(e.gamma,e.kernel,s,c,u,m,n,r);yield d.then((t=>{i=t}),(t=>{throw new Error(`Error: ${t}`)})),i[ut].name=Ot,i[mt].name=$t,i[dt].name=Ht,i[ht].name=Wt,i[pt].name=Tt,i[ft].name=Bt,i[yt].name=Mt;let h={trainGamma:e.gamma,kernelType:e.kernel,kernelParams:s,trainLabels:r,normalizedTrainData:a.DataFrame.fromColumns(i[ct]),means:i[ut],stdDevs:i[mt],modelParams:i[dt],modelWeights:i[ht],predictedLabels:i[pt],correctness:i[ft],confusionMatrix:i[yt],trainError:void 0,featuresCount:l.length,trainSamplesCount:l[0].length};return function(t){let e=t.confusionMatrix.getRawData(),n=e[vt],r=e[_t],a=e[gt],o=e[wt],i=n+o,s=a+r,l=n/i,c=r/s,u=n/(n+a),m=r/(r+o),d=(n+r)/(i+s),h=(l+c)/2;t.sensitivity=l,t.specificity=c,t.balancedAccuracy=h,t.positivePredicitveValue=u,t.negativePredicitveValue=m,t.trainError=100*(1-d)}(h),h}))}(e,o,i)}))}function be(t,e){t.name=se,t.columns.add(e.trainLabels),t.columns.add(e.predictedLabels),t.columns.add(e.correctness);let r=n.shell.addTableView(t);r.addViewer(a.Viewer.form(function(t){let e=t.kernelParams.getRawData();return a.DataFrame.fromColumns([a.Column.fromList("double",jt,[t.trainGamma]),a.Column.fromStrings(Gt,[Qt[t.kernelType]]),a.Column.fromList("double",Kt,[e[0]]),a.Column.fromList("double",Ut,[e[1]]),a.Column.fromList("double",qt,[t.featuresCount]),a.Column.fromList("double",Yt,[t.trainSamplesCount]),a.Column.fromList("double",Jt,[t.trainError]),a.Column.fromList("double",ae,[t.balancedAccuracy]),a.Column.fromList("double",ne,[t.sensitivity]),a.Column.fromList("double",re,[t.specificity]),a.Column.fromList("double",oe,[t.positivePredicitveValue]),a.Column.fromList("double",ie,[t.negativePredicitveValue])])}(e))),r.addViewer(a.Viewer.scatterPlot(t,{title:le,color:e.predictedLabels.name})),r.addViewer(a.Viewer.scatterPlot(t,{title:ce,color:e.trainLabels.name})),r.addViewer(a.Viewer.grid(function(t){let e=t.confusionMatrix.getRawData();return a.DataFrame.fromColumns([a.Column.fromStrings("",[Xt,Zt]),a.Column.fromList("int",te,[e[vt],e[gt]]),a.Column.fromList("int",ee,[e[wt],e[_t]])])}(e))),r.addViewer(a.Viewer.scatterPlot(t,{title:ue,color:e.correctness.name}))}function Se(t){let e=t.normalizedTrainData.columns,n=t.trainSamplesCount,r=t.featuresCount,a=new Uint8Array(de*(he+pe+n+r+r+n+ge+r+ge+r*n)),o=a.buffer,i=0,s=new Int32Array(o,i,he);s[fe]=t.kernelType,s[ye]=n,s[ve]=r,i+=he*de;let l=new Float32Array(o,i,pe);l.set(t.kernelParams.getRawData()),i+=pe*de,l=new Float32Array(o,i,n),l.set(t.trainLabels.getRawData()),i+=n*de,l=new Float32Array(o,i,r),l.set(t.means.getRawData()),i+=r*de,l=new Float32Array(o,i,r),l.set(t.stdDevs.getRawData()),i+=r*de,l=new Float32Array(o,i,n+ge),l.set(t.modelParams.getRawData()),i+=(n+ge)*de,l=new Float32Array(o,i,r+ge),l.set(t.modelWeights.getRawData()),i+=(r+ge)*de;for(const t of e)l=new Float32Array(o,i,r),l.set(t.getRawData()),i+=r*de;return a}function Ce(e,n){return rt(this,void 0,void 0,(function*(){let r=function(t){let e=t.buffer,n=0,r=new Int32Array(e,n,he);n+=he*de;let o=r[ye],i=r[ve];const s=a.Column.fromFloat32Array(zt,new Float32Array(e,n,pe));n+=pe*de;const l=a.Column.fromFloat32Array(Nt,new Float32Array(e,n,o));n+=o*de;const c=a.Column.fromFloat32Array(Ot,new Float32Array(e,n,i));n+=i*de;const u=a.Column.fromFloat32Array($t,new Float32Array(e,n,i));n+=i*de;const m=a.Column.fromFloat32Array(Ht,new Float32Array(e,n,o+ge));n+=(o+ge)*de;const d=a.Column.fromFloat32Array(Wt,new Float32Array(e,n,i+ge));n+=(i+ge)*de;let h=[];for(let t=0;t<o;t++)h.push(a.Column.fromFloat32Array(t.toString(),new Float32Array(e,n,i))),n+=i*de;const p=a.DataFrame.fromColumns(h);return{kernelType:r[fe],kernelParams:s,trainLabels:l,means:c,stdDevs:u,modelParams:m,modelWeights:d,normalizedTrainData:p}}(new Uint8Array(n)),o=yield function(e,n){return rt(this,void 0,void 0,(function*(){let r,a=async function(e,n,r,a,o,i,s,l,c){return new Promise(((u,m)=>{const d=new Worker(new URL(t.p+t.u(604),t.b));d.postMessage(L(EDA.predictByLSSVM.arguments,[e,n,r,a,o,i,s,l,c])),d.onmessage=function(t){d.terminate(),u(E(EDA.predictByLSSVM,t.data))}}))}(e.kernelType,e.kernelParams,e.normalizedTrainData.columns,e.trainLabels,e.means,e.stdDevs,e.modelParams,e.modelWeights,n);return yield a.then((t=>{r=t}),(t=>{throw new Error(`Error: ${t}`)})),r}))}(r,e.columns);return o.name=me,a.DataFrame.fromColumns([o])}))}var Ae=function(t,e,n,r){return new(n||(n=Promise))((function(a,o){function i(t){try{l(r.next(t))}catch(t){o(t)}}function s(t){try{l(r.throw(t))}catch(t){o(t)}}function l(t){var e;t.done?a(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,s)}l((r=r.apply(t,e||[])).next())}))};const ke=new a.Package;function De(){n.shell.info(ke.webRoot)}function Fe(){return Ae(this,void 0,void 0,(function*(){yield async function(){await initEDA()}()}))}function Pe(e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){return function(t){for(const e of t.columns.toList())e.name="PCA"+e.name;return t}(yield function(e,n,r,a,o){return z(this,void 0,void 0,(function*(){G(n,r);let e,i=async function(e,n,r,a,o){return new Promise(((e,i)=>{const s=new Worker(new URL(t.p+t.u(155),t.b));s.postMessage(L(EDA.principalComponentAnalysis.arguments,[n,r,a,o])),s.onmessage=function(t){s.terminate(),e(E(EDA.principalComponentAnalysis,t.data))}}))}(0,n,r,a?1:0,o?1:0);return yield i.then((t=>{e=t}),(t=>{throw new Error(`Error: ${t}`)})),e}))}(0,n,r,a,o))}))}function Le(t,e,r,o,i){return Ae(this,void 0,void 0,(function*(){const s=yield K(0,r,o,i);!function(t,e,r,o,i){let s=n.shell.getTableView(t.name);s.addViewer(U(e,o,i[0])),s.addViewer(q(r,i[1])),s.addViewer(function(t,e){let n=[],r=[];for(let e of t)r.push(e.name);n.push(a.Column.fromStrings("labels",r));for(let t=0;t<e.length;t++)e[t].name=`x.loading.p${t+1}`,n.push(e[t]);let o=a.DataFrame.fromColumns(n);return o.name="Loadings",a.Viewer.scatterPlot(o,{title:o.name,x:e[0].name,y:e[e.length-1].name,markerType:"circle",labels:"labels"})}(r,i[4])),s.addViewer(Y(e,i[2],i[3]))}(t,e,r,o,s)}))}function Ee(){return Ae(this,void 0,void 0,(function*(){const t=new l("Partial least squares regression","Analysis of multidimensional data."),e=et(),a=e.columns.byName("model"),o=e.columns.byName("price"),i=e.columns.remove("price").remove("model"),s=yield K(0,i,o,3),c=et();let u,m;c.name="Cars",yield t.step("Data",(()=>Ae(this,void 0,void 0,(function*(){n.shell.addTableView(c),u=n.shell.getTableView(c.name)}))),{description:"Each car has many features - patterns extraction is complicated.",delay:0}).step("Model",(()=>Ae(this,void 0,void 0,(function*(){m=r.dialog({title:"Multivariate Analysis (PLS)"}).add(r.tableInput("Table",c)).add(r.columnsInput("Features",e,i.toList,{available:void 0,checked:i.names()})).add(r.columnInput("Names",e,a,void 0)).add(r.columnInput("Predict",e,o,void 0)).add(r.intInput("Components",3,void 0)).onOK((()=>{n.shell.info("Multivariate analysis has been already performed.")})).show({x:400,y:140})}))),{description:"Predict car price by its other features.",delay:0}).step("Regression coeffcicients",(()=>Ae(this,void 0,void 0,(function*(){m.close(),u.addViewer(q(i,s[1]))}))),{description:'The feature "diesel" affects the price the most.',delay:0}).step("Scores",(()=>Ae(this,void 0,void 0,(function*(){u.addViewer(Y(a,s[2],s[3]))}))),{description:"Similarities & dissimilarities: alfaromeo and mercedes are different.",delay:0}).step("Prediction",(()=>Ae(this,void 0,void 0,(function*(){u.addViewer(U(a,o,s[0]))}))),{description:"Closer to the line means better price prediction.",delay:0}).start()}))}function Ie(t,e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){return yield nt(at,[0,0],t,e,n,r,a,o)}))}function xe(t,e,n,r,a,o,i){return Ae(this,void 0,void 0,(function*(){return yield nt(it,[e,0],t,n,r,a,o,i)}))}function Ve(t,e,n,r){return Ae(this,void 0,void 0,(function*(){const a=yield _e({gamma:n,kernel:at},t,e);return r&&be(t,a),Se(a)}))}function Re(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}function Ne(t,e,n,r,a){return Ae(this,void 0,void 0,(function*(){const o=yield _e({gamma:n,kernel:it,sigma:r},t,e);return a&&be(t,o),Se(o)}))}function Te(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}function Be(t,e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){const i=yield _e({gamma:n,kernel:ot,cParam:r,dParam:a},t,e);return o&&be(t,i),Se(i)}))}function Me(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}function Oe(t,e,n,r,a,o){return Ae(this,void 0,void 0,(function*(){const i=yield _e({gamma:n,kernel:st,kappa:r,theta:a},t,e);return o&&be(t,i),Se(i)}))}function $e(t,e){return Ae(this,void 0,void 0,(function*(){return yield Ce(t,e)}))}eda=e})();
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"package.js","mappings":"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","sources":["webpack://eda/webpack/bootstrap","webpack://eda/webpack/runtime/define property getters","webpack://eda/webpack/runtime/get javascript chunk filename","webpack://eda/webpack/runtime/global","webpack://eda/webpack/runtime/hasOwnProperty shorthand","webpack://eda/webpack/runtime/make namespace object","webpack://eda/webpack/runtime/publicPath","webpack://eda/webpack/runtime/jsonp chunk loading","webpack://eda/external var \"grok\"","webpack://eda/external var \"ui\"","webpack://eda/external var \"DG\"","webpack://eda/./node_modules/@datagrok-libraries/utils/src/test.js","webpack://eda/./node_modules/@datagrok-libraries/tutorials/src/demo-script.js","webpack://eda/./wasm/callWasm.js","webpack://eda/./wasm/callWasmForWebWorker.js","webpack://eda/./src/utils.ts","webpack://eda/./src/EDAtools.ts","webpack://eda/./wasm/EDAAPI.js","webpack://eda/./src/EDAui.ts","webpack://eda/./src/dataGenerators.ts","webpack://eda/./src/svm.ts","webpack://eda/./src/package.ts"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\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) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\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\t359: 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","const __WEBPACK_NAMESPACE_OBJECT__ = grok;","const __WEBPACK_NAMESPACE_OBJECT__ = ui;","const __WEBPACK_NAMESPACE_OBJECT__ = DG;","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';\nexport const tests = {};\nconst autoTestsCatName = 'Auto Tests';\nconst wasRegistered = {};\nexport let currentCategory;\nexport var assure;\n(function (assure) {\n    function notNull(value, name) {\n        if (value == null)\n            throw new Error(`${name == null ? 'Value' : name} not defined`);\n    }\n    assure.notNull = notNull;\n})(assure || (assure = {}));\nexport class TestContext {\n    constructor(catchUnhandled, report) {\n        this.catchUnhandled = true;\n        this.report = false;\n        if (catchUnhandled !== undefined)\n            this.catchUnhandled = catchUnhandled;\n        if (report !== undefined)\n            this.report = report;\n    }\n    ;\n}\nexport class Test {\n    constructor(category, name, test, options) {\n        var _a;\n        this.category = category;\n        this.name = name;\n        options !== null && options !== void 0 ? options : (options = {});\n        (_a = options.timeout) !== null && _a !== void 0 ? _a : (options.timeout = 30000);\n        this.options = options;\n        this.test = () => __awaiter(this, void 0, void 0, function* () {\n            return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {\n                let result = '';\n                try {\n                    result = yield test();\n                }\n                catch (e) {\n                    reject(e);\n                }\n                resolve(result);\n            }));\n        });\n    }\n}\nexport function testEvent(event, handler, trigger, ms = 0) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let sub;\n        return new Promise((resolve, reject) => {\n            sub = event.subscribe((args) => {\n                try {\n                    handler(args);\n                }\n                catch (e) {\n                    reject(e);\n                }\n                sub.unsubscribe();\n                resolve('OK');\n            });\n            setTimeout(() => {\n                sub.unsubscribe();\n                // eslint-disable-next-line prefer-promise-reject-errors\n                reject('timeout');\n            }, ms);\n            trigger();\n        });\n    });\n}\nexport function test(name, test, options) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    if (tests[currentCategory].tests == undefined)\n        tests[currentCategory].tests = [];\n    tests[currentCategory].tests.push(new Test(currentCategory, name, test, options));\n}\n/* Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual, expected = true, error) {\n    if (error)\n        error = `${error}, `;\n    else\n        error = '';\n    if (actual !== expected)\n        throw new Error(`${error}Expected \"${expected}\", got \"${actual}\"`);\n}\nexport function expectFloat(actual, expected, tolerance = 0.001, error) {\n    if ((actual === Number.POSITIVE_INFINITY && expected === Number.POSITIVE_INFINITY) ||\n        (actual === Number.NEGATIVE_INFINITY && expected === Number.NEGATIVE_INFINITY) ||\n        (actual === Number.NaN && expected === Number.NaN) || (isNaN(actual) && isNaN(expected)))\n        return;\n    const areEqual = Math.abs(actual - expected) < tolerance;\n    expect(areEqual, true, `${error !== null && error !== void 0 ? error : ''} (tolerance = ${tolerance})`);\n    if (!areEqual)\n        throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);\n}\nexport function expectTable(actual, expected, error) {\n    const expectedRowCount = expected.rowCount;\n    const actualRowCount = actual.rowCount;\n    expect(actualRowCount, expectedRowCount, `${error !== null && error !== void 0 ? error : ''}, row count`);\n    for (const column of expected.columns) {\n        const actualColumn = actual.columns.byName(column.name);\n        if (actualColumn == null)\n            throw new Error(`Column ${column.name} not found`);\n        if (actualColumn.type != column.type)\n            throw new Error(`Column ${column.name} type expected ${column.type} got ${actualColumn.type}`);\n        for (let i = 0; i < expectedRowCount; i++) {\n            const value = column.get(i);\n            const actualValue = actualColumn.get(i);\n            if (column.type == DG.TYPE.FLOAT)\n                expectFloat(actualValue, value, 0.0001, error);\n            else if (column.type == DG.TYPE.DATE_TIME)\n                expect(actualValue.isSame(value), true, error);\n            else\n                expect(actualValue, value, error);\n        }\n    }\n}\nexport function expectObject(actual, expected) {\n    for (const [expectedKey, expectedValue] of Object.entries(expected)) {\n        if (!actual.hasOwnProperty(expectedKey))\n            throw new Error(`Expected property \"${expectedKey}\" not found`);\n        const actualValue = actual[expectedKey];\n        if (actualValue instanceof Array && expectedValue instanceof Array)\n            expectArray(actualValue, expectedValue);\n        else if (actualValue instanceof Object && expectedValue instanceof Object)\n            expectObject(actualValue, expectedValue);\n        else if (Number.isFinite(actualValue) && Number.isFinite(expectedValue))\n            expectFloat(actualValue, expectedValue);\n        else if (actualValue != expectedValue)\n            throw new Error(`Expected (${expectedValue}) for key '${expectedKey}', got (${actualValue})`);\n    }\n}\nexport function expectArray(actual, expected) {\n    const actualLength = actual.length;\n    const expectedLength = expected.length;\n    if (actualLength != expectedLength) {\n        throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +\n            `and expected array length is ${expectedLength}`);\n    }\n    for (let i = 0; i < actualLength; i++) {\n        if (actual[i] instanceof Array && expected[i] instanceof Array)\n            expectArray(actual[i], expected[i]);\n        else if (actual[i] instanceof Object && expected[i] instanceof Object)\n            expectObject(actual[i], expected[i]);\n        else if (actual[i] != expected[i])\n            throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);\n    }\n}\n/* Defines a test suite. */\nexport function category(category, tests) {\n    currentCategory = category;\n    tests();\n}\n/* Defines a function to be executed before the tests in this category are executed. */\nexport function before(before) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].before = before;\n}\n/* Defines a function to be executed after the tests in this category are executed. */\nexport function after(after) {\n    if (tests[currentCategory] == undefined)\n        tests[currentCategory] = {};\n    tests[currentCategory].after = after;\n}\nfunction addNamespace(s, f) {\n    return s.replace(new RegExp(f.name, 'gi'), f.nqName);\n}\nexport function initAutoTests(packageId, module) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (wasRegistered[packageId])\n            return;\n        const moduleTests = module ? module.tests : tests;\n        if (moduleTests[autoTestsCatName] !== undefined) {\n            wasRegistered[packageId] = true;\n            return;\n        }\n        const moduleAutoTests = [];\n        const packFunctions = yield grok.dapi.functions.filter(`package.id = \"${packageId}\"`).list();\n        const reg = new RegExp(/.*\\/\\/\\s*skip[:\\s]*(.*)$/);\n        for (const f of packFunctions) {\n            const tests = f.options['test'];\n            if (!(tests && Array.isArray(tests) && tests.length))\n                continue;\n            for (let i = 0; i < tests.length; i++) {\n                const skipReasons = tests[i].match(reg);\n                let skipReason;\n                if (skipReasons && (skipReasons === null || skipReasons === void 0 ? void 0 : skipReasons.length) > 1)\n                    skipReason = skipReasons[1];\n                moduleAutoTests.push(new Test(autoTestsCatName, tests.length === 1 ? f.name : `${f.name} ${i + 1}`, () => __awaiter(this, void 0, void 0, function* () {\n                    const res = yield grok.functions.eval(addNamespace(tests[i], f));\n                    // eslint-disable-next-line no-throw-literal\n                    if (res !== true)\n                        throw `Failed: ${tests[i]}`;\n                }), { skipReason: skipReason }));\n            }\n        }\n        wasRegistered[packageId] = true;\n        if (!moduleAutoTests.length)\n            return;\n        moduleTests[autoTestsCatName] = { tests: moduleAutoTests };\n    });\n}\nexport function runTests(options) {\n    var _a, _b, _c, _d;\n    var _e;\n    return __awaiter(this, void 0, void 0, function* () {\n        const package_ = (_b = (_a = grok.functions.getCurrentCall()) === null || _a === void 0 ? void 0 : _a.func) === null || _b === void 0 ? void 0 : _b.package;\n        yield initAutoTests(package_.id);\n        const results = [];\n        console.log(`Running tests`);\n        options !== null && options !== void 0 ? options : (options = {});\n        (_c = (_e = options).testContext) !== null && _c !== void 0 ? _c : (_e.testContext = new TestContext());\n        grok.shell.lastError = '';\n        for (const [key, value] of Object.entries(tests)) {\n            if ((options === null || options === void 0 ? void 0 : options.category) != undefined) {\n                if (!key.toLowerCase().startsWith(options === null || options === void 0 ? void 0 : options.category.toLowerCase()))\n                    continue;\n            }\n            console.log(`Started ${key} category`);\n            try {\n                if (value.before)\n                    yield value.before();\n            }\n            catch (x) {\n                value.beforeStatus = x.toString();\n            }\n            const t = (_d = value.tests) !== null && _d !== void 0 ? _d : [];\n            const res = [];\n            for (let i = 0; i < t.length; i++)\n                res.push(yield execTest(t[i], options === null || options === void 0 ? void 0 : options.test));\n            const data = (yield Promise.all(res)).filter((d) => d.result != 'skipped');\n            try {\n                if (value.after)\n                    yield value.after();\n            }\n            catch (x) {\n                value.afterStatus = x.toString();\n            }\n            if (value.afterStatus)\n                data.push({ category: key, name: 'init', result: value.afterStatus, success: false, ms: 0, skipped: false });\n            if (value.beforeStatus)\n                data.push({ category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0, skipped: false });\n            results.push(...data);\n        }\n        if (options.testContext.catchUnhandled) {\n            yield delay(1000);\n            if (grok.shell.lastError.length > 0) {\n                results.push({\n                    category: 'Unhandled exceptions',\n                    name: 'exceptions',\n                    result: grok.shell.lastError, success: false, ms: 0, skipped: false\n                });\n            }\n        }\n        if (options.testContext.report) {\n            const logger = new DG.Logger();\n            const successful = results.filter((r) => r.success).length;\n            const skipped = results.filter((r) => r.skipped).length;\n            const failed = results.filter((r) => !r.success);\n            const description = 'Package @package tested: @successful successful, @skipped skipped, @failed failed tests';\n            const params = {\n                successful: successful,\n                skipped: skipped,\n                failed: failed.length,\n                package: package_\n            };\n            for (const r of failed)\n                Object.assign(params, { [`${r.category} | ${r.name}`]: r.result });\n            logger.log(description, params, 'package-tested');\n        }\n        return results;\n    });\n}\nfunction execTest(t, predicate) {\n    var _a, _b, _c;\n    return __awaiter(this, void 0, void 0, function* () {\n        let r;\n        const filter = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));\n        const skip = ((_a = t.options) === null || _a === void 0 ? void 0 : _a.skipReason) || filter;\n        const skipReason = filter ? 'skipped' : (_b = t.options) === null || _b === void 0 ? void 0 : _b.skipReason;\n        if (!skip)\n            console.log(`Started ${t.category} ${t.name}`);\n        const start = new Date();\n        try {\n            if (skip)\n                r = { success: true, result: skipReason, ms: 0, skipped: true };\n            else\n                r = { success: true, result: (_c = yield t.test()) !== null && _c !== void 0 ? _c : 'OK', ms: 0, skipped: false };\n        }\n        catch (x) {\n            r = { success: false, result: x.toString(), ms: 0, skipped: false };\n        }\n        const stop = new Date();\n        // @ts-ignore\n        r.ms = stop - start;\n        if (!skip)\n            console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);\n        r.category = t.category;\n        r.name = t.name;\n        return r;\n    });\n}\n/* Waits [ms] milliseconds */\nexport function delay(ms) {\n    return __awaiter(this, void 0, void 0, function* () {\n        yield new Promise((r) => setTimeout(r, ms));\n    });\n}\nexport function awaitCheck(checkHandler, error = 'Timeout exceeded', wait = 500, interval = 50) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return new Promise((resolve, reject) => {\n            setTimeout(() => {\n                clearInterval(intervalId);\n                reject(new Error(error));\n            }, wait);\n            // @ts-ignore\n            const intervalId = setInterval(() => {\n                if (checkHandler()) {\n                    clearInterval(intervalId);\n                    resolve();\n                }\n            }, interval);\n        });\n    });\n}\nexport function isDialogPresent(dialogTitle) {\n    const dialogs = DG.Dialog.getOpenDialogs();\n    for (let i = 0; i < dialogs.length; i++) {\n        if (dialogs[i].title == dialogTitle)\n            return true;\n    }\n    return false;\n}\nexport function testViewer(v, df, detectSemanticTypes = false) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (detectSemanticTypes)\n            yield grok.data.detectSemanticTypes(df);\n        const tv = grok.shell.addTableView(df);\n        const viewerName = `[name=viewer-${v.replace(/\\s+/g, '-')} i]`;\n        const selector = `${viewerName} canvas,${viewerName} svg,${viewerName} img,\n    ${viewerName} input,${viewerName} h1,${viewerName} a`;\n        const res = [];\n        try {\n            let viewer = tv.addViewer(v);\n            yield awaitCheck(() => document.querySelector(selector) !== null, 'cannot load viewer', 3000);\n            res.push(Array.from(tv.viewers).length);\n            Array.from(df.row(0).cells).forEach((c) => c.value = null);\n            df.rows.select((row) => row.idx > 1 && row.idx < 7);\n            for (let i = 7; i < 12; i++)\n                df.filter.set(i, false);\n            df.currentRowIdx = 1;\n            const props = viewer.getOptions(true).look;\n            const newProps = {};\n            Object.keys(props).filter((k) => typeof props[k] === 'boolean').forEach((k) => newProps[k] = !props[k]);\n            viewer.setOptions(newProps);\n            yield delay(250);\n            const layout = tv.saveLayout();\n            const oldProps = viewer.getOptions().look;\n            tv.resetLayout();\n            res.push(Array.from(tv.viewers).length);\n            tv.loadLayout(layout);\n            yield awaitCheck(() => document.querySelector(selector) !== null, 'cannot load viewer from layout', 3000);\n            yield delay(250);\n            res.push(Array.from(tv.viewers).length);\n            viewer = Array.from(tv.viewers).find((v) => v.type !== 'Grid');\n            expectArray(res, [2, 1, 2]);\n            expect(JSON.stringify(viewer.getOptions().look), JSON.stringify(oldProps));\n        }\n        finally {\n            tv.close();\n            grok.shell.closeTable(df);\n        }\n    });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport {Observable, Subscription} from 'rxjs';\nimport Timeout = NodeJS.Timeout;\nimport {DataFrame} from 'datagrok-api/dg';\n\nexport const tests: {\n  [key: string]: {\n    tests?: Test[], before?: () => Promise<void>, after?: () => Promise<void>,\n    beforeStatus?: string, afterStatus?: string\n  }\n} = {};\n\nconst autoTestsCatName = 'Auto Tests';\nconst wasRegistered: {[key: string]: boolean} = {};\nexport let currentCategory: string;\n\nexport namespace assure {\n  export function notNull(value: any, name?: string) {\n    if (value == null)\n      throw new Error(`${name == null ? 'Value' : name} not defined`);\n  }\n}\n\nexport interface TestOptions {\n  timeout?: number;\n  unhandledExceptionTimeout?: number;\n  skipReason?: string;\n}\n\nexport class TestContext {\n  catchUnhandled = true;\n  report = false;\n\n  constructor(catchUnhandled?: boolean, report?: boolean) {\n    if (catchUnhandled !== undefined) this.catchUnhandled = catchUnhandled;\n    if (report !== undefined) this.report = report;\n  };\n}\n\nexport class Test {\n  test: () => Promise<any>;\n  name: string;\n  category: string;\n  options?: TestOptions;\n\n  constructor(category: string, name: string, test: () => Promise<any>, options?: TestOptions) {\n    this.category = category;\n    this.name = name;\n    options ??= {};\n    options.timeout ??= 30000;\n    this.options = options;\n    this.test = async (): Promise<any> => {\n      return new Promise(async (resolve, reject) => {\n        let result = '';\n        try {\n          result = await test();\n        } catch (e: any) {\n          reject(e);\n        }\n        resolve(result);\n      });\n    };\n  }\n}\n\nexport async function testEvent<T>(event: Observable<T>,\n  handler: (args: T) => void, trigger: () => void, ms: number = 0): Promise<string> {\n  let sub: Subscription;\n  return new Promise((resolve, reject) => {\n    sub = event.subscribe((args) => {\n      try {\n        handler(args);\n      } catch (e) {\n        reject(e);\n      }\n      sub.unsubscribe();\n      resolve('OK');\n    });\n    setTimeout(() => {\n      sub.unsubscribe();\n      // eslint-disable-next-line prefer-promise-reject-errors\n      reject('timeout');\n    }, ms);\n    trigger();\n  });\n}\n\nexport function test(name: string, test: () => Promise<any>, options?: TestOptions): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  if (tests[currentCategory].tests == undefined)\n    tests[currentCategory].tests = [];\n  tests[currentCategory].tests!.push(new Test(currentCategory, name, test, options));\n}\n\n/* Tests two objects for equality, throws an exception if they are not equal. */\nexport function expect(actual: any, expected: any = true, error?: string): void {\n  if (error)\n    error = `${error}, `;\n  else error = '';\n  if (actual !== expected)\n    throw new Error(`${error}Expected \"${expected}\", got \"${actual}\"`);\n}\n\nexport function expectFloat(actual: number, expected: number, tolerance = 0.001, error?: string): void {\n  if ((actual === Number.POSITIVE_INFINITY && expected === Number.POSITIVE_INFINITY) ||\n      (actual === Number.NEGATIVE_INFINITY && expected === Number.NEGATIVE_INFINITY) ||\n      (actual === Number.NaN && expected === Number.NaN) || (isNaN(actual) && isNaN(expected)))\n    return;\n  const areEqual = Math.abs(actual - expected) < tolerance;\n  expect(areEqual, true, `${error ?? ''} (tolerance = ${tolerance})`);\n  if (!areEqual)\n    throw new Error(`Expected ${expected}, got ${actual} (tolerance = ${tolerance})`);\n}\n\nexport function expectTable(actual: DataFrame, expected: DataFrame, error?: string): void {\n  const expectedRowCount = expected.rowCount;\n  const actualRowCount = actual.rowCount;\n  expect(actualRowCount, expectedRowCount, `${error ?? ''}, row count`);\n\n  for (const column of expected.columns) {\n    const actualColumn = actual.columns.byName(column.name);\n    if (actualColumn == null)\n      throw new Error(`Column ${column.name} not found`);\n    if (actualColumn.type != column.type)\n      throw new Error(`Column ${column.name} type expected ${column.type} got ${actualColumn.type}`);\n    for (let i = 0; i < expectedRowCount; i++) {\n      const value = column.get(i);\n      const actualValue = actualColumn.get(i);\n      if (column.type == DG.TYPE.FLOAT)\n        expectFloat(actualValue, value, 0.0001, error);\n      else if (column.type == DG.TYPE.DATE_TIME)\n        expect(actualValue.isSame(value), true, error);\n      else\n        expect(actualValue, value, error);\n    }\n  }\n}\n\nexport function expectObject(actual: { [key: string]: any }, expected: { [key: string]: any }) {\n  for (const [expectedKey, expectedValue] of Object.entries(expected)) {\n    if (!actual.hasOwnProperty(expectedKey))\n      throw new Error(`Expected property \"${expectedKey}\" not found`);\n\n    const actualValue = actual[expectedKey];\n    if (actualValue instanceof Array && expectedValue instanceof Array)\n      expectArray(actualValue, expectedValue);\n    else if (actualValue instanceof Object && expectedValue instanceof Object)\n      expectObject(actualValue, expectedValue);\n    else if (Number.isFinite(actualValue) && Number.isFinite(expectedValue))\n      expectFloat(actualValue, expectedValue);\n    else if (actualValue != expectedValue)\n      throw new Error(`Expected (${expectedValue}) for key '${expectedKey}', got (${actualValue})`);\n  }\n}\n\nexport function expectArray(actual: ArrayLike<any>, expected: ArrayLike<any>) {\n  const actualLength = actual.length;\n  const expectedLength = expected.length;\n\n  if (actualLength != expectedLength) {\n    throw new Error(`Arrays are of different length: actual array length is ${actualLength} ` +\n      `and expected array length is ${expectedLength}`);\n  }\n\n  for (let i = 0; i < actualLength; i++) {\n    if (actual[i] instanceof Array && expected[i] instanceof Array)\n      expectArray(actual[i], expected[i]);\n    else if (actual[i] instanceof Object && expected[i] instanceof Object)\n      expectObject(actual[i], expected[i]);\n    else if (actual[i] != expected[i])\n      throw new Error(`Expected ${expected[i]} at position ${i}, got ${actual[i]}`);\n  }\n}\n\n/* Defines a test suite. */\nexport function category(category: string, tests: () => void): void {\n  currentCategory = category;\n  tests();\n}\n\n/* Defines a function to be executed before the tests in this category are executed. */\nexport function before(before: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].before = before;\n}\n\n/* Defines a function to be executed after the tests in this category are executed. */\nexport function after(after: () => Promise<void>): void {\n  if (tests[currentCategory] == undefined)\n    tests[currentCategory] = {};\n  tests[currentCategory].after = after;\n}\n\nfunction addNamespace(s: string, f: DG.Func): string {\n  return s.replace(new RegExp(f.name, 'gi'), f.nqName);\n}\n\nexport async function initAutoTests(packageId: string, module?: any) {\n  if (wasRegistered[packageId]) return;\n  const moduleTests = module ? module.tests : tests;\n  if (moduleTests[autoTestsCatName] !== undefined) {\n    wasRegistered[packageId] = true;\n    return;\n  }\n  const moduleAutoTests = [];\n  const packFunctions = await grok.dapi.functions.filter(`package.id = \"${packageId}\"`).list();\n  const reg = new RegExp(/.*\\/\\/\\s*skip[:\\s]*(.*)$/);\n  for (const f of packFunctions) {\n    const tests = f.options['test'];\n    if (!(tests && Array.isArray(tests) && tests.length)) continue;\n    for (let i = 0; i < tests.length; i++) {\n      const skipReasons = (tests[i] as string).match(reg);\n      let skipReason;\n      if (skipReasons && skipReasons?.length > 1) skipReason = skipReasons[1];\n      moduleAutoTests.push(new Test(autoTestsCatName, tests.length === 1 ? f.name : `${f.name} ${i + 1}`, async () => {\n        const res = await grok.functions.eval(addNamespace(tests[i], f));\n        // eslint-disable-next-line no-throw-literal\n        if (res !== true) throw `Failed: ${tests[i]}`;\n      }, {skipReason: skipReason}));\n    }\n  }\n  wasRegistered[packageId] = true;\n  if (!moduleAutoTests.length) return;\n  moduleTests[autoTestsCatName] = {tests: moduleAutoTests};\n}\n\nexport async function runTests(options?: {category?: string, test?: string, testContext?: TestContext}) {\n  const package_ = grok.functions.getCurrentCall()?.func?.package;\n  await initAutoTests(package_.id);\n  const results: { category?: string, name?: string, success: boolean,\n                   result: string, ms: number, skipped: boolean }[] = [];\n  console.log(`Running tests`);\n  options ??= {};\n  options!.testContext ??= new TestContext();\n  grok.shell.lastError = '';\n  for (const [key, value] of Object.entries(tests)) {\n    if (options?.category != undefined) {\n      if (!key.toLowerCase().startsWith(options?.category.toLowerCase()))\n        continue;\n    }\n    console.log(`Started ${key} category`);\n    try {\n      if (value.before)\n        await value.before();\n    } catch (x: any) {\n      value.beforeStatus = x.toString();\n    }\n    const t = value.tests ?? [];\n    const res = [];\n    for (let i = 0; i < t.length; i++)\n      res.push(await execTest(t[i], options?.test));\n    const data = (await Promise.all(res)).filter((d) => d.result != 'skipped');\n    try {\n      if (value.after)\n        await value.after();\n    } catch (x: any) {\n      value.afterStatus = x.toString();\n    }\n    if (value.afterStatus)\n      data.push({category: key, name: 'init', result: value.afterStatus, success: false, ms: 0, skipped: false});\n    if (value.beforeStatus)\n      data.push({category: key, name: 'init', result: value.beforeStatus, success: false, ms: 0, skipped: false});\n    results.push(...data);\n  }\n  if (options.testContext.catchUnhandled) {\n    await delay(1000);\n    if (grok.shell.lastError.length > 0) {\n      results.push({\n        category: 'Unhandled exceptions',\n        name: 'exceptions',\n        result: grok.shell.lastError, success: false, ms: 0, skipped: false\n      });\n    }\n  }\n  if (options.testContext.report) {\n    const logger = new DG.Logger();\n    const successful = results.filter((r) => r.success).length;\n    const skipped = results.filter((r) => r.skipped).length;\n    const failed = results.filter((r) => !r.success);\n    const description = 'Package @package tested: @successful successful, @skipped skipped, @failed failed tests';\n    const params = {\n      successful: successful,\n      skipped: skipped,\n      failed: failed.length,\n      package: package_\n    };\n    for (const r of failed) Object.assign(params, {[`${r.category} | ${r.name}`]: r.result});\n    logger.log(description, params, 'package-tested');\n  }\n  return results;\n}\n\nasync function execTest(t: Test, predicate: string | undefined) {\n  let r: { category?: string, name?: string, success: boolean, result: string, ms: number, skipped: boolean };\n  const filter = predicate != undefined && (!t.name.toLowerCase().startsWith(predicate.toLowerCase()));\n  const skip = t.options?.skipReason || filter;\n  const skipReason = filter ? 'skipped' : t.options?.skipReason;\n  if (!skip)\n    console.log(`Started ${t.category} ${t.name}`);\n  const start = new Date();\n  try {\n    if (skip)\n      r = {success: true, result: skipReason!, ms: 0, skipped: true};\n    else\n      r = {success: true, result: await t.test() ?? 'OK', ms: 0, skipped: false};\n  } catch (x: any) {\n    r = {success: false, result: x.toString(), ms: 0, skipped: false};\n  }\n  const stop = new Date();\n  // @ts-ignore\n  r.ms = stop - start;\n  if (!skip)\n    console.log(`Finished ${t.category} ${t.name} for ${r.ms} ms`);\n  r.category = t.category;\n  r.name = t.name;\n  return r;\n}\n\n/* Waits [ms] milliseconds */\nexport async function delay(ms: number) {\n  await new Promise((r) => setTimeout(r, ms));\n}\n\nexport async function awaitCheck(checkHandler: () => boolean,\n  error: string = 'Timeout exceeded', wait: number = 500, interval: number = 50): Promise<void> {\n  return new Promise((resolve, reject) => {\n    setTimeout(() => {\n      clearInterval(intervalId);\n      reject(new Error(error));\n    }, wait);\n    // @ts-ignore\n    const intervalId: Timeout = setInterval(() => {\n      if (checkHandler()) {\n        clearInterval(intervalId);\n        resolve();\n      }\n    }, interval);\n  });\n}\n\nexport function isDialogPresent(dialogTitle: string): boolean {\n  const dialogs = DG.Dialog.getOpenDialogs();\n  for (let i = 0; i < dialogs.length; i++) {\n    if (dialogs[i].title == dialogTitle)\n      return true;\n  }\n  return false;\n}\n\nexport async function testViewer(v: string, df: DG.DataFrame, detectSemanticTypes: boolean = false): Promise<void> {\n  if (detectSemanticTypes) await grok.data.detectSemanticTypes(df);\n  const tv = grok.shell.addTableView(df);\n  const viewerName = `[name=viewer-${v.replace(/\\s+/g, '-')} i]`;\n  const selector = `${viewerName} canvas,${viewerName} svg,${viewerName} img,\n    ${viewerName} input,${viewerName} h1,${viewerName} a`;\n  const res = [];\n  try {\n    let viewer = tv.addViewer(v);\n    await awaitCheck(() => document.querySelector(selector) !== null,\n      'cannot load viewer', 3000);\n    res.push(Array.from(tv.viewers).length);\n    Array.from(df.row(0).cells).forEach((c) => c.value = null);\n    df.rows.select((row) => row.idx > 1 && row.idx < 7);\n    for (let i = 7; i < 12; i++) df.filter.set(i, false);\n    df.currentRowIdx = 1;\n    const props = viewer.getOptions(true).look;\n    const newProps: Record<string, boolean> = {};\n    Object.keys(props).filter((k) => typeof props[k] === 'boolean').forEach((k) => newProps[k] = !props[k]);\n    viewer.setOptions(newProps);\n    await delay(250);\n    const layout = tv.saveLayout();\n    const oldProps = viewer.getOptions().look;\n    tv.resetLayout();\n    res.push(Array.from(tv.viewers).length);\n    tv.loadLayout(layout);\n    await awaitCheck(() => document.querySelector(selector) !== null,\n      'cannot load viewer from layout', 3000);\n    await delay(250);\n    res.push(Array.from(tv.viewers).length);\n    viewer = Array.from(tv.viewers).find((v) => v.type !== 'Grid')!;\n    expectArray(res, [2, 1, 2]);\n    expect(JSON.stringify(viewer.getOptions().look), JSON.stringify(oldProps));\n  } finally {\n    tv.close();\n    grok.shell.closeTable(df);\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 * as grok from 'datagrok-api/grok';\nimport { delay } from '@datagrok-libraries/utils/src/test';\n/** Demo script class. Could be used for creating demo scripts to show the platform capabilities */\nexport class DemoScript {\n    constructor(name, description, isAutomatic = false, options) {\n        var _a;\n        this.name = '';\n        this.description = '';\n        this._isAutomatic = false;\n        this._autoStartFirstStep = false;\n        this._currentStep = 0;\n        this._isStopped = false;\n        this._isCancelled = false;\n        this._isStepProcessed = false;\n        this._root = ui.div([], { id: 'demo-script',\n            classes: 'tutorials-root tutorials-track demo-app-script' });\n        this._steps = [];\n        this._mainHeader = ui.panel([], 'tutorials-main-header');\n        this._header = ui.h2('');\n        this._headerDiv = ui.divH([], 'tutorials-root-header');\n        this._stopStartBtn = ui.button(ui.iconFA('pause'), () => this._changeStopState(), 'Play / pause');\n        this._restartBtn = ui.button(ui.iconFA('redo'), () => this._restartScript(), 'Restart');\n        this._nextStepBtn = ui.button(ui.iconFA('play'), () => {\n            if (!this._isStepProcessed)\n                this._nextStep();\n        }, 'Next step');\n        this._activity = ui.panel([], 'tutorials-root-description');\n        this._progressDiv = ui.divV([], 'tutorials-root-progress');\n        this._progress = ui.element('progress');\n        this._progressSteps = ui.divText('');\n        this._closeBtn = ui.button(ui.iconFA('chevron-left'), () => this._closeDock(), 'Back to demo');\n        this.name = name;\n        this.description = description;\n        this._isAutomatic = isAutomatic;\n        this._autoStartFirstStep = (_a = options === null || options === void 0 ? void 0 : options.autoStartFirstStep) !== null && _a !== void 0 ? _a : false;\n        this._progress.max = 0;\n        this._progress.value = 1;\n        DemoScript.currentObject = this;\n    }\n    /** Returns demo script steps */\n    get steps() {\n        return this._steps;\n    }\n    /** Returns the amount of demo script steps */\n    get stepNumber() {\n        return this._steps.length;\n    }\n    /** Adds script header */\n    _addHeader() {\n        this._createHeaderDiv();\n        this._createProgressDiv();\n        this._mainHeader.append(this._headerDiv, this._progressDiv);\n    }\n    /** Creates script header div */\n    _createHeaderDiv() {\n        this._header.innerText = this.name;\n        this._headerDiv.append(this._closeBtn);\n        this._headerDiv.append(this._header);\n        this._nextStepBtn.firstChild.className = 'grok-icon fas fa-play';\n        this._headerDiv.append(this._isAutomatic ? this._stopStartBtn : this._nextStepBtn);\n    }\n    /** Creates script progress div */\n    _createProgressDiv() {\n        this._progress.max = this.stepNumber;\n        this._progressDiv.append(this._progress);\n        this._progressSteps = ui.divText(`Step: ${this._progress.value} of ${this.stepNumber}`);\n        this._progressDiv.append(this._progressSteps);\n    }\n    /** Adds description of the script */\n    _addDescription() {\n        var _a;\n        this._activity.append(ui.div(this.description, 'tutorials-root-description'));\n        for (let i = 0; i < this.stepNumber; i++) {\n            let instructionIndicator = ui.iconFA('clock');\n            if (!this._isAutomatic) {\n                if (i === 0) {\n                    instructionIndicator = ui.iconFA('play', () => this._nextStep(), 'Next step');\n                    instructionIndicator.className = 'grok-icon fas fa-play';\n                }\n            }\n            const instructionDiv = ui.div(this._steps[i].name, 'grok-tutorial-entry-instruction');\n            const currentStepDescription = ui.div((_a = this._steps[i].options) === null || _a === void 0 ? void 0 : _a.description, 'grok-tutorial-step-description hidden');\n            const entry = ui.divH([\n                instructionIndicator,\n                instructionDiv,\n            ], 'grok-tutorial-entry');\n            this._activity.append(entry, currentStepDescription);\n        }\n    }\n    /** Initializes the root of the demo script */\n    _initRoot() {\n        var _a, _b, _c;\n        grok.shell.windows.showContextPanel = true;\n        grok.shell.windows.showHelp = false;\n        const scriptDockNode = Array.from(grok.shell.dockManager.rootNode.children)[0];\n        this._node = grok.shell.dockManager.dock(this._root, DG.DOCK_TYPE.FILL, scriptDockNode, '');\n        if ((_b = (_a = scriptDockNode.parent.container.containerElement.firstElementChild) === null || _a === void 0 ? void 0 : _a.lastElementChild) === null || _b === void 0 ? void 0 : _b.classList.contains('tab-handle-list-container'))\n            (_c = scriptDockNode.parent.container.containerElement.firstElementChild) === null || _c === void 0 ? void 0 : _c.lastElementChild.remove();\n        this._node.container.containerElement.classList.add('tutorials-demo-script-container');\n        this._addHeader();\n        this._root.append(this._mainHeader);\n        this._addDescription();\n        this._root.append(this._activity);\n    }\n    /** Processes next step */\n    _nextStep() {\n        var _a, _b;\n        return __awaiter(this, void 0, void 0, function* () {\n            this._isStepProcessed = true;\n            if (!this._isAutomatic) {\n                this._nextStepBtn.classList.add('disabled');\n                this._nextStepBtn.firstChild.classList.add('fa-disabled');\n            }\n            const entry = this._activity.getElementsByClassName('grok-tutorial-entry')[this._currentStep];\n            const entryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n            const entryInstruction = this._activity.getElementsByClassName('grok-tutorial-step-description')[this._currentStep];\n            entryIndicator.className = 'grok-icon far fa-spinner-third fa-spin';\n            entryInstruction.classList.remove('hidden');\n            entryInstruction.classList.add('visible');\n            const currentStep = entry;\n            const stepDelay = ((_a = this._steps[this._currentStep].options) === null || _a === void 0 ? void 0 : _a.delay) ?\n                (_b = this._steps[this._currentStep].options) === null || _b === void 0 ? void 0 : _b.delay : 2000;\n            yield this._steps[this._currentStep].func();\n            this._scrollTo(this._root, currentStep.offsetTop - this._mainHeader.offsetHeight);\n            if (this._isAutomatic) {\n                yield this._countdown(entry, entryIndicator, stepDelay);\n                yield delay(stepDelay);\n            }\n            const newEntryIndicator = ui.iconFA('check');\n            entryIndicator.replaceWith(newEntryIndicator);\n            newEntryIndicator.className = 'grok-icon far fa-check';\n            this._progress.value++;\n            this._progressSteps.innerText = `Step: ${this._progress.value} of ${this.stepNumber}`;\n            this._currentStep++;\n            this._isStepProcessed = false;\n            if (this._currentStep === this.stepNumber) {\n                this._isAutomatic ? this._stopStartBtn.replaceWith(this._restartBtn) :\n                    this._nextStepBtn.replaceWith(this._restartBtn);\n                return;\n            }\n            if (!this._isAutomatic) {\n                const nextStepEntryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n                const startNextStepIcon = ui.iconFA('play', () => this._nextStep(), 'Next step');\n                startNextStepIcon.className = 'grok-icon fas fa-play';\n                nextStepEntryIndicator.replaceWith(startNextStepIcon);\n                this._nextStepBtn.classList.remove('disabled');\n                this._nextStepBtn.firstChild.classList.remove('fa-disabled');\n            }\n        });\n    }\n    /** Starts the demo script actions */\n    _startScript() {\n        return __awaiter(this, void 0, void 0, function* () {\n            for (let i = this._currentStep; i < this.stepNumber; i++) {\n                if (this._isStopped || this._isCancelled)\n                    break;\n                yield this._nextStep();\n            }\n        });\n    }\n    /**\n     * Scrolls to the current step\n     * @param element - Current step element in root\n     * @param y - y coordinate of the element\n     */\n    _scrollTo(element, y) {\n        element.focus();\n        element.scrollTop = y;\n    }\n    /**\n     * Adds an interactive delay indicator\n     * @param element - Current step element\n     * @param indicator - Current step indicator\n     * @param time - Indicator animation time\n     */\n    _countdown(element, indicator, time) {\n        return __awaiter(this, void 0, void 0, function* () {\n            const countdownDiv = ui.div([], 'demo-script-countdown');\n            indicator.classList.add('hidden');\n            let countdown = time / 1000;\n            const svg = this._createSVGIndicator(countdown);\n            countdownDiv.append(svg);\n            element.prepend(countdownDiv);\n            const interval = setInterval(() => {\n                countdown--;\n                if (countdown === 0) {\n                    clearInterval(interval);\n                    countdownDiv.remove();\n                    indicator.classList.remove('hidden');\n                    indicator.classList.add('visible');\n                }\n            }, 1000);\n        });\n    }\n    /**\n     * Creates SVG with countdown circle\n     * @param countdown - countdown time\n     * @returns SVG countdown indicator\n     */\n    _createSVGIndicator(countdown) {\n        const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n        const circle = document.createElementNS('http://www.w3.org/2000/svg', 'circle');\n        circle.setAttributeNS(null, 'cx', '7');\n        circle.setAttributeNS(null, 'cy', '7');\n        circle.setAttributeNS(null, 'r', '6');\n        circle.setAttributeNS(null, 'style', `animation: countdown ${countdown}s linear infinite forwards`);\n        svg.append(circle);\n        return svg;\n    }\n    /** Changes the state of the demo script (stop/play) */\n    _changeStopState() {\n        const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n        icon[0].className = 'grok-icon fas fa-play';\n        this._isStopped = !this._isStopped;\n        if (!this._isStopped) {\n            icon[0].className = 'grok-icon fal fa-pause';\n            if (!this._isStepProcessed)\n                this._startScript();\n        }\n    }\n    /** Restarts the script */\n    _restartScript() {\n        grok.shell.dockManager.close(this._node);\n        grok.shell.closeAll();\n        this._clearRoot();\n        this._setInitParams();\n        this.start();\n    }\n    /** Clears the root element */\n    _clearRoot() {\n        this._root = ui.div([], { id: 'demo-script', classes: 'tutorials-root tutorials-track demo-app-script' });\n        this._mainHeader = ui.panel([], 'tutorials-main-header');\n        this._header = ui.h2('');\n        this._headerDiv = ui.divH([], 'tutorials-root-header');\n        this._activity = ui.panel([], 'tutorials-root-description');\n        this._progressDiv = ui.divV([], 'tutorials-root-progress');\n        this._progress = ui.element('progress');\n        this._progressSteps = ui.divText('');\n        this._progress.max = 0;\n        this._progress.value = 1;\n    }\n    /** Sets initial parameters */\n    _setInitParams() {\n        this._currentStep = 0;\n        this._isStopped = false;\n        this._isCancelled = false;\n        const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n        icon[0].className = 'grok-icon fal fa-pause';\n        this._nextStepBtn.classList.remove('disabled');\n    }\n    /** Closes demo script dock */\n    _closeDock() {\n        grok.shell.dockManager.close(this._node);\n        this.cancelScript();\n    }\n    /** Cancels the script */\n    cancelScript() {\n        this._isCancelled = true;\n        DemoScript.currentObject = null;\n    }\n    /**\n     * Adds a new step to script\n     * @param name - Step name\n     * @param func - Step function\n     * @param options - Step options (description and delay after step ends)\n     * @returns Returns the current demo script object\n     */\n    step(name, func, options) {\n        this._steps[this.steps.length] = {\n            name: name,\n            func: func,\n            options: options,\n        };\n        return this;\n    }\n    /** Starts the demo script */\n    start() {\n        return __awaiter(this, void 0, void 0, function* () {\n            this._initRoot();\n            grok.shell.newView(this.name);\n            if (this._isAutomatic) {\n                this._startScript();\n                return;\n            }\n            if (this._autoStartFirstStep)\n                yield this._nextStep();\n        });\n    }\n}\nDemoScript.currentObject = null;\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo-script.js","sourceRoot":"","sources":["demo-script.ts"],"names":[],"mappings":"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","sourcesContent":["import * as DG from 'datagrok-api/dg';\nimport * as ui from 'datagrok-api/ui';\nimport * as grok from 'datagrok-api/grok';\n\nimport {delay} from '@datagrok-libraries/utils/src/test';\n\n\n/** Type for {@link DemoScript} step */\nexport type Step = {\n  name: string;\n  func: () => Promise<void>;\n\n  /** Step options: description and delay (in ms) after function ends */\n  options?: {\n    description?: string;\n    delay?: number;\n  }\n};\n\n/** Demo script class. Could be used for creating demo scripts to show the platform capabilities */\nexport class DemoScript {\n  name: string = '';\n  description: string = '';\n\n  static currentObject: DemoScript | null = null;\n\n  private _isAutomatic: boolean = false;\n  private _autoStartFirstStep: boolean = false;\n  private _currentStep: number = 0;\n  private _isStopped: boolean = false;\n  private _isCancelled: boolean = false;\n  private _isStepProcessed: boolean = false;\n\n  private _root: HTMLDivElement = ui.div([], {id: 'demo-script',\n    classes: 'tutorials-root tutorials-track demo-app-script'});\n\n  private _steps: Step[] = [];\n\n  private _mainHeader: HTMLDivElement = ui.panel([], 'tutorials-main-header');\n  private _header: HTMLHeadingElement = ui.h2('');\n  private _headerDiv: HTMLDivElement = ui.divH([], 'tutorials-root-header');\n  private _stopStartBtn: HTMLButtonElement = ui.button(ui.iconFA('pause'),\n    () => this._changeStopState(), 'Play / pause');\n  private _restartBtn: HTMLButtonElement = ui.button(ui.iconFA('redo'), () => this._restartScript(), 'Restart');\n  private _nextStepBtn: HTMLButtonElement = ui.button(ui.iconFA('play'), () => {\n    if (!this._isStepProcessed)\n      this._nextStep();\n  }, 'Next step');\n\n  private _activity: HTMLDivElement = ui.panel([], 'tutorials-root-description');\n\n  private _progressDiv: HTMLDivElement = ui.divV([], 'tutorials-root-progress');\n  private _progress: HTMLProgressElement = ui.element('progress');\n  private _progressSteps: HTMLDivElement = ui.divText('');\n\n  private _node?: DG.DockNode;\n  private _closeBtn: HTMLButtonElement = ui.button(ui.iconFA('chevron-left'), () => this._closeDock(), 'Back to demo');\n\n\n  constructor(name: string, description: string, isAutomatic: boolean = false,\n    options?: {autoStartFirstStep?: boolean}) {\n    this.name = name;\n    this.description = description;\n    this._isAutomatic = isAutomatic;\n    this._autoStartFirstStep = options?.autoStartFirstStep ?? false;\n\n    this._progress.max = 0;\n    this._progress.value = 1;\n\n    DemoScript.currentObject = this;\n  }\n\n  /** Returns demo script steps */\n  get steps(): Step[] {\n    return this._steps;\n  }\n\n  /** Returns the amount of demo script steps */\n  get stepNumber(): number {\n    return this._steps.length;\n  }\n\n\n  /** Adds script header */\n  private _addHeader(): void {\n    this._createHeaderDiv();\n    this._createProgressDiv();\n    this._mainHeader.append(this._headerDiv, this._progressDiv);\n  }\n\n  /** Creates script header div */\n  private _createHeaderDiv(): void {\n    this._header.innerText = this.name;\n    this._headerDiv.append(this._closeBtn);\n    this._headerDiv.append(this._header);\n\n    (this._nextStepBtn.firstChild as HTMLElement).className = 'grok-icon fas fa-play';\n\n    this._headerDiv.append(this._isAutomatic ? this._stopStartBtn : this._nextStepBtn);\n  }\n\n  /** Creates script progress div */\n  private _createProgressDiv(): void {\n    this._progress.max = this.stepNumber;\n    this._progressDiv.append(this._progress);\n    this._progressSteps = ui.divText(`Step: ${this._progress.value} of ${this.stepNumber}`);\n\n    this._progressDiv.append(this._progressSteps);\n  }\n\n  /** Adds description of the script */\n  private _addDescription(): void {\n    this._activity.append(ui.div(this.description, 'tutorials-root-description'));\n\n    for (let i = 0; i < this.stepNumber; i++) {\n      let instructionIndicator = ui.iconFA('clock');\n      if (!this._isAutomatic) {\n        if (i === 0) {\n          instructionIndicator = ui.iconFA('play', () => this._nextStep(), 'Next step');\n          instructionIndicator.className = 'grok-icon fas fa-play';\n        }\n      }\n      const instructionDiv = ui.div(this._steps[i].name, 'grok-tutorial-entry-instruction');\n      const currentStepDescription = ui.div(this._steps[i].options?.description,\n        'grok-tutorial-step-description hidden');\n      const entry = ui.divH([\n        instructionIndicator,\n        instructionDiv,\n      ], 'grok-tutorial-entry');\n\n      this._activity.append(entry, currentStepDescription);\n    }\n  }\n\n  /** Initializes the root of the demo script */\n  private _initRoot(): void {\n    grok.shell.windows.showContextPanel = true;\n    grok.shell.windows.showHelp = false;\n\n    const scriptDockNode = Array.from(grok.shell.dockManager.rootNode.children)[0];\n\n    this._node = grok.shell.dockManager.dock(this._root, DG.DOCK_TYPE.FILL, scriptDockNode, '');\n\n    if (scriptDockNode.parent.container.containerElement.firstElementChild?.lastElementChild?.\n      classList.contains('tab-handle-list-container'))\n      scriptDockNode.parent.container.containerElement.firstElementChild?.lastElementChild.remove();\n\n    this._node.container.containerElement.classList.add('tutorials-demo-script-container');\n\n    this._addHeader();\n    this._root.append(this._mainHeader);\n\n    this._addDescription();\n    this._root.append(this._activity);\n  }\n\n  /** Processes next step */\n  private async _nextStep(): Promise<void> {\n    this._isStepProcessed = true;\n    if (!this._isAutomatic) {\n      this._nextStepBtn.classList.add('disabled');\n      (this._nextStepBtn.firstChild as HTMLElement).classList.add('fa-disabled');\n    }\n\n    const entry = this._activity.getElementsByClassName('grok-tutorial-entry')[this._currentStep];\n    const entryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n    const entryInstruction = this._activity.getElementsByClassName('grok-tutorial-step-description')[this._currentStep];\n\n    entryIndicator.className = 'grok-icon far fa-spinner-third fa-spin';\n    entryInstruction.classList.remove('hidden');\n    entryInstruction.classList.add('visible');\n\n    const currentStep = entry as HTMLDivElement;\n    const stepDelay = this._steps[this._currentStep].options?.delay ?\n      this._steps[this._currentStep].options?.delay! : 2000;\n\n    await this._steps[this._currentStep].func();\n    this._scrollTo(this._root, currentStep.offsetTop - this._mainHeader.offsetHeight);\n    if (this._isAutomatic) {\n      await this._countdown(entry as HTMLElement, entryIndicator as HTMLElement, stepDelay);\n      await delay(stepDelay);\n    }\n\n    const newEntryIndicator = ui.iconFA('check');\n    entryIndicator.replaceWith(newEntryIndicator);\n    newEntryIndicator.className = 'grok-icon far fa-check';\n\n    this._progress.value++;\n    this._progressSteps.innerText = `Step: ${this._progress.value} of ${this.stepNumber}`;\n\n    this._currentStep++;\n    this._isStepProcessed = false;\n\n    if (this._currentStep === this.stepNumber) {\n      this._isAutomatic ? this._stopStartBtn.replaceWith(this._restartBtn) :\n        this._nextStepBtn.replaceWith(this._restartBtn);\n      return;\n    }\n\n    if (!this._isAutomatic) {\n      const nextStepEntryIndicator = this._activity.getElementsByClassName('grok-icon')[this._currentStep];\n      const startNextStepIcon = ui.iconFA('play', () => this._nextStep(), 'Next step');\n      startNextStepIcon.className = 'grok-icon fas fa-play';\n      nextStepEntryIndicator.replaceWith(startNextStepIcon);\n      this._nextStepBtn.classList.remove('disabled');\n      (this._nextStepBtn.firstChild as HTMLElement).classList.remove('fa-disabled');\n    }\n  }\n\n  /** Starts the demo script actions */\n  private async _startScript(): Promise<void> {\n    for (let i = this._currentStep; i < this.stepNumber; i++) {\n      if (this._isStopped || this._isCancelled)\n        break;\n\n      await this._nextStep();\n    }\n  }\n\n  /**\n   * Scrolls to the current step\n   * @param element - Current step element in root\n   * @param y - y coordinate of the element\n   */\n  private _scrollTo(element: HTMLDivElement, y: number): void {\n    element.focus();\n    element.scrollTop = y;\n  }\n\n  /**\n   * Adds an interactive delay indicator\n   * @param element - Current step element\n   * @param indicator - Current step indicator\n   * @param time - Indicator animation time\n   */\n  private async _countdown(element: HTMLElement, indicator: HTMLElement, time: number): Promise<void> {\n    const countdownDiv: HTMLDivElement = ui.div([], 'demo-script-countdown');\n\n    indicator.classList.add('hidden');\n\n    let countdown = time / 1000;\n    const svg = this._createSVGIndicator(countdown);\n\n    countdownDiv.append(svg);\n    element.prepend(countdownDiv);\n\n    const interval = setInterval(() => {\n      countdown--;\n      if (countdown === 0) {\n        clearInterval(interval);\n        countdownDiv.remove();\n\n        indicator.classList.remove('hidden');\n        indicator.classList.add('visible');\n      }\n    }, 1000);\n  }\n\n  /**\n   * Creates SVG with countdown circle\n   * @param countdown - countdown time\n   * @returns SVG countdown indicator\n   */\n  private _createSVGIndicator(countdown: number): SVGSVGElement {\n    const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n    const circle = document.createElementNS('http://www.w3.org/2000/svg', 'circle');\n    circle.setAttributeNS(null, 'cx', '7');\n    circle.setAttributeNS(null, 'cy', '7');\n    circle.setAttributeNS(null, 'r', '6');\n    circle.setAttributeNS(null, 'style', `animation: countdown ${countdown}s linear infinite forwards`);\n    svg.append(circle);\n\n    return svg;\n  }\n\n  /** Changes the state of the demo script (stop/play) */\n  private _changeStopState(): void {\n    const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n    icon[0].className = 'grok-icon fas fa-play';\n    this._isStopped = !this._isStopped;\n\n    if (!this._isStopped) {\n      icon[0].className = 'grok-icon fal fa-pause';\n      if (!this._isStepProcessed)\n        this._startScript();\n    }\n  }\n\n  /** Restarts the script */\n  private _restartScript(): void {\n    grok.shell.dockManager.close(this._node!);\n    grok.shell.closeAll();\n    this._clearRoot();\n    this._setInitParams();\n    this.start();\n  }\n\n  /** Clears the root element */\n  private _clearRoot(): void {\n    this._root = ui.div([], {id: 'demo-script', classes: 'tutorials-root tutorials-track demo-app-script'});\n\n    this._mainHeader = ui.panel([], 'tutorials-main-header');\n    this._header = ui.h2('');\n    this._headerDiv = ui.divH([], 'tutorials-root-header');\n\n    this._activity = ui.panel([], 'tutorials-root-description');\n\n    this._progressDiv = ui.divV([], 'tutorials-root-progress');\n    this._progress = ui.element('progress');\n    this._progressSteps = ui.divText('');\n\n    this._progress.max = 0;\n    this._progress.value = 1;\n  }\n\n  /** Sets initial parameters */\n  private _setInitParams(): void {\n    this._currentStep = 0;\n    this._isStopped = false;\n    this._isCancelled = false;\n\n    const icon = this._stopStartBtn.getElementsByClassName('grok-icon');\n    icon[0].className = 'grok-icon fal fa-pause';\n    this._nextStepBtn.classList.remove('disabled');\n  }\n\n  /** Closes demo script dock */\n  private _closeDock(): void {\n    grok.shell.dockManager.close(this._node!);\n    this.cancelScript();\n  }\n\n  /** Cancels the script */\n  cancelScript(): void {\n    this._isCancelled = true;\n    DemoScript.currentObject = null;\n  }\n\n  /**\n   * Adds a new step to script\n   * @param name - Step name\n   * @param func - Step function\n   * @param options - Step options (description and delay after step ends)\n   * @returns Returns the current demo script object\n   */\n  step(name: string, func: () => Promise<void>, options?: {description?: string, delay?: number}): this {\n    this._steps[this.steps.length] = {\n      name: name,\n      func: func,\n      options: options,\n    };\n    return this;\n  }\n\n  /** Starts the demo script */\n  async start(): Promise<void> {\n    this._initRoot();\n    grok.shell.newView(this.name);\n\n    if (this._isAutomatic) {\n      this._startScript();\n      return;\n    }\n\n    if (this._autoStartFirstStep)\n      await this._nextStep();\n  }\n}\n"]}","// Runtime system for exported C/C++-functions call.\n// It was previousely developed and does NOT provide call wasm-functions in WebWorkers.\n\n// type-to-heap correspondence\nconst heapMap = {\"i32\": \"HEAP32\", // Int32Array\n                 \"f32\": \"HEAPF32\" // Float32Array\n                };\n\n// type signature to typed array ,app\nconst typeMap = {\"i32\": Int32Array, // Int32Array\n                 \"f32\": Float32Array // Float32Array\n                }; \n \n// type-to-shift map\nconst shiftMap = {\"i32\": 2, // Int32Array\n                  \"f32\": 2 // Float32Array\n                 };\n\n// type-to-column_creator map\nconst typeToColumnCreatorMap = {\"i32\": DG.Column.fromInt32Array,\n                                \"f32\": DG.Column.fromFloat32Array};\n \n\n// CLASSES THAT ARE USED BY CPP-WRAPPER\n\n// simple argument: a number \nclass Arg{\n\n    constructor(data) {\n        this.data = data;        \n    }\n\n    complementArrOfParams(arrOfParams) {\n        arrOfParams.push(this.data);\n    }\n\n    complementArrOfTypes(arrOfTypes) {\n        arrOfTypes.push('number');        \n    }\n\n    allocateMemoryForBuffer(module) {}\n\n    isMemoryForBufferAllocated(){\n        return true;\n    }\n\n    putDataToBuffer(module) {}\n\n    getDataFromBuffer(module) {}\n\n    freeBuffer(module) {}\n}\n\n// column argument\nclass ArgColumn extends Arg {\n\n    constructor(data, targetType, toUpdate = false) {\n        super(data);\n        this.type = targetType;\n        this.toUpdate = toUpdate;\n        this.buf = 0;    \n        this.numOfRows = data.length;\n    }\n\n    complementArrOfParams(arrOfParams) {\n        arrOfParams.push(this.buf);\n        arrOfParams.push(this.numOfRows);\n    }\n\n    complementArrOfTypes(arrOfTypes) {\n        arrOfTypes.push('number');\n        arrOfTypes.push('number');        \n    }\n\n    allocateMemoryForBuffer(module) {\n        this.buf = module._malloc(this.numOfRows * typeMap[this.type].BYTES_PER_ELEMENT);\n    }\n\n    isMemoryForBufferAllocated(){\n        return (this.buf != 0);\n    }\n\n    putDataToBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let shift = shiftMap[type];\n            let heap = module[heapMap[type]];            \n            let array = null;\n            let col = this.data;\n\n            if(((col.type == 'int') && (type == 'i32')) \n               || ((col.type == 'double') && (type == 'f32')))\n              array = col.getRawData();\n            else\n              array = new typeMap[type](col.getRawData());\n\n            if(array) \n              heap.set(array, this.buf >> shift);\n        }\n    }\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let buffer = this.buf;\n            let bytes = typeMap[type].BYTES_PER_ELEMENT;\n            let array = this.data.getRawData();\n\n            for(let i = 0; i < this.numOfRows; i++)\n                array[i] = heap[buffer / bytes + i];\n        }\n    }\n\n    freeBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n           module._free(this.buf);\n           this.buf = 0;\n        }\n    }\n\n}\n\n// new column argument: a new column is created\nclass ArgNewColumn extends ArgColumn {\n    constructor(targetType, numOfRows) {\n        super([], targetType, true);\n        this.numOfRows = numOfRows;\n    }\n\n    putDataToBuffer(module) {}\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let buf = this.buf;\n            \n            let columnCreator = typeToColumnCreatorMap[type];   \n            \n            let arr = new typeMap[type](this.numOfRows);            \n\n            for(let i = 0; i < arr.length; i++)\n                arr[i] = heap[buf / arr.BYTES_PER_ELEMENT + i];\n\n            this.data = columnCreator('name', arr);\n\n            //console.log(arr);\n            \n            // This makes mistake, when this.numOfRows = 5 (TODO: investigate why)\n            //this.data = columnCreator('name', new typeMap[type](heap.buffer, this.buf, this.numOfRows));\n\n            //console.log(this.data.getRawData());\n        }\n    }\n}\n\n// an array of columns argument\nclass ArgColumns extends Arg {\n\n    constructor(data, targetType, toUpdate = false) {\n        super(data);\n        this.type = targetType;\n        this.toUpdate = toUpdate;\n        this.buf = 0;    \n        this.numOfColumns = data.length;\n        this.numOfRows = data[0].length;\n    }\n\n    complementArrOfParams(arrOfParams) {\n        arrOfParams.push(this.buf);\n        arrOfParams.push(this.numOfRows);\n        arrOfParams.push(this.numOfColumns);\n    }\n\n    complementArrOfTypes(arrOfTypes) {\n        arrOfTypes.push('number');\n        arrOfTypes.push('number');\n        arrOfTypes.push('number');        \n    }\n\n    allocateMemoryForBuffer(module) {\n        this.buf = module._malloc(this.numOfRows * this.numOfColumns \n                                  * typeMap[this.type].BYTES_PER_ELEMENT);\n    }\n\n    isMemoryForBufferAllocated(){\n        return (this.buf != 0);\n    }\n\n    putDataToBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let shift = shiftMap[type];\n            let heap = module[heapMap[type]];\n            let numOfBytes = typeMap[type].BYTES_PER_ELEMENT;\n            \n            // put columns data to buffer\n            for(let i = 0; i < this.numOfColumns; i++) {\n                let array = null;\n                let col = this.data[i];\n\n                if(((col.type == 'int') && (type == 'i32')) \n                   || ((col.type == 'double') && (type == 'f32')))\n                     array = col.getRawData();\n                else\n                     array = new typeMap[type](col.getRawData());\n\n                // check data array\n                if(array != null) \n                    heap.set(array, (this.buf + i * this.numOfRows * numOfBytes) >> shift);                                   \n            }\n        }\n    }\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let numOfRows = this.numOfRows;\n            let numOfCols = this.numOfColumns;                 \n            let arr = new typeMap[type](heap.buffer, this.buf, numOfRows * numOfCols);\n       \n            for(let i = 0; i < numOfCols; i++) {\n                let colData = this.data[i].getRawData();\n                for(let j = 0; j < numOfRows; j++)\n                  colData[j] = arr[j + i * numOfRows];                    \n            }\n        }\n    }\n\n    freeBuffer(module) {\n        if(this.isMemoryForBufferAllocated()) {\n           module._free(this.buf);\n           this.buf = 0;\n        }\n    }\n\n}\n\n// an array of new columns: new columns are created\nclass ArgNewColumns extends ArgColumns {\n\n    constructor(targetType, numOfRows, numOfColumns) {\n        super([[]], targetType, true);  \n        this.data = [];        \n        this.numOfColumns = numOfColumns;\n        this.numOfRows = numOfRows;\n    }\n\n    putDataToBuffer(module) { }\n\n    getDataFromBuffer(module) {\n        if(this.toUpdate && this.isMemoryForBufferAllocated()) {\n            let type = this.type;\n            let heap = module[heapMap[type]];\n            let numOfRows = this.numOfRows;\n            let numOfCols = this.numOfColumns;\n            let numOfBytes = typeMap[type].BYTES_PER_ELEMENT;                       \n            let columnCreator = typeToColumnCreatorMap[type];\n            let buf = this.buf;\n\n            for(let i = 0; i < numOfCols; i++) {\n                let arr = new typeMap[type](numOfRows);\n\n                for(let j = 0; j < numOfRows; j++)\n                    arr[j] = heap[buf / numOfBytes + j + i * numOfRows];\n                \n                this.data.push(columnCreator((i + 1).toString(), arr));\n            }\n\n            // create columns: here, may be a problem when numOfRows = 5            \n            /*for(let i = 0; i < numOfCols; i++)\n                this.data.push(columnCreator((i + 1).toString(), new typeMap[type](heap.buffer, \n                    this.buf + i * numOfRows * numOfBytes, numOfRows)));*/\n        }\n    }\n}\n\n// a wrapper for exported C/C++-function call\nfunction cppFuncWrapper(module, cFuncName, returnType, args)\n{\n    let result;\n\n    // allocate memory for buffers\n    for(let arg of args)         \n        arg.allocateMemoryForBuffer(module);\n    \n    let isEnoughOfMemoryAllocated = true;\n\n    // check memory allocation\n    for(let arg of args)\n        isEnoughOfMemoryAllocated &= arg.isMemoryForBufferAllocated();  \n    \n    // run exported function if enough of memory is allocated\n    if(isEnoughOfMemoryAllocated) {\n\n        let params = []; // arguments that are put to the exported function\n        let types = []; // their types\n\n        // prepare data that is put to exported function\n        for(let arg of args) {\n            arg.complementArrOfParams(params);\n            arg.complementArrOfTypes(types);\n            arg.putDataToBuffer(module);\n        }\n\n        let extendedTypeOfReturn = (returnType == 'num') ? 'number' : null;   \n        \n        // call exported function\n        if(extendedTypeOfReturn)\n            result = module.ccall(cFuncName, extendedTypeOfReturn, types, params);\n        else\n            result = module.ccall(cFuncName, extendedTypeOfReturn, types, params);\n                    \n        // update and get data from buffers if required\n        for(let arg of args)\n            arg.getDataFromBuffer(module);       \n    }\n\n    // clear buffers\n    for(let arg of args)         \n        arg.freeBuffer(module);\n\n    if(result != undefined)\n        return result;    \n} // cppFuncWrapper\n\n\n// A LAYER BETWEEN JS AND CPP-WRAPPER\n\n// Parameters creator\nlet Param = {\n    intColumn (column) {\n        return new ArgColumn(column, 'i32');\n    },\n    \n    newIntColumn (numOfRows) {\n        return new ArgNewColumn('i32', numOfRows);\n    },\n\n    intColumns(columns){\n        return new ArgColumns(columns.toList(), 'i32');\n    },\n\n    newIntColumns(numOfRows, numOfColumns) {\n        return new ArgNewColumns('i32', numOfRows, numOfColumns);\n    },\n\n    floatColumn (column) {\n        return new ArgColumn(column, 'f32');\n    },\n\n    newFloatColumn (numOfRows) {\n        return new ArgNewColumn('f32', numOfRows);\n    },\n\n    floatColumns(columns){\n        return new ArgColumns(columns.toList(), 'f32');\n    },\n\n    newFloatColumns(numOfRows, numOfColumns) {\n        return new ArgNewColumns('f32', numOfRows, numOfColumns);\n    },\n\n    int(number) {\n        return new Arg(number);\n    },\n\n    num(number) {\n        return new Arg(number);\n    }\n};\n\n// Return value creator\nlet Return = {\n    tableFromColumns(argColumns) {\n        return DG.DataFrame.fromColumns(argColumns.data);\n    },\n\n    num(number) {\n        return number;\n    },\n\n    int(number) {\n        return number;\n    },\n\n    double(number) {\n        return number;\n    },\n\n    column(argColumn) {\n        return argColumn.data;\n    }\n};\n\n// The main tool that combines all together\nexport function callWasm(module, funcName, inputs) {\n    // get specification of exported C/C++-function\n    let funcSpecification = module[funcName];\n\n    // get argumnets\n    let args = funcSpecification.arguments; \n\n    // array of arguments that further are used by cpp-wrapper\n    let cppFuncInput = [];\n\n    // complete an input for cpp\n    let i = 0;\n    for(let key in args){\n        let arg = args[key]; \n        \n        // skip auxiliry element\n        if(key == '_callResult')             \n            continue;\n\n        // create an argument\n        switch(arg.type){\n            case 'floatColumns':\n            case 'int':\n            case 'num':\n            case 'floatColumn':\n            case 'intColumn':\n            case 'intColumns':\n                arg.data = Param[arg.type](inputs[i]);\n                i++;\n                break;\n            case 'newFloatColumns':\n            case 'newIntColumns':\n                let val1 = args[ arg['numOfRows']['ref'] ].data[arg['numOfRows']['value']];\n                let val2 = args[ arg['numOfColumns']['ref'] ].data[arg['numOfColumns']['value']];\n                arg.data = Param[arg.type](val1, val2);\n                break;\n            case 'newFloatColumn':\n            case 'newIntColumn':\n                let val = args[ arg['numOfRows']['ref'] ].data[arg['numOfRows']['value']];\n                arg.data = Param[arg.type](val);\n                break;\n            } // switch\n\n        cppFuncInput.push(args[key].data);\n\n    } // for key    \n\n    // CALL EXPORTED CPP-FUNCTION\n    let callResult = cppFuncWrapper(module, funcName, 'num', cppFuncInput);\n\n    // store result that is returned by exported cpp-function\n    args._callResult = Param.num(callResult);\n\n    // create output\n    let output = funcSpecification.output;\n\n    // if a single object must be returned\n    if(output['type'] != 'objects')\n      return Return[output['type']](args[output['source']].data);\n\n    let arrayToReturn = [];\n\n    // push data of the required arguments\n    for(let name of output['source'])\n      arrayToReturn.push(args[name].data.data);\n\n    return arrayToReturn;\n  } // callWasm","// Utilities for calling wasm-functions via webworker.\n\n// We use an approach that is well described here:\n// https://becominghuman.ai/passing-and-returning-webassembly-array-parameters-a0f572c65d97\n// It has been modified for usage in DATAGROK.\n\n// Constants for wasm-functions in webworkers runtime system\nconst TYPE = 'type';\nconst NUM_TYPE = 'num';\nconst FLOAT_COLUMN_TYPE = 'floatColumn';\nconst INT_COLUMN_TYPE = 'intColumn';\nconst FLOAT_COLUMNS_TYPE = 'floatColumns';\nconst NEW_FLOAT_COLUMNS_TYPE = 'newFloatColumns';\nconst INT_COLUMNS_TYPE = 'intColumns';\nconst NEW_INT_COLUMNS_TYPE = 'newIntColumns';\nconst NEW_FLOAT_COLUMN_TYPE = 'newFloatColumn';\nconst NEW_INT_COLUMN_TYPE = 'newIntColumn';\nconst COLUMN = 'column';\nconst CALL_RESULT = '_callResult';\nconst NUM_OF_ROWS = 'numOfRows';\nconst NUM_OF_COLUMNS = 'numOfColumns';\nconst REF = 'ref';\nconst VALUE = 'value';\nconst TABLE_OF_COLUMNS = 'tableFromColumns';\nconst OBJECTS = 'objects';\nconst INT_TYPE = 'int';\nconst DOUBLE_TYPE = 'double';\nconst NUMBER = 'number';\n\n// Type-to-heap correspondence.\n// It is required for JS-module generated by Emscripten,\n// and it is used, when passing array data to/from wasm-functions.\n// More info can be found at the following link:\n// https://becominghuman.ai/passing-and-returning-webassembly-array-parameters-a0f572c65d97\nconst heapMap = {\n                 'intColumn': \"HEAP32\",\n                 'floatColumn': \"HEAPF32\",\n                 'floatColumns': \"HEAPF32\",\n                 'newFloatColumns': \"HEAPF32\",\n                 'intColumns': \"HEAP32\",\n                 'newIntColumns': \"HEAP32\",\n                 'newFloatColumn': \"HEAPF32\",\n                 'newIntColumn': \"HEAP32\"\n                };\n\n// Type signature to typed array map.\n// It is used, when manipulating column(s).\nconst typeMap = {\n                 'intColumn': Int32Array,\n                 'floatColumn': Float32Array,\n                 'floatColumns': Float32Array,\n                 'newFloatColumns': Float32Array,\n                 'intColumns': Int32Array,  \n                 'newIntColumns': Int32Array,\n                 'newFloatColumn': Float32Array,\n                 'newIntColumn': Int32Array\n                }; \n\n// Type-to-shift map.\n// It is used, when passing array to/from wasm-functions.\n// More info can be found at the following link:\n// https://becominghuman.ai/passing-and-returning-webassembly-array-parameters-a0f572c65d97 \nconst shiftMap = {'intColumn': 2, \n                  'floatColumn': 2, \n                  'floatColumns': 2,  \n                  'newFloatColumns': 2, \n                  'intColumns': 2,  \n                  'newIntColumns': 2,\n                  'newFloatColumn': 2,\n                  'newIntColumn': 2\n                 };         \n\n// Get input for C++-function.\n// This function takes specification of arguments (argsSpecification) & input data (inputVals)\n// and returns input that will be further used in cpp/wasm-function.\nexport function getCppInput(argsSpecification, inputVals) {\n    let cppFuncInput = [];\n    let ref;\n\n    // complete an input for cpp\n    let i = 0;\n    for(const key in argsSpecification) {\n        const arg = argsSpecification[key]; \n        const type = arg.type;\n        \n        // skip auxiliry element\n        if(key === CALL_RESULT)             \n            continue;\n\n        // here, we consider each type of input\n        switch(type) {           \n \n            // numbers\n            case NUM_TYPE:                \n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                arg.data = inputVals[i];\n                i++;\n                break;\n\n            // column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n\n                let array;\n\n                // this is OK if type of column and target type coinside\n                //array = inputVals[i].getRawData();\n\n                let col = inputVals[i];\n\n                // here, we check types and perform an appropriate transform\n                if( ( (col.type === INT_TYPE) && (type === INT_COLUMN_TYPE) ) \n                   || ( (col.type === DOUBLE_TYPE) && (type === FLOAT_COLUMN_TYPE) ) )\n                     array = col.getRawData();\n                else\n                     array = new typeMap[type](col.getRawData());\n\n                /*if(((col.type == 'int') && (type == INT_COLUMN_TYPE)) \n                     || ((col.type == 'double') && (type == FLOAT_COLUMN_TYPE)))\n                       array = col.getRawData();\n                else\n                       array = new typeMap[type](col.getRawData());*/\n\n                // check types\n                arg.data = { 'array': array,\n                             'numOfRows': array.length};                             \n               \n                i++;\n                break;\n\n            // new column \n            case NEW_INT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n                let val = 0;                \n\n                ref = arg[NUM_OF_ROWS][REF];\n\n                if (argsSpecification[ref].type === NUM_TYPE)\n                    val = argsSpecification[ref].data;\n                else\n                    val = argsSpecification[ref].data[arg[NUM_OF_ROWS][VALUE]];                                \n\n                arg.data = {'numOfRows': val};\n\n                i++;\n                break;\n\n            // columns or column_list\n            case INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:                \n                let arrays = [];                \n\n                // this is OK if type of columns and target type coinside\n                //for(let col of inputVals[i].toList())\n                //  arrays.push(col.getRawData());\n\n                // here, we check types and perform an appropriate transform\n                for(let col of inputVals[i].toList())\n                  if( ( (col.type === INT_TYPE) && (type === INT_COLUMN_TYPE) ) \n                    || ( (col.type === DOUBLE_TYPE) && (type === FLOAT_COLUMN_TYPE) ) )\n                    arrays.push(col.getRawData());\n                  else\n                    arrays.push(new typeMap[type](col.getRawData()));\n                \n                /*for(let col of inputVals[i].toList())\n                    if(((col.type == 'int') && (type == INT_COLUMN_TYPE)) \n                      || ((col.type == 'double') && (type == FLOAT_COLUMN_TYPE)))\n                      arrays.push(col.getRawData());\n                    else\n                      arrays.push(new typeMap[type](col.getRawData()));*/\n\n                arg.data = { 'arrays': arrays,\n                    'numOfRows': arrays[0].length,\n                    'numOfColumns': arrays.length};\n\n                i++;  \n                break;\n\n            // new columns or new column_list\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                let val1 = 0;\n                let val2 = 0;\n\n                ref = arg[NUM_OF_ROWS][REF];\n\n                if (argsSpecification[ref].type === NUM_TYPE)\n                    val1 = argsSpecification[ref].data;\n                else\n                    val1 = argsSpecification[ref].data[arg[NUM_OF_ROWS][VALUE]];\n\n                ref = arg[NUM_OF_COLUMNS][REF];\n\n                //console.log('Ref:');\n                //console.log(ref);\n                //console.log(argsSpecification[ref].data);\n\n                if (argsSpecification[ref].type === NUM_TYPE)\n                    val2 = argsSpecification[ref].data;\n                else\n                    val2 = argsSpecification[ref].data[arg[NUM_OF_COLUMNS][VALUE]];                \n\n                arg.data = {'numOfRows': val1,\n                  'numOfColumns': val2};\n\n                i++;\n                break;            \n\n            default: \n                return; // TODO: specify behaviour           \n            } // switch        \n\n        cppFuncInput.push(arg);\n    } // for key\n\n    //console.log('cppFuncInput:');\n    //console.log(cppFuncInput);\n\n    return cppFuncInput;\n} // getCppInput\n\n// Allocate memory for buffers for array data\nfunction allocateMemoryForBuffer(module, inputs) {\n    for(const arg of inputs) { \n        const type = arg.type;\n\n        switch(type) { // Process each type of input\n\n            // numbers\n            case NUM_TYPE: \n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // column & new column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                arg.data.buf = module._malloc(arg.data.numOfRows * typeMap[type].BYTES_PER_ELEMENT);\n                break;\n\n            // columns & new columns\n            case INT_COLUMNS_TYPE:             \n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:             \n            case NEW_FLOAT_COLUMNS_TYPE: // allocation memory for columns that are created\n                arg.data.buf = module._malloc(arg.data.numOfRows * arg.data.numOfColumns \n                    * typeMap[type].BYTES_PER_ELEMENT);\n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break; \n        }  \n    }\n    \n    //console.log('inputs after memory allocation:');\n    //console.log(inputs);\n} // allocateMemoryForBuffer\n\n// Get array of values that are put to wasm-function.\nfunction getArrOfWasmParams(inputs) {\n    let params = [];\n\n    // Process each type of input\n    for(const arg of inputs) {\n        switch (arg.type) {\n\n            // numbers\n            case NUM_TYPE:            \n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                params.push(arg.data);\n                break;\n\n            // column & new column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                params.push(arg.data.buf);                \n                params.push(arg.data.numOfRows);\n                break;\n            \n            // columns & new columns\n            case INT_COLUMNS_TYPE:\n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE: \n                params.push(arg.data.buf);\n                params.push(arg.data.numOfRows);\n                params.push(arg.data.numOfColumns);\n                break;\n        \n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n\n    return params;\n} // getArrOfWasmParams\n\n// Get array of types that are put to wasm-function.\nfunction getArrOfWasmTypes(inputs) {\n    let types = [];\n\n    for(const arg of inputs) {\n        switch (arg.type) { // Process each type of input\n\n            // numbers\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                types.push(NUMBER);\n                break;\n\n            // column & new column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                types.push(NUMBER);                \n                types.push(NUMBER);\n                break;\n            \n            // columns & new columns\n            case INT_COLUMNS_TYPE:\n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                types.push(NUMBER);\n                types.push(NUMBER);\n                types.push(NUMBER);\n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n\n    return types;\n} // getArrOfWasmTypes\n\n// Put array data to buffer\nfunction putDataToBuffer(module, inputs) {\n    let shift;\n    let heap;    \n    \n    for(const arg of inputs) {\n        const type = arg.type;\n\n        switch (type) { // Process each type of input\n\n            // numbers\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:                \n                break;\n                \n            // column\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:                \n                shift = shiftMap[type];\n                heap = module[heapMap[type]];  \n                heap.set(arg.data.array, arg.data.buf >> shift);\n                break;\n            \n            // columns\n            case INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n                shift = shiftMap[type];\n                heap = module[heapMap[type]];\n                let numOfBytes = typeMap[type].BYTES_PER_ELEMENT;\n                let buf = arg.data.buf;\n                let numOfColumns = arg.data.numOfColumns;\n                let numOfRows = arg.data.numOfRows;\n                let arrays = arg.data.arrays;\n\n                for(let i = 0; i < numOfColumns; i++)\n                    heap.set(arrays[i], (buf + i * numOfRows * numOfBytes) >> shift);\n                                \n                break;\n\n            // new column(s)\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:                \n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n} // putDataToBuffer\n\n// Get array data from buffer.\nfunction getDataFromBuffer(module, inputs) {\n\n    let heap;\n    let numOfRows;\n    let numOfCols;\n    let numOfBytes;    \n    let buf;\n\n    for(const arg of inputs) {\n        const type = arg.type;\n\n        switch (type) { // Process each type of input\n            \n            // number\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // column(s)\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case FLOAT_COLUMNS_TYPE:  \n            case INT_COLUMNS_TYPE:          \n                break;\n\n            // new column\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                heap = module[heapMap[type]];\n                numOfRows = arg.data.numOfRows;\n                numOfBytes = typeMap[type].BYTES_PER_ELEMENT;    \n                buf = arg.data.buf;\n                let array = new typeMap[type](numOfRows);\n\n                for(let j = 0; j < numOfRows; j++)\n                    array[j] = heap[buf / numOfBytes + j];\n\n                arg.array = array;\n\n                break;\n\n            // new columns\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE: \n                heap = module[heapMap[type]];\n                numOfRows = arg.data.numOfRows;\n                numOfCols = arg.data.numOfColumns;\n                numOfBytes = typeMap[type].BYTES_PER_ELEMENT;    \n                buf = arg.data.buf;\n                let arrays = [];\n\n                for(let i = 0; i < numOfCols; i++) {\n                   let arr = new typeMap[type](numOfRows);\n\n                   for(let j = 0; j < numOfRows; j++)\n                      arr[j] = heap[buf / numOfBytes + j + i * numOfRows];               \n                \n                   arrays.push(arr);\n                }\n\n                arg.arrays = arrays;\n                \n                break;\n        \n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }            \n} // getDataFromBuffer\n\n// Clear memory allocated for array data\nfunction clearMemoryForBuffer(module, inputs) {\n    for(const arg of inputs) \n        switch(arg.type) { // process each type of input\n\n            // number\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // each non-number case\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:                \n            case INT_COLUMNS_TYPE:\n            case NEW_INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                module._free(arg.data.buf);\n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break; \n        }    \n} // clearMemoryForBuffer\n\n// Extract newly created data: new column(s) are created\nfunction extractNewlyCreatedData(funcSpecificationArgs, argsAfterWasmCall) {\n    // type-to-column_creator map\n    const typeToColumnCreatorMap = {'newFloatColumns': DG.Column.fromFloat32Array,\n                                    'newIntColumns': DG.Column.fromInt32Array,\n                                    'newFloatColumn': DG.Column.fromFloat32Array,\n                                    'newIntColumn': DG.Column.fromInt32Array};\n\n    let i = 0;\n\n    for(const key in funcSpecificationArgs) \n    {\n        const arg = funcSpecificationArgs[key];\n\n        switch(arg.type){ // Process each type\n\n            // number\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n                break;\n\n            // column(s)\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n            case INT_COLUMNS_TYPE:\n                break;\n\n            // new column\n            case NEW_FLOAT_COLUMN_TYPE:\n            case NEW_INT_COLUMN_TYPE:\n                let name;\n\n                // specify name for column\n                if(arg.name == undefined)\n                    name = (0).toString();\n                else \n                    names = arg.name;\n\n                arg.column = typeToColumnCreatorMap[arg.type](name,\n                    argsAfterWasmCall[i].array);\n                break;\n\n            // new columns\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                let columns = [];\n                let length = argsAfterWasmCall[i].arrays.length;\n\n                let names = [];\n\n                // specify name for column\n                if(arg.names == undefined)\n                    for(let k = 1; k <= length; k++)\n                        names.push((k).toString());\n                else names = arg.names;\n\n                for(let j = 0; j < length; j++)\n                    columns.push(typeToColumnCreatorMap[arg.type](names[j],\n                        argsAfterWasmCall[i].arrays[j]));\n\n                arg.columns = columns;\n                \n                break;\n\n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n\n        i++;\n    }\n} // extractNewlyCreatedData\n\n// Get output data: overall output is created\nfunction getOutput(funcSpecification) {  \n    let output = funcSpecification.output;\n    \n    const typeToDataFieldMap = {'newFloatColumns': 'columns',\n                                'newIntColumns': 'columns',\n                                'newFloatColumn': 'column',\n                                'newIntColumn': 'column'};\n\n    switch(output.type) {\n\n        case NUM_TYPE:\n        case INT_TYPE:\n        case DOUBLE_TYPE:\n            return funcSpecification.arguments[output.source];\n            break;\n\n        case COLUMN:\n            return funcSpecification.arguments[output.source].column;\n            break;\n\n        case TABLE_OF_COLUMNS:\n            return DG.DataFrame.fromColumns(funcSpecification.arguments[output.source].columns);\n            break;\n\n        case OBJECTS:\n            let arrayToReturn = [];\n            \n            // push data of the required arguments\n            for(let name of output.source) {\n                let arg = funcSpecification.arguments[name];\n                arrayToReturn.push(arg[typeToDataFieldMap[arg.type]]);\n            }                \n\n            return arrayToReturn;\n            break;\n\n        // TODO: process other cases and mistakes\n        default:\n            break;\n    }\n\n} // getOutput\n\n// Clear newly created data fields (new column(s))\nfunction clearNewlyCreatedData(funcSpecificationArgs) { \n    for(const key in funcSpecificationArgs) {\n        const arg = funcSpecificationArgs[key];\n\n        switch (arg.type) {\n            case NUM_TYPE:\n            case INT_TYPE:\n            case DOUBLE_TYPE:\n            case INT_COLUMN_TYPE:\n            case FLOAT_COLUMN_TYPE:            \n            case INT_COLUMNS_TYPE:\n            case FLOAT_COLUMNS_TYPE:\n                break;\n\n            case NEW_INT_COLUMN_TYPE:\n            case NEW_FLOAT_COLUMN_TYPE:\n                arg.column = null;                \n                break;\n\n            case NEW_INT_COLUMNS_TYPE:\n            case NEW_FLOAT_COLUMNS_TYPE:\n                arg.columns = null;\n                break;\n        \n            // TODO: process other cases and mistakes\n            default:\n                break;\n        }\n    }\n} // clearNewlyCreatedData\n\n// THE MAIN FUNCTION: a wrapper for C++-function call\nexport function cppWrapper(module, args, cppFuncName, returnType) {\n    // allocate memory for arrays that are passed to C++-function\n    allocateMemoryForBuffer(module, args);\n\n    // put data (just column(s)) to allocated buffers\n    putDataToBuffer(module, args);\n\n    // create array of parameters that are passed to C++-function\n    let params = getArrOfWasmParams(args);\n\n    //console.log('params:');\n    //console.log(params);\n\n    // create array of parameters' types that are passed to C++-function\n    let types = getArrOfWasmTypes(args);\n    \n    //console.log('types:');\n    //console.log(types);\n\n    // call wasm-function\n    let result = module.ccall(cppFuncName, returnType, types, params);\n    \n    //console.log(result);\n\n    // get data from buffers (just column(s))\n    getDataFromBuffer(module, args);        \n\n    // clear memory that was previousely allocated\n    clearMemoryForBuffer(module, args);\n\n    //console.log('done');\n\n    return result;\n}\n\n// Get the required output.\n// It takes a specification of the function and the data computed\n// and extracts the required results.\nexport function getResult(funcSpecification, dataFromWebWorker) {\n    funcSpecification.arguments._callResult = dataFromWebWorker.callResult;  \n\n    extractNewlyCreatedData(funcSpecification.arguments, dataFromWebWorker.args);    \n\n    let outPut = getOutput(funcSpecification);\n\n    // Below, we remove newly created column(s), which are created at the extraction-step.\n    // It is especially required, when multiple call of wasm-functions in webworker.\n    clearNewlyCreatedData(funcSpecification.arguments);\n\n    return outPut;\n}","// Inputs correctness check tools\n//Limitation constants\nconst COMP_MIN = 1;\nconst SAMPLES_COUNT_MIN = 1;\nconst FEATURES_COUNT_MIN = 1;\nconst PERCENTAGE_MIN = 0;\nconst PERCENTAGE_MAX = 100;\nconst MAX_ELEMENTS_COUNT = 100000000;\n// Error messages\nconst COMP_POSITVE_MES = 'components must be positive.';\nconst COMP_EXCESS = 'components must not be greater than feautures count.';\nconst INCORERRECT_MIN_MAX_MES = 'min must be less than max.';\nconst INCORERRECT_FEATURES_MES = 'features must be positive.';\nconst INCORERRECT_SAMPLES_MES = 'samples must be positive.';\nconst INCORERRECT_PERCENTAGE_MES = 'violators percentage must be from the range from 0 to 100.';\nconst DATAFRAME_IS_TOO_BIG_MES = 'dataframe is too big.';\n// Check components count (PCA, PLS)\nexport function checkComponenets(features, components) {\n    if (components < COMP_MIN)\n        throw new Error(COMP_POSITVE_MES);\n    if (components > features.length)\n        throw new Error(COMP_EXCESS);\n    if (features.length * features.byIndex(0).length > MAX_ELEMENTS_COUNT)\n        throw new Error(DATAFRAME_IS_TOO_BIG_MES);\n}\n// Check inputs of data for SVM testing generator\nexport function checkGeneratorSVMinputs(samplesCount, featuresCount, min, max, violatorsPercentage) {\n    if (min >= max)\n        throw new Error(INCORERRECT_MIN_MAX_MES);\n    if (featuresCount < FEATURES_COUNT_MIN)\n        throw new Error(INCORERRECT_FEATURES_MES);\n    if (samplesCount < SAMPLES_COUNT_MIN)\n        throw new Error(INCORERRECT_SAMPLES_MES);\n    if ((violatorsPercentage < PERCENTAGE_MIN) || (violatorsPercentage > PERCENTAGE_MAX))\n        throw new Error(INCORERRECT_PERCENTAGE_MES);\n}\n","// Exploratory data analysis (EDA) tools\nvar __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 { _principalComponentAnalysisInWebWorker, _partialLeastSquareRegressionInWebWorker } from '../wasm/EDAAPI';\nimport { checkComponenets } from './utils';\n// Principal components analysis (PCA)\nexport function computePCA(table, features, components, center, scale) {\n    return __awaiter(this, void 0, void 0, function* () {\n        checkComponenets(features, components);\n        const centerNum = center ? 1 : 0;\n        const scaleNum = scale ? 1 : 0;\n        let _output;\n        let _promise = _principalComponentAnalysisInWebWorker(table, features, components, centerNum, scaleNum);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        return _output;\n    });\n}\n// Partial least square regression (PLS)\nexport function computePLS(table, features, predict, components) {\n    return __awaiter(this, void 0, void 0, function* () {\n        checkComponenets(features, components);\n        let _output;\n        let _promise = _partialLeastSquareRegressionInWebWorker(table, features, predict, components);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        return _output;\n    });\n}\n","// The following code is generated automatically.\n// JavaScript API for call wasm-functions from the module EDA\n\n// Imports for call wasm runtime-system: in the main stream and in webworkers\nimport {callWasm} from '../wasm/callWasm';\nimport {getCppInput, getResult} from '../wasm/callWasmForWebWorker';\n\nexport async function _initEDAAPI() {\n  await initEDA();\n}\n\nexport function _principalComponentAnalysis(table, columns, componentsCount, centerNum, scaleNum) {\n  return callWasm(EDA, 'principalComponentAnalysis', [columns, componentsCount, centerNum, scaleNum]);\n}\n\nexport async function _principalComponentAnalysisInWebWorker(table, columns, componentsCount, centerNum, scaleNum) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/principalComponentAnalysisWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['principalComponentAnalysis'].arguments,[columns, componentsCount, centerNum, scaleNum]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['principalComponentAnalysis'], e.data));\n    }\n  });\n}\n\nexport function _error(df, col1, col2) {\n  return callWasm(EDA, 'error', [col1, col2]);\n}\n\nexport async function _errorInWebWorker(df, col1, col2) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/errorWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['error'].arguments,[col1, col2]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['error'], e.data));\n    }\n  });\n}\n\nexport function _partialLeastSquareRegression(table, features, predict, componentsCount) {\n  return callWasm(EDA, 'partialLeastSquareRegression', [features, predict, componentsCount]);\n}\n\nexport async function _partialLeastSquareRegressionInWebWorker(table, features, predict, componentsCount) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/partialLeastSquareRegressionWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['partialLeastSquareRegression'].arguments,[features, predict, componentsCount]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['partialLeastSquareRegression'], e.data));\n    }\n  });\n}\n\nexport function _generateDataset(kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage) {\n  return callWasm(EDA, 'generateDataset', [kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage]);\n}\n\nexport async function _generateDatasetInWebWorker(kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/generateDatasetWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['generateDataset'].arguments,[kernel, kernelParams, samplesCount, featuresCount, min, max, violatorsPercentage]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['generateDataset'], e.data));\n    }\n  });\n}\n\nexport function _normalizeDataset(data) {\n  return callWasm(EDA, 'normalizeDataset', [data]);\n}\n\nexport async function _normalizeDatasetInWebWorker(data) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/normalizeDatasetWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['normalizeDataset'].arguments,[data]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['normalizeDataset'], e.data));\n    }\n  });\n}\n\nexport function _trainLSSVM(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels) {\n  return callWasm(EDA, 'trainLSSVM', [gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels]);\n}\n\nexport async function _trainLSSVMInWebWorker(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/trainLSSVMWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['trainLSSVM'].arguments,[gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, dataset, labels]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['trainLSSVM'], e.data));\n    }\n  });\n}\n\nexport function _predictByLSSVM(kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData) {\n  return callWasm(EDA, 'predictByLSSVM', [kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData]);\n}\n\nexport async function _predictByLSSVMInWebWorker(kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/predictByLSSVMWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['predictByLSSVM'].arguments,[kernel, kernelParams, normalizedData, labels, means, stdDevs, modelParams, precomputedWeights, targetData]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['predictByLSSVM'], e.data));\n    }\n  });\n}\n\nexport function _trainAndAnalyzeLSSVM(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels) {\n  return callWasm(EDA, 'trainAndAnalyzeLSSVM', [gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels]);\n}\n\nexport async function _trainAndAnalyzeLSSVMInWebWorker(gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels) {\n  return new Promise((resolve, reject) => {\n    const worker = new Worker(new URL('../wasm/workers/trainAndAnalyzeLSSVMWorker.js', import.meta.url));\n    worker.postMessage(getCppInput(EDA['trainAndAnalyzeLSSVM'].arguments,[gamma, kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels]));\n    worker.onmessage = function(e) {\n      worker.terminate();\n      resolve(getResult(EDA['trainAndAnalyzeLSSVM'], e.data));\n    }\n  });\n}\n\n","// Custom UI for Exploratory data analysis (EDA) tools\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\n// Rename PCA columns\nexport function renamePCAcolumns(pcaTable) {\n    for (const col of pcaTable.columns.toList())\n        col.name = 'PCA' + col.name;\n    return pcaTable;\n}\n// Predicted vs Reference scatter plot\nexport function predictedVersusReferenceScatterPlot(samplesNames, reference, prediction) {\n    prediction.name = reference.name + '(predicted)';\n    let dfReferencePrediction = DG.DataFrame.fromColumns([samplesNames, reference, prediction]);\n    dfReferencePrediction.name = 'Reference vs. Predicted';\n    return DG.Viewer.scatterPlot(dfReferencePrediction, { title: dfReferencePrediction.name,\n        x: reference.name,\n        y: prediction.name,\n        showRegressionLine: true,\n        markerType: 'circle',\n        labels: samplesNames.name\n    });\n}\n// Regression Coefficients Bar Chart\nexport function regressionCoefficientsBarChart(features, regressionCoeffs) {\n    regressionCoeffs.name = 'regression coefficient';\n    let namesOfPredictors = [];\n    for (const col of features)\n        namesOfPredictors.push(col.name);\n    let predictorNamesColumn = DG.Column.fromStrings('feature', namesOfPredictors);\n    let dfRegrCoefs = DG.DataFrame.fromColumns([predictorNamesColumn, regressionCoeffs]);\n    dfRegrCoefs.name = 'Regression Coefficients';\n    return DG.Viewer.barChart(dfRegrCoefs, { title: dfRegrCoefs.name, split: 'feature',\n        value: 'regression coefficient', valueAggrType: 'avg' });\n}\n// Scores Scatter Plot\nexport function scoresScatterPlot(samplesNames, xScores, yScores) {\n    let scoresColumns = [samplesNames];\n    for (let i = 0; i < xScores.length; i++) {\n        xScores[i].name = `x.score.t${i + 1}`;\n        scoresColumns.push(xScores[i]);\n    }\n    for (let i = 0; i < yScores.length; i++) {\n        yScores[i].name = `y.score.u${i + 1}`;\n        scoresColumns.push(yScores[i]);\n    }\n    let scores = DG.DataFrame.fromColumns(scoresColumns);\n    scores.name = 'Scores';\n    //grok.shell.addTableView(scores);\n    const index = xScores.length > 1 ? 1 : 0;\n    return DG.Viewer.scatterPlot(scores, { title: scores.name,\n        x: xScores[0].name,\n        y: xScores[index].name,\n        markerType: 'circle',\n        labels: samplesNames.name\n    });\n}\n// Loading Scatter Plot\nexport function loadingScatterPlot(features, xLoadings) {\n    let loadingCols = [];\n    let loadingLabels = [];\n    for (let col of features)\n        loadingLabels.push(col.name);\n    loadingCols.push(DG.Column.fromStrings('labels', loadingLabels));\n    for (let i = 0; i < xLoadings.length; i++) {\n        xLoadings[i].name = `x.loading.p${i + 1}`;\n        loadingCols.push(xLoadings[i]);\n    }\n    let dfLoadings = DG.DataFrame.fromColumns(loadingCols);\n    dfLoadings.name = 'Loadings';\n    return DG.Viewer.scatterPlot(dfLoadings, { title: dfLoadings.name,\n        x: xLoadings[0].name,\n        y: xLoadings[xLoadings.length - 1].name,\n        markerType: 'circle',\n        labels: 'labels'\n    });\n}\n// Add PLS visualization\nexport function addPLSvisualization(table, samplesNames, features, predict, plsOutput) {\n    let view = grok.shell.getTableView(table.name);\n    // 1. Predicted vs Reference scatter plot\n    view.addViewer(predictedVersusReferenceScatterPlot(samplesNames, predict, plsOutput[0]));\n    // 2. Regression Coefficients Bar Chart\n    view.addViewer(regressionCoefficientsBarChart(features, plsOutput[1]));\n    // 3. Loading Scatter Plot\n    view.addViewer(loadingScatterPlot(features, plsOutput[4]));\n    // 4. Scores Scatter Plot\n    view.addViewer(scoresScatterPlot(samplesNames, plsOutput[2], plsOutput[3]));\n}\n","// Test data generation tools\nvar __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 { checkGeneratorSVMinputs } from './utils';\nimport { _generateDatasetInWebWorker } from '../wasm/EDAAPI';\nconst SVM_GEN_FEATURES_INDEX = 0;\nconst SVM_GEN_LABELS_INDEX = 1;\nconst SVM_FEATURE_NAME = 'Feature #';\nconst SVM_LABEL_NAME = 'Label';\n// Returns the dataframe \"cars\"\nexport function carsDataframe() {\n    return DG.DataFrame.fromColumns([\n        DG.Column.fromStrings('model', ['alfaromeo', 'audi', 'bmw', 'chevrolet', 'dodge1', 'dodge2', 'honda1', 'honda2', 'isuzu', 'jaguar', 'mazda', 'mercedes', 'mercury', 'mitsubishi', 'nissan1', 'nissan2', 'peugot', 'plymouth', 'porsche', 'saab', 'subaru', 'toyota1', 'toyota2', 'toyota3', 'toyota4', 'volkswagen1', 'volkswagen2', 'volvo1', 'volvo2', 'volvo3']),\n        DG.Column.fromInt32Array('diesel', new Int32Array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 1])),\n        DG.Column.fromInt32Array('turbo', new Int32Array([0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 1])),\n        DG.Column.fromInt32Array('two.doors', new Int32Array([1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0])),\n        DG.Column.fromInt32Array('hatchback', new Int32Array([1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0])),\n        DG.Column.fromFloat32Array('wheel.base', new Float32Array([94.5, 105.80000305175781, 101.19999694824219, 94.5, 93.69999694824219, 93.69999694824219, 93.69999694824219, 96.5, 94.30000305175781, 113, 93.0999984741211, 115.5999984741211, 102.69999694824219, 93.69999694824219, 94.5, 94.5, 93.69999694824219, 114.19999694824219, 89.5, 99.0999984741211, 97.19999694824219, 95.69999694824219, 95.69999694824219, 98.4000015258789, 102.4000015258789, 97.30000305175781, 100.4000015258789, 104.30000305175781, 109.0999984741211, 109.0999984741211])),\n        DG.Column.fromFloat32Array('length', new Float32Array([171.1999969482422, 192.6999969482422, 176.8000030517578, 158.8000030517578, 157.3000030517578, 157.3000030517578, 150, 175.39999389648438, 170.6999969482422, 199.60000610351562, 166.8000030517578, 202.60000610351562, 178.39999389648438, 157.3000030517578, 170.1999969482422, 165.3000030517578, 157.3000030517578, 198.89999389648438, 168.89999389648438, 186.60000610351562, 172, 158.6999969482422, 166.3000030517578, 176.1999969482422, 175.60000610351562, 171.6999969482422, 180.1999969482422, 188.8000030517578, 188.8000030517578, 188.8000030517578])),\n        DG.Column.fromFloat32Array('width', new Float32Array([65.5, 71.4000015258789, 64.80000305175781, 63.599998474121094, 63.79999923706055, 63.79999923706055, 64, 65.19999694824219, 61.79999923706055, 69.5999984741211, 64.19999694824219, 71.69999694824219, 68, 64.4000015258789, 63.79999923706055, 63.79999923706055, 63.79999923706055, 68.4000015258789, 65, 66.5, 65.4000015258789, 63.599998474121094, 64.4000015258789, 65.5999984741211, 66.5, 65.5, 66.9000015258789, 67.19999694824219, 68.80000305175781, 68.9000015258789])),\n        DG.Column.fromFloat32Array('height', new Float32Array([52.400001525878906, 55.70000076293945, 54.29999923706055, 52, 50.79999923706055, 50.599998474121094, 52.599998474121094, 54.099998474121094, 53.5, 52.79999923706055, 54.099998474121094, 56.29999923706055, 54.79999923706055, 50.79999923706055, 53.5, 54.5, 50.599998474121094, 58.70000076293945, 51.599998474121094, 56.099998474121094, 52.5, 54.5, 53, 52, 54.900001525878906, 55.70000076293945, 55.099998474121094, 56.20000076293945, 55.5, 55.5])),\n        DG.Column.fromInt32Array('curb.weight', new Int32Array([2823, 2844, 2395, 1909, 2128, 1967, 1956, 2304, 2337, 4066, 1950, 3770, 2910, 1918, 2024, 1951, 1967, 3430, 2800, 2695, 2190, 1985, 2275, 2551, 2480, 2261, 2661, 2912, 3049, 3217])),\n        DG.Column.fromInt32Array('eng.size', new Int32Array([152, 136, 108, 90, 98, 90, 92, 110, 111, 258, 91, 183, 140, 92, 97, 97, 90, 152, 194, 121, 108, 92, 110, 146, 110, 97, 136, 141, 141, 145])),\n        DG.Column.fromInt32Array('horsepower', new Int32Array([154, 110, 101, 70, 102, 68, 76, 86, 78, 176, 68, 123, 175, 68, 69, 69, 68, 95, 207, 110, 82, 62, 56, 116, 73, 52, 110, 114, 160, 106])),\n        DG.Column.fromInt32Array('peak.rpm', new Int32Array([5000, 5500, 5800, 5400, 5500, 5500, 6000, 5800, 4800, 4750, 5000, 4350, 5000, 5500, 5200, 5200, 5500, 4150, 5900, 5250, 4400, 4800, 4500, 4800, 4500, 4800, 5500, 5400, 5300, 4800])),\n        DG.Column.fromInt32Array('symbol', new Int32Array([1, 1, 2, 0, 1, 1, 1, 0, 0, 0, 1, -1, 1, 2, 1, 1, 1, 0, 3, 2, 0, 1, 0, 2, -1, 2, 0, -2, -1, -1])),\n        DG.Column.fromInt32Array('city.mpg', new Int32Array([19, 19, 23, 38, 24, 31, 30, 27, 24, 15, 31, 22, 19, 37, 31, 31, 31, 25, 17, 21, 28, 35, 34, 24, 30, 37, 19, 23, 19, 26])),\n        DG.Column.fromInt32Array('highway.mpg', new Int32Array([26, 25, 29, 43, 30, 38, 34, 33, 29, 19, 38, 25, 24, 41, 37, 37, 38, 25, 25, 28, 33, 39, 36, 30, 33, 46, 24, 28, 25, 27])),\n        DG.Column.fromInt32Array('price', new Int32Array([16500, 17710, 16430, 6575, 7957, 6229, 7129, 8845, 6785, 35550, 7395, 31600, 16503, 5389, 7349, 7299, 6229, 13860, 37028, 12170, 7775, 5348, 7898, 9989, 10698, 7775, 13295, 12940, 19045, 22470])),\n    ]);\n} // carsDataframe\n// Generate dataset for testing binary classifiers\nexport function testDataForBinaryClassification(kernel, kernelParams, name, samplesCount, featuresCount, min, max, violatorsPercentage) {\n    return __awaiter(this, void 0, void 0, function* () {\n        // check inputs\n        checkGeneratorSVMinputs(samplesCount, featuresCount, min, max, violatorsPercentage);\n        // kernel params column\n        const kernelParamsCol = DG.Column.fromList('double', 'kernelParams', kernelParams);\n        // CALL WASM-COMPUTATIONS  \n        let _output;\n        let _promise = _generateDatasetInWebWorker(kernel, kernelParamsCol, samplesCount, featuresCount, min, max, violatorsPercentage);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        // Rename labels column\n        _output[SVM_GEN_LABELS_INDEX].name = SVM_LABEL_NAME;\n        // Rename feature columns\n        for (const col of _output[SVM_GEN_FEATURES_INDEX])\n            col.name = SVM_FEATURE_NAME + col.name;\n        // Create dataframe\n        const df = DG.DataFrame.fromColumns(_output[SVM_GEN_FEATURES_INDEX]);\n        df.name = name;\n        df.columns.add(_output[SVM_GEN_LABELS_INDEX]);\n        return df;\n    });\n} // testDataForMachineLearning\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};\n/* Support vector machine (SVM) tools.\n   It's developed for applying in combination with DATAGROK predictive tools.\n\n   Training & predicting are provided by wasm-computations.\n\n   Least square support vector machine (LS-SVM) is implemented:\n     [1] Suykens, J., Vandewalle, J. \"Least Squares Support Vector Machine Classifiers\",\n           Neural Processing Letters 9, 293-300 (1999). https://doi.org/10.1023/A:1018628609742\n*/\nimport * as grok from 'datagrok-api/grok';\nimport * as DG from 'datagrok-api/dg';\nimport { _trainAndAnalyzeLSSVMInWebWorker, _predictByLSSVMInWebWorker } from '../wasm/EDAAPI';\n// 1. CONSTANTS\n// kernel types\nexport const LINEAR = 0;\nexport const POLYNOMIAL = 1;\nexport const RBF = 2;\nexport const SIGMOID = 3;\n// output-related\nconst CONFUSION_MATR_SIZE = 4;\nconst NORMALIZED_DATA_INDEX = 0;\nconst MEANS_INDEX = 1;\nconst STD_DEVS_INDEX = 2;\nconst MODEL_PARAMS_INDEX = 3;\nconst MODEL_WEIGHTS_INDEX = 4;\nconst PREDICTED_LABELS_INDEX = 5;\nconst CORRECTNESS_INDEX = 6;\nconst CONFUSION_MATRIX_INDEX = 7;\nconst TRUE_POSITIVE_INDEX = 0;\nconst FALSE_NEGATIVE_INDEX = 1;\nconst FALSE_POSITIVE_INDEX = 2;\nconst TRUE_NEGATIVE_INDEX = 3;\n// kernel parameters indeces\nconst RBF_SIGMA_INDEX = 0;\nconst POLYNOMIAL_C_INDEX = 0;\nconst POLYNOMIAL_D_INDEX = 1;\nconst SIGMOID_KAPPA_INDEX = 0;\nconst SIGMOID_THETA_INDEX = 1;\n// hyperparameters limits\nconst GAMMA_INFIMUM_LIMIT = 0;\nconst RBF_SIGMA_INFIMUM_LIMIT = 0;\nconst POLYNOMIAL_C_INFIMUM_LIMIT = 0;\nconst POLYNOMIAL_D_INFIMUM_LIMIT = 0;\n// error messages\nconst WRONG_GAMMA_MESSAGE = 'gamma must be strictly positive.';\nconst WRONG_RBF_SIGMA_MESSAGE = 'sigma must be strictly positive.';\nconst WRONG_POLYNOMIAL_C_MESSAGE = 'c must be strictly positive.';\nconst WRONG_POLYNOMIAL_D_MESSAGE = 'd must be strictly positive.';\nconst WRONG_KERNEL_MESSAGE = 'incorrect kernel.';\n// names\nconst LABELS = 'Labels';\nconst PREDICTED = 'predicted';\nconst CORRECTNESS = 'correctness';\nconst CONFUSION_MATRIX_NAME = 'Confusion matrix';\nconst MEAN = 'mean';\nconst STD_DEV = 'std dev';\nconst MODEL_PARAMS_NAME = 'alpha';\nconst MODEL_WEIGHTS_NAME = 'weight';\nconst GAMMA = 'gamma';\nconst KERNEL = 'kernel';\nconst KERNEL_PARAMS = 'kernel params';\nconst KERNEL_PARAM_1 = 'kernel param 1';\nconst KERNEL_PARAM_2 = 'kernel param 2';\nconst FEATURES_COUNT_NAME = 'features count';\nconst TRAIN_SAMPLES_COUNT_NAME = 'train samples count';\nconst TRAIN_ERROR = 'Train error,%';\nconst KERNEL_TYPE_TO_NAME_MAP = ['linear', 'polynomial', 'RBF', 'sigmoid'];\nconst POSITIVE_NAME = 'positive (P)';\nconst NEGATIVE_NAME = 'negative (N)';\nconst PREDICTED_POSITIVE_NAME = 'predicted positive (PP)';\nconst PREDICTED_NEGATIVE_NAME = 'predicted negative (PN)';\nconst SENSITIVITY = 'Sensitivity';\nconst SPECIFICITY = 'Specificity';\nconst BALANCED_ACCURACY = 'Balanced accuracy';\nconst POSITIVE_PREDICTIVE_VALUE = 'Positive predicitve value';\nconst NEGATIVE_PREDICTIVE_VALUE = 'Negative predicitve value';\nconst ML_REPORT = 'Model report';\nconst ML_REPORT_PREDICTED_LABELS = 'Predicted labels';\nconst ML_REPORT_TRAIN_LABELS = 'Train labels';\nconst ML_REPORT_CORRECTNESS = 'Prediction correctness';\nconst PREDICTION = 'prediction';\n// Pack/unpack constants\nconst BYTES = 4;\nconst INTS_COUNT = 3;\nconst KER_PARAMS_COUNT = 2;\nconst MODEL_KERNEL_INDEX = 0;\nconst SAMPLES_COUNT_INDEX = 1;\nconst FEATURES_COUNT_INDEX = 2;\n// misc\nconst INIT_VALUE = 0; // any number can be used\nconst LS_SVM_ADD_CONST = 1; // see [1] for more details\n// 2. TOOLS\n// Check LS-SVM learning hyperparameters\nfunction checkHyperparameters(hyperparameters) {\n    // check gamma\n    if (hyperparameters.gamma <= GAMMA_INFIMUM_LIMIT)\n        throw new Error(WRONG_GAMMA_MESSAGE);\n    // check kernel & its parameters\n    switch (hyperparameters.kernel) {\n        case LINEAR: // the case of linear kernel\n            return;\n        case RBF: // the case of RBF kernel\n            if (hyperparameters.sigma <= RBF_SIGMA_INFIMUM_LIMIT)\n                throw new Error(WRONG_RBF_SIGMA_MESSAGE);\n            return;\n        case POLYNOMIAL: // the case of polynomial kernel\n            // check c\n            if (hyperparameters.cParam <= POLYNOMIAL_C_INFIMUM_LIMIT)\n                throw new Error(WRONG_POLYNOMIAL_C_MESSAGE);\n            // check d\n            if (hyperparameters.dParam <= POLYNOMIAL_D_INFIMUM_LIMIT)\n                throw new Error(WRONG_POLYNOMIAL_D_MESSAGE);\n            return;\n        case SIGMOID: // the case of polynomial kernel\n            return;\n        default: // incorrect kernel\n            throw new Error(WRONG_KERNEL_MESSAGE);\n    } // switch    \n} // checkHyperparameters\n// Returnes labels predicted by the model specified\nfunction predict(model, dataset) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let _output;\n        let _promise = _predictByLSSVMInWebWorker(model.kernelType, model.kernelParams, model.normalizedTrainData.columns, model.trainLabels, model.means, model.stdDevs, model.modelParams, model.modelWeights, dataset);\n        yield _promise.then(_result => { _output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        return _output;\n    });\n} // predict\n// Evaluate accuracy of the model\nfunction evaluateAccuracy(model) {\n    let data = model.confusionMatrix.getRawData();\n    // here, the classic notation is used (see https://en.wikipedia.org/wiki/Sensitivity_and_specificity)\n    let TP = data[TRUE_POSITIVE_INDEX]; // true positive\n    let TN = data[TRUE_NEGATIVE_INDEX]; // true negative\n    let FP = data[FALSE_POSITIVE_INDEX]; // false positive\n    let FN = data[FALSE_NEGATIVE_INDEX]; // false negative\n    let P = TP + FN; // positive\n    let N = FP + TN; // negative\n    let TPR = TP / P; // true positive rate\n    let TNR = TN / N; // true negative rate\n    let PPV = TP / (TP + FP); // positive predicitve value\n    let NPV = TN / (TN + FN); // negative predicitve value\n    let ACC = (TP + TN) / (P + N); // accuracy\n    let BA = (TPR + TNR) / 2; // balanced accuracy\n    model.sensitivity = TPR;\n    model.specificity = TNR;\n    model.balancedAccuracy = BA;\n    model.positivePredicitveValue = PPV;\n    model.negativePredicitveValue = NPV;\n    model.trainError = (1 - ACC) * 100; // train error, %\n} // evaluateAccuracy\n// Returns trained LS-SVM model.\nfunction trainAndAnalyzeModel(hyperparameters, dataset, labels) {\n    return __awaiter(this, void 0, void 0, function* () {\n        // check correctness of hyperparameter gamma\n        checkHyperparameters(hyperparameters);\n        // create default kernel params array\n        const kernelParamsArray = [INIT_VALUE, INIT_VALUE];\n        // fill kernelParams\n        switch (hyperparameters.kernel) {\n            case LINEAR: // no kernel parameters in the case of linear kernel\n                break;\n            case RBF: // sigma parameter in the case of RBF-kernel\n                kernelParamsArray[RBF_SIGMA_INDEX] = hyperparameters.sigma;\n                break;\n            case POLYNOMIAL: // sigma parameter in the case of polynomial kernel\n                kernelParamsArray[POLYNOMIAL_C_INDEX] = hyperparameters.cParam;\n                kernelParamsArray[POLYNOMIAL_D_INDEX] = hyperparameters.dParam;\n                break;\n            case SIGMOID: // sigma parameter in the case of sigmoid kernel\n                kernelParamsArray[SIGMOID_KAPPA_INDEX] = hyperparameters.kappa;\n                kernelParamsArray[SIGMOID_THETA_INDEX] = hyperparameters.theta;\n                break;\n            default: // incorrect kernel \n                throw new Error(WRONG_KERNEL_MESSAGE);\n        }\n        ;\n        // create kernel params column\n        let kernelParams = DG.Column.fromList('double', KERNEL_PARAMS, kernelParamsArray);\n        // compute size of model params & precomputed weigths\n        let trainCols = dataset.toList();\n        let modelParamsCount = trainCols[0].length + LS_SVM_ADD_CONST;\n        let precomputedWeightsCount = trainCols.length + LS_SVM_ADD_CONST;\n        let confusionMatrixElementsCount = CONFUSION_MATR_SIZE;\n        // call webassembly training function\n        let output;\n        let _promise = _trainAndAnalyzeLSSVMInWebWorker(hyperparameters.gamma, hyperparameters.kernel, kernelParams, modelParamsCount, precomputedWeightsCount, confusionMatrixElementsCount, dataset, labels);\n        yield _promise.then(_result => { output = _result; }, _error => { throw new Error(`Error: ${_error}`); });\n        // rename output columns\n        output[MEANS_INDEX].name = MEAN;\n        output[STD_DEVS_INDEX].name = STD_DEV;\n        output[MODEL_PARAMS_INDEX].name = MODEL_PARAMS_NAME;\n        output[MODEL_WEIGHTS_INDEX].name = MODEL_WEIGHTS_NAME;\n        output[PREDICTED_LABELS_INDEX].name = PREDICTED;\n        output[CORRECTNESS_INDEX].name = CORRECTNESS;\n        output[CONFUSION_MATRIX_INDEX].name = CONFUSION_MATRIX_NAME;\n        // complete model\n        let model = {\n            trainGamma: hyperparameters.gamma,\n            kernelType: hyperparameters.kernel,\n            kernelParams: kernelParams,\n            trainLabels: labels,\n            normalizedTrainData: DG.DataFrame.fromColumns(output[NORMALIZED_DATA_INDEX]),\n            means: output[MEANS_INDEX],\n            stdDevs: output[STD_DEVS_INDEX],\n            modelParams: output[MODEL_PARAMS_INDEX],\n            modelWeights: output[MODEL_WEIGHTS_INDEX],\n            predictedLabels: output[PREDICTED_LABELS_INDEX],\n            correctness: output[CORRECTNESS_INDEX],\n            confusionMatrix: output[CONFUSION_MATRIX_INDEX],\n            trainError: undefined,\n            featuresCount: trainCols.length,\n            trainSamplesCount: trainCols[0].length\n        };\n        evaluateAccuracy(model);\n        return model;\n    });\n} // trainAndAnalyzeModel\n// Wrapper for combining the function \"trainAndAnalyzeModel\" with Datagrok predicitve tools\nexport function getTrainedModel(hyperparameters, df, predict_column) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let columns = df.columns;\n        let labels = columns.byName(predict_column);\n        columns.remove(predict_column);\n        return yield trainAndAnalyzeModel(hyperparameters, columns, labels);\n    });\n}\n// Returns dataframe with short info about model\nfunction getModelInfo(model) {\n    let kernelParams = model.kernelParams.getRawData();\n    return DG.DataFrame.fromColumns([\n        DG.Column.fromList('double', GAMMA, [model.trainGamma]),\n        DG.Column.fromStrings(KERNEL, [KERNEL_TYPE_TO_NAME_MAP[model.kernelType]]),\n        DG.Column.fromList('double', KERNEL_PARAM_1, [kernelParams[0]]),\n        DG.Column.fromList('double', KERNEL_PARAM_2, [kernelParams[1]]),\n        DG.Column.fromList('double', FEATURES_COUNT_NAME, [model.featuresCount]),\n        DG.Column.fromList('double', TRAIN_SAMPLES_COUNT_NAME, [model.trainSamplesCount]),\n        DG.Column.fromList('double', TRAIN_ERROR, [model.trainError]),\n        DG.Column.fromList('double', BALANCED_ACCURACY, [model.balancedAccuracy]),\n        DG.Column.fromList('double', SENSITIVITY, [model.sensitivity]),\n        DG.Column.fromList('double', SPECIFICITY, [model.specificity]),\n        DG.Column.fromList('double', POSITIVE_PREDICTIVE_VALUE, [model.positivePredicitveValue]),\n        DG.Column.fromList('double', NEGATIVE_PREDICTIVE_VALUE, [model.negativePredicitveValue])\n    ]);\n}\n// Get dataframe with confusion matrix\nfunction getConfusionMatrixDF(model) {\n    let data = model.confusionMatrix.getRawData();\n    return DG.DataFrame.fromColumns([\n        DG.Column.fromStrings('', [POSITIVE_NAME, NEGATIVE_NAME]),\n        DG.Column.fromList('int', PREDICTED_POSITIVE_NAME, [data[TRUE_POSITIVE_INDEX], data[FALSE_POSITIVE_INDEX]]),\n        DG.Column.fromList('int', PREDICTED_NEGATIVE_NAME, [data[FALSE_NEGATIVE_INDEX], data[TRUE_NEGATIVE_INDEX]])\n    ]);\n}\n// Show training report\nexport function showTrainReport(df, model) {\n    df.name = ML_REPORT;\n    df.columns.add(model.trainLabels);\n    df.columns.add(model.predictedLabels);\n    df.columns.add(model.correctness);\n    let dfView = grok.shell.addTableView(df);\n    dfView.addViewer(DG.Viewer.form(getModelInfo(model)));\n    dfView.addViewer(DG.Viewer.scatterPlot(df, { title: ML_REPORT_PREDICTED_LABELS,\n        color: model.predictedLabels.name\n    }));\n    dfView.addViewer(DG.Viewer.scatterPlot(df, { title: ML_REPORT_TRAIN_LABELS,\n        color: model.trainLabels.name\n    }));\n    dfView.addViewer(DG.Viewer.grid(getConfusionMatrixDF(model)));\n    dfView.addViewer(DG.Viewer.scatterPlot(df, { title: ML_REPORT_CORRECTNESS,\n        color: model.correctness.name\n    }));\n} // showTrainReport\n// Returns trained model packed into UInt8Array\nexport function getPackedModel(model) {\n    // get principal data\n    let dataCols = model.normalizedTrainData.columns;\n    let samplesCount = model.trainSamplesCount;\n    let featuresCount = model.featuresCount;\n    /*let bufferSize = BYTES * (7 + featuresCount * samplesCount\n      + 3 * featuresCount + 2 * samplesCount);*/\n    // compute size of packed model\n    let bufferSize = BYTES * (INTS_COUNT + KER_PARAMS_COUNT +\n        samplesCount + featuresCount + featuresCount + samplesCount + LS_SVM_ADD_CONST\n        + featuresCount + LS_SVM_ADD_CONST + featuresCount * samplesCount);\n    // packed model\n    let result = new Uint8Array(bufferSize);\n    let buffer = result.buffer;\n    let offset = 0;\n    // pack kernel type and sizes\n    let ints = new Int32Array(buffer, offset, INTS_COUNT);\n    ints[MODEL_KERNEL_INDEX] = model.kernelType;\n    ints[SAMPLES_COUNT_INDEX] = samplesCount;\n    ints[FEATURES_COUNT_INDEX] = featuresCount;\n    offset += INTS_COUNT * BYTES;\n    // pack kernel parameters\n    let floats = new Float32Array(buffer, offset, KER_PARAMS_COUNT);\n    floats.set(model.kernelParams.getRawData());\n    offset += KER_PARAMS_COUNT * BYTES;\n    // pack pack labels of training data\n    floats = new Float32Array(buffer, offset, samplesCount);\n    floats.set(model.trainLabels.getRawData());\n    offset += samplesCount * BYTES;\n    // pack mean values of training data\n    floats = new Float32Array(buffer, offset, featuresCount);\n    floats.set(model.means.getRawData());\n    offset += featuresCount * BYTES;\n    // pack standard deviations of training data\n    floats = new Float32Array(buffer, offset, featuresCount);\n    floats.set(model.stdDevs.getRawData());\n    offset += featuresCount * BYTES;\n    // pack model paramters\n    floats = new Float32Array(buffer, offset, samplesCount + LS_SVM_ADD_CONST);\n    floats.set(model.modelParams.getRawData());\n    offset += (samplesCount + LS_SVM_ADD_CONST) * BYTES;\n    // pack model's precomputed weights\n    floats = new Float32Array(buffer, offset, featuresCount + LS_SVM_ADD_CONST);\n    floats.set(model.modelWeights.getRawData());\n    offset += (featuresCount + LS_SVM_ADD_CONST) * BYTES;\n    // pack training dataset\n    for (const col of dataCols) {\n        floats = new Float32Array(buffer, offset, featuresCount);\n        floats.set(col.getRawData());\n        offset += featuresCount * BYTES;\n    }\n    return result;\n} // getPackedModel\n// Returns unpacked model\nfunction getUnpackedModel(packedModel) {\n    let modelBytes = packedModel.buffer;\n    let offset = 0;\n    // extract kernel type and sizes\n    let header = new Int32Array(modelBytes, offset, INTS_COUNT);\n    offset += INTS_COUNT * BYTES;\n    let samplesCount = header[SAMPLES_COUNT_INDEX];\n    let featuresCount = header[FEATURES_COUNT_INDEX];\n    // extract parameters of kernel\n    const kernelParams = DG.Column.fromFloat32Array(KERNEL_PARAMS, new Float32Array(modelBytes, offset, KER_PARAMS_COUNT));\n    offset += KER_PARAMS_COUNT * BYTES;\n    // extract training labels\n    const trainLabels = DG.Column.fromFloat32Array(LABELS, new Float32Array(modelBytes, offset, samplesCount));\n    offset += samplesCount * BYTES;\n    // extract mean values of training data\n    const means = DG.Column.fromFloat32Array(MEAN, new Float32Array(modelBytes, offset, featuresCount));\n    offset += featuresCount * BYTES;\n    // extract standard deviations of training data\n    const stdDevs = DG.Column.fromFloat32Array(STD_DEV, new Float32Array(modelBytes, offset, featuresCount));\n    offset += featuresCount * BYTES;\n    // extract parameters of model\n    const modelParams = DG.Column.fromFloat32Array(MODEL_PARAMS_NAME, new Float32Array(modelBytes, offset, samplesCount + LS_SVM_ADD_CONST));\n    offset += (samplesCount + LS_SVM_ADD_CONST) * BYTES;\n    // extract model's precomputed weights\n    const modelWeights = DG.Column.fromFloat32Array(MODEL_WEIGHTS_NAME, new Float32Array(modelBytes, offset, featuresCount + LS_SVM_ADD_CONST));\n    offset += (featuresCount + LS_SVM_ADD_CONST) * BYTES;\n    // extract training data columns\n    let dataCols = [];\n    for (let i = 0; i < samplesCount; i++) {\n        dataCols.push(DG.Column.fromFloat32Array(i.toString(), new Float32Array(modelBytes, offset, featuresCount)));\n        offset += featuresCount * BYTES;\n    }\n    const normalizedTrainData = DG.DataFrame.fromColumns(dataCols);\n    let model = { kernelType: header[MODEL_KERNEL_INDEX],\n        kernelParams: kernelParams,\n        trainLabels: trainLabels,\n        means: means,\n        stdDevs: stdDevs,\n        modelParams: modelParams,\n        modelWeights: modelWeights,\n        normalizedTrainData: normalizedTrainData\n    };\n    return model;\n} // getUnpackedModel\n// Wrapper for combining the function \"predict\" with Datagrok predicitve tools\nexport function getPrediction(df, packedModel) {\n    return __awaiter(this, void 0, void 0, function* () {\n        let model = getUnpackedModel(new Uint8Array(packedModel));\n        let res = yield predict(model, df.columns);\n        res.name = PREDICTION;\n        return DG.DataFrame.fromColumns([res]);\n    });\n} // getPrediction\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};\n/* Do not change these import lines to match external modules in webpack configuration */\nimport * as grok from 'datagrok-api/grok';\nimport * as ui from 'datagrok-api/ui';\nimport * as DG from 'datagrok-api/dg';\nimport { DemoScript } from '@datagrok-libraries/tutorials/src/demo-script';\nimport { _initEDAAPI } from '../wasm/EDAAPI';\nimport { computePCA, computePLS } from './EDAtools';\nimport { renamePCAcolumns, addPLSvisualization, regressionCoefficientsBarChart, scoresScatterPlot, predictedVersusReferenceScatterPlot } from './EDAui';\nimport { carsDataframe, testDataForBinaryClassification } from './dataGenerators';\nimport { LINEAR, RBF, POLYNOMIAL, SIGMOID, getTrainedModel, getPrediction, showTrainReport, getPackedModel } from './svm';\nexport const _package = new DG.Package();\n//name: info\nexport function info() {\n    grok.shell.info(_package.webRoot);\n}\n//tags: init\nexport function init() {\n    return __awaiter(this, void 0, void 0, function* () {\n        yield _initEDAAPI();\n    });\n}\n//top-menu: Tools | Data Science | Principal Component Analysis...\n//name: PCA\n//description: Principal component analysis (PCA).\n//input: dataframe table\n//input: column_list features {type: numerical}\n//input: int components = 2\n//input: bool center = true\n//input: bool scale = true\n//output: dataframe result {action:join(table)}\nexport function PCA(table, features, components, center, scale) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return renamePCAcolumns(yield computePCA(table, features, components, center, scale));\n    });\n}\n//top-menu: ML | Multivariate Analysis (PLS)...\n//name: Multivariate Analysis (PLS)\n//description: Multidimensional data analysis using partial least squares (PLS) regression. It reduces the predictors to a smaller set of uncorrelated components and performs least squares regression on them.\n//input: dataframe table\n//input: column names\n//input: column_list features {type: numerical}\n//input: column predict {type: numerical}\n//input: int components = 3\nexport function PLS(table, names, features, predict, components) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const plsResults = yield computePLS(table, features, predict, components);\n        addPLSvisualization(table, names, features, predict, plsResults);\n    });\n}\n//name: MVA demo\n//description: Multidimensional data analysis using partial least squares (PLS) regression. It reduces the predictors to a smaller set of uncorrelated components and performs least squares regression on them.\n//meta.demoPath: Compute | Multivariate analysis\n//meta.isDemoScript: True\nexport function demoMultivariateAnalysis() {\n    return __awaiter(this, void 0, void 0, function* () {\n        const demoScript = new DemoScript('Partial least squares regression', 'Analysis of multidimensional data.');\n        const cars = carsDataframe();\n        const components = 3;\n        const names = cars.columns.byName('model');\n        const predict = cars.columns.byName('price');\n        const features = cars.columns.remove('price').remove('model');\n        const plsOutput = yield computePLS(cars, features, predict, components);\n        const sourceCars = carsDataframe();\n        sourceCars.name = 'Cars';\n        let view;\n        let dialog;\n        yield demoScript\n            .step('Data', () => __awaiter(this, void 0, void 0, function* () {\n            grok.shell.addTableView(sourceCars);\n            view = grok.shell.getTableView(sourceCars.name);\n        }), { description: 'Each car has many features - patterns extraction is complicated.', delay: 0 })\n            .step('Model', () => __awaiter(this, void 0, void 0, function* () {\n            dialog = ui.dialog({ title: 'Multivariate Analysis (PLS)' })\n                .add(ui.tableInput('Table', sourceCars))\n                .add(ui.columnsInput('Features', cars, features.toList, { available: undefined, checked: features.names() }))\n                .add(ui.columnInput('Names', cars, names, undefined))\n                .add(ui.columnInput('Predict', cars, predict, undefined))\n                .add(ui.intInput('Components', components, undefined))\n                .onOK(() => {\n                grok.shell.info('Multivariate analysis has been already performed.');\n            })\n                .show({ x: 400, y: 140 });\n        }), { description: 'Predict car price by its other features.', delay: 0 })\n            .step('Regression coeffcicients', () => __awaiter(this, void 0, void 0, function* () {\n            dialog.close();\n            view.addViewer(regressionCoefficientsBarChart(features, plsOutput[1]));\n        }), { description: 'The feature \"diesel\" affects the price the most.', delay: 0 })\n            .step('Scores', () => __awaiter(this, void 0, void 0, function* () { view.addViewer(scoresScatterPlot(names, plsOutput[2], plsOutput[3])); }), { description: 'Similarities & dissimilarities: alfaromeo and mercedes are different.', delay: 0 })\n            .step('Prediction', () => __awaiter(this, void 0, void 0, function* () { view.addViewer(predictedVersusReferenceScatterPlot(names, predict, plsOutput[0])); }), { description: 'Closer to the line means better price prediction.', delay: 0 })\n            .start();\n    });\n}\n//name: Generate linear separable dataset\n//description: Generates linear separble dataset for testing binary classificators.\n//input: string name = 'Data' {caption: name; category: Dataset}\n//input: int samplesCount = 1000 {caption: samples; category: Size}\n//input: int featuresCount = 2 {caption: features; category: Size}\n//input: double min = -39 {caption: min; category: Range}\n//input: double max = 173 {caption: max; category: Range}\n//input: double violatorsPercentage = 5 {caption: violators; units: %; category: Dataset}\n//output: dataframe df\nexport function testDataLinearSeparable(name, samplesCount, featuresCount, min, max, violatorsPercentage) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield testDataForBinaryClassification(LINEAR, [0, 0], name, samplesCount, featuresCount, min, max, violatorsPercentage);\n    });\n}\n//name: Generate linear non-separable dataset\n//description: Generates linear non-separble dataset for testing binary classificators.\n//input: string name = 'Data' {caption: name; category: Dataset}\n//input: double sigma = 90  {caption: sigma; category: Hyperparameters} [RBF-kernel paramater]\n//input: int samplesCount = 1000 {caption: samples; category: Size}\n//input: int featuresCount = 2 {caption: features; category: Size}\n//input: double min = -39 {caption: min; category: Range}\n//input: double max = 173 {caption: max; category: Range}\n//input: double violatorsPercentage = 5 {caption: violators; units: %; category: Dataset}\n//output: dataframe df\nexport function testDataLinearNonSeparable(name, sigma, samplesCount, featuresCount, min, max, violatorsPercentage) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield testDataForBinaryClassification(RBF, [sigma, 0], name, samplesCount, featuresCount, min, max, violatorsPercentage);\n    });\n}\n//name: trainLinearKernelSVM\n//meta.mlname: linear kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainLinearKernelSVM(df, predict_column, gamma, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: LINEAR }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n}\n//name: applyLinearKernelSVM\n//meta.mlname: linear kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applyLinearKernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n//name: trainRBFkernelSVM\n//meta.mlname: RBF-kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: double sigma = 1.5 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainRBFkernelSVM(df, predict_column, gamma, sigma, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: RBF, sigma: sigma }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n}\n//name: applyRBFkernelSVM\n//meta.mlname: RBF-kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applyRBFkernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n//name: trainPolynomialKernelSVM\n//meta.mlname: polynomial kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: double c = 1 {category: Hyperparameters}\n//input: double d = 2 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainPolynomialKernelSVM(df, predict_column, gamma, c, d, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: POLYNOMIAL, cParam: c, dParam: d }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n} // trainPolynomialKernelSVM\n//name: applyPolynomialKernelSVM\n//meta.mlname: polynomial kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applyPolynomialKernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n//name: trainSigmoidKernelSVM\n//meta.mlname: sigmoid kernel LS-SVM\n//meta.mlrole: train\n//input: dataframe df\n//input: string predict_column\n//input: double gamma = 1.0 {category: Hyperparameters}\n//input: double kappa = 1 {category: Hyperparameters}\n//input: double theta = 1 {category: Hyperparameters}\n//input: bool toShowReport = false {caption: to show report; category: Report}\n//output: dynamic model\nexport function trainSigmoidKernelSVM(df, predict_column, gamma, kappa, theta, toShowReport) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const trainedModel = yield getTrainedModel({ gamma: gamma, kernel: SIGMOID, kappa: kappa, theta: theta }, df, predict_column);\n        if (toShowReport)\n            showTrainReport(df, trainedModel);\n        return getPackedModel(trainedModel);\n    });\n} // trainSigmoidKernelSVM\n//name: applySigmoidKernelSVM\n//meta.mlname: sigmoid kernel LS-SVM\n//meta.mlrole: apply\n//input: dataframe df\n//input: dynamic model\n//output: dataframe table\nexport function applySigmoidKernelSVM(df, model) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return yield getPrediction(df, model);\n    });\n}\n"],"names":["__webpack_require__","exports","definition","key","o","Object","defineProperty","enumerable","get","chunkId","g","globalThis","this","Function","e","window","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","scriptUrl","importScripts","location","document","currentScript","src","scripts","getElementsByTagName","length","i","Error","replace","p","b","baseURI","self","href","grok","ui","DG","assure","delay","ms","thisArg","_arguments","generator","Promise","setTimeout","P","resolve","reject","fulfilled","step","next","rejected","result","done","then","apply","notNull","name","DemoScript","constructor","description","isAutomatic","options","_a","_isAutomatic","_autoStartFirstStep","_currentStep","_isStopped","_isCancelled","_isStepProcessed","_root","id","classes","_steps","_mainHeader","_header","_headerDiv","_stopStartBtn","_changeStopState","_restartBtn","_restartScript","_nextStepBtn","_nextStep","_activity","_progressDiv","_progress","_progressSteps","_closeBtn","_closeDock","autoStartFirstStep","max","currentObject","steps","stepNumber","_addHeader","_createHeaderDiv","_createProgressDiv","append","innerText","firstChild","className","_addDescription","instructionIndicator","instructionDiv","currentStepDescription","entry","_initRoot","_b","_c","scriptDockNode","Array","from","_node","parent","container","containerElement","firstElementChild","lastElementChild","classList","contains","remove","add","getElementsByClassName","entryIndicator","entryInstruction","currentStep","stepDelay","func","_scrollTo","offsetTop","offsetHeight","_countdown","newEntryIndicator","replaceWith","nextStepEntryIndicator","startNextStepIcon","_startScript","element","y","focus","scrollTop","indicator","time","countdownDiv","countdown","svg","_createSVGIndicator","prepend","interval","setInterval","clearInterval","createElementNS","circle","setAttributeNS","icon","_clearRoot","_setInitParams","start","cancelScript","Int32Array","Float32Array","Column","fromInt32Array","fromFloat32Array","NUM_TYPE","FLOAT_COLUMN_TYPE","INT_COLUMN_TYPE","FLOAT_COLUMNS_TYPE","NEW_FLOAT_COLUMNS_TYPE","INT_COLUMNS_TYPE","NEW_INT_COLUMNS_TYPE","NEW_FLOAT_COLUMN_TYPE","NEW_INT_COLUMN_TYPE","COLUMN","CALL_RESULT","NUM_OF_ROWS","NUM_OF_COLUMNS","REF","VALUE","TABLE_OF_COLUMNS","OBJECTS","INT_TYPE","DOUBLE_TYPE","argsSpecification","inputVals","ref","cppFuncInput","arg","type","data","array","col","getRawData","val","arrays","toList","push","val1","val2","funcSpecification","dataFromWebWorker","arguments","_callResult","callResult","funcSpecificationArgs","argsAfterWasmCall","typeToColumnCreatorMap","undefined","toString","names","column","columns","k","j","extractNewlyCreatedData","args","outPut","output","typeToDataFieldMap","source","DataFrame","fromColumns","arrayToReturn","getOutput","clearNewlyCreatedData","COMP_MIN","SAMPLES_COUNT_MIN","FEATURES_COUNT_MIN","PERCENTAGE_MIN","PERCENTAGE_MAX","MAX_ELEMENTS_COUNT","COMP_POSITVE_MES","COMP_EXCESS","INCORERRECT_MIN_MAX_MES","INCORERRECT_FEATURES_MES","INCORERRECT_SAMPLES_MES","INCORERRECT_PERCENTAGE_MES","DATAFRAME_IS_TOO_BIG_MES","checkComponenets","features","components","byIndex","computePLS","table","predict","_output","_promise","async","componentsCount","worker","Worker","URL","postMessage","EDA","onmessage","terminate","_partialLeastSquareRegressionInWebWorker","_result","_error","predictedVersusReferenceScatterPlot","samplesNames","reference","prediction","dfReferencePrediction","title","x","showRegressionLine","markerType","labels","regressionCoefficientsBarChart","regressionCoeffs","namesOfPredictors","predictorNamesColumn","dfRegrCoefs","split","valueAggrType","scoresScatterPlot","xScores","yScores","scoresColumns","scores","index","SVM_GEN_FEATURES_INDEX","SVM_GEN_LABELS_INDEX","SVM_FEATURE_NAME","SVM_LABEL_NAME","carsDataframe","testDataForBinaryClassification","kernel","kernelParams","samplesCount","featuresCount","min","violatorsPercentage","checkGeneratorSVMinputs","kernelParamsCol","_generateDatasetInWebWorker","df","LINEAR","POLYNOMIAL","RBF","SIGMOID","CONFUSION_MATR_SIZE","NORMALIZED_DATA_INDEX","MEANS_INDEX","STD_DEVS_INDEX","MODEL_PARAMS_INDEX","MODEL_WEIGHTS_INDEX","PREDICTED_LABELS_INDEX","CORRECTNESS_INDEX","CONFUSION_MATRIX_INDEX","TRUE_POSITIVE_INDEX","FALSE_NEGATIVE_INDEX","FALSE_POSITIVE_INDEX","TRUE_NEGATIVE_INDEX","RBF_SIGMA_INDEX","POLYNOMIAL_C_INDEX","POLYNOMIAL_D_INDEX","SIGMOID_KAPPA_INDEX","SIGMOID_THETA_INDEX","GAMMA_INFIMUM_LIMIT","RBF_SIGMA_INFIMUM_LIMIT","POLYNOMIAL_C_INFIMUM_LIMIT","POLYNOMIAL_D_INFIMUM_LIMIT","WRONG_GAMMA_MESSAGE","WRONG_RBF_SIGMA_MESSAGE","WRONG_POLYNOMIAL_C_MESSAGE","WRONG_POLYNOMIAL_D_MESSAGE","WRONG_KERNEL_MESSAGE","LABELS","PREDICTED","CORRECTNESS","CONFUSION_MATRIX_NAME","MEAN","STD_DEV","MODEL_PARAMS_NAME","MODEL_WEIGHTS_NAME","GAMMA","KERNEL","KERNEL_PARAMS","KERNEL_PARAM_1","KERNEL_PARAM_2","FEATURES_COUNT_NAME","TRAIN_SAMPLES_COUNT_NAME","TRAIN_ERROR","KERNEL_TYPE_TO_NAME_MAP","POSITIVE_NAME","NEGATIVE_NAME","PREDICTED_POSITIVE_NAME","PREDICTED_NEGATIVE_NAME","SENSITIVITY","SPECIFICITY","BALANCED_ACCURACY","POSITIVE_PREDICTIVE_VALUE","NEGATIVE_PREDICTIVE_VALUE","ML_REPORT","ML_REPORT_PREDICTED_LABELS","ML_REPORT_TRAIN_LABELS","ML_REPORT_CORRECTNESS","PREDICTION","BYTES","INTS_COUNT","KER_PARAMS_COUNT","MODEL_KERNEL_INDEX","SAMPLES_COUNT_INDEX","FEATURES_COUNT_INDEX","INIT_VALUE","LS_SVM_ADD_CONST","getTrainedModel","hyperparameters","predict_column","byName","dataset","gamma","sigma","cParam","dParam","checkHyperparameters","kernelParamsArray","kappa","theta","trainCols","modelParamsCount","precomputedWeightsCount","confusionMatrixElementsCount","_trainAndAnalyzeLSSVMInWebWorker","model","trainGamma","kernelType","trainLabels","normalizedTrainData","means","stdDevs","modelParams","modelWeights","predictedLabels","correctness","confusionMatrix","trainError","trainSamplesCount","TP","TN","FP","FN","N","TPR","TNR","PPV","NPV","ACC","BA","sensitivity","specificity","balancedAccuracy","positivePredicitveValue","negativePredicitveValue","evaluateAccuracy","trainAndAnalyzeModel","showTrainReport","dfView","addViewer","getModelInfo","color","getConfusionMatrixDF","getPackedModel","dataCols","Uint8Array","buffer","offset","ints","floats","set","getPrediction","packedModel","modelBytes","header","getUnpackedModel","res","normalizedData","precomputedWeights","targetData","_predictByLSSVMInWebWorker","_package","info","webRoot","init","initEDA","_initEDAAPI","PCA","center","scale","pcaTable","renamePCAcolumns","centerNum","scaleNum","_principalComponentAnalysisInWebWorker","computePCA","PLS","plsResults","plsOutput","view","xLoadings","loadingCols","loadingLabels","dfLoadings","loadingScatterPlot","addPLSvisualization","demoMultivariateAnalysis","demoScript","cars","sourceCars","dialog","available","checked","onOK","show","close","testDataLinearSeparable","testDataLinearNonSeparable","trainLinearKernelSVM","toShowReport","trainedModel","applyLinearKernelSVM","trainRBFkernelSVM","applyRBFkernelSVM","trainPolynomialKernelSVM","c","d","applyPolynomialKernelSVM","trainSigmoidKernelSVM","applySigmoidKernelSVM"],"sourceRoot":""}