diff --git a/package.json b/package.json index 6d4c46b..a1ff0fe 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "physics-simulation-engine", - "version": "2.2.0", + "version": "2.2.1", "description": "A Simulation Engine for Physics Simulation", "main": "./src/app.js", "scripts": { diff --git a/versions/2.2.1/pSEngine.min.js b/versions/2.2.1/pSEngine.min.js new file mode 100644 index 0000000..e19d425 --- /dev/null +++ b/versions/2.2.1/pSEngine.min.js @@ -0,0 +1,2 @@ +var pSEngine=function(t){var e={};function i(s){if(e[s])return e[s].exports;var n=e[s]={i:s,l:!1,exports:{}};return t[s].call(n.exports,n,n.exports,i),n.l=!0,n.exports}return i.m=t,i.c=e,i.d=function(t,e,s){i.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:s})},i.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var s=Object.create(null);if(i.r(s),Object.defineProperty(s,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var n in t)i.d(s,n,function(e){return t[e]}.bind(null,n));return s},i.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(e,"a",e),e},i.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},i.p="/",i(i.s=8)}([function(t,e,i){"use strict";i(1);class s{constructor(t,e,i,s="rgb(255, 255, 255)",n){this.x=t||0,this.y=e||0,this.z=i||0,this.color=s,this.setName(n)}set(t,e,i){return t instanceof s?(this.x=t.x||0,this.y=t.y||0,this.z=t.z||0,this):(this.x=t||0,this.y=t||0,this.z=t||0,this)}setName(t){return null==t||(t instanceof pSText?this.name=t:this.name=new pSText(t,new s(this.x,this.y,this.z))),this}equals(t,e,i){return t instanceof s?this.equals(t.x,t.y,t.z):this.x==t&&this.y==e&&this.z==i}copy(){return new s(this.x,this.y,this.z)}clear(){return this.set(0,0,0)}toString(){return`Vector Object : [${this.x}, ${this.y}, ${this.z}]`}add(t,e,i){return t instanceof s?this.add(t.x,t.y,t.z):(this.x+=t||0,this.y+=e||0,this.y+=i||0,this)}sub(t,e,i){return t instanceof s?this.sub(t.x,t.y,t.z):this.add(-t,-e,-i)}mult(t){return"number"==typeof t&&isFinite(t)?(this.x*=t,this.y*=t,this.z*=t,this):(console.warn("Vector::mult()","c is undefined or isn't a finite number"),this)}div(t){return"number"==typeof t&&isFinite(t)?0==t?(console.error("Cannot divide by 0"),this):this.mult(1/t):(console.warn("Vector::div()","c is undefined or isn't a finite number"),this)}static add(t,e){return t.copy().add(e)}static sub(t,e){return t.copy().sub(e)}static mult(t,e){return t.copy().mult(e)}static div(t,e){return t.copy().div(e)}dot(t,e,i){return t instanceof s?this.dot(t.x,t.y,t.z):this.x*(t||0)+this.y*(e||0)+this.z*(i||0)}cross(t){return new s(this.y*t.z-this.z*t.y,this.z*t.x-this.x*t.z,this.x*t.y-this.y*t.x)}normalize(){const t=this.mag();return 0!==t&&this.div(t),this}limit(t,e){let i=this.mag();return ie&&this.div(i).mult(e),this}mag(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}setMag(t){return this.normalize().mult(t)}rotate(t){const e=this.getAngle()+t,i=this.mag();return this.x=Math.cos(e)*i,this.y=Math.sin(e)*i,this}getAngle(){return Math.atan2(this.y,this.x)}static dist(t,e){return s.sub(t,e).mag()}static dot(t,e,i,s){return t.copy().dot(e,i,s)}static cross(t,e){return t.copy().cross(e)}static normalize(t){return t.copy().normalize()}static rotate(t,e){return t.copy().rotate(e)}draw(t,e,i){null!=t?s.draw(t,this,this.color,e,i):s.draw(void 0,this,this.color)}static draw(t,e,i="rgb(255, 255, 255)",s=5,n=1){(null!=t&&0!=t.z||0!=e.z)&&console.warn("Vector drawing is only implemented in 2D yet.");let r=_pSimulationInstance.plotter;if(push(),null!=t){let e=r.computeForXY(t.x,t.y);translate(e.x-width/2,e.y-height/2)}let o=r.computeForXY(0,0),a=r.computeForXY(e.x,e.y);if(push(),r.drawer.stroke(i).strokeWeight(n).fill(i),line(o.x,o.y,a.x,a.y),translate(a.x,a.y),rotate(a.sub(o).getAngle()),translate(-s-2,0),triangle(0,s/2,0,-s/2,s,0),pop(),null!=e.name){let t=e.getAngle();t<0&&(t+=2*PI);let o=.8*e.name.cWidth;(PI/4=3.0.0 in order to use Text and Tex strings."),this.textSize=i,this.color=s,this.pos=e,this.showHitbox=n,this.setText(t)}draw(){let t=_pSimulationInstance.plotter.drawer,e=t.plotter.computeForXY(this.pos.x,this.pos.y);if(push(),translate(-this.svgImg.width/2,-this.svgImg.height/2),image(this.svgImg,e.x,e.y,this.svgImg.width,this.svgImg.height),this.showHitbox){let i=this.svgImg.height,s=this.svgImg.width;t.stroke(this.color).strokeWeight(1).noFill(),line(e.x,e.y,e.x+s,e.y),line(e.x,e.y+i,e.x+s,e.y+i),line(e.x,e.y+i,e.x,e.y),line(e.x+s,e.y+i,e.x+s,e.y)}pop()}setText(t){this.text=t;let e="")[0]+"";return e=e.replace(/this.timeLength?this.finalDraw(this):(this.lastKey=t(e,this)/this.scaleTime,this.lastKey)}updateKey(){return this.getKey(this.update)}drawKey(){return this.getKey(this.draw)}update(){}draw(){}};var n=class extends s{constructor(t,e){super(t,e),this.i=-1,this.currentShape=this.nextShape(e),this.localDt=0}nextShape(t){this.i++;let e=this.i+1;return e>t.length-1&&(e=0),[t[this.i],t[e]]}update(t,e){}draw(t,e){let i=e.timeLength/e.datas.length;null!=e.currentShape[0]&&null!=e.currentShape[1]&&t-e.localDt>=i&&(e.currentShape=e.nextShape(e.datas),e.localDt+=i),e.drawCurrentShape(e.datas,(t,e,i,s)=>{let n=1;return t==i&&(n=e/s),n},e,e.i+1,t-e.localDt,i)}finalDraw(t){this.drawCurrentShape(this.datas,()=>1,this,this.datas.length,0)}drawCurrentShape(t,e,i,s,n,r){for(let o=0;o=t.length&&(a=0),_pSimulationInstance.plotter.drawer.noFill().strokeWeight(3).stroke(255).line(t[o].pos.x,t[o].pos.y,t[o].pos.x+(t[a].pos.x-t[o].pos.x)*s,t[o].pos.y+(t[a].pos.y-t[o].pos.y)*s)}}};var r=class extends s{constructor(t,e){super(t,e),null==this.datas.min&&(this.datas.min=0),null==this.datas.max&&(this.datas.max=1)}update(t,e){let i=t/e.timeLength;return i<.5?2*i*i*(e.datas.max-e.datas.min)+e.datas.min:((4-2*i)*i-1)*(e.datas.max-e.datas.min)+e.datas.min}draw(t,e){}finalDraw(t){return t.datas.max}};e.a=class{static new(t,e=1,i={}){switch(t||(t="easeInOutCubic"),t){case"easeInOutCubic":return new r(e,i);case"interpolation":return new n(e,i)}}}},function(t,e,i){"use strict";var s=i(4),n=i(5);e.a=class{constructor(){this.config={},this.beginTime=Date.now(),this.lastUpdateTime=Date.now(),this.lastDrawTime=Date.now(),this.config.engine=this.getDefaultEngineConfig(),this.config.custom={},window.getCustomConfig=this.getCustomConfig,window.getEngineConfig=this.getEngineConfig,this.dtMoy=this.config.engine.runner.rollbackControl.minimalUpdateFPS,this.dtTotal=0,this.dtCount=0}instanciate(){this.createP5Instance(),this.plotter=new s.a(this,new n.a),window.runSimulator(this)}createP5Instance(){let t=this.getCanvasProportions(this.config.engine.window.proportions);this.canvas=createCanvas(t.w,t.h),this.canvas.parent(this.config.engine.runner.divId);let e=this.config.engine.runner;e.UPDATE_FPS>=e.DRAW_FPS?frameRate(e.UPDATE_FPS):console.error("The Updates FPS must be superior as the Draws FPS."),window.draw=function(){let t=_pSimulationInstance,e=Date.now(),i=(e-t.lastUpdateTime)/1e3,s=t.dtMoy+t.dtMoy*t.config.engine.runner.rollbackControl.maxStandardDeviation;i>s&&(i=t.dtMoy),t.lastUpdateTime=e,t.plotter.update(i*t.config.engine.runner.simulationSpeed),e-t.lastDrawTime>=1/t.config.engine.runner.DRAW_FPS&&(i<=s&&(t.dtTotal+=i,t.dtCount+=1,t.dtCount%t.config.engine.runner.rollbackControl.averageTimeSample==0&&(t.dtMoy=t.dtTotal/t.dtCount,t.dtTotal=0,t.dtCount=0)),t.plotter.draw(),t.lastDrawTime=e)},window.windowResized=function(){let t=_pSimulationInstance.getCanvasProportions(_pSimulationInstance.config.engine.window.proportions);resizeCanvas(t.w,t.h)}}getCanvasProportions(t){let e,i;return t.isRelative?(e=windowWidth*t.width,i=windowHeight*t.height):(e=t.width+"px",i=t.height+"px"),{w:e,h:i}}addObjects(t,e=1,...i){if(t instanceof Function)for(let s=0;s{"loading"===document.readyState?t():window.addEventListener("load",t,!1)}).then(()=>{new n})}]); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://pSEngine/webpack/bootstrap","webpack://pSEngine/./src/utilities/Vector.js","webpack://pSEngine/./src/drawer/objects/Text.js","webpack://pSEngine/./src/drawer/animations/pSAnimationHandler.js","webpack://pSEngine/./src/drawer/animations/pSInterpolation.js","webpack://pSEngine/./src/drawer/animations/pSEaseInOutCubic.js","webpack://pSEngine/./src/drawer/Animation.js","webpack://pSEngine/./src/core/Simulator.js","webpack://pSEngine/./src/drawer/Plotter.js","webpack://pSEngine/./src/drawer/Drawer.js","webpack://pSEngine/./src/drawer/objects/Point.js","webpack://pSEngine/./src/drawer/objects/Triangle.js","webpack://pSEngine/./src/app.js","webpack://pSEngine/(webpack)/buildin/global.js","webpack://pSEngine/./src/core/main.js","webpack://pSEngine/./src/core/init.js"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","Vector","x","y","z","color","this","setName","undefined","pSText","equals","set","add","sub","isFinite","console","warn","error","mult","v1","v2","copy","div","dot","v","vLen","mag","min","max","Math","sqrt","normalize","angle","newAngle","getAngle","magnitude","cos","sin","atan2","cross","rotate","initialPos","headSize","strokeWeight","draw","pointingPos","strokeW","plotter","_pSimulationInstance","push","computeForXY","translate","width","height","zzPosition","endPos","drawer","stroke","fill","line","triangle","pop","PI","xOffset","cWidth","yOffset","desc","asc","setColor","setPosition","setOffset","arrowOrPos","text","pos","textSize","showHitbox","window","MathJax","setText","svgImg","image","h","w","noFill","svg","tex2svg","display","em","ex","containerWidth","lineWidth","scale","innerHTML","split","replace","parseFloat","exec","loadImage","URL","createObjectURL","Blob","type","timeLength","datas","scaleTime","isAnimating","initialT","lastKey","getKey","update","Date","getTime","f","dt","finalDraw","super","currentShape","nextShape","localDt","points","j","length","th","drawCurrentShape","lt","ti","percent","percentFunction","maxI","time","animationName","config","beginTime","now","lastUpdateTime","lastDrawTime","engine","getDefaultEngineConfig","custom","getCustomConfig","getEngineConfig","dtMoy","runner","rollbackControl","minimalUpdateFPS","dtTotal","dtCount","createP5Instance","runSimulator","getCanvasProportions","proportions","canvas","createCanvas","parent","divId","ru","UPDATE_FPS","DRAW_FPS","frameRate","currentTime","critiqDt","maxStandardDeviation","simulationSpeed","averageTimeSample","windowResized","resizeCanvas","cP","isRelative","windowWidth","windowHeight","customObject","number","params","Function","copyParamsTemp","Array","addingObjectsConfigKeyWords","runFunctions","slice","runClass","objectsL","squareByX","offset","backgroundColor","g","b","gridColor","a","displayGrid","configFunc","simulator","plConf","bg","background","centerPos","noStroke","ellipse","xRel","yRel","point","x0","y0","x1","y1","v0","rx","ry","rect","TYPE","beginShape","endShape","vertex","pointName","pointSize","vectorName","drawOriginVector","pointSizeDrawing","textPadding","parseInt","p0","p1","p2","fillColor","strokeColor","setCoordinates","pG","global","pSPoint","pSTriangle","pSAnimation","e","p5","setup","instanciate","pSEngine","getPSEngineVar","Promise","resolve","reject","document","readyState","addEventListener","then"],"mappings":"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","file":"pSEngine.min.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 8);\n","import './../drawer/objects/Text';\r\n\r\n/**\r\n* A class for every 3D Vectors.\r\n* <br/>Please note that current vector may only be used in <b>2D</b>.\r\n*/\r\nclass Vector {\r\n    /**\r\n    * Creates a new Vector (each coordinate gets a 0 if value not provided)\r\n    * @param x X coordinate\r\n    * @param y Y coordinate\r\n    * @param color Color of the Vector 'rgba(R, G, B, A)'\r\n    * @param name Name of the Vector to be potentially displayed (@see draw method)\r\n    * @return this\r\n    */\r\n    constructor(x, y, z, color = 'rgb(255, 255, 255)', name) {\r\n        this.x    = x || 0;\r\n        this.y    = y || 0;\r\n        this.z    = z || 0;\r\n\r\n        this.color = color;\r\n\r\n        this.setName(name);\r\n    }\r\n\r\n\r\n\r\n    /* ========= BASIC VECTOR METHODS ========= */\r\n    /**\r\n    * Set x, y, z coordinates (each coordinate gets a 0 if value not provided)\r\n    * @param x New X coordinate OR a Vector x to be equal to\r\n    * @param y New Y coordinate\r\n    * @param z New Z coordinate\r\n    * @return this\r\n    */\r\n    set(x, y, z) {\r\n        if(x instanceof Vector) {\r\n            this.x = x.x || 0;\r\n            this.y = x.y || 0;\r\n            this.z = x.z || 0;\r\n            return this;\r\n        }\r\n\r\n        this.x = x || 0;\r\n        this.y = x || 0;\r\n        this.z = x || 0;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Set vector name\r\n    * @param name New name of the Vector\r\n    * @return this\r\n    */\r\n    setName(name) {\r\n        if(name == undefined)\r\n            return this;\r\n\r\n        if(name instanceof pSText)\r\n            this.name = name;\r\n        else\r\n            this.name = new pSText(name, new Vector(this.x, this.y, this.z));\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Check if two vectors or pair of coordinates are equal\r\n    * @param x X coordinate OR a Vector x for egality checking\r\n    * @param y Y coordinate\r\n    * @param z Z coordinate\r\n    * @return true if equal\r\n    */\r\n    equals(x, y, z) {\r\n        if(x instanceof Vector)\r\n            return this.equals(x.x, x.y, x.z);\r\n\r\n        return (this.x == x) && (this.y == y) && (this.z == z);\r\n    }\r\n\r\n    /** @return a copy of the current Vector */\r\n    copy() { return new Vector(this.x, this.y, this.z); }\r\n\r\n    /** @return this Vector with coordinates set to (0, 0, 0) */\r\n    clear() { return this.set(0, 0, 0); }\r\n\r\n    /** @return A String representation of the object */\r\n    toString() { return `Vector Object : [${this.x}, ${this.y}, ${this.z}]`; }\r\n    /* ======================================== */\r\n\r\n\r\n\r\n\r\n\r\n    /* ========= BASIC VECTOR OPERATIONS ========= */\r\n    /**\r\n    * Add two vectors or pair of coordinates together\r\n    * @param x X coordinate OR a Vector x\r\n    * @param y Y coordinate\r\n    * @param z Z coordinate\r\n    * @return this\r\n    */\r\n    add(x, y, z) {\r\n        if(x instanceof Vector)\r\n            return this.add(x.x, x.y, x.z);\r\n\r\n        this.x += x || 0;\r\n        this.y += y || 0;\r\n        this.y += z || 0;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Sustract two vectors or pair of coordinates together\r\n    * @param x X coordinate OR a Vector x\r\n    * @param y Y coordinate\r\n    * @param z Z coordinate\r\n    * @return this\r\n    */\r\n    sub(x, y, z) {\r\n        if(x instanceof Vector)\r\n            return this.sub(x.x, x.y, x.z);\r\n\r\n        return this.add(-x, -y, -z);\r\n    }\r\n\r\n    /**\r\n    * Multiply this Vector by a scalar\r\n    * @param c The multiplication scalar\r\n    * @return this\r\n    */\r\n    mult(c) {\r\n        if(!(typeof c === 'number') || !isFinite(c)) {\r\n            console.warn(\r\n                'Vector::mult()',\r\n                'c is undefined or isn\\'t a finite number'\r\n            );\r\n            return this;\r\n        }\r\n\r\n        this.x *= c;\r\n        this.y *= c;\r\n        this.z *= c;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Divides this Vector by a scalar\r\n    * @param c The division scalar\r\n    * @return this\r\n    */\r\n    div(c) {\r\n        if(!(typeof c === 'number') || !isFinite(c)) {\r\n            console.warn(\r\n                'Vector::div()',\r\n                'c is undefined or isn\\'t a finite number'\r\n            );\r\n            return this;\r\n        }\r\n        if(c == 0) {\r\n            console.error('Cannot divide by 0');\r\n            return this;\r\n        }\r\n\r\n        return this.mult(1 / c);\r\n    }\r\n\r\n\r\n\r\n    // Static methods\r\n    /**\r\n    * Add two vectors together\r\n    * @param v1 The first vector\r\n    * @param v2 The second vector\r\n    * @return A new Vector\r\n    */\r\n    static add(v1, v2) { return (v1.copy()).add(v2); }\r\n\r\n    /**\r\n    * Subtract two vectors together\r\n    * @param v1 The first vector\r\n    * @param v2 The second vector\r\n    * @return A new Vector\r\n    */\r\n    static sub(v1, v2) { return (v1.copy()).sub(v2); }\r\n\r\n    /**\r\n    * Multiply a vector by a scalar\r\n    * @param v1 The vector\r\n    * @param c A scalar c\r\n    * @return A new multiplied Vector\r\n    */\r\n    static mult(v1, c) { return (v1.copy()).mult(c); }\r\n\r\n    /**\r\n    * Divides two vectors together\r\n    * @param v1 The vector\r\n    * @param c A scalar c\r\n    * @return A new divided Vector\r\n    */\r\n    static div (v1, c) { return (v1.copy()).div(c); }\r\n    /* =========================================== */\r\n\r\n\r\n\r\n\r\n\r\n    /* ========= ADVANCED MATH VECTOR OPERATIONS ========= */\r\n    // Dot and cross products\r\n    /**\r\n    * Dot product between a Vector OR a pair of coordinates\r\n    * @param x X coordinate OR a Vector x\r\n    * @param y Y coordinate\r\n    * @param z Z coordinate\r\n    * @return this\r\n    */\r\n    dot(x, y, z) {\r\n        if(x instanceof Vector)\r\n            return this.dot(x.x, x.y, x.z);\r\n\r\n        return this.x * (x || 0) + this.y * (y || 0) + this.z * (z || 0);\r\n    }\r\n\r\n    /**\r\n    * Cross product with a Vector\r\n    * @param v The vector\r\n    * @return this\r\n    */\r\n    cross(v) {\r\n        return new Vector(\r\n            this.y * v.z - this.z * v.y,\r\n            this.z * v.x - this.x * v.z,\r\n            this.x * v.y - this.y * v.x\r\n        );\r\n    }\r\n\r\n\r\n\r\n    // Magnitude\r\n    /** @return the normalized Vector */\r\n    normalize() {\r\n        const vLen = this.mag();\r\n        if (vLen !== 0)\r\n            this.div(vLen);\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Limit the magnitude of the vector between a min and a max value\r\n    * @param min Minimum value of the Vector magnitude\r\n    * @param max Maximum value of the Vector magnitude\r\n    * @return this\r\n    */\r\n    limit(min, max) {\r\n    \tlet m = this.mag();\r\n    \tif(m < min)\r\n    \t\tthis.div(m).mult(min);\r\n    \tif(m > max)\r\n    \t\tthis.div(m).mult(max);\r\n    \treturn this;\r\n    }\r\n\r\n    /** @return the magnitude of this vector */\r\n    mag() { return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z); }\r\n\r\n    /**\r\n    * Set the magnitude of this vector\r\n    * @param mag The new magnitude\r\n    * @return this\r\n    */\r\n    setMag(mag) { return this.normalize().mult(mag); }\r\n\r\n\r\n\r\n    // Angles\r\n    /**\r\n    * Rotate this vector by an angle on the XY plane\r\n    * @param angle An angle IN RADIANS\r\n    * @return this\r\n    */\r\n    rotate(angle) {\r\n        const newAngle  = this.getAngle() + angle;\r\n        const magnitude = this.mag();\r\n\r\n        this.x = Math.cos(newAngle) * magnitude;\r\n        this.y = Math.sin(newAngle) * magnitude;\r\n\r\n        return this;\r\n    }\r\n\r\n    /** @return the angle between this vector and the origin */\r\n    getAngle() { return Math.atan2(this.y, this.x); }\r\n\r\n\r\n\r\n    // Static methods\r\n    /**\r\n    * Distance bewteen two vectors\r\n    * @param v1 The first vector\r\n    * @param v2 The second vector\r\n    * @return the distance between the two positions where the arrow are pointing to\r\n    */\r\n    static dist(v1, v2) { return Vector.sub(v1, v2).mag(); }\r\n\r\n    /**\r\n    * Dot product between a Vector OR a pair of coordinates\r\n    * @param v1 The first vector\r\n    * @param x X coordinate OR a Vector x\r\n    * @param y Y coordinate\r\n    * @param z Z coordinate\r\n    * @return the dotted new vector\r\n    */\r\n    static dot(v1, x, y, z) { return (v1.copy()).dot(x, y, z); }\r\n\r\n    /**\r\n    * Cross product with a Vector\r\n    * @param v1 The first vector\r\n    * @param v2 The second vector\r\n    * @return the crossed new vector\r\n    */\r\n    static cross(v1, v2) { return (v1.copy()).cross(v2); }\r\n\r\n    /** @return the normalized Vector */\r\n    static normalize(v1) { return (v1.copy()).normalize(); }\r\n\r\n    /**\r\n    * Rotate a vector by an angle\r\n    * @param v1 The vector to be rotated\r\n    * @param angle An angle IN RADIANS\r\n    * @return the rotated vector\r\n    */\r\n    static rotate (v1, angle) { return (v1.copy()).rotate(angle); }\r\n    /* =================================================== */\r\n\r\n\r\n\r\n\r\n\r\n    /* ========= DRAWING VECTORS ========= */\r\n    /**\r\n    * Draw a vector to the canvas using the `Drawer` class\r\n    * @param initialPos The beginning position of the Vector Arrow\r\n    * @param headSize Size of the head in pixels (default = 5 px)\r\n    * @param strokeWeight Stroke weight of the Vector in pixels (default = 1 px)\r\n    */\r\n    draw(initialPos, headSize, strokeWeight) {\r\n        if(initialPos != undefined)\r\n            Vector.draw(initialPos, this, this.color, headSize, strokeWeight);\r\n        else\r\n            Vector.draw(undefined , this, this.color);\r\n    }\r\n\r\n    /**\r\n    * (Please avoid directly using this method)\r\n    * Draw a vector to the canvas using the `Drawer` class\r\n    * @param initialPos The beginning position of the Vector Arrow\r\n    * @param initialPos The ending position of the Vector Arrow\r\n    * @param color Color of the arrow (default `rgb(255, 255, 255)`)\r\n    * @param headSize Size of the head in pixels (default = 5 px)\r\n    * @param strokeWeight Stroke weight of the Vector in pixels (default = 1 px)\r\n    */\r\n    static draw(initialPos, pointingPos, color = 'rgb(255, 255, 255)', headSize = 5, strokeW = 1) {\r\n        if((initialPos != undefined && initialPos.z != 0) || pointingPos.z != 0)\r\n            console.warn(\"Vector drawing is only implemented in 2D yet.\");\r\n\r\n        let plotter = _pSimulationInstance.plotter;\r\n\r\n        push();\r\n            // DRAW VECTOR\r\n            if(initialPos != undefined) {\r\n                let p = plotter.computeForXY(initialPos.x, initialPos.y);\r\n                translate(p.x - width / 2, p.y - height / 2);\r\n            }\r\n\r\n            let zzPosition = plotter.computeForXY(0, 0);\r\n            let endPos     = plotter.computeForXY(pointingPos.x, pointingPos.y);\r\n\r\n            push();\r\n                plotter.drawer\r\n                    .stroke(color)\r\n                    .strokeWeight(strokeW)\r\n                    .fill(color);\r\n\r\n                line(zzPosition.x, zzPosition.y, endPos.x, endPos.y);\r\n                translate(endPos.x, endPos.y);\r\n\r\n                rotate(endPos.sub(zzPosition).getAngle());\r\n                translate(-headSize - 2, 0);\r\n                triangle(0, headSize / 2, 0, -headSize / 2, headSize, 0);\r\n        \tpop();\r\n\r\n\r\n            // DRAW VECTOR NAME\r\n            if(pointingPos.name != undefined) {\r\n                // Offset of the text based on the angle on the unit circle\r\n                let angle = pointingPos.getAngle();\r\n                if(angle < 0)\r\n                    angle += 2*PI;\r\n\r\n                let xOffset = 0.8 * pointingPos.name.cWidth;\r\n                if(    (PI/4   < angle && angle <= PI/2  )\r\n                    || (3*PI/4 < angle && angle <= 5*PI/4)\r\n                    || (3*PI/2 < angle && angle <= 7*PI/4)\r\n                ) xOffset *= -1;\r\n\r\n                let yOffset = -1.1 * pointingPos.name.desc + 1.1 * pointingPos.name.asc;\r\n                if(    (PI/4   < angle && angle <=   PI/2)\r\n                    || (PI/2   < angle && angle <= 3*PI/4)\r\n                    || (PI     < angle && angle <= 5*PI/4)\r\n                    || (7*PI/4 < angle && angle <=   2*PI)\r\n                ) yOffset *= -1;\r\n\r\n                pointingPos.name\r\n                    .setColor(color)\r\n                    .setPosition(pointingPos.x / 2, pointingPos.y / 2)\r\n                    .setOffset(xOffset, yOffset)\r\n                    .draw(plotter.drawer);\r\n\r\n\r\n                // ARROW ON TOP\r\n                let arrowOrPos = plotter.computeForXY(pointingPos.x / 2, pointingPos.y / 2);\r\n                plotter.drawer\r\n                    .stroke(color)\r\n                    .strokeWeight(strokeW)\r\n                    .fill(color);\r\n\r\n                translate(\r\n                    arrowOrPos.x + xOffset - pointingPos.name.cWidth / 2,\r\n                    arrowOrPos.y + yOffset - pointingPos.name.asc\r\n                );\r\n                line(0, 0, pointingPos.name.cWidth, 0);\r\n\r\n                // Triangle\r\n                push();\r\n                    translate(headSize + pointingPos.name.cWidth / 1.5, 0);\r\n                    triangle(0, headSize / 4, 0, -headSize / 4, headSize / 2, 0);\r\n                pop();\r\n            }\r\n        pop();\r\n\r\n        return this;\r\n    }\r\n    /* =================================== */\r\n}\r\n\r\nexport default Vector;\r\n","class pSText {\r\n    /**\r\n    * @param text LaTeX code (insert '\\text{TEXT}' for plain text)\r\n    * @param pos text position (default (0, 0))\r\n    * @param textSize text size multiplier (default 1)\r\n    * @param color text color (default white)\r\n    * @param showHitbox true : show text hitbox (default : false)\r\n    */\r\n    constructor(text, pos = new Vector(), textSize = 1, color = \"#FFFFFF\", showHitbox = false) {\r\n        if(window.MathJax == undefined)\r\n\t\t\tconsole.error('You must import MathJax.js >=3.0.0 in order to use Text and Tex strings.');\r\n\r\n        this.textSize   = textSize;\r\n        this.color      = color;\r\n        this.pos        = pos;\r\n        this.showHitbox = showHitbox;\r\n\r\n        this.setText(text);\r\n    }\r\n\r\n    /**\r\n    * Draw the text to the screen\r\n    */\r\n    draw() {\r\n        let drawer = _pSimulationInstance.plotter.drawer;\r\n        let pos    = drawer.plotter.computeForXY(this.pos.x, this.pos.y);\r\n\r\n        push();\r\n            translate(-this.svgImg.width / 2, -this.svgImg.height / 2);\r\n\r\n            image(this.svgImg, pos.x, pos.y, this.svgImg.width, this.svgImg.height);\r\n\r\n            if(this.showHitbox) {\r\n                let h = this.svgImg.height;\r\n                let w = this.svgImg.width;\r\n\r\n                drawer\r\n                    .stroke(this.color)\r\n                    .strokeWeight(1)\r\n                    .noFill();\r\n                line(pos.x    , pos.y    , pos.x + w, pos.y    );\r\n                line(pos.x    , pos.y + h, pos.x + w, pos.y + h);\r\n                line(pos.x    , pos.y + h, pos.x    , pos.y    );\r\n                line(pos.x + w, pos.y + h, pos.x + w, pos.y    );\r\n            }\r\n        pop();\r\n    }\r\n\r\n    /**\r\n    * Change text value\r\n    */\r\n    setText(text) {\r\n        this.text = text;\r\n\r\n        let svg = '<svg' + MathJax.tex2svg(this.text,\r\n            { display : true, em : 12, ex : 6, containerWidth : 80 * 6, lineWidth : 100000, scale : 1 }\r\n        ).innerHTML.split('<svg')[1].split('</svg>')[0] + '</svg>';\r\n\r\n        svg = svg\r\n            .replace(/<g/g           , '<g color=\"' + this.color + '\"')\r\n            .replace(/width=\"(.*?)\"/ , 'width=\"'  + parseFloat(/width=\"(.*?)\"/ .exec(svg)[1].split('ex')[0]) * this.textSize + 'ex\"')\r\n            .replace(/height=\"(.*?)\"/, 'height=\"' + parseFloat(/height=\"(.*?)\"/.exec(svg)[1].split('ex')[0]) * this.textSize + 'ex\"');\r\n\r\n        this.svgImg = loadImage(URL.createObjectURL(new Blob([svg], { type: 'image/svg+xml' })));\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Changes text position\r\n    * @param x new X position\r\n    * @param y new Y position\r\n    */\r\n    setPosition(x, y) {\r\n        this.pos.x = x;\r\n        this.pos.y = y;\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Changes text color\r\n    * @param color New color\r\n    */\r\n    setColor(color) {\r\n        this.color = color;\r\n        return this;\r\n    }\r\n}\r\n\r\nexport default pSText;\r\n","class pSAnimationHandler {\r\n    /**\r\n    * Creates a new abstract animation\r\n    * @param timeLength Length of the animation in seconds\r\n    * @param datas Custom animation datas\r\n    */\r\n    constructor(timeLength, datas) {\r\n        this.scaleTime   = 1;\r\n        this.isAnimating = false;\r\n        this.initialT    = 0;\r\n        this.datas       = datas;\r\n        this.timeLength  = timeLength;\r\n        this.lastKey     = this.getKey(this.update) / this.scaleTime;\r\n    }\r\n\r\n    /** Start (or restart) the current animation */\r\n    start() {\r\n        this.isAnimating = true;\r\n        this.initialT    = (new Date()).getTime() / 1000;\r\n    }\r\n\r\n    /** Stop the current animation */\r\n    stop() {\r\n        this.isAnimating = false;\r\n        this.initialT    = 0;\r\n    }\r\n\r\n    /**\r\n    * @param f Current drawing animation function\r\n    * @return f(dt)\r\n    */\r\n    getKey(f) {\r\n        let dt = (new Date()).getTime() / 1000 - this.initialT;\r\n\r\n        if(dt > this.timeLength)\r\n            return this.finalDraw(this);\r\n\r\n        this.lastKey = f(dt, this) / this.scaleTime;\r\n\r\n        return this.lastKey;\r\n    }\r\n\r\n    /** @return the current update key */\r\n    updateKey() { return this.getKey(this.update); }\r\n    /** @return the current draw key */\r\n    drawKey  () { return this.getKey(this.draw  ); }\r\n\r\n    /** Update loop for overwriting */\r\n    update() {}\r\n    /** Draw loop for overwriting */\r\n    draw  () {}\r\n}\r\n\r\nexport default pSAnimationHandler;\r\n","import pSAnimationHandler from './pSAnimationHandler';\r\n\r\nclass pSInterpolation extends pSAnimationHandler {\r\n    /**\r\n    * Interpolation animation\r\n    * @param timeLength Duration of the animation in seconds\r\n    * @param datas The datas to be interpolated '[Point1, Point2, ...]'\r\n    */\r\n    constructor(timeLength, datas) {\r\n        super(timeLength, datas);\r\n\r\n        this.i = -1;\r\n        this.currentShape = this.nextShape(datas);\r\n\r\n        this.localDt = 0;\r\n    }\r\n\r\n    /** Set shape based on animation and points */\r\n    nextShape(points) {\r\n        this.i++;\r\n\r\n        let j = this.i + 1;\r\n        if(j > points.length - 1)\r\n            j = 0;\r\n\r\n        return [points[this.i], points[j]];\r\n    }\r\n\r\n    /**\r\n    * @param time Current time of the animation\r\n    * @param th current pSEaseInOutCubic instance\r\n    * @return the corresponding update key\r\n    */\r\n    update(dt, th) { }\r\n\r\n    /**\r\n    * @param time Current time of the animation\r\n    * @param th current pSEaseInOutCubic instance\r\n    * @return the corresponding draw key\r\n    */\r\n    draw(dt, th) {\r\n        let c = th.timeLength / th.datas.length;\r\n        if(!(th.currentShape[0] == undefined || th.currentShape[1] == undefined)) {\r\n            if(dt - th.localDt >= c) {\r\n                th.currentShape = th.nextShape(th.datas);\r\n                th.localDt += c;\r\n            }\r\n        }\r\n\r\n        th.drawCurrentShape(\r\n            th.datas,\r\n            (i, lt, ti, c) => {\r\n                let percent = 1;\r\n                if(i == ti)\r\n                    percent = lt / c;\r\n                return percent;\r\n            }, th, th.i + 1, dt - th.localDt, c);\r\n    }\r\n\r\n    /**\r\n    * Draw the final animation\r\n    * @param th current pSEaseInOutCubic instance\r\n    */\r\n    finalDraw(th) {\r\n        this.drawCurrentShape(this.datas, () => 1, this, this.datas.length, 0);\r\n    }\r\n\r\n    /**\r\n    * Draw current shape on screen\r\n    * @param d this.datas\r\n    * @param percentFunction Current animation get percent function\r\n    * @param th current pSEaseInOutCubic instance\r\n    * @param maxI Max points count\r\n    * @param lt Current time value\r\n    * @param c Final time value / max points count\r\n    */\r\n    drawCurrentShape(d, percentFunction, th, maxI, lt, c) {\r\n        for (let i = 0; i < maxI; i++) {\r\n            let percent = percentFunction(i, lt, th.i, c);\r\n\r\n            let n = i + 1;\r\n            if(n >= d.length) n = 0;\r\n\r\n            _pSimulationInstance.plotter.drawer\r\n                .noFill()\r\n                .strokeWeight(3)\r\n                .stroke(255)\r\n                .line(\r\n                    d[i].pos.x,\r\n                    d[i].pos.y,\r\n                    d[i].pos.x + (d[n].pos.x - d[i].pos.x) * percent,\r\n                    d[i].pos.y + (d[n].pos.y - d[i].pos.y) * percent\r\n                );\r\n        }\r\n    }\r\n}\r\n\r\nexport default pSInterpolation;\r\n","import pSAnimationHandler from './pSAnimationHandler';\r\n\r\nclass pSEaseInOutCubic extends pSAnimationHandler {\r\n    /**\r\n    * Ease in and out cubic animation\r\n    * @param timeLength Duration of the animation in seconds\r\n    * @param datas Minimum and maximum values '{ min : 0, max : 1 }'\r\n    */\r\n    constructor(timeLength, datas) {\r\n        super(timeLength, datas);\r\n\r\n        if(this.datas.min == undefined)\r\n            this.datas.min = 0;\r\n        if(this.datas.max == undefined)\r\n            this.datas.max = 1;\r\n    }\r\n\r\n    /**\r\n    * @param time Current time of the animation\r\n    * @param th current pSEaseInOutCubic instance\r\n    * @return the corresponding key\r\n    */\r\n    update(time, th) {\r\n        let t = time / th.timeLength;\r\n        if(t < 0.5)\r\n            return (2 * t * t) * (th.datas.max - th.datas.min) + th.datas.min;\r\n        return (-1 + (4 - 2 * t) * t) * (th.datas.max - th.datas.min) + th.datas.min;\r\n    }\r\n\r\n    /**\r\n    * @param time Current time of the animation\r\n    * @param th current pSEaseInOutCubic instance\r\n    * @return the corresponding draw key\r\n    */\r\n    draw(dt, t) { }\r\n\r\n    /**\r\n    * Draw the final animation\r\n    * @param th current pSEaseInOutCubic instance\r\n    */\r\n    finalDraw(th) {\r\n        return th.datas.max;\r\n    }\r\n}\r\n\r\nexport default pSEaseInOutCubic;\r\n","import pSInterpolation  from './animations/pSInterpolation';\r\nimport pSEaseInOutCubic from './animations/pSEaseInOutCubic';\r\n\r\nclass Animation {\r\n    /**\r\n    * Creates a new animation\r\n    * @param animationName Name of the animation ('easeInOutCubic', 'interpolation')\r\n    * @param timeLength Length of the animation in seconds (default : 1)\r\n    * @param datas Optional parameter (see specific animation for animation informations)\r\n    */\r\n    static new(animationName, timeLength = 1, datas = {}) {\r\n        if(!animationName)\r\n            animationName = 'easeInOutCubic';\r\n\r\n        switch (animationName) {\r\n            case 'easeInOutCubic':\r\n                return new pSEaseInOutCubic(timeLength, datas);\r\n                break;\r\n\r\n            case 'interpolation':\r\n                return new pSInterpolation(timeLength, datas);\r\n        }\r\n    }\r\n}\r\n\r\nexport default Animation;\r\n","import pSPlotter from './../drawer/Plotter';\r\nimport pSDrawer  from './../drawer/Drawer';\r\n\r\nclass pSimulator {\r\n    constructor() {\r\n        this.config         = {};\r\n        this.beginTime      = Date.now();\r\n        this.lastUpdateTime = Date.now();\r\n        this.lastDrawTime   = Date.now();\r\n\r\n        this.config.engine  = this.getDefaultEngineConfig();\r\n        this.config.custom  = {};\r\n\r\n        window.getCustomConfig = this.getCustomConfig;\r\n        window.getEngineConfig = this.getEngineConfig;\r\n\r\n        this.dtMoy         = this.config.engine.runner.rollbackControl.minimalUpdateFPS;\r\n        this.dtTotal       = 0;\r\n        this.dtCount       = 0;\r\n    }\r\n\r\n\r\n    /** Instanciate the pSimulator */\r\n    instanciate() {\r\n        this.createP5Instance();\r\n        this.plotter = new pSPlotter(this, new pSDrawer());\r\n\r\n        window.runSimulator(this); // start is the main function\r\n    }\r\n\r\n\r\n\r\n    /** Creates a new p5 instance and creates loops for the simulation */\r\n    createP5Instance() {\r\n        let p       = this.getCanvasProportions(this.config.engine.window.proportions);\r\n        this.canvas = createCanvas(p.w, p.h);\r\n        this.canvas.parent(this.config.engine.runner.divId);\r\n\r\n        let ru = this.config.engine.runner;\r\n        if(ru.UPDATE_FPS >= ru.DRAW_FPS) frameRate(ru.UPDATE_FPS);\r\n        else console.error('The Updates FPS must be superior as the Draws FPS.')\r\n\r\n\r\n        // runs every time it's possible\r\n        window.draw = function() {\r\n            let s            = _pSimulationInstance;\r\n        \tlet currentTime  = Date.now();\r\n        \tlet dt           = (currentTime - s.lastUpdateTime) / 1000;\r\n            let critiqDt     = s.dtMoy + s.dtMoy * s.config.engine.runner.rollbackControl.maxStandardDeviation;\r\n\r\n            if(dt > critiqDt)\r\n                dt = s.dtMoy;\r\n\r\n        \ts.lastUpdateTime = currentTime;\r\n        \ts.plotter.update(dt * s.config.engine.runner.simulationSpeed);\r\n\r\n            if(currentTime - s.lastDrawTime >= 1 / s.config.engine.runner.DRAW_FPS) {\r\n                if(dt <= critiqDt) {\r\n                    s.dtTotal += dt;\r\n                    s.dtCount += 1;\r\n                    if(s.dtCount % s.config.engine.runner.rollbackControl.averageTimeSample == 0) {\r\n                        s.dtMoy   = s.dtTotal / s.dtCount;\r\n                        s.dtTotal = 0;\r\n                        s.dtCount = 0;\r\n                    }\r\n                }\r\n\r\n                s.plotter.draw();\r\n                s.lastDrawTime = currentTime;\r\n            }\r\n        };\r\n\r\n        // runs every time the window is resized\r\n        window.windowResized = function() {\r\n            let p = _pSimulationInstance.getCanvasProportions(_pSimulationInstance.config.engine.window.proportions);\r\n            resizeCanvas(p.w, p.h);\r\n        };\r\n    }\r\n\r\n\r\n\r\n    /** @return {w, h} proportions of the canvas based on the parameters */\r\n    getCanvasProportions(cP) {\r\n        let w, h;\r\n\r\n        if(cP.isRelative) {\r\n            w = windowWidth  * cP.width;\r\n            h = windowHeight * cP.height;\r\n        }\r\n        else {\r\n            w = cP.width  + \"px\";\r\n            h = cP.height + \"px\";\r\n        }\r\n\r\n        return {w, h};\r\n    }\r\n\r\n    /**\r\n    * @param customObject the Object that is going to be simulated (can be instanciated or not)\r\n    * @param number Number of objects to be instanciated\r\n    * @param params The parameters in the function\r\n    * @return this\r\n    */\r\n    addObjects(customObject, number = 1, ...params) {\r\n        if(customObject instanceof Function) {\r\n            for (let i = 0; i < number; i++) {\r\n                let copyParamsTemp = [];\r\n                for (let j = 0; j < params.length; j++) {\r\n                    if(\r\n                           params[j] instanceof Array\r\n                        && params[j][0] != undefined\r\n                        && params[j][1] != undefined\r\n                        && params[j][1] instanceof Function\r\n                    )\r\n                    {\r\n                        if     (params[j][0] == this.config.engine.runner.addingObjectsConfigKeyWords.runFunctions)\r\n                            copyParamsTemp.push(params[j][1](...params[j].slice(2)));\r\n                        else if(params[j][0] == this.config.engine.runner.addingObjectsConfigKeyWords.runClass)\r\n                            copyParamsTemp.push(new params[j][1](...params[j].slice(2)));\r\n                    }\r\n                    else\r\n                        copyParamsTemp.push(params[j]);\r\n                }\r\n                this.plotter.objectsL.push(new customObject(...copyParamsTemp));\r\n            }\r\n        }\r\n        else\r\n            this.plotter.objectsL.push(customObject);\r\n\r\n        return this;\r\n    }\r\n\r\n    /** @return the default configuration of the engine */\r\n    getDefaultEngineConfig() {\r\n        return {\r\n            runner : {\r\n                divId : 'simulationContent',\r\n                UPDATE_FPS : 120,\r\n                DRAW_FPS   : 60,\r\n                simulationSpeed : 1,\r\n                addingObjectsConfigKeyWords : {  // keywords for when we add objects at the start of the engine\r\n                    runFunctions : '_RUN_F', // run a function with       ['_RUN_F', functionName, param1, param2, ...],\r\n                    runClass     : '_RUN_C'  // instanciates a class with ['_RUN_C', className   , param1, param2, ...]\r\n                },\r\n                rollbackControl : {\r\n                    maxStandardDeviation : 0.8,  // maximum tick deviation percentage for the software to consider as a rollback (in seconds)\r\n                    averageTimeSample    : 20,   // sample size for tick average (in seconds),\r\n                    minimalUpdateFPS     : 0.15  // minimal update frames\r\n                }\r\n            },\r\n            window : {\r\n                proportions : {  // window height and width on relative or absolute sizes\r\n                    isRelative : true,\r\n                    width  : 0.99,\r\n                    height : 0.99\r\n                }\r\n            },\r\n        \tplotter : {\r\n        \t\tscale : {  // displays x relative units on each side\r\n        \t\t\tx : 10,\r\n        \t\t\ty : 10,\r\n        \t\t\tsquareByX : true\r\n        \t\t},\r\n        \t\toffset : {  // x and y relative offset\r\n        \t\t\tx : 0,\r\n        \t\t\ty : 0\r\n        \t\t},\r\n                backgroundColor : {\r\n                    draw : true,\r\n                    color : { r : 0  , g : 0  , b : 0 }\r\n                },\r\n                gridColor       : { r : 255, g : 255, b : 255, a : 0.6 },\r\n        \t\tdisplayGrid     : true  // true : display graph on the screen\r\n        \t}\r\n        };\r\n    }\r\n\r\n    /**\r\n    * @param configFunc The function that modifies engine configuration\r\n    * @return this\r\n    */\r\n    setEngineConfig(configFunc) {\r\n        configFunc(this.config.engine);\r\n        window.windowResized(); // if proportions changed\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * @param config The function that modifies custom configuration\r\n    * @return this\r\n    */\r\n    setCustomConfig(configFunc) {\r\n        configFunc(this.config.custom);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * @return the engine configuration\r\n    */\r\n    getEngineConfig() {\r\n        return window._pSimulationInstance.config.engine;\r\n    }\r\n\r\n    /**\r\n    * @return the custom configuration\r\n    */\r\n    getCustomConfig() {\r\n        return window._pSimulationInstance.config.custom;\r\n    }\r\n\r\n\r\n    getPSEngineVar() {\r\n        /**\r\n        * @TODO\r\n        */\r\n    }\r\n}\r\n\r\nexport default pSimulator;\r\n","import './../utilities/Vector';\r\n\r\nclass pSPlotter {\r\n    /**\r\n    * @param simulator Main Engine simulator\r\n    * @param drawer Main Engine drawer instance\r\n    */\r\n    constructor(simulator, drawer) {\r\n        this.simulator = simulator;\r\n        this.drawer    = drawer;\r\n        this.objectsL  = [];\r\n\r\n        this.drawer.plotter = this;\r\n    }\r\n\r\n    /**\r\n    * Update main loop\r\n    * @param dt Delta time since last update (in seconds)\r\n    */\r\n    update(dt) {\r\n        for (let i = 0; i < this.objectsL.length; i++)\r\n            this.objectsL[i].update(dt, this.objectsL);\r\n    }\r\n\r\n    /* Draw main loop */\r\n    draw() {\r\n        let plConf = this.simulator.config.engine.plotter;\r\n        let bg     = plConf.backgroundColor.color;\r\n\r\n        if(plConf.backgroundColor.draw) {\r\n            background(bg.r, bg.g, bg.b);\r\n        }\r\n\r\n        // Draw every object to the screen\r\n        for (let i = 0; i < this.objectsL.length; i++)\r\n            this.objectsL[i].draw(this.drawer);\r\n\r\n\r\n        // Draw the grid\r\n        if(this.simulator.config.engine.plotter.displayGrid) {\r\n            /** @TODO To be implemented */\r\n            let centerPos = this.computeForXY(0, 0);\r\n            this.drawer\r\n                .noStroke()\r\n                .fill(plConf.gridColor.r, plConf.gridColor.g, plConf.gridColor.b, plConf.gridColor.a)\r\n                .ellipse(centerPos.x, centerPos.y, 10, 10);\r\n        }\r\n    }\r\n\r\n\r\n\r\n    /**\r\n    * Compute the X and Y pixel position based on the drawing parameters\r\n    * @param xRel X relative position\r\n    * @param yRel Y relative position\r\n    * @return {X, Y} object\r\n    */\r\n    computeForXY(xRel, yRel) {\r\n        let c = this.simulator.config.engine.plotter;\r\n        let v = new Vector(((xRel + c.offset.x) / c.scale.x + 1)  * width / 2);\r\n\r\n        if(!c.scale.squareByX)\r\n            v.y = ((-yRel + c.offset.y) / c.scale.y + 1) * height / 2;\r\n        else\r\n            v.y = ((-yRel + c.offset.y) / c.scale.x)     * width  / 2 + height / 2;\r\n\r\n        return v;\r\n    }\r\n\r\n\r\n    /**\r\n    * Compute the X and Y plot position based on the pixel position\r\n    * @param xRel X pixel position\r\n    * @param yRel Y pixel position\r\n    * @return {X, Y} object\r\n    */\r\n    computeForXYFromPixel(x, y) {\r\n        let c = _pSimulationInstance.config.engine.plotter;\r\n        let v = new Vector(((x * 2) / width - 1) * c.scale.x - c.offset.x);\r\n\r\n        if(!c.scale.squareByX)\r\n            v.y = -(((y * 2) / height - 1)           * c.scale.y - c.offset.y);\r\n        else\r\n            v.y = -((((y - 2 * height) * 2) / width) * c.scale.y - c.offset.y);\r\n\r\n        return v;\r\n    }\r\n}\r\n\r\nexport default pSPlotter;\r\n","class pSDrawer {\r\n    /** Construct the main pSEngine drawer */\r\n    constructor(plotter) {\r\n        this.plotter = null; // set when loaded in the Plotter class\r\n    }\r\n\r\n\r\n\r\n    /**\r\n    * Draw a point to the screen\r\n    * @param x X simulation coordinate\r\n    * @param y Y simulation coordinate\r\n    * @return this\r\n    */\r\n    point(x, y) {\r\n        let v = this.plotter.computeForXY(x, y);\r\n        point(v.x, v.y);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Draw a line from one point to the other to the screen\r\n    * @param x0 X initial simulation coordinate\r\n    * @param y0 Y initial simulation coordinate\r\n    * @param x1 X end simulation coordinate\r\n    * @param y1 Y end simulation coordinate\r\n    * @return this\r\n    */\r\n    line(x0, y0, x1, y1) {\r\n        let v0 = this.plotter.computeForXY(x0, y0);\r\n        let v1 = this.plotter.computeForXY(x1, y1);\r\n        line(v0.x, v0.y, v1.x, v1.y);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Draw an ellipse\r\n    * @param x X center simulation coordinate\r\n    * @param y Y center simulation coordinate\r\n    * @param rx X ellipse radius\r\n    * @param ry Y ellipse radius\r\n    * @return this\r\n    */\r\n    ellipse(x, y, rx, ry) {\r\n        let v = this.plotter.computeForXY(x, y);\r\n        ellipse(v.x, v.y, rx, ry);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Draw a circle\r\n    * @param x X center simulation coordinate\r\n    * @param y Y center simulation coordinate\r\n    * @param r Circle radius\r\n    * @return this\r\n    */\r\n    circle(x, y, r) {\r\n    \treturn this.ellipse(x, y, r, r);\r\n    }\r\n\r\n    /**\r\n    * Draw a rectangle\r\n    * @param x X bottom left simulation coordinate\r\n    * @param y Y bottom left simulation coordinate\r\n    * @param w Rectangle width\r\n    * @param h Rectangle height\r\n    * @return this\r\n    */\r\n    rect(x, y, w, h) {\r\n        let v0 = this.plotter.computeForXY(x, y);\r\n        let v1 = this.plotter.computeForXY(\r\n            -_pSimulationInstance.config.engine.plotter.scale.x + w,\r\n             _pSimulationInstance.config.engine.plotter.scale.y + h\r\n         );\r\n         rect(v0.x, v0.y, v1.x, v1.y);\r\n         return this;\r\n    };\r\n\r\n\r\n\r\n    /**\r\n    * Set stroke color\r\n    * @param r Red value (0 to 255), or 'rgb(r, g, b)' or 'rgba(r, g, b, a)'\r\n    * @param g Green value (0 to 255)\r\n    * @param b Blue value (0 to 255)\r\n    * @param a Alpha value (0 to 255)\r\n    * @return this\r\n    */\r\n    stroke(r, g, b, a) {\r\n        if(a == undefined) {\r\n            if(b == undefined) {\r\n                if(g == undefined)\r\n                    stroke(r);\r\n                else\r\n                    stroke(r, g);\r\n            }\r\n            else\r\n                stroke(r, g, b);\r\n        }\r\n        else\r\n            stroke(`rgba(${r}, ${g}, ${b}, ${a})`);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Set stroke weight\r\n    * @param n Stroke weight (integer)\r\n    */\r\n    strokeWeight(n) {\r\n        strokeWeight(n);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n    * Set fill color\r\n    * @param r Red value (0 to 255), or 'rgb(r, g, b)' or 'rgba(r, g, b, a)'\r\n    * @param g Green value (0 to 255)\r\n    * @param b Blue value (0 to 255)\r\n    * @param a Alpha value (0 to 255)\r\n    * @return this\r\n    */\r\n    fill(r, g, b, a) {\r\n        if(a == undefined) {\r\n            if(b == undefined) {\r\n                if(g == undefined)\r\n                    fill(r);\r\n                else\r\n                    fill(r, g);\r\n            }\r\n            else\r\n                fill(r, g, b);\r\n        }\r\n        else\r\n            fill(`rgba(${r}, ${g}, ${b}, ${a})`);\r\n        return this;\r\n    }\r\n\r\n\r\n\r\n    beginShape(TYPE) {\r\n        beginShape(TYPE);\r\n        return this;\r\n    }\r\n\r\n    endShape() {\r\n        endShape();\r\n        return this;\r\n    }\r\n\r\n    vertex(x, y) {\r\n        let v = this.plotter.computeForXY(x, y);\r\n        vertex(v.x, v.y);\r\n        return this;\r\n    }\r\n\r\n    pop() {\r\n        pop();\r\n        return this;\r\n    }\r\n\r\n    push() {\r\n        push();\r\n        return this;\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n    /** Remove stroke of the shape */\r\n    noStroke() {\r\n        noStroke();\r\n        return this;\r\n    }\r\n\r\n    /** No fill the shape */\r\n    noFill() {\r\n        noFill();\r\n        return this;\r\n    }\r\n}\r\n\r\nexport default pSDrawer;\r\n","import './../../utilities/Vector';\r\nimport './../Animation';\r\nimport './Text';\r\n\r\n\r\nclass pSPoint {\r\n    /**\r\n    * Creates a new Point\r\n    * @param x X point position\r\n    * @param y Y point position\r\n    * @param color drawing color of the point\r\n    * @param pointName name of the point (in LaTeX)\r\n    * @param pointSize Size of the point (default 6)\r\n    * @param vectorName Name of the vector\r\n    * @param drawOriginVector true : draw the vector from the origin to this point\r\n    */\r\n    constructor(x, y, color = 'white', pointName, pointSize = 6, vectorName, drawOriginVector = true) {\r\n        this.pos = new Vector(x, y, color, vectorName);\r\n\r\n        if(pointName != undefined)\r\n            this.pointName = new pSText(pointName, this.pos, 18, color);\r\n\r\n        this.drawOriginVector = drawOriginVector;\r\n        this.pointSize        = pointSize;\r\n        this.pointSizeDrawing = pointSize;\r\n\r\n        this.textPadding = 0.4;\r\n    }\r\n\r\n    /**\r\n    * Updates the point\r\n    * @param dt Delta time since last update\r\n    */\r\n    update(dt) { }\r\n\r\n    /**\r\n    * Draw the point to the screen\r\n    */\r\n    draw() {\r\n        let drawer = _pSimulationInstance.plotter.drawer;\r\n\r\n        // POINT LOCATION\r\n        drawer\r\n            .fill(parseInt(this.pos.color[0] * 0.4), parseInt(this.pos.color[1] * 0.4), parseInt(this.pos.color[2] * 0.4))\r\n            .noStroke()\r\n            .ellipse(this.pos.x, this.pos.y, this.pointSizeDrawing, this.pointSizeDrawing)\r\n            .stroke(this.pos.color)\r\n            .strokeWeight(1.1)\r\n            .noFill()\r\n            .ellipse(this.pos.x, this.pos.y, this.pointSizeDrawing, this.pointSizeDrawing)\r\n        ;\r\n\r\n        // ORIGIN VECTOR\r\n        if(this.pos.name != undefined && this.drawOriginVector)\r\n            this.pos.draw();\r\n\r\n        // POINT NAME\r\n        if(this.pointName == undefined)\r\n            return;\r\n\r\n        this.pointName.pos = (this.pos.copy()).add(0, this.textPadding);\r\n        if(this.pos.name != undefined && this.drawOriginVector && this.pos.y < 0)\r\n            this.pointName.pos = (this.pos.copy()).add(0, -this.textPadding);\r\n\r\n        this.pointName.draw(drawer);\r\n    }\r\n}\r\n\r\nexport default pSPoint;\r\n","import './../../utilities/Vector';\r\nimport './../Animation';\r\nimport './Text';\r\n\r\nclass pSTriangle {\r\n    /**\r\n    * Creates a new Triangle\r\n    * @param p0 Vector to the first point of the triangle\r\n    * @param p1 Vector to the second point of the triangle (default (0, 0))\r\n    * @param p2 Vector to the third point of the triangle (default (0, 0))\r\n    * @param fillColor The triangle fill color (default none)\r\n    * @param strokeColor The triangle stroke color (default none)\r\n    * @param strokeWeight The triangle strokeWeight (default 1)\r\n    */\r\n    constructor(p0, p1 = new Vector(), p2 = new Vector(), fillColor = 'white', strokeColor = 'none', strokeWeight = 1) {\r\n        this.setCoordinates(p0, p1, p2);\r\n\r\n        // Colors\r\n        this.fillColor    = fillColor;\r\n        this.strokeColor  = strokeColor;\r\n        this.strokeWeight = strokeWeight;\r\n    }\r\n\r\n\r\n    /**\r\n    * @param p0 Vector to the first point of the triangle\r\n    * @param p1 Vector to the second point of the triangle (default last point)\r\n    * @param p2 Vector to the third point of the triangle (default last point)\r\n    */\r\n    setCoordinates(p0, p1, p2) {\r\n        this.p0 = p0 || new Vector(p0.x, p0.y);\r\n        this.p1 = p1 == undefined ? this.p1 : new Vector(p1.x, p1.y);\r\n        this.p2 = p2 == undefined ? this.p2 : new Vector(p2.x, p2.y);\r\n\r\n        // The barycenter, or center of mass. This is the\r\n        // point around which the triangle will rotate.\r\n        this.pG = Vector.div(Vector.add(Vector.add(this.p0, this.p1), this.p2), 3);\r\n\r\n        // The vectors pointing from the barycenter to P0, P1\r\n        // and P2. They are useful when rotating the triangle.\r\n        this.v0 = Vector.sub(this.p0, this.pG);\r\n        this.v1 = Vector.sub(this.p1, this.pG);\r\n        this.v2 = Vector.sub(this.p2, this.pG);\r\n    }\r\n\r\n\r\n    /**\r\n    * Rotates the triangle by the specified angle, around\r\n    * its center of mass.\r\n    * @param angle Angle of rotation\r\n    */\r\n    rotate(angle) {\r\n        this.v0.rotate(angle);\r\n        this.v1.rotate(angle);\r\n        this.v2.rotate(angle);\r\n\r\n        this.p0 = Vector.add(this.v0, this.pG);\r\n        this.p1 = Vector.add(this.v1, this.pG);\r\n        this.p2 = Vector.add(this.v2, this.pG);\r\n    }\r\n\r\n\r\n    /**\r\n    * Updates the triangle\r\n    * @param dt Delta time since last update\r\n    */\r\n    update(dt) {}\r\n\r\n\r\n    /**\r\n    * Draws the triangle on the screen.\r\n    */\r\n    draw() {\r\n        let d = _pSimulationInstance.plotter.drawer;\r\n\r\n        if(this.fillColor == 'none')\r\n            d.noFill();\r\n        else\r\n            d.fill(this.fillColor);\r\n\r\n        if(this.strokeColor == 'none')\r\n            d.noStroke();\r\n        else\r\n            d.stroke(this.strokeColor).strokeWeight(this.strokeWeight);\r\n\r\n        d.push()\r\n            .beginShape()\r\n                .vertex(this.p0.x, this.p0.y)\r\n                .vertex(this.p1.x, this.p1.y)\r\n                .vertex(this.p2.x, this.p2.y)\r\n                .vertex(this.p0.x, this.p0.y)\r\n            .endShape()\r\n        .pop();\r\n    }\r\n}\r\n\r\nexport default pSTriangle;\r\n","// ========== PSENGINE VARIABLES ==========\r\n// ==== Core ====\r\nimport pSimulator from './core/Simulator';\r\n\r\n// ==== Drawer ====\r\n// Objects\r\nimport pSPoint    from './drawer/objects/Point';\r\nimport pSText     from './drawer/objects/Text';\r\nimport pSTriangle from './drawer/objects/Triangle';\r\n\r\n// Root\r\nimport Animation  from './drawer/Animation';\r\nimport pSDrawer   from './drawer/Drawer';\r\nimport pSPlotter  from './drawer/Plotter';\r\n\r\n// ==== Utilities ====\r\nimport Vector     from './utilities/Vector';\r\n\r\n\r\n// ========== GLOBAL VARIABLES ==========\r\n// ==== Drawer ====\r\n// Objects\r\nglobal.pSPoint     = pSPoint;\r\nglobal.pSText      = pSText;\r\nglobal.pSTriangle  = pSTriangle;\r\n\r\n// Root\r\nglobal.pSAnimation = Animation;\r\n\r\n// ==== Utilities ====\r\nglobal.Vector      = Vector;\r\n\r\n\r\n// ========== PSENGINE LAUNCH ==========\r\nimport './core/init';\r\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","import pSimulator from './Simulator';\r\n\r\nclass pSEngine {\r\n\tconstructor() {\r\n\t\tif(window.p5 == undefined)\r\n\t\t\tconsole.error(\r\n\t\t\t\t'You must import p5.js in order to run the Physics Simulation Engine.',\r\n\t\t\t\t'More informations on the p5 website https://p5js.org/.'\r\n\t\t\t);\r\n\r\n\t\t// uses the p5 functions\r\n\t\twindow.setup = function() {\r\n\t\t\twindow._pSimulationInstance = new pSimulator();\r\n\t\t\twindow._pSimulationInstance.instanciate();\r\n\t\t\twindow.pSEngine = window._pSimulationInstance.getPSEngineVar();\r\n\t\t};\r\n\t}\r\n}\r\n\r\nexport default pSEngine;\r\n","import pSEngine from './main';\r\n\r\nconst _pSglobalEngineInit = () => {\r\n\tnew pSEngine();\r\n};\r\n\r\nconst waitForDocumentReady = new Promise((resolve, reject) => {\r\n    if(document.readyState === 'loading') // complete\r\n        resolve();\r\n    else\r\n        window.addEventListener('load', resolve, false);\r\n});\r\n\r\nwaitForDocumentReady.then(_pSglobalEngineInit);\r\n\r\nexport default pSEngine;\r\n"],"sourceRoot":""} \ No newline at end of file