From 4d255d89f7d8dbe7e34e7866b0582636199ea603 Mon Sep 17 00:00:00 2001 From: ndujar Date: Sun, 14 Aug 2016 08:19:58 +0300 Subject: [PATCH] Modification of the sleepCheck conditions --- dist/behaviors/attractor.js | 4 +- dist/behaviors/body-collision-detection.js | 4 +- dist/behaviors/body-impulse-response.js | 4 +- dist/behaviors/constant-acceleration.js | 4 +- dist/behaviors/edge-collision-detection.js | 4 +- dist/behaviors/interactive.js | 4 +- dist/behaviors/newtonian.js | 4 +- dist/behaviors/sweep-prune.js | 4 +- dist/behaviors/verlet-constraints.js | 4 +- dist/bodies/circle.js | 4 +- dist/bodies/compound.js | 4 +- dist/bodies/convex-polygon.js | 4 +- dist/bodies/rectangle.js | 4 +- dist/geometries/circle.js | 4 +- dist/geometries/compound.js | 4 +- dist/geometries/convex-polygon.js | 4 +- dist/geometries/rectangle.js | 4 +- dist/integrators/improved-euler.js | 4 +- dist/integrators/velocity-verlet-alt.js | 4 +- dist/integrators/velocity-verlet.js | 4 +- dist/physicsjs-full.js | 80 +- dist/physicsjs-full.min.js | 10 +- dist/physicsjs.js | 80 +- dist/physicsjs.min.js | 8 +- dist/renderers/canvas.js | 4 +- dist/renderers/debug.js | 4 +- dist/renderers/dom.js | 4 +- dist/renderers/pixi-renderer.js | 4 +- examples/Performance/index.html | 21 + examples/Performance/index.html~ | 21 + examples/Performance/jquery-2.0.3.min.js | 6 + examples/Performance/jquery-2.0.3.min~ | 0 examples/Performance/physicsjs-full-0.7.0.js~ | 11975 ++++++++++++++++ examples/Performance/physicsjs-full-KE.js | 11950 +++++++++++++++ examples/Performance/physicsjs-full-KE.js~ | 11950 +++++++++++++++ examples/Performance/physicsjs-full.js | 11965 +++++++++++++++ examples/Performance/physicsjs-full.js~ | 11965 +++++++++++++++ examples/Performance/script.js | 116 + examples/Performance/script.js~ | 116 + examples/Performance/style.css~ | 5 + examples/physicsjs-full.js | 80 +- src/core/body.js | 55 +- src/core/body.js~ | 506 + src/core/world.js | 10 +- src/core/world.js~ | 822 ++ 45 files changed, 61542 insertions(+), 295 deletions(-) create mode 100644 examples/Performance/index.html create mode 100644 examples/Performance/index.html~ create mode 100644 examples/Performance/jquery-2.0.3.min.js create mode 100644 examples/Performance/jquery-2.0.3.min~ create mode 100644 examples/Performance/physicsjs-full-0.7.0.js~ create mode 100644 examples/Performance/physicsjs-full-KE.js create mode 100644 examples/Performance/physicsjs-full-KE.js~ create mode 100644 examples/Performance/physicsjs-full.js create mode 100644 examples/Performance/physicsjs-full.js~ create mode 100644 examples/Performance/script.js create mode 100644 examples/Performance/script.js~ create mode 100644 examples/Performance/style.css~ create mode 100644 src/core/body.js~ create mode 100644 src/core/world.js~ diff --git a/dist/behaviors/attractor.js b/dist/behaviors/attractor.js index ba1b2b31..9a393d96 100644 --- a/dist/behaviors/attractor.js +++ b/dist/behaviors/attractor.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/body-collision-detection.js b/dist/behaviors/body-collision-detection.js index 2121e2c1..fefe4136 100644 --- a/dist/behaviors/body-collision-detection.js +++ b/dist/behaviors/body-collision-detection.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/body-impulse-response.js b/dist/behaviors/body-impulse-response.js index 63f1d8d1..241c66da 100644 --- a/dist/behaviors/body-impulse-response.js +++ b/dist/behaviors/body-impulse-response.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/constant-acceleration.js b/dist/behaviors/constant-acceleration.js index 2a453116..afd35cbc 100644 --- a/dist/behaviors/constant-acceleration.js +++ b/dist/behaviors/constant-acceleration.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/edge-collision-detection.js b/dist/behaviors/edge-collision-detection.js index 5d774a8f..e470edac 100644 --- a/dist/behaviors/edge-collision-detection.js +++ b/dist/behaviors/edge-collision-detection.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/interactive.js b/dist/behaviors/interactive.js index 2d9ca6eb..79335bb2 100644 --- a/dist/behaviors/interactive.js +++ b/dist/behaviors/interactive.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/newtonian.js b/dist/behaviors/newtonian.js index 748aca01..b70c7e09 100644 --- a/dist/behaviors/newtonian.js +++ b/dist/behaviors/newtonian.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/sweep-prune.js b/dist/behaviors/sweep-prune.js index 4076a3e5..cde12865 100644 --- a/dist/behaviors/sweep-prune.js +++ b/dist/behaviors/sweep-prune.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/behaviors/verlet-constraints.js b/dist/behaviors/verlet-constraints.js index 3a2b643b..4d0bc6dd 100644 --- a/dist/behaviors/verlet-constraints.js +++ b/dist/behaviors/verlet-constraints.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/bodies/circle.js b/dist/bodies/circle.js index d04f31ba..f46cd6b1 100644 --- a/dist/bodies/circle.js +++ b/dist/bodies/circle.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/bodies/compound.js b/dist/bodies/compound.js index be742341..08e83906 100644 --- a/dist/bodies/compound.js +++ b/dist/bodies/compound.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/bodies/convex-polygon.js b/dist/bodies/convex-polygon.js index a68736ea..8f1e9171 100644 --- a/dist/bodies/convex-polygon.js +++ b/dist/bodies/convex-polygon.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/bodies/rectangle.js b/dist/bodies/rectangle.js index 22235652..9daf8f22 100644 --- a/dist/bodies/rectangle.js +++ b/dist/bodies/rectangle.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/geometries/circle.js b/dist/geometries/circle.js index 6ff8d95e..5770a497 100644 --- a/dist/geometries/circle.js +++ b/dist/geometries/circle.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/geometries/compound.js b/dist/geometries/compound.js index 93589fc1..41be43aa 100644 --- a/dist/geometries/compound.js +++ b/dist/geometries/compound.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/geometries/convex-polygon.js b/dist/geometries/convex-polygon.js index 82859fb7..3e750e40 100644 --- a/dist/geometries/convex-polygon.js +++ b/dist/geometries/convex-polygon.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/geometries/rectangle.js b/dist/geometries/rectangle.js index f10b93df..655af819 100644 --- a/dist/geometries/rectangle.js +++ b/dist/geometries/rectangle.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/integrators/improved-euler.js b/dist/integrators/improved-euler.js index 5c308763..4f550d93 100644 --- a/dist/integrators/improved-euler.js +++ b/dist/integrators/improved-euler.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/integrators/velocity-verlet-alt.js b/dist/integrators/velocity-verlet-alt.js index 414aedf1..2d7898b2 100644 --- a/dist/integrators/velocity-verlet-alt.js +++ b/dist/integrators/velocity-verlet-alt.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/integrators/velocity-verlet.js b/dist/integrators/velocity-verlet.js index 26d74947..3d7e1ad0 100644 --- a/dist/integrators/velocity-verlet.js +++ b/dist/integrators/velocity-verlet.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/physicsjs-full.js b/dist/physicsjs-full.js index 96309861..9bb6e54f 100644 --- a/dist/physicsjs-full.js +++ b/dist/physicsjs-full.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ @@ -3709,13 +3709,6 @@ Physics.scratchpad = (function(){ } }; - // private storage for sleeping - this._sleepAngPosMean = 0; - this._sleepAngPosVariance = 0; - this._sleepPosMean = new vector(); - this._sleepPosVariance = new vector(); - this._sleepMeanK = 0; - // cleanup delete this.x; delete this.y; @@ -3850,13 +3843,7 @@ Physics.scratchpad = (function(){ } else if ( dt === false ){ // force wakup - this.asleep = false; - this._sleepMeanK = 0; - this._sleepAngPosMean = 0; - this._sleepAngPosVariance = 0; - this._sleepPosMean.zero(); - this._sleepPosVariance.zero(); - this.sleepIdleTime = 0; + this.asleep = false; } else if ( dt && !this.asleep ) { @@ -3884,57 +3871,26 @@ Physics.scratchpad = (function(){ } var limit - ,v - ,d - ,r - ,aabb - ,scratch = Physics.scratchpad() - ,diff = scratch.vector() - ,diff2 = scratch.vector() - ,kfac - ,stats + ,Ek ; - dt = dt || 0; - aabb = this.geometry.aabb(); - r = Math.max(aabb.hw, aabb.hh); - if ( this.asleep ){ - // check velocity - v = this.state.vel.norm() + Math.abs(r * this.state.angular.vel); - limit = this.sleepSpeedLimit || (opts && opts.sleepSpeedLimit) || 0; + + // check kinetic energy (linear and rotational) + Ek = 0.5* this.mass * this.state.vel.dot(this.state.vel) + + 0.5*Math.abs(this.moi * this.state.angular.vel.dot(this.state.angular.vel)); + + limit = this.sleepEnergyLimit || (opts && opts.sleepEnergyLimit) || 0; - if ( v >= limit ){ + if ( Ek >= limit ){ + this.sleep( false ); - return scratch.done(); - } - } - - this._sleepMeanK++; - kfac = this._sleepMeanK > 1 ? 1/(this._sleepMeanK - 1) : 0; - Physics.statistics.pushRunningVectorAvg( this.state.pos, this._sleepMeanK, this._sleepPosMean, this._sleepPosVariance ); - // we take the sin because that maps the discontinuous angle to a continuous value - // then the statistics calculations work better - stats = Physics.statistics.pushRunningAvg( Math.sin(this.state.angular.pos), this._sleepMeanK, this._sleepAngPosMean, this._sleepAngPosVariance ); - this._sleepAngPosMean = stats[0]; - this._sleepAngPosVariance = stats[1]; - v = this._sleepPosVariance.norm() + Math.abs(r * Math.asin(stats[1])); - v *= kfac; - limit = this.sleepVarianceLimit || (opts && opts.sleepVarianceLimit) || 0; - // console.log(v, limit, kfac, this._sleepPosVariance.norm(), stats[1]) - if ( v <= limit ){ - // check idle time - limit = this.sleepTimeLimit || (opts && opts.sleepTimeLimit) || 0; - this.sleepIdleTime = (this.sleepIdleTime || 0) + dt; - - if ( this.sleepIdleTime > limit ){ - this.asleep = true; + } - } else { - this.sleep( false ); + } - scratch.done(); + }, /** @@ -5041,10 +4997,8 @@ Physics.geometry.nearestPointOnLine = function nearestPointOnLine( pt, linePt1, // is sleeping disabled? sleepDisabled: false, - // speed at which bodies wake up - sleepSpeedLimit: 0.05, - // variance in position below which bodies fall asleep - sleepVarianceLimit: 0.02, + // Kinetic Energy at which bodies wake up + sleepEnergyLimit: 0.00000001, // time (ms) before sleepy bodies fall asleep sleepTimeLimit: 500 }; diff --git a/dist/physicsjs-full.min.js b/dist/physicsjs-full.min.js index ae662f39..af15b2f7 100644 --- a/dist/physicsjs-full.min.js +++ b/dist/physicsjs-full.min.js @@ -1,11 +1,11 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ -!function(a,b){"object"==typeof exports?module.exports=b.call(a):"function"==typeof define&&define.amd?define(function(){return b.call(a)}):a.Physics=b.call(a)}("undefined"!=typeof window?window:this,function(){"use strict";var a=this,b=a.document,c=function f(){return f.world.apply(f,arguments)};c.util={},function(){c.aabb=function(a,b,c,d){var e={x:0,y:0,hw:0,hh:0};return void 0===a?e:(a&&void 0!==a.x&&(c=b.x,d=b.y,b=a.y,a=a.x),void 0===d&&void 0!==a&&void 0!==b?(e.hw=.5*a,e.hh=.5*b,c&&void 0!==c.x&&(e.x=c.x,e.y=c.y),e):(e.hw=.5*Math.abs(c-a),e.hh=.5*Math.abs(d-b),e.x=.5*(c+a),e.y=.5*(d+b),e))},c.aabb.contains=function(a,b){return b.x>a.x-a.hw&&b.xa.y-a.hh&&b.y=d&&f>=e||f>=c&&e>=f?(c=a.y-a.hh,d=b.y-b.hh,e=a.y+a.hh,f=b.y+b.hh,e>=d&&f>=e||f>=c&&e>=f):!1}}(),function(){var a=1e-4,b=100,d=function(a,b,c){var d=b.normSq()-b.dot(a),e=b.dot(a)-a.normSq();return 0>d?c.clone(b).negate():e>0?c.clone(a).negate():(c.clone(b).vsub(a),c.perp(a.cross(c)>0))},e=function(a){var b,d,e=a.length,f=a[e-2],g=a[e-3],h=c.scratchpad(),i=h.vector().clone(f.pt),j=h.vector().clone(g.pt).vsub(i);return j.equals(c.vector.zero)?h.done({a:f.a,b:f.b}):(b=-j.dot(i)/j.normSq(),d=1-b,h.done(0>=d?{a:g.a,b:g.b}:0>=b?{a:f.a,b:f.b}:{a:i.clone(f.a).mult(d).vadd(j.clone(g.a).mult(b)).values(),b:i.clone(f.b).mult(d).vadd(j.clone(g.b).mult(b)).values()}))},f=function(f,g,h,i){var j,k,l,m,n=!1,o=!1,p=!1,q=[],r=1,s=c.scratchpad(),t=s.vector().clone(g||c.vector.axis[0]),u=s.vector(),v=s.vector(),w=s.vector(),x=s.vector(),y=0;for(m=f(t),r=q.push(m),u.clone(m.pt),t.negate();++y;){if(u.swap(v),m=f(t),r=q.push(m),u.clone(m.pt),i&&i(q),u.equals(c.vector.zero)){n=!0;break}if(!o&&u.dot(t)<=0){if(h)break;o=!0}if(2===r)t=d(u,v,t);else if(o){if(t.normalize(),m=v.dot(t),Math.abs(m-u.dot(t))0,l^u.cross(j)>0)q.shift(),j.perp(!l),t.swap(j);else{if(!(l^k.cross(u)>0)){n=!0;break}q.splice(1,1),k.perp(l),t.swap(j)}if(y>b)return s.done(),{simplex:q,iterations:y,distance:0,maxIterationsReached:!0}}return s.done(),m={overlap:n,simplex:q,iterations:y},p!==!1&&(m.distance=p,m.closest=e(q)),m};c.gjk=f}(),function(){c.statistics={pushRunningAvg:function(a,b,c,d){var e=a-c;return c+=e/b,d+=e*(a-c),[c,d]},pushRunningVectorAvg:function(a,b,c,d){var e=1/b,f=a.get(0)-c.get(0),g=a.get(1)-c.get(1);c.add(f*e,g*e),d&&(f*=a.get(0)-c.get(0),g*=a.get(1)-c.get(1),d.add(f,g))}}}(),function(){var a=function b(a,d,e){return this instanceof b?(this.v=new c.vector,this.o=new c.vector,a instanceof b?void this.clone(a):(a&&this.setTranslation(a),void this.setRotation(d||0,e))):new b(a,d)};a.prototype.setTranslation=function(a){return this.v.clone(a),this},a.prototype.setRotation=function(a,b){return this.cosA=Math.cos(a),this.sinA=Math.sin(a),b?this.o.clone(b):this.o.zero(),this},a.prototype.clone=function(b){return b?(this.setTranslation(b.v),this.cosA=b.cosA,this.sinA=b.sinA,this.o.clone(b.o),this):new a(this)},c.transform=a}(),function(a){var b=Math.sqrt,d=Math.min,e=Math.max,f=(Math.acos,Math.atan2),g=2*Math.PI,h=!!a.Float64Array,i=function j(a,b){return this instanceof j?(this._=h?new Float64Array(5):[],void(a&&(void 0!==a.x||a._&&a._.length)?this.clone(a):(this.recalc=!0,this.set(a,b)))):new j(a,b)};Object.defineProperties(i.prototype,{x:{get:function(){return+this._[0]},set:function(a){a=+a||0,this.recalc=a===this._[0],this._[0]=a}},y:{get:function(){return+this._[1]},set:function(a){a=+a||0,this.recalc=a===this._[1],this._[1]=a}}}),i.prototype.set=function(a,b){return this.recalc=!0,this._[0]=+a||0,this._[1]=+b||0,this},i.prototype.get=function(a){return this._[a]},i.prototype.vadd=function(a){return this.recalc=!0,this._[0]+=a._[0],this._[1]+=a._[1],this},i.prototype.vsub=function(a){return this.recalc=!0,this._[0]-=a._[0],this._[1]-=a._[1],this},i.prototype.add=function(a,b){return this.recalc=!0,this._[0]+=+a||0,this._[1]+=+b||0,this},i.prototype.sub=function(a,b){return this.recalc=!0,this._[0]-=a,this._[1]-=void 0===b?0:b,this},i.prototype.mult=function(a){return this.recalc||(this._[4]*=a*a,this._[3]*=a),this._[0]*=a,this._[1]*=a,this},i.prototype.dot=function(a){return this._[0]*a._[0]+this._[1]*a._[1]},i.prototype.cross=function(a){return-this._[0]*a._[1]+this._[1]*a._[0]},i.prototype.proj=function(a){return this.dot(a)/a.norm()},i.prototype.vproj=function(a){var b=this.dot(a)/a.normSq();return this.clone(a).mult(b)},i.prototype.angle=function(a){var b;if(this.equals(i.zero))return a?a.angle():0/0;for(b=a&&!a.equals(i.zero)?f(this._[1]*a._[0]-this._[0]*a._[1],this._[0]*a._[0]+this._[1]*a._[1]):f(this._[1],this._[0]);b>Math.PI;)b-=g;for(;b<-Math.PI;)b+=g;return b},i.prototype.angle2=function(a,b){for(var c=a._[0]-this._[0],d=a._[1]-this._[1],e=b._[0]-this._[0],h=b._[1]-this._[1],i=f(d*e-c*h,c*e+d*h);i>Math.PI;)i-=g;for(;i<-Math.PI;)i+=g;return i},i.prototype.norm=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[3]},i.prototype.normSq=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[4]},i.prototype.dist=function(a){var c,d;return b((c=a._[0]-this._[0])*c+(d=a._[1]-this._[1])*d)},i.prototype.distSq=function(a){var b,c;return(b=a._[0]-this._[0])*b+(c=a._[1]-this._[1])*c},i.prototype.perp=function(a){var b=this._[0];return a?(this._[0]=this._[1],this._[1]=-b):(this._[0]=-this._[1],this._[1]=b),this},i.prototype.normalize=function(){var a=this.norm();return 0===a?this:(a=1/a,this._[0]*=a,this._[1]*=a,this._[3]=1,this._[4]=1,this)},i.prototype.transform=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d,this._[1]-=e,this.set(this._[0]*c-this._[1]*b+d+a.v._[0],this._[0]*b+this._[1]*c+e+a.v._[1])},i.prototype.transformInv=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d+a.v._[0],this._[1]-=e+a.v._[1],this.set(this._[0]*c+this._[1]*b+d,-this._[0]*b+this._[1]*c+e)},i.prototype.rotate=function(a,b){var c,d,e=0,f=0;return"number"==typeof a?(c=Math.sin(a),d=Math.cos(a),b&&(e=b.x,f=b.y)):(c=a.sinA,d=a.cosA,e=a.o._[0],f=a.o._[1]),this._[0]-=e,this._[1]-=f,this.set(this._[0]*d-this._[1]*c+e,this._[0]*c+this._[1]*d+f)},i.prototype.rotateInv=function(a){return this.set((this._[0]-a.o._[0])*a.cosA+(this._[1]-a.o._[1])*a.sinA+a.o._[0],-(this._[0]-a.o._[0])*a.sinA+(this._[1]-a.o._[1])*a.cosA+a.o._[1])},i.prototype.translate=function(a){return this.vadd(a.v)},i.prototype.translateInv=function(a){return this.vsub(a.v)},i.prototype.clone=function(a){return a?a._?(this.recalc=a.recalc,a.recalc||(this._[3]=a._[3],this._[4]=a._[4]),this._[0]=a._[0],this._[1]=a._[1],this):this.set(a.x,a.y):new i(this)},i.prototype.swap=function(a){var b=this._;return this._=a._,a._=b,b=this.recalc,this.recalc=a.recalc,a.recalc=b,this},i.prototype.values=function(){return{x:this._[0],y:this._[1]}},i.prototype.zero=function(){return this._[3]=0,this._[4]=0,this._[0]=0,this._[1]=0,this},i.prototype.negate=function(a){return void 0!==a?(this._[a]=-this._[a],this):(this._[0]=-this._[0],this._[1]=-this._[1],this)},i.prototype.clamp=function(a,b){return this._[0]=d(e(this._[0],a.x),b.x),this._[1]=d(e(this._[1],a.y),b.y),this.recalc=!0,this},i.prototype.toString=function(){return"("+this._[0]+", "+this._[1]+")"},i.prototype.equals=function(a){return this._[0]===a._[0]&&this._[1]===a._[1]&&this._[2]===a._[2]},i.axis=[new i(1,0),new i(0,1)],i.zero=new i(0,0),c.vector=i}(this),function(a){var b=a.Physics;c.noConflict=function(){return a.Physics===c&&(a.Physics=b),c}}(this);var d=c.util.decorator=function(a,b){var d={},e={},f=function(a,b){var d,e;for(e in b)d=Object.getOwnPropertyDescriptor(b,e),d.get||d.set?Object.defineProperty(a,e,d):c.util.isFunction(d.value)&&(a[e]=d.value);return a},g=Object.getPrototypeOf;"function"!=typeof g&&(g="object"==typeof"test".__proto__?function(a){return a.__proto__}:function(a){return a.constructor.prototype});var h=Object.create;"function"!=typeof h&&(h=function(a){function b(){}return b.prototype=a,new b});var i=function(b,d){return"object"==typeof b?(e=f(e,b),void(e.type=a)):void("type"!==b&&c.util.isFunction(d)&&(e[b]=d))};i(b);var j=function(b,c,i,j){var k,l=e;if("string"!=typeof c)j=i,i=c;else{if(l=d[c],!l)throw'Error: "'+c+'" '+a+" not defined";l=l.prototype}if("function"==typeof i)k=d[b],k?k.prototype=f(k.prototype,i(g(k.prototype))):(k=d[b]=function(a){this.init&&this.init(a)},k.prototype=h(l),k.prototype=f(k.prototype,i(l,k.prototype))),k.prototype.type=a,k.prototype.name=b;else if(j=i||{},k=d[b],!k)throw'Error: "'+b+'" '+a+" not defined";return j?new k(j):void 0};return j.mixin=i,j};c.util.indexOf=function(a,b){for(var c=0,d=a.length;d>c;){if(d--,a[c]===b)return c;if(a[d]===b)return d;c++}return-1},c.util.clearArray=function(a){for(var b=a.length;b--;)a.pop();return a},c.util.throttle=function(a,b,c){var d,e,f=!1,g=function(){clearTimeout(d),f?(f=!1,d=setTimeout(g,b),a.apply(c,e)):d=!1};return c=c||null,function(){f=!0,e=arguments,d||g()}};var e=function(a,b){return c.util.isPlainObject(b)?c.util.extend({},a,b,e):void 0!==b?b:a};return c.util.options=function(a,b){var d,f={},g=[];return d=function(a,d){c.util.extend(b,a,d?e:null);for(var f=0,h=g.length;h>f;++f)g[f](b);return b},d.defaults=function(a,d){return c.util.extend(f,a,d?e:null),c.util.defaults(b,f,d?e:null),f},d.onChange=function(a){g.push(a)},b=b||d,d.defaults(a),d},c.util.pairHash=function(a,b){return a=0|a,b=0|b,(0|a)===(0|b)?-1:0|((0|a)>(0|b)?a<<16|65535&b:b<<16|65535&a)},c.util.bind=Function.prototype.bind?function(a,b,c){return c=Array.prototype.slice.call(arguments,1),Function.prototype.bind.apply(a,c)}:function(a,b,c){return c=Array.prototype.slice.call(arguments,2),function(){return a.apply(b,c.concat(Array.prototype.slice.call(arguments)))}},c.util.find=function(a,b){var c,d,e=a.length;for(c=0;e>c;c++)if(d=a[c],b(d,c,a))return d},c.util.filter=function(a,b){var c,d,e=a.length,f=[];for(c=0;e>c;c++)d=a[c],b(d,c,a)&&f.push(d);return f},function(){function a(a){c.util.clearArray(a),v.length-1?0:-1:a?0:-1}function g(a){var b=this.cache,c=typeof a;if("boolean"===c||null==a)b[a]=!0;else{"number"!==c&&"string"!==c&&(c="object");var d="number"===c?a:y+a,e=b[c]||(b[c]={});"object"===c?(e[d]||(e[d]=[])).push(a):e[d]=!0}}function h(a){var b=-1,c=a.length,e=a[0],f=a[c/2|0],h=a[c-1];if(e&&"object"==typeof e&&f&&"object"==typeof f&&h&&"object"==typeof h)return!1;var i=d();i["false"]=i["null"]=i["true"]=i.undefined=!1;var j=d();for(j.array=a,j.cache=i,j.push=g;++b=u&&k===c.util.indexOf,o=i||n?e():m;if(n){var p=h(o);k=f,o=p}for(;++jb;b++)d=a[b],e=i(0,++f),h[f]=h[e],h[e]=d;return h},c.util.isObject=function(a){return!(!a||!n[typeof a])},c.util.isFunction=j,c.util.isArray=Array.isArray||function(a){return a&&"object"==typeof a&&"number"==typeof a.length&&s.call(a)===p||!1};var C=RegExp("^"+String(s).replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/toString| for [^\]]+/g,".*?")+"$");c.util.isPlainObject=Object.getPrototypeOf?function(a){if(!a||s.call(a)!==q)return!1;var b=a.valueOf,c=k(b)&&(c=Object.getPrototypeOf(b))&&Object.getPrototypeOf(c);return c?a===c||Object.getPrototypeOf(a)===c:l(a)}:l,c.util.uniq=function(a,b,c){return"boolean"!=typeof b&&null!=b&&(c=b,b=!1),m(a,b,c)};var D=function(a,b,c){var d,e=a,f=e;if(!e)return f;var g,h=arguments,i=0,j="number"==typeof c?2:h.length;for(j>2&&"function"==typeof h[j-1]&&(g=h[--j]);++id;){var f=d+e>>>1;c(a[f])=b.maxScratches)throw f},a.prototype={done:function(a){this._active=!1;for(var b=0;j>b;++b)this[b]=0;return h.push(this),a}},b=function k(b){if(b)return k.fn(b);var c=h.pop()||new a;return c._active=!0,c},b.maxScratches=100,b.maxIndex=20,b.fn=function(b){for(var c=[],d=0,e=b.length;e>d;d++)c.push(d);c="a"+c.join(",a");var f=new Function("fn, scratches, Scratch","return function("+c+"){ var scratch = scratches.pop() || new Scratch( scratches );scratch._active = true;return scratch.done( fn(scratch, "+c+") );};");return f(b,h,a)},b.register=function(c,f,h){var i=a.prototype,k=j++,l="_"+c+"Stack",m=h&&h.useFactory;if(c in i)throw g;a.prototype[c]=function(){var a=this[l]||(this[l]=[]),c=0|this[k];if(this[k]=c+1,!this._active)throw d;if(c>=b.maxIndex)throw e;return a[c]||(a[c]=m?f():new f)}},b.register("vector",c.vector),b.register("transform",c.transform),b}(),function(){function a(a){return a._priority_}var b=1;c.scratchpad.register("event",function(){return{}},{useFactory:!0});var d=function e(){return this instanceof e?void 0:new e};d.prototype={on:function(d,e,f,g){var h,i,j;if(this._topics=this._topics||(this._topics={}),c.util.isObject(d)){for(var k in d)this.on(k,d[k],e,f);return this}return h=this._topics[d]||(this._topics[d]=[]),i=e,c.util.isObject(f)?(e=c.util.bind(e,f),e._bindfn_=i,e._one_=i._one_,e._scope_=f):void 0===g&&(g=f),e._priority_=void 0===g?b:g,j=c.util.sortedIndex(h,e,a),h.splice(j,0,e),this},off:function(a,b,d){var e,f;if(!this._topics)return this;if(a===!0)return this._topics={},this;if(c.util.isObject(a)){for(var g in a)this.off(g,a[g]);return this}if(e=this._topics[a],!e)return this;if(b===!0)return this._topics[a]=[],this;for(var h=0,i=e.length;i>h;h++)if(f=e[h],!(f._bindfn_!==b&&f!==b||d&&f._scope_!==d)){e.splice(h,1);break}return this},emit:function(a,b){if(!this._topics)return this;var d,e,f=this._topics[a],g=f&&f.length,h=c.scratchpad();if(!g)return h.done(this);for(e=h.event(),e.topic=a,e.handler=d;g--;)d=f[g],d(b,e),d._one_&&f.splice(g,1);return h.done(this)},one:function(a,b,d){if(c.util.isObject(a)){for(var e in a)this.one(e,a[e],b,d);return this}return b._one_=!0,this.on(a,b,d),this}},c.util.pubsub=d}(),function(a){function b(){return l&&l.now?l.now()+l.timing.navigationStart:Date.now()}function d(){var c;a.requestAnimationFrame(d),j&&(c=b(),c&&k.emit("tick",c))}function e(){return j=!0,this}function f(){return j=!1,this}function g(a){return k.on("tick",a),this}function h(a){return k.off("tick",a),this}function i(){return!!j}var j=!0,k=c.util.pubsub(),l=a.performance;a.requestAnimationFrame?d():j=!1,c.util.ticker={now:b,start:e,stop:f,on:g,off:h,isActive:i}}(this),function(){var a=function(){return!0},b=c.util.indexOf,d=function(a,b){return function(c){return a(c[b])}},e=function(a,d){return function(e){e=d?e[d]:e;var f,g=0;if(c.util.isArray(e)){if(c.util.isArray(a)){if(f=e.length,f!==a.length)return!1;for(;f>g;){if(f--,-1===b(a,e[g])||-1===b(a,e[f]))return!1;g++}return!0}return b(e,a)>-1}return e===a}},f=function(a,b){var c=e(a,b);return function(a){return!c(a)}},g=function(a,d){return function(e){e=d?e[d]:e;var f,g=0;if(c.util.isArray(e)){for(f=e.length;f>g;){if(f--,b(a,e[g])>-1||b(a,e[f])>-1)return!0;g++}return!1}return b(a,e)>-1}},h=function(a,b){var c=g(a,b);return function(a){return!c(a)}},i=function(a){return a=new c.vector(a),function(b){var d=b.aabb();return c.aabb.contains(d,a)}},j=function(a){return a.next?function(b){for(var c=a;c;){if(!c(b))return!1;c=c.next}return!0}:a},k=function(a){return a.next?function(b){for(var c=a;c;){if(c(b))return!0;c=c.next}return!1}:a},l={$eq:e,$ne:f,$in:g,$nin:h,$at:i},m=function n(b,f){var g,h,i,m,o,p;if(f){if("$or"===f||"$and"===f){for(g=0,h=b.length;h>g;++g)p=n(b[g]),o=o?o.next=p:m=p;return"$or"===f?k(m):j(m)}if(g=l[f])return g(b);throw"Unknown query operation: "+f}for(g in b)i=b[g],p="$"===g[0]?n(i,g):c.util.isPlainObject(i)?d(n(i),g):e(i,g),o=o?o.next=p:m=p;return j(m||a)};c.query=m}(this),function(){var a={priority:0};c.behavior=d("behavior",{init:function(b){this.options=c.util.options(a),this.options(b)},applyTo:function(a){return this._targets=a===!0?null:c.util.uniq(a),this},getTargets:function(){return this._targets||(this._world?this._world._bodies:[])},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},connect:function(a){this.behave&&a.on("integrate:positions",this.behave,this,this.options.priority)},disconnect:function(a){this.behave&&a.off("integrate:positions",this.behave,this)},behave:null})}(),function(){{var a={hidden:!1,treatment:"dynamic",mass:1,restitution:1,cof:.8,view:null},b=1;2*Math.PI}c.body=d("body",{init:function(d){var e=this,f=c.vector;if(this.options=c.util.options(a,this),this.options.onChange(function(a){e.offset=new f(a.offset)}),this.options(d),this.state={pos:new f(this.x,this.y),vel:new f(this.vx,this.vy),acc:new f,angular:{pos:this.angle||0,vel:this.angularVelocity||0,acc:0},old:{pos:new f,vel:new f,acc:new f,angular:{pos:0,vel:0,acc:0}}},this._sleepAngPosMean=0,this._sleepAngPosVariance=0,this._sleepPosMean=new f,this._sleepPosVariance=new f,this._sleepMeanK=0,delete this.x,delete this.y,delete this.vx,delete this.vy,delete this.angle,delete this.angularVelocity,0===this.mass)throw"Error: Bodies must have non-zero mass";this.uid=b++,this.geometry=c.geometry("point")},sleep:function(a){return a===!0?this.asleep=!0:a===!1?(this.asleep=!1,this._sleepMeanK=0,this._sleepAngPosMean=0,this._sleepAngPosVariance=0,this._sleepPosMean.zero(),this._sleepPosVariance.zero(),this.sleepIdleTime=0):a&&!this.asleep&&this.sleepCheck(a),this.asleep},sleepCheck:function(a){var b=this._world&&this._world.options;if(!(this.sleepDisabled||b&&b.sleepDisabled)){{var d,e,f,g,h,i,j=c.scratchpad();j.vector(),j.vector()}if(a=a||0,g=this.geometry.aabb(),f=Math.max(g.hw,g.hh),this.asleep&&(e=this.state.vel.norm()+Math.abs(f*this.state.angular.vel),d=this.sleepSpeedLimit||b&&b.sleepSpeedLimit||0,e>=d))return this.sleep(!1),j.done();this._sleepMeanK++,h=this._sleepMeanK>1?1/(this._sleepMeanK-1):0,c.statistics.pushRunningVectorAvg(this.state.pos,this._sleepMeanK,this._sleepPosMean,this._sleepPosVariance),i=c.statistics.pushRunningAvg(Math.sin(this.state.angular.pos),this._sleepMeanK,this._sleepAngPosMean,this._sleepAngPosVariance),this._sleepAngPosMean=i[0],this._sleepAngPosVariance=i[1],e=this._sleepPosVariance.norm()+Math.abs(f*Math.asin(i[1])),e*=h,d=this.sleepVarianceLimit||b&&b.sleepVarianceLimit||0,d>=e?(d=this.sleepTimeLimit||b&&b.sleepTimeLimit||0,this.sleepIdleTime=(this.sleepIdleTime||0)+a,this.sleepIdleTime>d&&(this.asleep=!0)):this.sleep(!1),j.done()}},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},accelerate:function(a){return"dynamic"===this.treatment&&this.state.acc.vadd(a),this},applyForce:function(a,b){if("dynamic"!==this.treatment)return this;var d,e=c.scratchpad(),f=e.vector();return b&&this.moi&&(d=this.state,f.clone(b),this.state.angular.acc-=f.cross(a)/this.moi),this.accelerate(f.clone(a).mult(1/this.mass)),e.done(),this},getGlobalOffset:function(a){return a=a||new c.vector,a.clone(this.offset).rotate(this.state.angular.pos),a},aabb:function(){var a=this.state.angular.pos,b=c.scratchpad(),d=b.vector(),e=this.geometry.aabb(a);return this.getGlobalOffset(d),e.x+=this.state.pos._[0]+d._[0],e.y+=this.state.pos._[1]+d._[1],b.done(e)},toBodyCoords:function(a){return a.vsub(this.state.pos).rotate(-this.state.angular.pos)},toWorldCoords:function(a){return a.rotate(this.state.angular.pos).vadd(this.state.pos)},recalc:function(){return this}}),c.body.getCOM=function(a,b){var d,e,f,g=a&&a.length,h=0;if(b=b||new c.vector,!g)return b.zero();if(1===g)return b.clone(a[0].state.pos);for(b.zero(),f=0;g>f;f++)d=a[f],e=d.state.pos,b.add(e._[0]*d.mass,e._[1]*d.mass),h+=d.mass;return b.mult(1/h),b}}(),function(){c.geometry=d("geometry",{init:function(a){this.options=c.util.options(),this.options(a),this._aabb=new c.aabb},aabb:function(){return c.aabb.clone(this._aabb)},getFarthestHullPoint:function(a,b){return b=b||new c.vector,b.set(0,0)},getFarthestCorePoint:function(a,b){return b=b||new c.vector,b.set(0,0)}})}(),c.geometry.regularPolygonVertices=function(a,b){var c,d=[],e=2*Math.PI/a,f=0;for(c=0;a>c;c++)d.push({x:b*Math.cos(f),y:b*Math.sin(f)}),f+=e;return d},c.geometry.isPolygonConvex=function(a){var b=c.scratchpad(),d=b.vector(),e=b.vector(),f=b.vector(),g=!0,h=!1,i=a.length;if(!a||!i)return!1;if(3>i)return b.done(),g;d.clone(a[0]).vsub(f.clone(a[i-1]));for(var j=1;i>=j;++j){if(e.clone(a[j%i]).vsub(f.clone(a[(j-1)%i])),h===!1)h=d.cross(e);else if(h>0^d.cross(e)>0){g=!1;break}e.swap(d)}return b.done(),g},c.geometry.getPolygonMOI=function(a){var b,d=c.scratchpad(),e=d.vector(),f=d.vector(),g=0,h=0,i=a.length;if(2>i)return d.done(),0;if(2===i)return b=f.clone(a[1]).distSq(e.clone(a[0])),d.done(),b/12;e.clone(a[0]);for(var j=1;i>j;++j)f.clone(a[j]),b=Math.abs(f.cross(e)),g+=b*(f.normSq()+f.dot(e)+e.normSq()),h+=b,e.swap(f);return d.done(),g/(6*h)},c.geometry.isPointInPolygon=function(a,b){var d=c.scratchpad(),e=d.vector().clone(a),f=d.vector(),g=d.vector(),h=0,i=b.length;if(2>i)return h=e.equals(f.clone(b[0])),d.done(),h;if(2===i)return h=e.angle(f.clone(b[0])),h+=e.angle(f.clone(b[1])),d.done(),Math.abs(h)===Math.PI;f.clone(b[0]).vsub(e);for(var j=1;i>=j;++j)g.clone(b[j%i]).vsub(e),h+=g.angle(f),f.swap(g);return d.done(),Math.abs(h)>1e-6},c.geometry.getPolygonArea=function(a){var b=c.scratchpad(),d=b.vector(),e=b.vector(),f=0,g=a.length;if(3>g)return b.done(),0;d.clone(a[g-1]);for(var h=0;g>h;++h)e.clone(a[h]),f+=d.cross(e),d.swap(e);return b.done(),f/2},c.geometry.getPolygonCentroid=function(a){var b,d=c.scratchpad(),e=d.vector(),f=d.vector(),g=new c.vector,h=a.length;if(2>h)return d.done(),new c.vector(a[0]);if(2===h)return d.done(),new c.vector((a[1].x+a[0].x)/2,(a[1].y+a[0].y)/2);e.clone(a[h-1]);for(var i=0;h>i;++i)f.clone(a[i]),b=e.cross(f),e.vadd(f).mult(b),g.vadd(e),e.swap(f);return b=1/(6*c.geometry.getPolygonArea(a)),d.done(),g.mult(b)},c.geometry.nearestPointOnLine=function(a,b,d){var e,f,g=c.scratchpad(),h=g.vector().clone(a),i=g.vector().clone(b).vsub(h),j=g.vector().clone(d).vsub(h).vsub(i);return j.equals(c.vector.zero)?(g.done(),new c.vector(b)):(e=-j.dot(i)/j.normSq(),f=1-e,0>=f?(g.done(),new c.vector(d)):0>=e?(g.done(),new c.vector(b)):(h=new c.vector(d).mult(e).vadd(i.clone(b).mult(f)),g.done(),h))},function(){var a={drag:0};c.integrator=d("integrator",{init:function(b){this.options=c.util.options(a),this.options(b)},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},integrate:function(a,b){var c=this._world;return this.integrateVelocities(a,b),c&&c.emit("integrate:velocities",{bodies:a,dt:b}),this.integratePositions(a,b),c&&c.emit("integrate:positions",{bodies:a,dt:b}),this},connect:null,disconnect:null,integrateVelocities:function(){throw"The integrator.integrateVelocities() method must be overriden"},integratePositions:function(){throw"The integrator.integratePositions() method must be overriden"}})}(),function(){var e={meta:!1,metaRefresh:200,width:600,height:600,autoResize:!0};c.renderer=d("renderer",{init:function(d){var f=this,g="string"==typeof d.el?b.getElementById(d.el):d.el;this.options=c.util.options(e),this.options(d),this.el=g?g:b.body,this.container=g&&g.parentNode?g.parentNode:b.body,this.drawMeta=c.util.throttle(c.util.bind(this.drawMeta,this),this.options.metaRefresh),a.addEventListener("resize",c.util.throttle(function(){f.options.autoResize&&f.resize()}),100)},resize:function(a,b){void 0===a&&void 0===b&&(a=this.container.offsetWidth,b=this.container.offsetHeight),this.width=a||0,this.height=b||0},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},render:function(a,b){var c,d;this.beforeRender&&this.beforeRender(),this._world.emit("beforeRender",{renderer:this,bodies:a,meta:b}),this.options.meta&&this.drawMeta(b),this._interpolateTime=b.interpolateTime;for(var e=0,f=a.length;f>e;++e)c=a[e],d=c.view||(c.view=this.createView(c.geometry,c.styles)),c.hidden||this.drawBody(c,d);return this},createView:function(){throw"You must override the renderer.createView() method."},drawMeta:function(){throw"You must override the renderer.drawMeta() method."},drawBody:function(){throw"You must override the renderer.drawBody() method."}})}(),function(){var a=function e(a,b,c){for(var d,f,g=function(){return e(a,b,c)};d=a.shift();)if(f=d.apply(b,c),f&&f.then)return f.then(g)},b={timestep:6,maxIPF:4,webworker:!1,integrator:"verlet",sleepDisabled:!1,sleepSpeedLimit:.05,sleepVarianceLimit:.02,sleepTimeLimit:500},d=function f(a,b){return this instanceof f?void this.init(a,b):new f(a,b)};d.prototype=c.util.extend({},c.util.pubsub.prototype,{init:function(d,e){var f=this;(c.util.isFunction(d)||c.util.isArray(d))&&(e=d,d={}),this._meta={fps:0,ipf:0},this._bodies=[],this._behaviors=[],this._integrator=null,this._renderer=null,this._paused=!1,this._warp=1,this._time=0,this.options=c.util.options(b),this.options.onChange(function(a){f.timestep(a.timestep)}),this.options(d),this.add(c.integrator(this.options.integrator)),c.util.isFunction(e)?a([e],this,[this,c]):c.util.isArray(e)&&a(e,this,[this,c])},options:null,add:function(a){var b=0,d=a&&a.length||0,e=c.util.isArray(a)?a[0]:a;if(!e)return this;do switch(e.type){case"behavior":this.addBehavior(e);break;case"integrator":this.integrator(e);break;case"renderer":this.renderer(e);break;case"body":this.addBody(e);break;default:throw'Error: failed to add item of unknown type "'+e.type+'" to world'}while(++b-1},integrator:function(a){return void 0===a?this._integrator:this._integrator===a?this:(this._integrator&&(this._integrator.setWorld(null),this.emit("remove:integrator",{integrator:this._integrator})),a&&(this._integrator=a,this._integrator.setWorld(this),this.emit("add:integrator",{integrator:this._integrator})),this)},renderer:function(a){return void 0===a?this._renderer:this._renderer===a?this:(this._renderer&&(this._renderer.setWorld(null),this.emit("remove:renderer",{renderer:this._renderer})),a&&(this._renderer=a,this._renderer.setWorld(this),this.emit("add:renderer",{renderer:this._renderer})),this)},timestep:function(a){return a?(this._dt=+a.toPrecision(4),this._maxJump=a*this.options.maxIPF,this):this._dt},wakeUpAll:function(){var a=0,b=this._bodies.length;for(a=0;b>a;a++)this._bodies[a].sleep(!1)},addBehavior:function(a){return this.has(a)?this:(a.setWorld(this),this._behaviors.push(a),this.emit("add:behavior",{behavior:a}),this)},getBehaviors:function(){return[].concat(this._behaviors)},removeBehavior:function(a){var b=this._behaviors;if(a)for(var c=0,d=b.length;d>c;++c)if(a===b[c]){b.splice(c,1),a.setWorld(null),this.emit("remove:behavior",{behavior:a});break}return this},addBody:function(a){return this.has(a)?this:(a.setWorld(this),this._bodies.push(a),this.emit("add:body",{body:a}),this)},getBodies:function(){return[].concat(this._bodies)},removeBody:function(a){var b=this._bodies;if(a)for(var c=0,d=b.length;d>c;++c)if(a===b[c]){b.splice(c,1),a.setWorld(null),this.emit("remove:body",{body:a});break}return this},findOne:function(a){var b=this,d="function"==typeof a?a:c.query(a);return c.util.find(b._bodies,d)||!1},find:function(a){var b=this,d="function"==typeof a?a:c.query(a);return c.util.filter(b._bodies,d)},iterate:function(a){this._integrator.integrate(this._bodies,a)},step:function(a){var b,d,e,f=this._time,g=this._warp,h=1/g,i=this._dt,j=i*h,k=this._maxJump*h,l=this._meta;if(this._paused||void 0===this._animTime)return this._animTime=a||this._animTime||c.util.ticker.now(),this._paused||this.emit("step",l),this;if(a=a||this._animTime+j,b=a-this._animTime,b>k&&(this._animTime=a-k,b=k),d=b*g,e=f+d-i,this.emit("beforeStep"),e>=f)for(;e>=f;)f+=i,this._animTime+=j,this._time=f,this.iterate(i);return l.fps=1e3/(a-this._lastTime),l.ipf=(d/i).toFixed(2),l.interpolateTime=i+e-f,this._lastTime=a,this.emit("step",l),this},warp:function(a){return void 0===a?this._warp:(this._warp=a||1,this)},render:function(){if(!this._renderer)throw"No renderer added to world";return this._renderer.render(this._bodies,this._meta),this.emit("render",{bodies:this._bodies,meta:this._meta,renderer:this._renderer}),this},pause:function(){return this._paused=!0,this.emit("pause"),this},unpause:function(){return this._paused=!1,this.emit("unpause"),this},isPaused:function(){return!!this._paused},destroy:function(){var a=this;a.pause(),this.emit("destroy"),a.off(!0),a.remove(a.getBodies()),a.remove(a.getBehaviors()),a.integrator(null),a.renderer(null) -}}),c.world=d}(),c.integrator("verlet",function(a){return c.body.mixin({started:function(a){return void 0!==a&&(this._started=!0),!!this._started}}),{init:function(b){a.init.call(this,b)},integrateVelocities:function(a,b){for(var c,d=b*b,e=1-this.options.drag,f=null,g=this.prevDt||b,h=.5*(d+b*g),i=0,j=a.length;j>i;++i)f=a[i],c=f.state,"static"===f.treatment||f.sleep(b)?(c.vel.zero(),c.acc.zero(),c.angular.vel=0,c.angular.acc=0):(c.vel.equals(c.old.vel)&&f.started()?c.vel.clone(c.pos).vsub(c.old.pos):(c.old.pos.clone(c.pos).vsub(c.vel),c.vel.mult(b)),e&&c.vel.mult(e),c.vel.vadd(c.acc.mult(h)),c.vel.mult(1/b),c.old.vel.clone(c.vel),c.acc.zero(),c.angular.vel===c.old.angular.vel&&f.started()?c.angular.vel=c.angular.pos-c.old.angular.pos:(c.old.angular.pos=c.angular.pos-c.angular.vel,c.angular.vel*=b),c.angular.vel+=c.angular.acc*h,c.angular.vel/=b,c.old.angular.vel=c.angular.vel,c.angular.acc=0,f.started(!0))},integratePositions:function(a,b){for(var c,d=null,e=this.prevDt||b,f=b/e,g=0,h=a.length;h>g;++g)d=a[g],c=d.state,"static"===d.treatment||d.sleep()||(c.vel.mult(b*f),c.old.pos.clone(c.pos),c.pos.vadd(c.vel),c.vel.mult(1/(b*f)),c.old.vel.clone(c.vel),c.angular.vel*=b*f,c.old.angular.pos=c.angular.pos,c.angular.pos+=c.angular.vel,c.angular.vel/=b*f,c.old.angular.vel=c.angular.vel);this.prevDt=b}}}),c.geometry("point",function(){}),c.body("point",function(a){return{init:function(b){a.init.call(this,b),this.moi=0}}}),c.geometry("circle",function(a){var b={radius:1};return{init:function(d){a.init.call(this,d),this.options.defaults(b),this.options.onChange(function(a){this.radius=a.radius}),this.options(d),this._aabb=c.aabb(),this.radius=this.options.radius},aabb:function(){var a=this.radius;return this._aabb.hw!==a&&(this._aabb=c.aabb(-a,-a,a,a)),c.aabb.clone(this._aabb)},getFarthestHullPoint:function(a,b){return b=b||new c.vector,b.clone(a).normalize().mult(this.radius)},getFarthestCorePoint:function(a,b,d){return b=b||new c.vector,b.clone(a).normalize().mult(this.radius-d)}}}),c.geometry("compound",function(a){var b={};return{init:function(c){a.init.call(this,c),this.options.defaults(b),this.options(c),this.children=[]},addChild:function(a,b,d){return this._aabb=null,this.children.push({g:a,pos:new c.vector(b),angle:d}),this},clear:function(){return this._aabb=null,this.children=[],this},aabb:function(a){if(!a&&this._aabb)return c.aabb.clone(this._aabb);var b,d,e,f=c.scratchpad(),g=c.vector();a=a||0;for(var h=0,i=this.children.length;i>h;h++)d=this.children[h],b=d.g.aabb(a+d.angle),g.clone(d.pos),a&&g.rotate(a),b.x+=g._[0],b.y+=g._[1],e=e?c.aabb.union(e,b,!0):b;return a||(this._aabb=c.aabb.clone(e)),f.done(e)},getFarthestHullPoint:function(a,b){var d,e,f=this.children.length,g=c.scratchpad(),h=g.vector(),i=0,j=0;for(b=b||new c.vector,e=0;f>e;e++)d=this.children[e],d.g.getFarthestHullPoint(a.rotate(-d.angle),h),i=h.rotate(d.angle).vadd(d.pos).proj(a.rotate(d.angle)),i>j&&(j=i,b.swap(h));return g.done(b)},getFarthestCorePoint:function(a,b,d){var e,f,g=this.children.length,h=c.scratchpad(),i=h.vector(),j=0,k=0;for(b=b||new c.vector,f=0;g>f;f++)e=this.children[f],e.g.getFarthestCorePoint(a.rotate(-e.angle),i,d),j=i.rotate(e.angle).vadd(e.pos).proj(a.rotate(e.angle)),j>k&&(k=j,b.swap(i));return h.done(b)}}}),c.geometry("convex-polygon",function(a){var b="Error: The vertices specified do not match that of a _convex_ polygon.",d={};return{init:function(b){var c=this;a.init.call(this,b),this.options.defaults(d),this.options.onChange(function(a){c.setVertices(a.vertices||[])}),this.options(b),c.setVertices(this.options.vertices||[])},setVertices:function(a){var d=c.scratchpad(),e=d.transform(),f=this.vertices=[];if(!c.geometry.isPolygonConvex(a))throw b;e.setRotation(0),e.setTranslation(c.geometry.getPolygonCentroid(a).negate());for(var g=0,h=a.length;h>g;++g)f.push(new c.vector(a[g]).translate(e));return this._area=c.geometry.getPolygonArea(f),this._aabb=!1,d.done(this)},aabb:function(a){if(!a&&this._aabb)return c.aabb.clone(this._aabb);var b,d=c.scratchpad(),e=d.vector(),f=d.transform().setRotation(a||0),g=d.vector().set(1,0).rotateInv(f),h=d.vector().set(0,1).rotateInv(f),i=this.getFarthestHullPoint(g,e).proj(g),j=-this.getFarthestHullPoint(g.negate(),e).proj(g),k=this.getFarthestHullPoint(h,e).proj(h),l=-this.getFarthestHullPoint(h.negate(),e).proj(h);return b=c.aabb(j,l,i,k),a||(this._aabb=c.aabb.clone(b)),d.done(),b},getFarthestHullPoint:function(a,b,d){var e,f,g,h=this.vertices,i=h.length,j=2;if(b=b||new c.vector,2>i)return d&&(d.idx=0),b.clone(h[0]);if(f=h[0].dot(a),e=h[1].dot(a),2===i)return g=e>=f?1:0,d&&(d.idx=g),b.clone(h[g]);if(e>=f){for(;i>j&&e>=f;)f=e,e=h[j].dot(a),j++;return e>=f&&j++,g=j-2,d&&(d.idx=j-2),b.clone(h[g])}for(j=i;j>1&&f>=e;)j--,e=f,f=h[j].dot(a);return g=(j+1)%i,d&&(d.idx=g),b.clone(h[g])},getFarthestCorePoint:function(a,b,d){var e,f=c.scratchpad(),g=f.vector(),h=f.vector(),i=this.vertices,j=i.length,k=this._area>0,l={};return b=this.getFarthestHullPoint(a,b,l),g.clone(i[(l.idx+1)%j]).vsub(b).normalize().perp(k),h.clone(i[(l.idx-1+j)%j]).vsub(b).normalize().perp(!k),e=d/(1+g.dot(h)),b.vadd(g.vadd(h).mult(e)),f.done(),b}}}),c.geometry("rectangle",function(a){var b={};return{init:function(c){var d=this;a.init.call(this,c),this.options.defaults(b),this.options.onChange(function(){d.width=d.options.width||1,d.height=d.options.height||1}),this.options(c)},aabb:function(a){if(!a)return c.aabb(this.width,this.height);var b=c.scratchpad(),d=b.vector(),e=b.transform().setRotation(a||0),f=b.vector().set(1,0).rotateInv(e),g=b.vector().set(0,1).rotateInv(e),h=this.getFarthestHullPoint(f,d).proj(f),i=-this.getFarthestHullPoint(f.negate(),d).proj(f),j=this.getFarthestHullPoint(g,d).proj(g),k=-this.getFarthestHullPoint(g.negate(),d).proj(g);return b.done(),c.aabb(i,k,h,j)},getFarthestHullPoint:function(a,b){b=b||new c.vector;var d=a.x,e=a.y;return d=0===d?0:0>d?.5*-this.width:.5*this.width,e=0===e?0:0>e?.5*-this.height:.5*this.height,b.set(d,e)},getFarthestCorePoint:function(a,b,c){var d,e;return b=this.getFarthestHullPoint(a,b),d=b.x,e=b.y,b.x=0===d?0:0>d?d+c:d-c,b.y=0===e?0:0>e?e+c:e-c,b}}}),c.body("circle",function(a){var b={radius:1};return{init:function(d){a.init.call(this,d),d=c.util.extend({},b,d),this.geometry=c.geometry("circle",{radius:d.radius}),this.recalc()},recalc:function(){a.recalc.call(this),this.moi=this.mass*this.geometry.radius*this.geometry.radius/2}}}),c.body("compound",function(a){return{init:function(b){a.init.call(this,b),this.mass=0,this.moi=0,this.children=[],this.geometry=c.geometry("compound"),this.addChildren(b.children)},connect:function(){if(this.mass<=0)throw"Can not add empty compound body to world."},addChild:function(a){return this.addChildren([a]),this},addChildren:function(a){var b,d,e,f=this,g=c.scratchpad(),h=g.vector().zero(),i=a&&a.length,j=0;if(!i)return g.done(this);for(e=0;i>e;e++)b=a[e],b._world&&b._world.remove(b),this.children.push(b),this.geometry.addChild(b.geometry,new c.vector(b.offset).rotate(b.state.angular.pos).vadd(b.state.pos),b.state.angular.pos),d=b.state.pos,h.add(d._[0]*b.mass,d._[1]*b.mass),j+=b.mass;return this.mass+=j,h.mult(1/this.mass),this.offset.vsub(h),this._world&&this._world.one("render",function(){f.view=null}),this.recalc(),g.done(this)},clear:function(){return this._aabb=null,this.moi=0,this.mass=0,this.offset.zero(),this.children=[],this.geometry.clear(),this},refreshGeometry:function(){this.geometry.clear();for(var a,b=0,d=this.children.length;d>b;b++)a=this.children[b],this.geometry.addChild(a.geometry,new c.vector(a.state.pos).vadd(a.offset),a.state.angular.pos);return this},recalc:function(){a.recalc.call(this);for(var b,c=0,d=0,e=this.children.length;e>d;d++)b=this.children[d],b.recalc(),c+=b.moi+b.mass*b.state.pos.normSq();return this.moi=c,this}}}),c.body("convex-polygon",function(a){var b={};return{init:function(d){a.init.call(this,d),d=c.util.extend({},b,d),this.geometry=c.geometry("convex-polygon",{vertices:d.vertices}),this.recalc()},recalc:function(){a.recalc.call(this),this.moi=c.geometry.getPolygonMOI(this.geometry.vertices)}}}),c.body("rectangle",function(a){var b={};return{init:function(d){a.init.call(this,d),d=c.util.extend({},b,d),this.geometry=c.geometry("rectangle",{width:d.width,height:d.height}),this.recalc()},recalc:function(){var b=this.geometry.width,c=this.geometry.height;a.recalc.call(this),this.moi=(b*b+c*c)*this.mass/12}}}),c.behavior("attractor",function(a){var b={pos:null,strength:1,order:2,max:!1,min:!1};return{init:function(d){var e=this;this._pos=new c.vector,a.init.call(this),this.options.defaults(b),this.options.onChange(function(a){e._maxDist=a.max===!1?1/0:a.max,e._minDist=a.min?a.min:10,e.position(a.pos)}),this.options(d)},position:function(a){var b=this;return a?(this._pos.clone(a),b):this._pos.values()},behave:function(){for(var a,b,d,e=this.getTargets(),f=this.options.order,g=this.options.strength,h=this._minDist,i=this._maxDist,j=c.scratchpad(),k=j.vector(),l=0,m=e.length;m>l;l++)a=e[l],k.clone(this._pos),k.vsub(a.state.pos),b=k.norm(),b>h&&i>b&&(d=g/Math.pow(b,f),a.accelerate(k.normalize().mult(d)));j.done()}}}),c.behavior("body-collision-detection",function(a){var b=[],d=function(a,d){var e=c.util.pairHash(a.uid,d.uid),f=b[e];return f||(f=b[e]=function(b){var c=f.tA,e=f.tB,g=f.tmpv1,h=f.tmpv2;return f.useCore?(g=a.geometry.getFarthestCorePoint(b.rotateInv(c),g,f.marginA),h=d.geometry.getFarthestCorePoint(b.rotate(c).rotateInv(e).negate(),h,f.marginB)):(g=a.geometry.getFarthestHullPoint(b.rotateInv(c),g),h=d.geometry.getFarthestHullPoint(b.rotate(c).rotateInv(e).negate(),h)),g.vadd(a.offset).transform(c),h.vadd(d.offset).transform(e),b.negate().rotate(e),{a:g.values(),b:h.values(),pt:g.vsub(h).values()}},f.tA=new c.transform,f.tB=new c.transform,f.tmpv1=new c.vector,f.tmpv2=new c.vector),f.useCore=!1,f.margin=0,f.tA.setRotation(a.state.angular.pos).setTranslation(a.state.pos),f.tB.setRotation(d.state.angular.pos).setTranslation(d.state.pos),f.bodyA=a,f.bodyB=d,f},e=function(a,b){var e,f,g,h,i=c.scratchpad(),j=i.vector(),k=i.vector(),l=i.vector(),m=!1,n=a.aabb(),o=Math.min(n.hw,n.hh),p=b.aabb(),q=Math.min(p.hw,p.hh);if(g=d(a,b),j.clone(a.state.pos).vadd(a.getGlobalOffset(l)).vsub(b.state.pos).vsub(b.getGlobalOffset(l)),f=c.gjk(g,j,!0),f.overlap){for(m={bodyA:a,bodyB:b},h=.01*Math.min(o||1,q||1),g.useCore=!0,g.marginA=0,g.marginB=0;(f.overlap||0===f.distance)&&(g.marginA=e)return i.done(!1);m.overlap=e,m.norm=j.clone(f.closest.b).vsub(k.clone(f.closest.a)).normalize().values(),m.mtv=j.mult(e).values(),m.pos=j.clone(m.norm).mult(g.marginA).vadd(k.clone(f.closest.a)).vsub(a.state.pos).values()}return i.done(m)},f=function(a,b){var d,e=c.scratchpad(),f=e.vector(),g=e.vector(),h=!1;return f.clone(b.state.pos).vadd(b.getGlobalOffset(g)).vsub(a.state.pos).vsub(a.getGlobalOffset(g)),d=f.norm()-(a.geometry.radius+b.geometry.radius),f.equals(c.vector.zero)&&f.set(1,0),0>=d&&(h={bodyA:a,bodyB:b,norm:f.normalize().values(),mtv:f.mult(-d).values(),pos:f.mult(-a.geometry.radius/d).vadd(g).values(),overlap:-d}),e.done(h)},g=function i(a,b){if(!("static"!==a.treatment&&"kinematic"!==a.treatment||"static"!==b.treatment&&"kinematic"!==b.treatment))return!1;if("circle"===a.geometry.name&&"circle"===b.geometry.name)return f(a,b);if("compound"===a.geometry.name||"compound"===b.geometry.name){var d,g,h,j,k="compound"===a.geometry.name,l=k?a:b,m=k?b:a,n=[],o=c.scratchpad(),p=(o.vector(),o.vector()),q=m.aabb();for(h=0,j=l.children.length;j>h;h++){if(g=l.children[h],p.clone(g.state.pos),g.offset.vadd(p.vadd(l.offset).rotate(-g.state.angular.pos)),g.state.pos.clone(l.state.pos),g.state.angular.pos+=l.state.angular.pos,c.aabb.overlap(q,g.aabb()))if(d=i(m,g),d instanceof Array)for(var r,s=0,t=d.length;t>s;s++)r=d[s],r.bodyA===g?r.bodyA=l:r.bodyB=l,n.push(r);else d&&(d.bodyA===g?d.bodyA=l:d.bodyB=l,n.push(d));g.state.angular.pos-=l.state.angular.pos,g.offset.vsub(p),g.state.pos.clone(p.rotate(g.state.angular.pos).vsub(l.offset))}return o.done(n)}return e(a,b)},h={check:"collisions:candidates",channel:"collisions:detected"};return{init:function(b){a.init.call(this),this.options.defaults(h),this.options(b)},connect:function(a){this.options.check===!0?a.on("integrate:velocities",this.checkAll,this):a.on(this.options.check,this.check,this)},disconnect:function(a){this.options.check===!0?a.off("integrate:velocities",this.checkAll,this):a.off(this.options.check,this.check,this)},check:function(a){for(var b,d,e,f=a.candidates,h=this.getTargets(),i=[],j=this.prevContacts||{},k={},l=c.util.pairHash,m=0,n=f.length;n>m;++m)if(b=f[m],h===this._world._bodies||c.util.indexOf(h,b.bodyA)>-1&&c.util.indexOf(h,b.bodyB)>-1)if(d=g(b.bodyA,b.bodyB),d instanceof Array)for(var o,p=0,q=d.length;q>p;p++)o=d[p],o&&(e=l(b.bodyA.uid,b.bodyB.uid),k[e]=!0,o.collidedPreviously=j[e],i.push(o));else d&&(e=l(b.bodyA.uid,b.bodyB.uid),k[e]=!0,d.collidedPreviously=j[e],i.push(d));this.prevContacts=k,i.length&&this._world.emit(this.options.channel,{collisions:i})},checkAll:function(a){for(var b,d,e,f,h=this.getTargets(),i=(a.dt,[]),j=this.prevContacts||{},k={},l=c.util.pairHash,m=0,n=h.length;n>m;m++){b=h[m];for(var o=m+1;n>o;o++)if(d=h[o],e=g(b,d),e instanceof Array)for(var p,q=0,r=e.length;r>q;q++)p=e[q],p&&(f=l(b.uid,d.uid),k[f]=!0,p.collidedPreviously=j[f],i.push(p));else e&&(f=l(b.uid,d.uid),k[f]=!0,e.collidedPreviously=j[f],i.push(e))}this.prevContacts=k,i.length&&this._world.emit(this.options.channel,{collisions:i})}}}),c.behavior("body-impulse-response",function(a){function b(a){return a.uid}function d(a,b,c){var d,e;return e=b.norm(),d=e-a.proj(b),d=Math.max(0,Math.min(e,d)),0===e?c.zero():c.clone(b).mult(d/e),c}var e={check:"collisions:detected",mtvThreshold:1,bodyExtractDropoff:.5,forceWakeupAboveOverlapThreshold:!0};return{init:function(b){a.init.call(this),this.options.defaults(e),this.options(b),this._bodyList=[]},applyTo:!1,connect:function(a){a.on(this.options.check,this.respond,this)},disconnect:function(a){a.off(this.options.check,this.respond,this)},collideBodies:function(a,b,e,f,g,h){var i="static"===a.treatment||"kinematic"===a.treatment,j="static"===b.treatment||"kinematic"===b.treatment,k=c.scratchpad(),l=k.vector().clone(g);if(i&&j)return void k.done();var m,n,o,p,q=i?0:1/a.moi,r=j?0:1/b.moi,s=i?0:1/a.mass,t=j?0:1/b.mass,u=a.restitution*b.restitution,v=a.cof*b.cof,w=k.vector().clone(e),x=k.vector().clone(w).perp(),y=k.vector(),z=k.vector().clone(f),A=k.vector().clone(f).vadd(a.state.pos).vsub(b.state.pos),B=a.state.angular.vel,C=b.state.angular.vel,D=k.vector().clone(b.state.vel).vadd(y.clone(A).perp().mult(C)).vsub(a.state.vel).vsub(y.clone(z).perp().mult(B)),E=z.proj(w),F=z.proj(x),G=A.proj(w),H=A.proj(x),I=D.proj(w),J=D.proj(x);return h&&(i?(d(b._mtvTotal,l,y),b._mtvTotal.vadd(y)):j?(d(a._mtvTotal,l.negate(),y),a._mtvTotal.vadd(y),l.negate()):(p=.5,l.mult(p),d(b._mtvTotal,l,y),b._mtvTotal.vadd(y),l.clone(g).mult(p-1),d(a._mtvTotal,l,y),a._mtvTotal.vadd(y))),I>=0?void k.done():(q=1/0===q?0:q,r=1/0===r?0:r,m=-((1+u)*I)/(s+t+q*F*F+r*H*H),i?(b.state.vel.vadd(w.mult(m*t)),b.state.angular.vel-=m*r*H):j?(a.state.vel.vsub(w.mult(m*s)),a.state.angular.vel+=m*q*F):(b.state.vel.vadd(w.mult(m*t)),b.state.angular.vel-=m*r*H,a.state.vel.vsub(w.mult(s*b.mass)),a.state.angular.vel+=m*q*F),v&&J&&(o=Math.abs(J)/(s+t+q*E*E+r*G*G),n=0>J?-1:1,m=v*Math.abs(m),m=Math.min(m,o),m*=n,i?(b.state.vel.vsub(x.mult(m*t)),b.state.angular.vel-=m*r*G):j?(a.state.vel.vadd(x.mult(m*s)),a.state.angular.vel+=m*q*E):(b.state.vel.vsub(x.mult(m*t)),b.state.angular.vel-=m*r*G,a.state.vel.vadd(x.mult(s*b.mass)),a.state.angular.vel+=m*q*E)),a.sleep()&&a.sleepCheck(),b.sleep()&&b.sleepCheck(),void k.done())},_pushUniq:function(a){var d=c.util.sortedIndex(this._bodyList,a,b);this._bodyList[d]!==a&&this._bodyList.splice(d,0,a)},respond:function(a){var b,d,e,f,g=this,h=a.collisions;for(d=0,e=h.length;e>d;++d)b=h[d],this._pushUniq(b.bodyA),this._pushUniq(b.bodyB),b.bodyA._mtvTotal=b.bodyA._mtvTotal||new c.vector,b.bodyB._mtvTotal=b.bodyB._mtvTotal||new c.vector,b.bodyA._oldmtvTotal=b.bodyA._oldmtvTotal||new c.vector,b.bodyB._oldmtvTotal=b.bodyB._oldmtvTotal||new c.vector,g.collideBodies(b.bodyA,b.bodyB,b.norm,b.pos,b.mtv,b.collidedPreviously);for(d=0,e=this._bodyList.length;e>d;++d)f=this._bodyList.pop(),f._mtvTotal.normSq()b;++b)a[b].accelerate(this._acc)}}}),c.behavior("edge-collision-detection",function(a){var b=function(a,b,d){var e,f=a.aabb(),g=c.scratchpad(),h=a.getGlobalOffset(g.vector()),i=g.transform(),j=g.vector(),k=g.vector(),l=!1,m=[];return e=f.x+f.hw-b.max.x,e>=0&&(j.set(1,0).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:1,y:0},mtv:{x:e,y:0},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),e=f.y+f.hh-b.max.y,e>=0&&(j.set(0,1).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:0,y:1},mtv:{x:0,y:e},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),e=b.min.x-(f.x-f.hw),e>=0&&(j.set(-1,0).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:-1,y:0},mtv:{x:-e,y:0},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),e=b.min.y-(f.y-f.hh),e>=0&&(j.set(0,-1).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:0,y:-1},mtv:{x:0,y:-e},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),g.done(),m},d=function(a,c,d){return b(a,c,d)},e={aabb:null,restitution:.99,cof:1,channel:"collisions:detected"};return{init:function(b){a.init.call(this),this.options.defaults(e),this.options(b),this.setAABB(this.options.aabb),this.restitution=this.options.restitution,this.body=c.body("point",{treatment:"static",restitution:this.options.restitution,cof:this.options.cof})},setAABB:function(a){if(!a)throw"Error: aabb not set";return this._edges={min:{x:a.x-a.hw,y:a.y-a.hh},max:{x:a.x+a.hw,y:a.y+a.hh}},this},connect:function(a){a.on("integrate:positions",this.checkAll,this,2)},disconnect:function(a){a.off("integrate:positions",this.checkAll,this,2)},checkAll:function(a){for(var b,e,f,g=this.getTargets(),h=(a.dt,[]),i=this._edges,j=this.body,k=this.prevContacts||{},l={},m=c.util.pairHash,n=0,o=g.length;o>n;n++)if(b=g[n],"dynamic"===b.treatment&&(e=d(b,i,j))){f=m(b.uid,j.uid);for(var p=0,q=e.length;q>p;p++)l[f]=!0,e[p].collidedPreviously=k[f];h.push.apply(h,e)}this.prevContacts=l,h.length&&this._world.emit(this.options.channel,{collisions:h})}}}),c.behavior("interactive",function(d){if(!b)return{};var e={el:null,moveThrottle:10,minVel:{x:-5,y:-5},maxVel:{x:5,y:5}},f=function(a){var b=0,c=0;if(a.offsetParent)do b+=a.offsetLeft,c+=a.offsetTop;while(a=a.offsetParent);return{left:b,top:c}};return{init:function(a){var g=this;if(d.init.call(this),this.options.defaults(e),this.options(a),this.bodyData={},this.bodyDataByUID={},this.el="string"==typeof this.options.el?b.getElementById(this.options.el):this.options.el,!this.el)throw"No DOM element specified";g.grab=function(a){var b,d,e,h,i,j,k,l;if(g._world)for(a.changedTouches||(a.changedTouches=[a]),i=f(a.target),k=0,l=a.changedTouches.length;l>k;k++)h=a.changedTouches[k],e=h.identifier||h.pointerId||"mouse",b={idx:e,x:h.pageX-i.left,y:h.pageY-i.top},d=g._world.findOne({$at:new c.vector(b),$in:g.getTargets()}),d?(d.state.vel.zero(),d.state.angular.vel=0,d.isGrabbed=!0,j=g.bodyData[e]||{},j.body=d,d.sleep(!1),j.time=c.util.ticker.now(),j.treatment=g.bodyDataByUID[d.uid]?g.bodyDataByUID[d.uid].treatment:d.treatment,d.treatment="kinematic",j.pos=j.pos||new c.vector,j.pos.clone(b),j.offset=j.offset||new c.vector,j.offset.clone(b).vsub(d.state.pos),j.oldPos=j.oldPos||new c.vector,j.oldPos.clone(b),b.body=d,g.bodyData[e]=j,g.bodyDataByUID[d.uid]=j,g._world.emit("interact:grab",b)):g._world.emit("interact:poke",b)},g.move=c.util.throttle(function(a){var b,d,e,h,i,j,k,l;if(g._world)for(a.changedTouches||(a.changedTouches=[a]),i=f(g.el),k=0,l=a.changedTouches.length;l>k;k++)h=a.changedTouches[k],e=h.identifier||h.pointerId||"mouse",b={idx:e,x:h.pageX-i.left,y:h.pageY-i.top},j=g.bodyData[e],j&&(d=j.body,d.sleep(!1),j.time=c.util.ticker.now(),j.oldPos.clone(j.pos),j.pos.clone(b),b.body=d),g._world.emit("interact:move",b)},g.options.moveThrottle),g.release=function(a){var b,d,e,h,i,j,k,l,m;if(g._world)for(a.changedTouches||(a.changedTouches=[a]),l=0,m=a.changedTouches.length;m>l;l++)i=f(g.el),h=a.changedTouches[l],e=h.identifier||h.pointerId||"mouse",b={idx:e,x:h.pageX-i.left,y:h.pageY-i.top},j=g.bodyData[e],j&&(d=j.body,d.sleep(!1),j.pos.clone(b),k=Math.max(c.util.ticker.now()-j.time,g.options.moveThrottle),d.treatment=j.treatment,d.state.vel.clone(j.pos).vsub(j.oldPos).mult(1/k),d.state.vel.clamp(g.options.minVel,g.options.maxVel),d.isGrabbed=!1,b.body=d,delete d.isGrabbed),g._world.emit("interact:release",b),delete g.bodyData[e]}},connect:function(b){b.on("integrate:positions",this.behave,this),a.PointerEvent?(this.el.addEventListener("pointerdown",this.grab),a.addEventListener("pointermove",this.move),a.addEventListener("pointerup",this.release)):(this.el.addEventListener("mousedown",this.grab),this.el.addEventListener("touchstart",this.grab),a.addEventListener("mousemove",this.move),a.addEventListener("touchmove",this.move),a.addEventListener("mouseup",this.release),a.addEventListener("touchend",this.release))},disconnect:function(b){b.off("integrate:positions",this.behave,this),a.PointerEvent?(this.el.removeEventListener("pointerdown",this.grab),a.removeEventListener("pointermove",this.move),a.removeEventListener("pointerup",this.release)):(this.el.removeEventListener("mousedown",this.grab),this.el.removeEventListener("touchstart",this.grab),a.removeEventListener("mousemove",this.move),a.removeEventListener("touchmove",this.move),a.removeEventListener("mouseup",this.release),a.removeEventListener("touchend",this.release))},behave:function(a){var b,c,d,e=this,f=Math.max(a.dt,e.options.moveThrottle);for(var g in e.bodyData)d=e.bodyData[g],c=d.body,b=c.state,b.vel.clone(d.pos).vsub(d.offset).vsub(b.pos).mult(1/f)}}}),c.behavior("newtonian",function(a){var b={strength:1,max:!1,min:!1};return{init:function(c){var d=this;a.init.call(this),this.options.defaults(b),this.options.onChange(function(a){d._maxDistSq=a.max===!1?1/0:a.max*a.max,d._minDistSq=a.min?a.min*a.min:100*a.strength}),this.options(c)},calcPotential:function(a,b,d){var e,f,g,h=this.options.strength,i=this._minDistSq,j=this._maxDistSq;return g=d||new c.vector,g.clone(b).vsub(a),e=g.normSq(),e>i&&j>e?(f=h/e,g.normalize().mult(f)):g.zero()},behave:function(){var a,b,d,e,f,g,h,i,j,k,l,m,n=this.getTargets(),o=c.scratchpad(),p=o.vector(),q=o.vector(),r=o.vector();for(h=0,k=n.length;k>h;h++)for(a=n[h],g=h+1;k>g;g++){if(b=n[g],"compound"===a.name?d=a:"compound"===b.name&&(d=b,b=a),d)if("compound"===b.name)for(i=0,l=d.children.length;l>i;i++)for(e=d.children[i],d.toWorldCoords(q.clone(e.state.pos).vadd(d.offset)),j=0,m=b.children.length;m>j;j++)f=b.children[j],b.toWorldCoords(r.clone(f.state.pos).vadd(b.offset)),this.calcPotential(q,r,p),d.accelerate(p.mult(f.mass)),b.accelerate(p.mult(e.mass/f.mass).negate());else for(i=0,l=d.children.length;l>i;i++)e=d.children[i],d.toWorldCoords(q.clone(e.state.pos).vadd(d.offset)),this.calcPotential(q,b.state.pos,p),d.accelerate(p.mult(b.mass)),b.accelerate(p.mult(e.mass/b.mass).negate());else this.calcPotential(a.state.pos,b.state.pos,p),a.accelerate(p.mult(b.mass)),b.accelerate(p.mult(a.mass/b.mass).negate());d=null}o.done()}}}),c.behavior("sweep-prune",function(a){var b=1,d=function(){return b++},e={x:0,y:1},f=2,g=c.util.pairHash;return{init:function(b){a.init.call(this),this.options.defaults({channel:"collisions:candidates"}),this.options(b),this.encounters=[],this.candidates=[],this.clear()},clear:function(){this.tracked=[],this.pairs=[],this.intervalLists=[];for(var a=0;f>a;++a)this.intervalLists[a]=[]},connect:function(a){a.on("add:body",this.trackBody,this),a.on("remove:body",this.untrackBody,this),a.on("integrate:positions",this.sweep,this,1);for(var b=a.getBodies(),c=0,d=b.length;d>c;++c)this.trackBody({body:b[c]})},disconnect:function(a){a.off("add:body",this.trackBody,this),a.off("remove:body",this.untrackBody,this),a.off("integrate:positions",this.sweep,this,1),this.clear()},broadPhase:function(){return this.updateIntervals(),this.sortIntervalLists(),this._world&&this._world.emit("sweep-prune:intervals",this.intervalLists),this.checkOverlaps()},sortIntervalLists:function(){for(var a,b,c,d,e,g,h,i,j,k=0;f>k;++k)for(a=this.intervalLists[k],c=0,b=a.length,j=k;++c0&&(i>g||i===g&&h.type&&!e.type);)a[d]=h,d--,h=a[d-1],i=h&&h.val.get(j);a[d]=e}},getPair:function(a,b,c){var d=g(a.id,b.id);if(d===!1)return null;var e=this.pairs[d];if(!e){if(!c)return null;e=this.pairs[d]={bodyA:a.body,bodyB:b.body,flag:1}}return c&&(e.flag=1),e},checkOverlaps:function(){var a,b,d,g,h,i,j,k,l,m=1<q;++q)for(a=0===q,h=this.intervalLists[q],j=0,i=h.length;i>j;j++)if(g=h[j],b=g.tracker,g.type)for(k=o,k=o-1;k>=0;k--)d=n[k],d===b?(o-1>k?n[k]=n.pop():n.pop(),o--):(l=this.getPair(b,d,a),l&&l.flag=0;)a=d[e],b=a.interval,c=a.body.aabb(),b.min.val.clone(c).sub(c.hw,c.hh),b.max.val.clone(c).add(c.hw,c.hh)},trackBody:function(a){var b=a.body,e={id:d(),body:b},g={min:{type:!1,val:new c.vector,tracker:e},max:{type:!0,val:new c.vector,tracker:e}};e.interval=g,this.tracked.push(e);for(var h=0;f>h;++h)this.intervalLists[h].push(g.min,g.max)},untrackBody:function(a){for(var b,c,d,e,g=a.body,h=this.tracked,i=0,j=h.length;j>i;++i)if(d=h[i],d.body===g){h.splice(i,1);for(var k=0;f>k;++k){e=0,b=this.intervalLists[k];for(var l=0,m=b.length;m>l;++l)if(c=b[l],c===d.interval.min||c===d.interval.max){if(b.splice(l,1),l--,j--,e>0)break;e++}}break}},sweep:function(){var a,b=this;a=b.broadPhase(),a.length&&this._world.emit(this.options.channel,{candidates:a})}}}),c.behavior("verlet-constraints",function(a){var b=2*Math.PI,d={iterations:2};return{init:function(b){a.init.call(this),this.options.defaults(d),this.options(b),this._distanceConstraints=[],this._angleConstraints=[]},connect:function(a){var b=a.integrator();if(b&&b.name.indexOf("verlet")<0)throw'The rigid constraint manager needs a world with a "verlet" compatible integrator.';a.on("integrate:positions",this.resolve,this)},disconnect:function(a){a.off("integrate:positions",this.resolve,this)},drop:function(){return this._distanceConstraints=[],this._angleConstraints=[],this},distanceConstraint:function(a,b,d,e){var f;return a&&b?(f={id:c.util.uniqueId("dis-constraint"),type:"dis",bodyA:a,bodyB:b,stiffness:d||.5,targetLength:e||b.state.pos.dist(a.state.pos)},f.targetLengthSq=f.targetLength*f.targetLength,this._distanceConstraints.push(f),f):!1},angleConstraint:function(a,b,d,e,f){var g;return a&&b?(g={id:c.util.uniqueId("ang-constraint"),type:"ang",bodyA:a,bodyB:b,bodyC:d,stiffness:e||.5,targetAngle:f||b.state.pos.angle2(a.state.pos,d.state.pos)},this._angleConstraints.push(g),g):!1},remove:function(a){var b,d,e,f,g;if(e=c.util.isObject(a),d=e?a.type:a.substr(0,3),b="ang"===d?this._angleConstraints:this._distanceConstraints,e){for(f=0,g=b.length;g>f;++f)if(b[f]===a)return b.splice(f,1),this}else for(f=0,g=b.length;g>f;++f)if(b[f].id===a)return b.splice(f,1),this;return this},resolveAngleConstraints:function(a){for(var d,e,f,g,h=this._angleConstraints,i=c.scratchpad(),j=i.transform(),k=0,l=h.length;l>k;++k)d=h[k],e=d.bodyB.state.pos.angle2(d.bodyA.state.pos,d.bodyC.state.pos),f=e-d.targetAngle,f&&(f<=-Math.PI?f+=b:f>=Math.PI&&(f-=b),j.setTranslation(d.bodyB.state.pos),f*=-a*d.stiffness,"dynamic"===d.bodyA.treatment&&"dynamic"===d.bodyB.treatment&&"dynamic"===d.bodyC.treatment&&(g=1/(d.bodyA.mass+d.bodyB.mass+d.bodyC.mass)),"dynamic"===d.bodyA.treatment&&(e="dynamic"===d.bodyB.treatment&&"dynamic"===d.bodyC.treatment?f*(d.bodyB.mass+d.bodyC.mass)*g:"dynamic"!==d.bodyB.treatment?f*d.bodyC.mass/(d.bodyC.mass+d.bodyA.mass):f*d.bodyB.mass/(d.bodyB.mass+d.bodyA.mass),j.setRotation(e),d.bodyA.state.pos.translateInv(j),d.bodyA.state.pos.rotate(j),d.bodyA.state.pos.translate(j)),"dynamic"===d.bodyC.treatment&&(e="dynamic"===d.bodyA.treatment&&"dynamic"===d.bodyB.treatment?-f*(d.bodyB.mass+d.bodyA.mass)*g:"dynamic"!==d.bodyB.treatment?-f*d.bodyA.mass/(d.bodyC.mass+d.bodyA.mass):-f*d.bodyB.mass/(d.bodyB.mass+d.bodyC.mass),j.setRotation(e),d.bodyC.state.pos.translateInv(j),d.bodyC.state.pos.rotate(j),d.bodyC.state.pos.translate(j)),"dynamic"===d.bodyB.treatment&&(e="dynamic"===d.bodyA.treatment&&"dynamic"===d.bodyC.treatment?f*(d.bodyA.mass+d.bodyC.mass)*g:"dynamic"!==d.bodyA.treatment?f*d.bodyC.mass/(d.bodyC.mass+d.bodyB.mass):f*d.bodyA.mass/(d.bodyA.mass+d.bodyC.mass),j.setRotation(e).setTranslation(d.bodyA.state.pos),d.bodyB.state.pos.translateInv(j),d.bodyB.state.pos.rotate(j),d.bodyB.state.pos.translate(j),j.setTranslation(d.bodyC.state.pos),d.bodyB.state.pos.translateInv(j),d.bodyB.state.pos.rotateInv(j),d.bodyB.state.pos.translate(j)),d.bodyA.sleepCheck(),d.bodyB.sleepCheck(),d.bodyC.sleepCheck());i.done()},resolveDistanceConstraints:function(a){for(var b,d,e,f,g=this._distanceConstraints,h=c.scratchpad(),i=h.vector(),j=0,k=g.length;k>j;++j)b=g[j],i.clone(b.bodyB.state.pos).vsub(b.bodyA.state.pos),d=i.normSq()||1e-4*Math.random(),e=a*b.stiffness*(d-b.targetLengthSq)/d,i.mult(e),f="dynamic"!==b.bodyA.treatment||"dynamic"!==b.bodyB.treatment?1:b.bodyB.mass/(b.bodyA.mass+b.bodyB.mass),"dynamic"===b.bodyA.treatment&&("dynamic"===b.bodyB.treatment&&i.mult(f),b.bodyA.state.pos.vadd(i),"dynamic"===b.bodyB.treatment&&i.mult(1/f)),"dynamic"===b.bodyB.treatment&&("dynamic"===b.bodyA.treatment&&i.mult(1-f),b.bodyB.state.pos.vsub(i)),b.bodyA.sleepCheck(),b.bodyB.sleepCheck();h.done()},shuffleConstraints:function(){this._distanceConstraints=c.util.shuffle(this._distanceConstraints),this._angleConstraints=c.util.shuffle(this._angleConstraints)},resolve:function(){for(var a=this.options.iterations,b=1/a,c=0;a>c;c++)this.resolveDistanceConstraints(b),this.resolveAngleConstraints(b)},getConstraints:function(){return{distanceConstraints:[].concat(this._distanceConstraints),angleConstraints:[].concat(this._angleConstraints)}}}}),c.integrator("improved-euler",function(a){return{init:function(b){a.init.call(this,b)},integrateVelocities:function(a,b){for(var c,d=1-this.options.drag,e=null,f=0,g=a.length;g>f;++f)e=a[f],c=e.state,"static"===e.treatment||e.sleep(b)?(c.vel.zero(),c.acc.zero(),c.angular.vel=0,c.angular.acc=0):(c.old.vel.clone(c.vel),c.old.acc.clone(c.acc),c.vel.vadd(c.acc.mult(b)),d&&c.vel.mult(d),c.acc.zero(),c.old.angular.vel=c.angular.vel,c.angular.vel+=c.angular.acc*b,c.angular.acc=0)},integratePositions:function(a,b){for(var d,e=.5*b*b,f=null,g=c.scratchpad(),h=g.vector(),i=0,j=a.length;j>i;++i)f=a[i],d=f.state,"static"===f.treatment||f.sleep()||(d.old.pos.clone(d.pos),h.clone(d.old.vel),d.pos.vadd(h.mult(b)).vadd(d.old.acc.mult(e)),d.old.acc.zero(),d.old.angular.pos=d.angular.pos,d.angular.pos+=d.old.angular.vel*b+d.old.angular.acc*e,d.old.angular.acc=0); -g.done()}}}),c.integrator("velocity-verlet-alt",function(a){return c.body.mixin({started:function(a){return void 0!==a&&(this._started=!0),!!this._started}}),{init:function(b){a.init.call(this,b)},integrateVelocities:function(a,b){for(var c,d=1-this.options.drag,e=null,f=0,g=a.length;g>f;++f)e=a[f],c=e.state,"static"!==e.treatment?(e.started()||(c.old.acc.clone(c.acc),c.old.acc.mult(b),c.old.vel.clone(c.vel).vsub(c.old.acc),c.old.acc.mult(1/b)),d&&c.vel.mult(d),c.vel.vadd(c.old.acc.vadd(c.acc).mult(.5*b)),e.started()||(c.old.angular.acc=c.angular.acc,c.old.angular.vel=c.angular.vel-c.old.angular.acc*b),c.angular.vel+=.5*(c.angular.acc+c.old.angular.acc)*b,c.angular.acc=0,e.started(!0)):(c.vel.zero(),c.acc.zero(),c.angular.vel=0,c.angular.acc=0)},integratePositions:function(a,b){for(var c,d=b*b,e=null,f=0,g=a.length;g>f;++f)e=a[f],c=e.state,"static"!==e.treatment&&(c.old.pos.clone(c.pos),c.old.vel.mult(b),c.old.acc.mult(.5*d),c.pos.vadd(c.old.vel).vadd(c.old.acc),c.old.vel.clone(c.vel),c.old.acc.clone(c.acc),c.acc.zero(),c.old.angular.pos=c.angular.pos,c.angular.pos+=c.angular.vel*b+.5*c.old.angular.acc*d,c.old.angular.vel=c.angular.vel,c.old.angular.acc=c.angular.acc,c.angular.acc=0)}}}),c.integrator("velocity-verlet",function(a){return c.body.mixin({started:function(a){return void 0!==a&&(this._started=!0),!!this._started}}),{init:function(b){a.init.call(this,b)},integrate:function(a,b){var c=this._world;return this.integratePositions(a,b),c&&c.emit("integrate:positions",{bodies:a,dt:b}),this.integrateVelocities(a,b),c&&c.emit("integrate:velocities",{bodies:a,dt:b}),this},integrateVelocities:function(a,b){for(var c,d=1-this.options.drag,e=null,f=0,g=a.length;g>f;++f)e=a[f],c=e.state,"static"===e.treatment||e.sleep()?(c.vel.zero(),c.acc.zero(),c.angular.vel=0,c.angular.acc=0):(d&&c.vel.mult(d),c.old.vel.clone(c.vel),c.vel.vadd(c.old.acc.vadd(c.acc).mult(.5*b)),c.old.acc.clone(c.acc),c.acc.zero(),c.old.angular.vel=c.angular.vel,c.old.angular.acc=c.angular.acc,c.angular.vel+=.5*(c.angular.acc+c.old.angular.acc)*b,c.angular.acc=0,e.started(!0))},integratePositions:function(a,b){for(var c,d=b*b,e=null,f=0,g=a.length;g>f;++f)e=a[f],c=e.state,"static"===e.treatment||e.sleep(b)||(e.started()||(c.old.acc.clone(c.acc),c.old.acc.mult(b),c.old.vel.clone(c.vel).vsub(c.old.acc),c.old.acc.mult(1/b)),c.old.pos.clone(c.pos),c.old.vel.mult(b),c.old.acc.mult(.5*d),c.pos.vadd(c.old.vel).vadd(c.old.acc),c.old.vel.mult(1/b),c.old.acc.mult(2/d),e.started()||(c.old.angular.acc=c.angular.acc,c.old.angular.vel=c.angular.vel-c.old.angular.acc*b),c.old.angular.pos=c.angular.pos,c.angular.pos+=c.angular.vel*b+.5*c.old.angular.acc*d)}}}),c.renderer("canvas",function(a){if(!b)return{};var d=2*Math.PI,e=function(a,c){var d=b.createElement(a||"div");return c&&(d.innerHTML=c),d},f={white:"#fff",violet:"#542437",blue:"#53777A"},g={metaEl:null,styles:{point:f.blue,circle:{strokeStyle:f.blue,lineWidth:1,fillStyle:f.blue,angleIndicator:f.white},rectangle:{strokeStyle:f.violet,lineWidth:1,fillStyle:f.violet,angleIndicator:f.white},"convex-polygon":{strokeStyle:f.violet,lineWidth:1,fillStyle:f.violet,angleIndicator:f.white}},offset:{x:0,y:0}};return{init:function(d){var f=this;if(a.init.call(this,d),this.options.defaults(g,!0),this.options.onChange(function(){f.options.offset=new c.vector(f.options.offset)}),this.options(d,!0),this.hiddenCanvas=b.createElement("canvas"),this.hiddenCanvas.width=this.hiddenCanvas.height=100,!this.hiddenCanvas.getContext)throw"Canvas not supported";this.hiddenCtx=this.hiddenCanvas.getContext("2d");var h=this.el;if("CANVAS"!==h.nodeName.toUpperCase()&&(h=b.createElement("canvas"),this.el.appendChild(h),"string"==typeof this.options.el&&this.el===b.body&&(h.id=this.options.el),this.el=h),this.container=this.el.parentNode,this.ctx=h.getContext("2d"),this.els={},this.options.meta){var i=this.options.metaEl||e();i.className="pjs-meta",this.els.fps=e("span"),this.els.ipf=e("span"),i.appendChild(e("span","fps: ")),i.appendChild(this.els.fps),i.appendChild(e("br")),i.appendChild(e("span","ipf: ")),i.appendChild(this.els.ipf),h.parentNode.insertBefore(i,h)}this._layers={},this.addLayer("main",this.el),this.options.autoResize?this.resize():this.resize(this.options.width,this.options.height)},layer:function(a){return a in this._layers?this._layers[a]:null},addLayer:function(a,d,e){var f=this,g=[],h=c.util.extend({},this.options.styles),i={id:a,el:d||b.createElement("canvas"),options:c.util.options({width:this.el.width,height:this.el.height,manual:!1,autoResize:!0,follow:null,offset:null,scale:1,zIndex:1})(e)};if(a in this._layers)throw'Layer "'+a+'" already added.';return this.el.parentNode.insertBefore(i.el,this.el),i.el.style.position="absolute",i.el.style.zIndex=i.options.zIndex,i.el.className+=" pjs-layer-"+i.id,i.ctx=i.el.getContext("2d"),i.ctx.scale(1,1),i.el.width=i.options.width,i.el.height=i.options.height,i.bodies=g,i.reset=function(a){return g=a||[],i},i.addToStack=function(a){return c.util.isArray(a)?g.push.apply(g,a):g.push(a),i},i.removeFromStack=function(a){var b,d;if(c.util.isArray(a))for(b=0,d=a.length;d>b;++b)i.removeFromStack(a[b]);else b=c.util.indexOf(g,a),b>-1&&g.splice(b,1);return i},i.render=function(a){var b,d,e,j=c.scratchpad(),k=j.vector().set(0,0),l=i.options.scale,m=g.length,n=f._interpolateTime,o=m||"main"!==i.id?g:f._world._bodies;if(i.options.manual)return j.done(),i;for(i.options.offset&&("center"===i.options.offset?k.add(.5*i.el.width,.5*i.el.height).mult(1/l):k.vadd(i.options.offset).mult(1/l)),i.options.follow&&(k.vsub(i.options.follow.state.pos),k.sub(i.options.follow.state.vel.get(0)*n,i.options.follow.state.vel.get(1)*n)),a!==!1&&i.ctx.clearRect(0,0,i.el.width,i.el.height),1!==l&&(i.ctx.save(),i.ctx.scale(l,l)),e=0,m=o.length;m>e;++e)b=o[e],b.hidden||(d=b.view||(b.view=f.createView(b.geometry,b.styles||h[b.geometry.name])),f.drawBody(b,b.view,i.ctx,k));return 1!==l&&i.ctx.restore(),j.done(),i},this._layers[a]=i,i},removeLayer:function(a){var b=a.id?a.id:a,c=this._layers[b].el;return c!==this.el&&c.parentNode.removeChild(c),delete this._layers[b],this},resize:function(b,c){var d;a.resize.call(this,b,c);for(var e in this._layers)d=this._layers[e],d.options.autoResize&&(d.el.width=this.width,d.el.height=this.height);return this},setStyle:function(a,b){b=b||this.ctx,c.util.isObject(a)?(a.strokeStyle=a.lineWidth?a.strokeStyle:"rgba(0,0,0,0)",c.util.extend(b,a)):(b.fillStyle=b.strokeStyle=a,b.lineWidth=1)},drawCircle:function(a,b,c,e,f){f=f||this.ctx,f.beginPath(),this.setStyle(e,f),f.arc(a,b,c,0,d,!1),f.closePath(),f.stroke(),f.fill()},drawPolygon:function(a,b,c){var d=a[0],e=d.x,f=d.y,g=a.length;c=c||this.ctx,c.beginPath(),this.setStyle(b,c),c.moveTo(e,f);for(var h=1;g>h;++h)d=a[h],e=d.x,f=d.y,c.lineTo(e,f);g>2&&c.closePath(),c.stroke(),c.fill()},drawRect:function(a,b,c,d,e,f){var g=.5*c,h=.5*d;f=f||this.ctx,this.setStyle(e,f),f.beginPath(),f.rect(a-g,b-h,c,d),f.closePath(),f.stroke(),f.fill()},drawLine:function(a,b,c,d){var e=a.x,f=a.y;d=d||this.ctx,d.beginPath(),this.setStyle(c,d),d.moveTo(e,f),e=b.x,f=b.y,d.lineTo(e,f),d.stroke(),d.fill()},draw:function(a,b,c,d){var e=a.name,f=+(d&&d.x),g=+(d&&d.y),h=a.aabb().hw;if(c=c||this.ctx,b=b||this.options.styles[e]||this.options.styles.circle||{},c.save(),c.translate(f,g),"circle"===e)this.drawCircle(0,0,a.radius,b,c);else if("convex-polygon"===e)this.drawPolygon(a.vertices,b,c);else if("rectangle"===e)this.drawRect(0,0,a.width,a.height,b,c);else if("compound"===e)for(var i,j=0,k=a.children.length;k>j;j++)i=a.children[j],c.translate(i.pos.x,i.pos.y),c.rotate(i.angle),this.draw(i.g,b,c),c.rotate(-i.angle),c.translate(-i.pos.x,-i.pos.y);else this.drawCircle(0,0,1,b,c);return"compound"!==e&&b.angleIndicator&&(c.beginPath(),this.setStyle(b.angleIndicator,c),c.moveTo(0,0),c.lineTo(h,0),c.closePath(),c.stroke()),c.restore(),this},createView:function(a,b){var c,d=a.aabb(),e=d.hw+Math.abs(d.x),f=d.hh+Math.abs(d.y),g={x:e+1,y:f+1},h=this.hiddenCtx,i=this.hiddenCanvas;return b=b||this.options.styles[name]||this.options.styles.circle||{},b.src?(c=new Image,c.src=b.src,b.width&&(c.width=b.width),b.height&&(c.height=b.height),c):(g.x+=0|b.lineWidth,g.y+=0|b.lineWidth,i.width=2*e+2+(2*b.lineWidth|0),i.height=2*f+2+(2*b.lineWidth|0),this.draw(a,b,h,g),c=new Image(i.width,i.height),c.src=i.toDataURL("image/png"),c)},drawMeta:function(a){this.els.fps.innerHTML=a.fps.toFixed(2),this.els.ipf.innerHTML=a.ipf},drawBody:function(a,b,c,d){var e,f,g,h=a.state.pos,i=a.offset,j=a.state.vel,k=this._interpolateTime||0;d=d||this.options.offset,c=c||this.ctx,e=h._[0]+d.x+j._[0]*k,f=h._[1]+d.y+j._[1]*k,g=a.state.angular.pos+a.state.angular.vel*k,c.save(),c.translate(e,f),c.rotate(g),c.translate(i._[0],i._[1]),c.drawImage(b,-b.width/2,-b.height/2,b.width,b.height),c.restore()},render:function(a,b){this._world.emit("beforeRender",{renderer:this,meta:b}),this.options.meta&&this.drawMeta(b),this._interpolateTime=b.interpolateTime;for(var c in this._layers)this._layers[c].render();return this}}}),c.renderer("dom",function(a){if(!b)return{};var c={},d=b.createElement("div"),e=function(a){return a.replace(/(?:^|\s)\w/g,function(a){return a.toUpperCase()})},f=function(a){if(c[a])return c[a];for(var b,f=["Webkit","Moz","Ms","O"],g=0,h=f.length;h>g;++g)if(b=f[g]+e(a),b in d.style)return c[a]=b;return b in d.style?c[a]=a:!1},g="pjs-",h="px",i=f("transform"),j=f("borderRadius"),k=function(a,c){var d=b.createElement(a||"div");return c&&(d.innerHTML=c),d};return{init:function(b){a.init.call(this,b);var c=this.el;if(c.style.position="relative",c.style.overflow="hidden",c.style[i]="translateZ(0)",c.style.width=this.options.width+h,c.style.height=this.options.height+h,this.els={},b.meta){var d=k();d.className="pjs-meta",this.els.fps=k("span"),this.els.ipf=k("span"),d.appendChild(k("span","fps: ")),d.appendChild(this.els.fps),d.appendChild(k("br")),d.appendChild(k("span","ipf: ")),d.appendChild(this.els.ipf),c.appendChild(d)}this.options.autoResize?this.resize():this.resize(this.options.width,this.options.height)},resize:function(b,c){a.resize.call(this,b,c),this.el.style.width=this.width+h,this.el.style.height=this.height+h},pointProperties:function(a){a.style.width="2px",a.style.height="2px",a.style.marginLeft="-1px",a.style.marginTop="-1px",a.style[j]="50%"},circleProperties:function(a,b){var c=b.aabb();a.style.width=2*c.hw+h,a.style.height=2*c.hh+h,a.style.marginLeft=-c.hw+h,a.style.marginTop=-c.hh+h,a.style[j]="50%"},rectangleProperties:function(a,b){var c=b.aabb();a.style.width=2*c.hw+h,a.style.height=2*c.hh+h,a.style.marginLeft=-c.hw+h,a.style.marginTop=-c.hh+h},createView:function(a){var b,c=k(),d=a.name+"Properties";if(c.className=g+a.name,c.style.position="absolute",c.style.top="0px",c.style.left="0px","compound"===a.name)for(var e,f=0,h=a.children.length;h>f;f++)e=a.children[f],b=k(),b.className=g+a.name+" "+g+"child",b.style.position="absolute",b.style.top="0px",b.style.left="0px",this[e.g.name+"Properties"]&&this[e.g.name+"Properties"](b,e.g),b.style[i]="translate("+e.pos._[0]+"px,"+e.pos._[1]+"px) rotate("+e.angle+"rad)",c.appendChild(b);else this[d]&&this[d](c,a);return this.el.appendChild(c),c},connect:function(a){a.on("add:body",this.attach,this),a.on("remove:body",this.detach,this)},disconnect:function(a){a.off("add:body",this.attach,this),a.off("remove:body",this.detach,this)},detach:function(a){var b=a.nodeType&&a||a.body&&a.body.view,c=b&&b.parentNode;return b&&c&&c.removeChild(b),this},attach:function(a){var b=a.nodeType&&a||a.body&&a.body.view;return b&&this.el.appendChild(b),this},drawMeta:function(a){this.els.fps.innerHTML=a.fps.toFixed(2),this.els.ipf.innerHTML=a.ipf},drawBody:function(a,b){var c,d,e,f=a.state.pos,g=a.state.vel,h=a.offset,j=this._interpolateTime;c=f._[0]+g._[0]*j,d=f._[1]+g._[1]*j,e=a.state.angular.pos+a.state.angular.vel*j,b.style[i]="translate("+c+"px,"+d+"px) rotate("+e+"rad) translate("+h._[0]+"px,"+h._[1]+"px)"}}}),c.renderer("pixi",function(d){if(!b)return{};var e=(2*Math.PI,{white:"0xFFFFFF",violet:"0x542437",blue:"0x53777A"}),f={font:"18px monospace",fill:"black",align:"left"},g={metaEl:null,offset:{x:0,y:0},styles:{color:!1,point:e.blue,circle:{strokeStyle:e.blue,lineWidth:1,fillStyle:e.blue,angleIndicator:e.white,fillAlpha:1,strokeAlpha:1,alpha:1},rectangle:{strokeStyle:e.violet,lineWidth:1,fillStyle:e.violet,angleIndicator:e.white,fillAlpha:1,strokeAlpha:1,alpha:1},"convex-polygon":{strokeStyle:e.violet,lineWidth:1,fillStyle:e.violet,angleIndicator:e.white,fillAlpha:1,strokeAlpha:1,alpha:1}}};return{init:function(e){var f,h,i=this;if("undefined"==typeof PIXI)throw"PIXI not present - cannot continue";d.init.call(this,e),this.options.defaults(g,!0),this.options.onChange(function(){i.options.offset=new c.vector(i.options.offset)}),this.options(e,!0),h=!this.options.styles.color||"transparent"===this.options.styles.color,this.stage=new PIXI.Stage(this.options.styles.color),this.meta={},f=this.el&&"CANVAS"===this.el.nodeName?f:null,this.renderer=new PIXI.autoDetectRenderer(this.options.width,this.options.height,{view:f,transparent:h,resolution:a.devicePixelRatio||1}),f||(this.el=this.el||b.body,this.el.appendChild(this.renderer.view)),this.options.autoResize?this.resize():this.resize(this.options.width,this.options.height)},resize:function(a,b){d.resize.call(this,a,b),this.renderer.resize(this.width,this.height)},connect:function(a){a.on("add:body",this.attach,this),a.on("remove:body",this.detach,this)},disconnect:function(a){a.off("add:body",this.attach,this),a.off("remove:body",this.detach,this)},detach:function(a){var b=a instanceof PIXI.Graphics&&a||a.body&&a.body.view;return b&&this.stage.removeChild(b),this},attach:function(a){var b=a instanceof PIXI.Graphics&&a||a.body&&a.body.view;return b&&this.stage.addChild(b),this},loadSpriteSheets:function(a,b){if(!c.util.isArray(a))throw"Spritesheets must be defined in arrays";var d=this,e=new PIXI.AssetLoader(a);return e.load(),e.on("onComplete",function(){d.assetsLoaded=!0,b()}),d},drawBody:function(a,b){var c,d,e,f=a.state.pos,g=a.state.vel,h=a.offset,i=this._interpolateTime||0;c=f._[0]+g._[0]*i,d=f._[1]+g._[1]*i,e=a.state.angular.pos+a.state.angular.vel*i,b.position.set(c,d),b.pivot.set(-h._[0],-h._[1]),b.rotation=e},render:function(a,b){d.render.call(this,a,b),this.renderer.render(this.stage)},setStyles:function(a,b){return c.util.isObject(b)?(b.fillStyle&&"transparent"!==b.fillStyle?(a.beginFill(b.fillStyle),a.fillAlpha=void 0!==b.fillAlpha?b.fillAlpha:1):(a.beginFill(),a.fillAlpha=0),a.lineStyle(b.lineWidth||0,b.strokeStyle,void 0!==b.strokeAlpha?b.strokeAlpha:1),a.alpha=void 0!==b.alpha?b.alpha:1):(b&&"transparent"!==b?a.beginFill(b):(a.beginFill(),a.fillAlpha=0),a.lineStyle(0)),a},createCircle:function(a,b,c,d){var e=new PIXI.Graphics;return this.setStyles(e,d),e.drawCircle(a,b,c),e.endFill(),e},createRect:function(a,b,c,d,e){var f=new PIXI.Graphics;return this.setStyles(f,e),f.drawRect(a,b,c,d),f.endFill(),f},createPolygon:function(a,b){var c=a[0],d=c.x,e=c.y,f=a.length,g={x:d,y:e},h=new PIXI.Graphics;this.setStyles(h,b),h.moveTo(d,e);for(var i=1;f>i;++i)c=a[i],d=c.x,e=c.y,h.lineTo(d,e);return f>2&&h.lineTo(g.x,g.y),h.endFill(),h},createLine:function(a,b,c){var d=a.x,e=a.y,f=new PIXI.Graphics;return this.setStyles(f,c),f.moveTo(d,e),d=b.x,e=b.y,f.lineTo(d,e),f.endFill(),f},createView:function(a,b,c){var d=null,e=a.aabb(),f=e.hw+Math.abs(e.x),g=(e.hh+Math.abs(e.y),a.name);if(c=c||this.stage,b=b||this.options.styles[g]||this.options.styles.circle||{},b.src)return d=PIXI.Sprite.fromImage(b.src),d.anchor.set(.5,.5),b.anchor&&(d.anchor.x=b.anchor.x,d.anchor.y=b.anchor.y),b.width&&(d.width=b.width),b.height&&(d.height=b.height),c.addChild(d),d;if("circle"===g)d=this.createCircle(0,0,a.radius,b);else if("convex-polygon"===g)d=this.createPolygon(a.vertices,b);else if("rectangle"===g)d=this.createRect(-a.width/2,-a.height/2,a.width,a.height,b);else if("compound"===g){d=new PIXI.Graphics;for(var h,i,j=0,k=a.children.length;k>j;j++)h=a.children[j],i=this.createView(h.g,b,d),i.position.set(h.pos.x,h.pos.y),i.rotation=h.angle}else d=this.createCircle(0,0,1,b);return"compound"!==g&&b.angleIndicator&&"transparent"!==b.angleIndicator&&(d.lineStyle(b.lineWidth,b.angleIndicator),d.moveTo(0,0),d.lineTo(f,0)),"compound"!==g&&(d.cacheAsBitmap=!0),c.addChild(d),d},drawMeta:function(a){this.meta.loaded?(this.meta.fps.setText("FPS: "+a.fps.toFixed(2)),this.meta.ipf.setText("IPF: "+a.ipf)):(this.meta.fps=new PIXI.Text("FPS: "+a.fps.toFixed(2),f),this.meta.fps.position.x=15,this.meta.fps.position.y=5,this.meta.ipf=new PIXI.Text("IPF: "+a.ipf,f),this.meta.ipf.position.x=15,this.meta.ipf.position.y=30,this.stage.addChild(this.meta.fps),this.stage.addChild(this.meta.ipf),this.meta.loaded=!0)},createDisplay:function(a,b){var c=null,d=null;switch(a){case"sprite":return d=PIXI.Texture.fromImage(b.texture),c=new PIXI.Sprite(d),b.anchor&&(c.anchor.x=b.anchor.x,c.anchor.y=b.anchor.y),b.container?b.container.addChild(c):this.stage.addChild(c),c;case"movieclip":if(!this.assetsLoaded)throw"No assets have been loaded. Use loadSpritesheet() first";var e=[],f=0;for(f;fa.x-a.hw&&b.xa.y-a.hh&&b.y0?c.clone(a).negate():(c.clone(b).vsub(a),c.perp(a.cross(c)>0))},e=function(a){var b,d,e=a.length,f=a[e-2],g=a[e-3],h=c.scratchpad(),i=h.vector().clone(f.pt),j=h.vector().clone(g.pt).vsub(i);return j.equals(c.vector.zero)?h.done({a:f.a,b:f.b}):(b=-j.dot(i)/j.normSq(),d=1-b,d<=0?h.done({a:g.a,b:g.b}):b<=0?h.done({a:f.a,b:f.b}):h.done({a:i.clone(f.a).mult(d).vadd(j.clone(g.a).mult(b)).values(),b:i.clone(f.b).mult(d).vadd(j.clone(g.b).mult(b)).values()}))},f=function(f,g,h,i){var j,k,l,m,n=!1,o=!1,p=!1,q=[],r=1,s=c.scratchpad(),t=s.vector().clone(g||c.vector.axis[0]),u=s.vector(),v=s.vector(),w=s.vector(),x=s.vector(),y=0;for(m=f(t),r=q.push(m),u.clone(m.pt),t.negate();++y;){if(u.swap(v),m=f(t),r=q.push(m),u.clone(m.pt),i&&i(q),u.equals(c.vector.zero)){n=!0;break}if(!o&&u.dot(t)<=0){if(h)break;o=!0}if(2===r)t=d(u,v,t);else if(o){if(t.normalize(),m=v.dot(t),Math.abs(m-u.dot(t))0,l^u.cross(j)>0)q.shift(),j.perp(!l),t.swap(j);else{if(!(l^k.cross(u)>0)){n=!0;break}q.splice(1,1),k.perp(l),t.swap(j)}if(y>b)return s.done(),{simplex:q,iterations:y,distance:0,maxIterationsReached:!0}}return s.done(),m={overlap:n,simplex:q,iterations:y},p!==!1&&(m.distance=p,m.closest=e(q)),m};c.gjk=f}(),function(){c.statistics={pushRunningAvg:function(a,b,c,d){var e=a-c;return c+=e/b,d+=e*(a-c),[c,d]},pushRunningVectorAvg:function(a,b,c,d){var e=1/b,f=a.get(0)-c.get(0),g=a.get(1)-c.get(1);c.add(f*e,g*e),d&&(f*=a.get(0)-c.get(0),g*=a.get(1)-c.get(1),d.add(f,g))}}}(),function(){var a=function b(a,d,e){return this instanceof b?(this.v=new c.vector,this.o=new c.vector,a instanceof b?void this.clone(a):(a&&this.setTranslation(a),void this.setRotation(d||0,e))):new b(a,d)};a.prototype.setTranslation=function(a){return this.v.clone(a),this},a.prototype.setRotation=function(a,b){return this.cosA=Math.cos(a),this.sinA=Math.sin(a),b?this.o.clone(b):this.o.zero(),this},a.prototype.clone=function(b){return b?(this.setTranslation(b.v),this.cosA=b.cosA,this.sinA=b.sinA,this.o.clone(b.o),this):new a(this)},c.transform=a}(),function(a){var b=Math.sqrt,d=Math.min,e=Math.max,f=(Math.acos,Math.atan2),g=2*Math.PI,h=!!a.Float64Array,i=function j(a,b){return this instanceof j?(h?this._=new Float64Array(5):this._=[],void(a&&(void 0!==a.x||a._&&a._.length)?this.clone(a):(this.recalc=!0,this.set(a,b)))):new j(a,b)};Object.defineProperties(i.prototype,{x:{get:function(){return+this._[0]},set:function(a){a=+a||0,this.recalc=a===this._[0],this._[0]=a}},y:{get:function(){return+this._[1]},set:function(a){a=+a||0,this.recalc=a===this._[1],this._[1]=a}}}),i.prototype.set=function(a,b){return this.recalc=!0,this._[0]=+a||0,this._[1]=+b||0,this},i.prototype.get=function(a){return this._[a]},i.prototype.vadd=function(a){return this.recalc=!0,this._[0]+=a._[0],this._[1]+=a._[1],this},i.prototype.vsub=function(a){return this.recalc=!0,this._[0]-=a._[0],this._[1]-=a._[1],this},i.prototype.add=function(a,b){return this.recalc=!0,this._[0]+=+a||0,this._[1]+=+b||0,this},i.prototype.sub=function(a,b){return this.recalc=!0,this._[0]-=a,this._[1]-=void 0===b?0:b,this},i.prototype.mult=function(a){return this.recalc||(this._[4]*=a*a,this._[3]*=a),this._[0]*=a,this._[1]*=a,this},i.prototype.dot=function(a){return this._[0]*a._[0]+this._[1]*a._[1]},i.prototype.cross=function(a){return-this._[0]*a._[1]+this._[1]*a._[0]},i.prototype.proj=function(a){return this.dot(a)/a.norm()},i.prototype.vproj=function(a){var b=this.dot(a)/a.normSq();return this.clone(a).mult(b)},i.prototype.angle=function(a){var b;if(this.equals(i.zero))return a?a.angle():NaN;for(b=a&&!a.equals(i.zero)?f(this._[1]*a._[0]-this._[0]*a._[1],this._[0]*a._[0]+this._[1]*a._[1]):f(this._[1],this._[0]);b>Math.PI;)b-=g;for(;b<-Math.PI;)b+=g;return b},i.prototype.angle2=function(a,b){for(var c=a._[0]-this._[0],d=a._[1]-this._[1],e=b._[0]-this._[0],h=b._[1]-this._[1],i=f(d*e-c*h,c*e+d*h);i>Math.PI;)i-=g;for(;i<-Math.PI;)i+=g;return i},i.prototype.norm=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[3]},i.prototype.normSq=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[4]},i.prototype.dist=function(a){var c,d;return b((c=a._[0]-this._[0])*c+(d=a._[1]-this._[1])*d)},i.prototype.distSq=function(a){var b,c;return(b=a._[0]-this._[0])*b+(c=a._[1]-this._[1])*c},i.prototype.perp=function(a){var b=this._[0];return a?(this._[0]=this._[1],this._[1]=-b):(this._[0]=-this._[1],this._[1]=b),this},i.prototype.normalize=function(){var a=this.norm();return 0===a?this:(a=1/a,this._[0]*=a,this._[1]*=a,this._[3]=1,this._[4]=1,this)},i.prototype.transform=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d,this._[1]-=e,this.set(this._[0]*c-this._[1]*b+d+a.v._[0],this._[0]*b+this._[1]*c+e+a.v._[1])},i.prototype.transformInv=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d+a.v._[0],this._[1]-=e+a.v._[1],this.set(this._[0]*c+this._[1]*b+d,-this._[0]*b+this._[1]*c+e)},i.prototype.rotate=function(a,b){var c,d,e=0,f=0;return"number"==typeof a?(c=Math.sin(a),d=Math.cos(a),b&&(e=b.x,f=b.y)):(c=a.sinA,d=a.cosA,e=a.o._[0],f=a.o._[1]),this._[0]-=e,this._[1]-=f,this.set(this._[0]*d-this._[1]*c+e,this._[0]*c+this._[1]*d+f)},i.prototype.rotateInv=function(a){return this.set((this._[0]-a.o._[0])*a.cosA+(this._[1]-a.o._[1])*a.sinA+a.o._[0],-(this._[0]-a.o._[0])*a.sinA+(this._[1]-a.o._[1])*a.cosA+a.o._[1])},i.prototype.translate=function(a){return this.vadd(a.v)},i.prototype.translateInv=function(a){return this.vsub(a.v)},i.prototype.clone=function(a){return a?a._?(this.recalc=a.recalc,a.recalc||(this._[3]=a._[3],this._[4]=a._[4]),this._[0]=a._[0],this._[1]=a._[1],this):this.set(a.x,a.y):new i(this)},i.prototype.swap=function(a){var b=this._;return this._=a._,a._=b,b=this.recalc,this.recalc=a.recalc,a.recalc=b,this},i.prototype.values=function(){return{x:this._[0],y:this._[1]}},i.prototype.zero=function(){return this._[3]=0,this._[4]=0,this._[0]=0,this._[1]=0,this},i.prototype.negate=function(a){return void 0!==a?(this._[a]=-this._[a],this):(this._[0]=-this._[0],this._[1]=-this._[1],this)},i.prototype.clamp=function(a,b){return this._[0]=d(e(this._[0],a.x),b.x),this._[1]=d(e(this._[1],a.y),b.y),this.recalc=!0,this},i.prototype.toString=function(){return"("+this._[0]+", "+this._[1]+")"},i.prototype.equals=function(a){return this._[0]===a._[0]&&this._[1]===a._[1]&&this._[2]===a._[2]},i.axis=[new i(1,0),new i(0,1)],i.zero=new i(0,0),c.vector=i}(this),function(a){var b=a.Physics;c.noConflict=function(){return a.Physics===c&&(a.Physics=b),c}}(this);var d=c.util.decorator=function(a,b){var d={},e={},f=function(a,b){var d,e;for(e in b)d=Object.getOwnPropertyDescriptor(b,e),d.get||d.set?Object.defineProperty(a,e,d):c.util.isFunction(d.value)&&(a[e]=d.value);return a},g=Object.getPrototypeOf;"function"!=typeof g&&(g="object"==typeof"test".__proto__?function(a){return a.__proto__}:function(a){return a.constructor.prototype});var h=Object.create;"function"!=typeof h&&(h=function(a){function b(){}return b.prototype=a,new b});var i=function(b,d){return"object"==typeof b?(e=f(e,b),void(e.type=a)):void("type"!==b&&c.util.isFunction(d)&&(e[b]=d))};i(b);var j=function(b,c,i,j){var k,l=e;if("string"!=typeof c)j=i,i=c;else{if(l=d[c],!l)throw'Error: "'+c+'" '+a+" not defined";l=l.prototype}if("function"==typeof i)k=d[b],k?k.prototype=f(k.prototype,i(g(k.prototype))):(k=d[b]=function(a){this.init&&this.init(a)},k.prototype=h(l),k.prototype=f(k.prototype,i(l,k.prototype))),k.prototype.type=a,k.prototype.name=b;else if(j=i||{},k=d[b],!k)throw'Error: "'+b+'" '+a+" not defined";if(j)return new k(j)};return j.mixin=i,j};c.util.indexOf=function(a,b){for(var c=0,d=a.length;c(0|b)?a<<16|65535&b:b<<16|65535&a)},Function.prototype.bind?c.util.bind=function(a,b,c){return c=Array.prototype.slice.call(arguments,1),Function.prototype.bind.apply(a,c)}:c.util.bind=function(a,b,c){return c=Array.prototype.slice.call(arguments,2),function(){return a.apply(b,c.concat(Array.prototype.slice.call(arguments)))}},c.util.find=function(a,b){var c,d,e=a.length;for(c=0;c-1?0:-1:a?0:-1}function g(a){var b=this.cache,c=typeof a;if("boolean"===c||null==a)b[a]=!0;else{"number"!==c&&"string"!==c&&(c="object");var d="number"===c?a:y+a,e=b[c]||(b[c]={});"object"===c?(e[d]||(e[d]=[])).push(a):e[d]=!0}}function h(a){var b=-1,c=a.length,e=a[0],f=a[c/2|0],h=a[c-1];if(e&&"object"==typeof e&&f&&"object"==typeof f&&h&&"object"==typeof h)return!1;var i=d();i["false"]=i["null"]=i["true"]=i.undefined=!1;var j=d();for(j.array=a,j.cache=i,j.push=g;++b=u&&k===c.util.indexOf,o=i||n?e():m;if(n){var p=h(o);k=f,o=p}for(;++j2&&"function"==typeof h[j-1]&&(g=h[--j]);++i>>1;c(a[f])=b.maxScratches)throw f},a.prototype={done:function(a){this._active=!1;for(var b=0;b=b.maxIndex)throw e;return a[c]||(a[c]=m?f():new f)}},b.register("vector",c.vector),b.register("transform",c.transform),b}(),function(){function a(a){return a._priority_}var b=1;c.scratchpad.register("event",function(){return{}},{useFactory:!0});var d=function e(){if(!(this instanceof e))return new e};d.prototype={on:function(d,e,f,g){var h,i,j;if(this._topics=this._topics||(this._topics={}),c.util.isObject(d)){for(var k in d)this.on(k,d[k],e,f);return this}return h=this._topics[d]||(this._topics[d]=[]),i=e,c.util.isObject(f)?(e=c.util.bind(e,f),e._bindfn_=i,e._one_=i._one_,e._scope_=f):void 0===g&&(g=f),e._priority_=void 0===g?b:g,j=c.util.sortedIndex(h,e,a),h.splice(j,0,e),this},off:function(a,b,d){var e,f;if(!this._topics)return this;if(a===!0)return this._topics={},this;if(c.util.isObject(a)){for(var g in a)this.off(g,a[g]);return this}if(e=this._topics[a],!e)return this;if(b===!0)return this._topics[a]=[],this;for(var h=0,i=e.length;h-1}return e===a}},g=function(a,b){var c=f(a,b);return function(a){return!c(a)}},h=function(a,b){return function(e){e=b?e[b]:e;var f,g=0;if(c.util.isArray(e)){for(f=e.length;g-1||d(a,e[f])>-1)return!0;g++}return!1}return d(a,e)>-1}},i=function(a,b){var c=h(a,b);return function(a){return!c(a)}},j=function(a){return a=new c.vector(a),function(b){var d=b.aabb();return c.aabb.contains(d,a)}},k=function(a){return a.next?function(b){for(var c=a;c;){if(!c(b))return!1;c=c.next}return!0}:a},l=function(a){return a.next?function(b){for(var c=a;c;){if(c(b))return!0;c=c.next}return!1}:a},m={$eq:f,$ne:g,$in:h,$nin:i,$at:j},n=function o(a,d){var g,h,i,j,n,p;if(d){if("$or"===d||"$and"===d){for(g=0,h=a.length;g=c&&this.sleep(!1))}},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},accelerate:function(a){return"dynamic"===this.treatment&&this.state.acc.vadd(a),this},applyForce:function(a,b){if("dynamic"!==this.treatment)return this;var d,e=c.scratchpad(),f=e.vector();return b&&this.moi&&(d=this.state,f.clone(b),this.state.angular.acc-=f.cross(a)/this.moi),this.accelerate(f.clone(a).mult(1/this.mass)),e.done(),this},getGlobalOffset:function(a){return a=a||new c.vector,a.clone(this.offset).rotate(this.state.angular.pos),a},aabb:function(){var a=this.state.angular.pos,b=c.scratchpad(),d=b.vector(),e=this.geometry.aabb(a);return this.getGlobalOffset(d),e.x+=this.state.pos._[0]+d._[0],e.y+=this.state.pos._[1]+d._[1],b.done(e)},toBodyCoords:function(a){return a.vsub(this.state.pos).rotate(-this.state.angular.pos)},toWorldCoords:function(a){return a.rotate(this.state.angular.pos).vadd(this.state.pos)},recalc:function(){return this}}),c.body.getCOM=function(a,b){var d,e,f,g=a&&a.length,h=0;if(b=b||new c.vector,!g)return b.zero();if(1===g)return b.clone(a[0].state.pos);for(b.zero(),f=0;f0^d.cross(e)>0){g=!1;break}e.swap(d)}return b.done(),g},c.geometry.getPolygonMOI=function(a){var b,d=c.scratchpad(),e=d.vector(),f=d.vector(),g=0,h=0,i=a.length;if(i<2)return d.done(),0;if(2===i)return b=f.clone(a[1]).distSq(e.clone(a[0])),d.done(),b/12;e.clone(a[0]);for(var j=1;j1e-6},c.geometry.getPolygonArea=function(a){var b=c.scratchpad(),d=b.vector(),e=b.vector(),f=0,g=a.length;if(g<3)return b.done(),0;d.clone(a[g-1]);for(var h=0;h-1},integrator:function(a){return void 0===a?this._integrator:this._integrator===a?this:(this._integrator&&(this._integrator.setWorld(null),this.emit("remove:integrator",{integrator:this._integrator})),a&&(this._integrator=a,this._integrator.setWorld(this),this.emit("add:integrator",{integrator:this._integrator})),this)},renderer:function(a){return void 0===a?this._renderer:this._renderer===a?this:(this._renderer&&(this._renderer.setWorld(null),this.emit("remove:renderer",{renderer:this._renderer})),a&&(this._renderer=a,this._renderer.setWorld(this),this.emit("add:renderer",{renderer:this._renderer})),this)},timestep:function(a){return a?(this._dt=+a.toPrecision(4),this._maxJump=a*this.options.maxIPF,this):this._dt},wakeUpAll:function(){var a=0,b=this._bodies.length;for(a=0;ak&&(this._animTime=a-k,b=k),d=b*g,e=f+d-i,this.emit("beforeStep"),f<=e)for(;f<=e;)f+=i,this._animTime+=j,this._time=f,this.iterate(i);return l.fps=1e3/(a-this._lastTime),l.ipf=(d/i).toFixed(2),l.interpolateTime=i+e-f,this._lastTime=a,this.emit("step",l),this},warp:function(a){return void 0===a?this._warp:(this._warp=a||1,this)},render:function(){if(!this._renderer)throw"No renderer added to world";return this._renderer.render(this._bodies,this._meta),this.emit("render",{bodies:this._bodies,meta:this._meta,renderer:this._renderer}),this},pause:function(){return this._paused=!0,this.emit("pause"),this},unpause:function(){return this._paused=!1,this.emit("unpause"),this},isPaused:function(){return!!this._paused},destroy:function(){var a=this;a.pause(),this.emit("destroy"),a.off(!0),a.remove(a.getBodies()),a.remove(a.getBehaviors()),a.integrator(null),a.renderer(null)}}),c.world=d}(),c.integrator("verlet",function(a){return c.body.mixin({started:function(a){return void 0!==a&&(this._started=!0),!!this._started}}),{init:function(b){a.init.call(this,b)},integrateVelocities:function(a,b){for(var c,d=b*b,e=1-this.options.drag,f=null,g=this.prevDt||b,h=.5*(d+b*g),i=0,j=a.length;ij&&(j=i,b.swap(h));return g.done(b)},getFarthestCorePoint:function(a,b,d){var e,f,g=this.children.length,h=c.scratchpad(),i=h.vector(),j=0,k=0;for(b=b||new c.vector,f=0;fk&&(k=j,b.swap(i));return h.done(b)}}}),c.geometry("convex-polygon",function(a){var b="Error: The vertices specified do not match that of a _convex_ polygon.",d={};return{init:function(b){var c=this;a.init.call(this,b),this.options.defaults(d),this.options.onChange(function(a){c.setVertices(a.vertices||[])}),this.options(b),c.setVertices(this.options.vertices||[])},setVertices:function(a){var d=c.scratchpad(),e=d.transform(),f=this.vertices=[];if(!c.geometry.isPolygonConvex(a))throw b;e.setRotation(0),e.setTranslation(c.geometry.getPolygonCentroid(a).negate());for(var g=0,h=a.length;g=f?1:0,d&&(d.idx=g),b.clone(h[g]);if(e>=f){for(;j=f;)f=e,e=h[j].dot(a),j++;return e>=f&&j++,g=j-2,d&&(d.idx=j-2),b.clone(h[g])}for(j=i;j>1&&f>=e;)j--,e=f,f=h[j].dot(a);return g=(j+1)%i,d&&(d.idx=g),b.clone(h[g])},getFarthestCorePoint:function(a,b,d){var e,f=c.scratchpad(),g=f.vector(),h=f.vector(),i=this.vertices,j=i.length,k=this._area>0,l={};return b=this.getFarthestHullPoint(a,b,l),g.clone(i[(l.idx+1)%j]).vsub(b).normalize().perp(k),h.clone(i[(l.idx-1+j)%j]).vsub(b).normalize().perp(!k),e=d/(1+g.dot(h)),b.vadd(g.vadd(h).mult(e)),f.done(),b}}}),c.geometry("rectangle",function(a){var b={};return{init:function(c){var d=this;a.init.call(this,c),this.options.defaults(b),this.options.onChange(function(a){d.width=d.options.width||1,d.height=d.options.height||1}),this.options(c)},aabb:function(a){if(!a)return c.aabb(this.width,this.height);var b=c.scratchpad(),d=b.vector(),e=b.transform().setRotation(a||0),f=b.vector().set(1,0).rotateInv(e),g=b.vector().set(0,1).rotateInv(e),h=this.getFarthestHullPoint(f,d).proj(f),i=-this.getFarthestHullPoint(f.negate(),d).proj(f),j=this.getFarthestHullPoint(g,d).proj(g),k=-this.getFarthestHullPoint(g.negate(),d).proj(g);return b.done(),c.aabb(i,k,h,j)},getFarthestHullPoint:function(a,b){b=b||new c.vector;var d=a.x,e=a.y;return d=0===d?0:d<0?.5*-this.width:.5*this.width,e=0===e?0:e<0?.5*-this.height:.5*this.height,b.set(d,e)},getFarthestCorePoint:function(a,b,c){var d,e;return b=this.getFarthestHullPoint(a,b),d=b.x,e=b.y,b.x=0===d?0:d<0?d+c:d-c,b.y=0===e?0:e<0?e+c:e-c,b}}}),c.body("circle",function(a){var b={radius:1};return{init:function(d){a.init.call(this,d),d=c.util.extend({},b,d),this.geometry=c.geometry("circle",{radius:d.radius}),this.recalc()},recalc:function(){a.recalc.call(this),this.moi=this.mass*this.geometry.radius*this.geometry.radius/2}}}),c.body("compound",function(a){return{init:function(b){a.init.call(this,b),this.mass=0,this.moi=0,this.children=[],this.geometry=c.geometry("compound"),this.addChildren(b.children)},connect:function(a){if(this.mass<=0)throw"Can not add empty compound body to world."},addChild:function(a){return this.addChildren([a]),this},addChildren:function(a){var b,d,e,f=this,g=c.scratchpad(),h=g.vector().zero(),i=a&&a.length,j=0;if(!i)return g.done(this);for(e=0;ei&&d-1&&c.util.indexOf(h,b.bodyB)>-1)if(d=g(b.bodyA,b.bodyB),d instanceof Array)for(var o,p=0,q=d.length;p=0?void k.done():(q=q===1/0?0:q,r=r===1/0?0:r,m=-((1+u)*I)/(s+t+q*F*F+r*H*H),i?(b.state.vel.vadd(w.mult(m*t)),b.state.angular.vel-=m*r*H):j?(a.state.vel.vsub(w.mult(m*s)),a.state.angular.vel+=m*q*F):(b.state.vel.vadd(w.mult(m*t)),b.state.angular.vel-=m*r*H,a.state.vel.vsub(w.mult(s*b.mass)),a.state.angular.vel+=m*q*F),v&&J&&(o=Math.abs(J)/(s+t+q*E*E+r*G*G),n=J<0?-1:1,m=v*Math.abs(m),m=Math.min(m,o),m*=n,i?(b.state.vel.vsub(x.mult(m*t)),b.state.angular.vel-=m*r*G):j?(a.state.vel.vadd(x.mult(m*s)),a.state.angular.vel+=m*q*E):(b.state.vel.vsub(x.mult(m*t)),b.state.angular.vel-=m*r*G,a.state.vel.vadd(x.mult(s*b.mass)),a.state.angular.vel+=m*q*E)),a.sleep()&&a.sleepCheck(),b.sleep()&&b.sleepCheck(),void k.done())},_pushUniq:function(a){var d=c.util.sortedIndex(this._bodyList,a,b);this._bodyList[d]!==a&&this._bodyList.splice(d,0,a)},respond:function(a){var b,d,e,f,g=this,h=a.collisions;for(d=0,e=h.length;d=0&&(j.set(1,0).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:1,y:0},mtv:{x:e,y:0},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),e=f.y+f.hh-b.max.y,e>=0&&(j.set(0,1).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:0,y:1},mtv:{x:0,y:e},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),e=b.min.x-(f.x-f.hw),e>=0&&(j.set(-1,0).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:-1,y:0},mtv:{x:-e,y:0},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),e=b.min.y-(f.y-f.hh),e>=0&&(j.set(0,-1).rotateInv(i.setRotation(a.state.angular.pos)),l={bodyA:a,bodyB:d,overlap:e,norm:{x:0,y:-1},mtv:{x:0,y:-e},pos:a.geometry.getFarthestHullPoint(j,k).rotate(i).vadd(h).values()},m.push(l)),g.done(),m},d=function(a,c,d){return b(a,c,d)},e={aabb:null,restitution:.99,cof:1,channel:"collisions:detected"};return{init:function(b){a.init.call(this),this.options.defaults(e),this.options(b),this.setAABB(this.options.aabb),this.restitution=this.options.restitution,this.body=c.body("point",{treatment:"static",restitution:this.options.restitution,cof:this.options.cof})},setAABB:function(a){if(!a)throw"Error: aabb not set";return this._edges={min:{x:a.x-a.hw,y:a.y-a.hh},max:{x:a.x+a.hw,y:a.y+a.hh}},this},connect:function(a){a.on("integrate:positions",this.checkAll,this,2)},disconnect:function(a){a.off("integrate:positions",this.checkAll,this,2)},checkAll:function(a){for(var b,e,f,g=this.getTargets(),h=(a.dt,[]),i=this._edges,j=this.body,k=this.prevContacts||{},l={},m=c.util.pairHash,n=0,o=g.length;ni&&e0&&(i>g||i===g&&h.type&&!e.type);)a[d]=h,d--,h=a[d-1],i=h&&h.val.get(j);a[d]=e}},getPair:function(a,b,c){var d=g(a.id,b.id);if(d===!1)return null;var e=this.pairs[d];if(!e){if(!c)return null;e=this.pairs[d]={bodyA:a.body,bodyB:b.body,flag:1}}return c&&(e.flag=1),e},checkOverlaps:function(){var a,b,d,g,h,i,j,k,l,m=1<=0;k--)d=n[k],d===b?(k=0;)a=d[e],b=a.interval,c=a.body.aabb(),b.min.val.clone(c).sub(c.hw,c.hh),b.max.val.clone(c).add(c.hw,c.hh)},trackBody:function(a){var b=a.body,e={id:d(),body:b},g={min:{type:!1,val:new c.vector,tracker:e},max:{type:!0,val:new c.vector,tracker:e}};e.interval=g,this.tracked.push(e);for(var h=0;h0)break;e++}}break}},sweep:function(a){var b,c=this;b=c.broadPhase(),b.length&&this._world.emit(this.options.channel,{candidates:b})}}}),c.behavior("verlet-constraints",function(a){var b=2*Math.PI,d={iterations:2};return{init:function(b){a.init.call(this),this.options.defaults(d),this.options(b),this._distanceConstraints=[],this._angleConstraints=[]},connect:function(a){var b=a.integrator();if(b&&b.name.indexOf("verlet")<0)throw'The rigid constraint manager needs a world with a "verlet" compatible integrator.';a.on("integrate:positions",this.resolve,this)},disconnect:function(a){a.off("integrate:positions",this.resolve,this)},drop:function(){return this._distanceConstraints=[],this._angleConstraints=[],this},distanceConstraint:function(a,b,d,e){var f;return!(!a||!b)&&(f={id:c.util.uniqueId("dis-constraint"),type:"dis",bodyA:a,bodyB:b,stiffness:d||.5,targetLength:e||b.state.pos.dist(a.state.pos)},f.targetLengthSq=f.targetLength*f.targetLength,this._distanceConstraints.push(f),f)},angleConstraint:function(a,b,d,e,f){var g;return!(!a||!b)&&(g={id:c.util.uniqueId("ang-constraint"),type:"ang",bodyA:a,bodyB:b,bodyC:d,stiffness:e||.5,targetAngle:f||b.state.pos.angle2(a.state.pos,d.state.pos)},this._angleConstraints.push(g),g)},remove:function(a){var b,d,e,f,g;if(e=c.util.isObject(a),d=e?a.type:a.substr(0,3),b="ang"===d?this._angleConstraints:this._distanceConstraints,e){for(f=0,g=b.length;f=Math.PI&&(f-=b),j.setTranslation(d.bodyB.state.pos),f*=-a*d.stiffness,"dynamic"===d.bodyA.treatment&&"dynamic"===d.bodyB.treatment&&"dynamic"===d.bodyC.treatment&&(g=1/(d.bodyA.mass+d.bodyB.mass+d.bodyC.mass)),"dynamic"===d.bodyA.treatment&&(e="dynamic"===d.bodyB.treatment&&"dynamic"===d.bodyC.treatment?f*(d.bodyB.mass+d.bodyC.mass)*g:"dynamic"!==d.bodyB.treatment?f*d.bodyC.mass/(d.bodyC.mass+d.bodyA.mass):f*d.bodyB.mass/(d.bodyB.mass+d.bodyA.mass),j.setRotation(e),d.bodyA.state.pos.translateInv(j),d.bodyA.state.pos.rotate(j),d.bodyA.state.pos.translate(j)),"dynamic"===d.bodyC.treatment&&(e="dynamic"===d.bodyA.treatment&&"dynamic"===d.bodyB.treatment?-f*(d.bodyB.mass+d.bodyA.mass)*g:"dynamic"!==d.bodyB.treatment?-f*d.bodyA.mass/(d.bodyC.mass+d.bodyA.mass):-f*d.bodyB.mass/(d.bodyB.mass+d.bodyC.mass),j.setRotation(e),d.bodyC.state.pos.translateInv(j),d.bodyC.state.pos.rotate(j),d.bodyC.state.pos.translate(j)),"dynamic"===d.bodyB.treatment&&(e="dynamic"===d.bodyA.treatment&&"dynamic"===d.bodyC.treatment?f*(d.bodyA.mass+d.bodyC.mass)*g:"dynamic"!==d.bodyA.treatment?f*d.bodyC.mass/(d.bodyC.mass+d.bodyB.mass):f*d.bodyA.mass/(d.bodyA.mass+d.bodyC.mass),j.setRotation(e).setTranslation(d.bodyA.state.pos),d.bodyB.state.pos.translateInv(j),d.bodyB.state.pos.rotate(j),d.bodyB.state.pos.translate(j),j.setTranslation(d.bodyC.state.pos),d.bodyB.state.pos.translateInv(j),d.bodyB.state.pos.rotateInv(j),d.bodyB.state.pos.translate(j)),d.bodyA.sleepCheck(),d.bodyB.sleepCheck(),d.bodyC.sleepCheck());i.done()},resolveDistanceConstraints:function(a){for(var b,d,e,f,g=this._distanceConstraints,h=c.scratchpad(),i=h.vector(),j=0,k=g.length;j-1&&g.splice(b,1);return i},i.render=function(a){var b,d,e,j=c.scratchpad(),k=j.vector().set(0,0),l=i.options.scale,m=g.length,n=f._interpolateTime,o=m||"main"!==i.id?g:f._world._bodies;if(i.options.manual)return j.done(),i;for(i.options.offset&&("center"===i.options.offset?k.add(.5*i.el.width,.5*i.el.height).mult(1/l):k.vadd(i.options.offset).mult(1/l)),i.options.follow&&(k.vsub(i.options.follow.state.pos),k.sub(i.options.follow.state.vel.get(0)*n,i.options.follow.state.vel.get(1)*n)),a!==!1&&i.ctx.clearRect(0,0,i.el.width,i.el.height),1!==l&&(i.ctx.save(),i.ctx.scale(l,l)),e=0,m=o.length;e2&&c.closePath(),c.stroke(),c.fill()},drawRect:function(a,b,c,d,e,f){var g=.5*c,h=.5*d;f=f||this.ctx,this.setStyle(e,f),f.beginPath(),f.rect(a-g,b-h,c,d),f.closePath(),f.stroke(),f.fill()},drawLine:function(a,b,c,d){var e=a.x,f=a.y;d=d||this.ctx,d.beginPath(),this.setStyle(c,d),d.moveTo(e,f),e=b.x,f=b.y,d.lineTo(e,f),d.stroke(),d.fill()},draw:function(a,b,c,d){var e=a.name,f=+(d&&d.x),g=+(d&&d.y),h=a.aabb().hw;if(c=c||this.ctx,b=b||this.options.styles[e]||this.options.styles.circle||{},c.save(),c.translate(f,g),"circle"===e)this.drawCircle(0,0,a.radius,b,c);else if("convex-polygon"===e)this.drawPolygon(a.vertices,b,c);else if("rectangle"===e)this.drawRect(0,0,a.width,a.height,b,c);else if("compound"===e)for(var i,j=0,k=a.children.length;j2&&h.lineTo(g.x,g.y),h.endFill(),h},createLine:function(a,b,c){var d=a.x,e=a.y,f=new PIXI.Graphics;return this.setStyles(f,c),f.moveTo(d,e),d=b.x,e=b.y,f.lineTo(d,e),f.endFill(),f},createView:function(a,b,c){var d=null,e=a.aabb(),f=e.hw+Math.abs(e.x),g=(e.hh+Math.abs(e.y),a.name);if(c=c||this.stage,b=b||this.options.styles[g]||this.options.styles.circle||{},b.src)return d=PIXI.Sprite.fromImage(b.src),d.anchor.set(.5,.5),b.anchor&&(d.anchor.x=b.anchor.x,d.anchor.y=b.anchor.y),b.width&&(d.width=b.width),b.height&&(d.height=b.height),c.addChild(d),d;if("circle"===g)d=this.createCircle(0,0,a.radius,b);else if("convex-polygon"===g)d=this.createPolygon(a.vertices,b);else if("rectangle"===g)d=this.createRect(-a.width/2,-a.height/2,a.width,a.height,b);else if("compound"===g){d=new PIXI.Graphics;for(var h,i,j=0,k=a.children.length;j + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ @@ -3709,13 +3709,6 @@ Physics.scratchpad = (function(){ } }; - // private storage for sleeping - this._sleepAngPosMean = 0; - this._sleepAngPosVariance = 0; - this._sleepPosMean = new vector(); - this._sleepPosVariance = new vector(); - this._sleepMeanK = 0; - // cleanup delete this.x; delete this.y; @@ -3850,13 +3843,7 @@ Physics.scratchpad = (function(){ } else if ( dt === false ){ // force wakup - this.asleep = false; - this._sleepMeanK = 0; - this._sleepAngPosMean = 0; - this._sleepAngPosVariance = 0; - this._sleepPosMean.zero(); - this._sleepPosVariance.zero(); - this.sleepIdleTime = 0; + this.asleep = false; } else if ( dt && !this.asleep ) { @@ -3884,57 +3871,26 @@ Physics.scratchpad = (function(){ } var limit - ,v - ,d - ,r - ,aabb - ,scratch = Physics.scratchpad() - ,diff = scratch.vector() - ,diff2 = scratch.vector() - ,kfac - ,stats + ,Ek ; - dt = dt || 0; - aabb = this.geometry.aabb(); - r = Math.max(aabb.hw, aabb.hh); - if ( this.asleep ){ - // check velocity - v = this.state.vel.norm() + Math.abs(r * this.state.angular.vel); - limit = this.sleepSpeedLimit || (opts && opts.sleepSpeedLimit) || 0; + + // check kinetic energy (linear and rotational) + Ek = 0.5* this.mass * this.state.vel.dot(this.state.vel) + + 0.5*Math.abs(this.moi * this.state.angular.vel.dot(this.state.angular.vel)); + + limit = this.sleepEnergyLimit || (opts && opts.sleepEnergyLimit) || 0; - if ( v >= limit ){ + if ( Ek >= limit ){ + this.sleep( false ); - return scratch.done(); - } - } - - this._sleepMeanK++; - kfac = this._sleepMeanK > 1 ? 1/(this._sleepMeanK - 1) : 0; - Physics.statistics.pushRunningVectorAvg( this.state.pos, this._sleepMeanK, this._sleepPosMean, this._sleepPosVariance ); - // we take the sin because that maps the discontinuous angle to a continuous value - // then the statistics calculations work better - stats = Physics.statistics.pushRunningAvg( Math.sin(this.state.angular.pos), this._sleepMeanK, this._sleepAngPosMean, this._sleepAngPosVariance ); - this._sleepAngPosMean = stats[0]; - this._sleepAngPosVariance = stats[1]; - v = this._sleepPosVariance.norm() + Math.abs(r * Math.asin(stats[1])); - v *= kfac; - limit = this.sleepVarianceLimit || (opts && opts.sleepVarianceLimit) || 0; - // console.log(v, limit, kfac, this._sleepPosVariance.norm(), stats[1]) - if ( v <= limit ){ - // check idle time - limit = this.sleepTimeLimit || (opts && opts.sleepTimeLimit) || 0; - this.sleepIdleTime = (this.sleepIdleTime || 0) + dt; - - if ( this.sleepIdleTime > limit ){ - this.asleep = true; + } - } else { - this.sleep( false ); + } - scratch.done(); + }, /** @@ -5041,10 +4997,8 @@ Physics.geometry.nearestPointOnLine = function nearestPointOnLine( pt, linePt1, // is sleeping disabled? sleepDisabled: false, - // speed at which bodies wake up - sleepSpeedLimit: 0.05, - // variance in position below which bodies fall asleep - sleepVarianceLimit: 0.02, + // Kinetic Energy at which bodies wake up + sleepEnergyLimit: 0.00000001, // time (ms) before sleepy bodies fall asleep sleepTimeLimit: 500 }; diff --git a/dist/physicsjs.min.js b/dist/physicsjs.min.js index 08d5e52a..ecd4a688 100644 --- a/dist/physicsjs.min.js +++ b/dist/physicsjs.min.js @@ -1,10 +1,10 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ -!function(a,b){"object"==typeof exports?module.exports=b.call(a):"function"==typeof define&&define.amd?define(function(){return b.call(a)}):a.Physics=b.call(a)}("undefined"!=typeof window?window:this,function(){"use strict";var a=this,b=a.document,c=function f(){return f.world.apply(f,arguments)};c.util={},function(){c.aabb=function(a,b,c,d){var e={x:0,y:0,hw:0,hh:0};return void 0===a?e:(a&&void 0!==a.x&&(c=b.x,d=b.y,b=a.y,a=a.x),void 0===d&&void 0!==a&&void 0!==b?(e.hw=.5*a,e.hh=.5*b,c&&void 0!==c.x&&(e.x=c.x,e.y=c.y),e):(e.hw=.5*Math.abs(c-a),e.hh=.5*Math.abs(d-b),e.x=.5*(c+a),e.y=.5*(d+b),e))},c.aabb.contains=function(a,b){return b.x>a.x-a.hw&&b.xa.y-a.hh&&b.y=d&&f>=e||f>=c&&e>=f?(c=a.y-a.hh,d=b.y-b.hh,e=a.y+a.hh,f=b.y+b.hh,e>=d&&f>=e||f>=c&&e>=f):!1}}(),function(){var a=1e-4,b=100,d=function(a,b,c){var d=b.normSq()-b.dot(a),e=b.dot(a)-a.normSq();return 0>d?c.clone(b).negate():e>0?c.clone(a).negate():(c.clone(b).vsub(a),c.perp(a.cross(c)>0))},e=function(a){var b,d,e=a.length,f=a[e-2],g=a[e-3],h=c.scratchpad(),i=h.vector().clone(f.pt),j=h.vector().clone(g.pt).vsub(i);return j.equals(c.vector.zero)?h.done({a:f.a,b:f.b}):(b=-j.dot(i)/j.normSq(),d=1-b,h.done(0>=d?{a:g.a,b:g.b}:0>=b?{a:f.a,b:f.b}:{a:i.clone(f.a).mult(d).vadd(j.clone(g.a).mult(b)).values(),b:i.clone(f.b).mult(d).vadd(j.clone(g.b).mult(b)).values()}))},f=function(f,g,h,i){var j,k,l,m,n=!1,o=!1,p=!1,q=[],r=1,s=c.scratchpad(),t=s.vector().clone(g||c.vector.axis[0]),u=s.vector(),v=s.vector(),w=s.vector(),x=s.vector(),y=0;for(m=f(t),r=q.push(m),u.clone(m.pt),t.negate();++y;){if(u.swap(v),m=f(t),r=q.push(m),u.clone(m.pt),i&&i(q),u.equals(c.vector.zero)){n=!0;break}if(!o&&u.dot(t)<=0){if(h)break;o=!0}if(2===r)t=d(u,v,t);else if(o){if(t.normalize(),m=v.dot(t),Math.abs(m-u.dot(t))0,l^u.cross(j)>0)q.shift(),j.perp(!l),t.swap(j);else{if(!(l^k.cross(u)>0)){n=!0;break}q.splice(1,1),k.perp(l),t.swap(j)}if(y>b)return s.done(),{simplex:q,iterations:y,distance:0,maxIterationsReached:!0}}return s.done(),m={overlap:n,simplex:q,iterations:y},p!==!1&&(m.distance=p,m.closest=e(q)),m};c.gjk=f}(),function(){c.statistics={pushRunningAvg:function(a,b,c,d){var e=a-c;return c+=e/b,d+=e*(a-c),[c,d]},pushRunningVectorAvg:function(a,b,c,d){var e=1/b,f=a.get(0)-c.get(0),g=a.get(1)-c.get(1);c.add(f*e,g*e),d&&(f*=a.get(0)-c.get(0),g*=a.get(1)-c.get(1),d.add(f,g))}}}(),function(){var a=function b(a,d,e){return this instanceof b?(this.v=new c.vector,this.o=new c.vector,a instanceof b?void this.clone(a):(a&&this.setTranslation(a),void this.setRotation(d||0,e))):new b(a,d)};a.prototype.setTranslation=function(a){return this.v.clone(a),this},a.prototype.setRotation=function(a,b){return this.cosA=Math.cos(a),this.sinA=Math.sin(a),b?this.o.clone(b):this.o.zero(),this},a.prototype.clone=function(b){return b?(this.setTranslation(b.v),this.cosA=b.cosA,this.sinA=b.sinA,this.o.clone(b.o),this):new a(this)},c.transform=a}(),function(a){var b=Math.sqrt,d=Math.min,e=Math.max,f=(Math.acos,Math.atan2),g=2*Math.PI,h=!!a.Float64Array,i=function j(a,b){return this instanceof j?(this._=h?new Float64Array(5):[],void(a&&(void 0!==a.x||a._&&a._.length)?this.clone(a):(this.recalc=!0,this.set(a,b)))):new j(a,b)};Object.defineProperties(i.prototype,{x:{get:function(){return+this._[0]},set:function(a){a=+a||0,this.recalc=a===this._[0],this._[0]=a}},y:{get:function(){return+this._[1]},set:function(a){a=+a||0,this.recalc=a===this._[1],this._[1]=a}}}),i.prototype.set=function(a,b){return this.recalc=!0,this._[0]=+a||0,this._[1]=+b||0,this},i.prototype.get=function(a){return this._[a]},i.prototype.vadd=function(a){return this.recalc=!0,this._[0]+=a._[0],this._[1]+=a._[1],this},i.prototype.vsub=function(a){return this.recalc=!0,this._[0]-=a._[0],this._[1]-=a._[1],this},i.prototype.add=function(a,b){return this.recalc=!0,this._[0]+=+a||0,this._[1]+=+b||0,this},i.prototype.sub=function(a,b){return this.recalc=!0,this._[0]-=a,this._[1]-=void 0===b?0:b,this},i.prototype.mult=function(a){return this.recalc||(this._[4]*=a*a,this._[3]*=a),this._[0]*=a,this._[1]*=a,this},i.prototype.dot=function(a){return this._[0]*a._[0]+this._[1]*a._[1]},i.prototype.cross=function(a){return-this._[0]*a._[1]+this._[1]*a._[0]},i.prototype.proj=function(a){return this.dot(a)/a.norm()},i.prototype.vproj=function(a){var b=this.dot(a)/a.normSq();return this.clone(a).mult(b)},i.prototype.angle=function(a){var b;if(this.equals(i.zero))return a?a.angle():0/0;for(b=a&&!a.equals(i.zero)?f(this._[1]*a._[0]-this._[0]*a._[1],this._[0]*a._[0]+this._[1]*a._[1]):f(this._[1],this._[0]);b>Math.PI;)b-=g;for(;b<-Math.PI;)b+=g;return b},i.prototype.angle2=function(a,b){for(var c=a._[0]-this._[0],d=a._[1]-this._[1],e=b._[0]-this._[0],h=b._[1]-this._[1],i=f(d*e-c*h,c*e+d*h);i>Math.PI;)i-=g;for(;i<-Math.PI;)i+=g;return i},i.prototype.norm=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[3]},i.prototype.normSq=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[4]},i.prototype.dist=function(a){var c,d;return b((c=a._[0]-this._[0])*c+(d=a._[1]-this._[1])*d)},i.prototype.distSq=function(a){var b,c;return(b=a._[0]-this._[0])*b+(c=a._[1]-this._[1])*c},i.prototype.perp=function(a){var b=this._[0];return a?(this._[0]=this._[1],this._[1]=-b):(this._[0]=-this._[1],this._[1]=b),this},i.prototype.normalize=function(){var a=this.norm();return 0===a?this:(a=1/a,this._[0]*=a,this._[1]*=a,this._[3]=1,this._[4]=1,this)},i.prototype.transform=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d,this._[1]-=e,this.set(this._[0]*c-this._[1]*b+d+a.v._[0],this._[0]*b+this._[1]*c+e+a.v._[1])},i.prototype.transformInv=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d+a.v._[0],this._[1]-=e+a.v._[1],this.set(this._[0]*c+this._[1]*b+d,-this._[0]*b+this._[1]*c+e)},i.prototype.rotate=function(a,b){var c,d,e=0,f=0;return"number"==typeof a?(c=Math.sin(a),d=Math.cos(a),b&&(e=b.x,f=b.y)):(c=a.sinA,d=a.cosA,e=a.o._[0],f=a.o._[1]),this._[0]-=e,this._[1]-=f,this.set(this._[0]*d-this._[1]*c+e,this._[0]*c+this._[1]*d+f)},i.prototype.rotateInv=function(a){return this.set((this._[0]-a.o._[0])*a.cosA+(this._[1]-a.o._[1])*a.sinA+a.o._[0],-(this._[0]-a.o._[0])*a.sinA+(this._[1]-a.o._[1])*a.cosA+a.o._[1])},i.prototype.translate=function(a){return this.vadd(a.v)},i.prototype.translateInv=function(a){return this.vsub(a.v)},i.prototype.clone=function(a){return a?a._?(this.recalc=a.recalc,a.recalc||(this._[3]=a._[3],this._[4]=a._[4]),this._[0]=a._[0],this._[1]=a._[1],this):this.set(a.x,a.y):new i(this)},i.prototype.swap=function(a){var b=this._;return this._=a._,a._=b,b=this.recalc,this.recalc=a.recalc,a.recalc=b,this},i.prototype.values=function(){return{x:this._[0],y:this._[1]}},i.prototype.zero=function(){return this._[3]=0,this._[4]=0,this._[0]=0,this._[1]=0,this},i.prototype.negate=function(a){return void 0!==a?(this._[a]=-this._[a],this):(this._[0]=-this._[0],this._[1]=-this._[1],this)},i.prototype.clamp=function(a,b){return this._[0]=d(e(this._[0],a.x),b.x),this._[1]=d(e(this._[1],a.y),b.y),this.recalc=!0,this},i.prototype.toString=function(){return"("+this._[0]+", "+this._[1]+")"},i.prototype.equals=function(a){return this._[0]===a._[0]&&this._[1]===a._[1]&&this._[2]===a._[2]},i.axis=[new i(1,0),new i(0,1)],i.zero=new i(0,0),c.vector=i}(this),function(a){var b=a.Physics;c.noConflict=function(){return a.Physics===c&&(a.Physics=b),c}}(this);var d=c.util.decorator=function(a,b){var d={},e={},f=function(a,b){var d,e;for(e in b)d=Object.getOwnPropertyDescriptor(b,e),d.get||d.set?Object.defineProperty(a,e,d):c.util.isFunction(d.value)&&(a[e]=d.value);return a},g=Object.getPrototypeOf;"function"!=typeof g&&(g="object"==typeof"test".__proto__?function(a){return a.__proto__}:function(a){return a.constructor.prototype});var h=Object.create;"function"!=typeof h&&(h=function(a){function b(){}return b.prototype=a,new b});var i=function(b,d){return"object"==typeof b?(e=f(e,b),void(e.type=a)):void("type"!==b&&c.util.isFunction(d)&&(e[b]=d))};i(b);var j=function(b,c,i,j){var k,l=e;if("string"!=typeof c)j=i,i=c;else{if(l=d[c],!l)throw'Error: "'+c+'" '+a+" not defined";l=l.prototype}if("function"==typeof i)k=d[b],k?k.prototype=f(k.prototype,i(g(k.prototype))):(k=d[b]=function(a){this.init&&this.init(a)},k.prototype=h(l),k.prototype=f(k.prototype,i(l,k.prototype))),k.prototype.type=a,k.prototype.name=b;else if(j=i||{},k=d[b],!k)throw'Error: "'+b+'" '+a+" not defined";return j?new k(j):void 0};return j.mixin=i,j};c.util.indexOf=function(a,b){for(var c=0,d=a.length;d>c;){if(d--,a[c]===b)return c;if(a[d]===b)return d;c++}return-1},c.util.clearArray=function(a){for(var b=a.length;b--;)a.pop();return a},c.util.throttle=function(a,b,c){var d,e,f=!1,g=function(){clearTimeout(d),f?(f=!1,d=setTimeout(g,b),a.apply(c,e)):d=!1};return c=c||null,function(){f=!0,e=arguments,d||g()}};var e=function(a,b){return c.util.isPlainObject(b)?c.util.extend({},a,b,e):void 0!==b?b:a};return c.util.options=function(a,b){var d,f={},g=[];return d=function(a,d){c.util.extend(b,a,d?e:null);for(var f=0,h=g.length;h>f;++f)g[f](b);return b},d.defaults=function(a,d){return c.util.extend(f,a,d?e:null),c.util.defaults(b,f,d?e:null),f},d.onChange=function(a){g.push(a)},b=b||d,d.defaults(a),d},c.util.pairHash=function(a,b){return a=0|a,b=0|b,(0|a)===(0|b)?-1:0|((0|a)>(0|b)?a<<16|65535&b:b<<16|65535&a)},c.util.bind=Function.prototype.bind?function(a,b,c){return c=Array.prototype.slice.call(arguments,1),Function.prototype.bind.apply(a,c)}:function(a,b,c){return c=Array.prototype.slice.call(arguments,2),function(){return a.apply(b,c.concat(Array.prototype.slice.call(arguments)))}},c.util.find=function(a,b){var c,d,e=a.length;for(c=0;e>c;c++)if(d=a[c],b(d,c,a))return d},c.util.filter=function(a,b){var c,d,e=a.length,f=[];for(c=0;e>c;c++)d=a[c],b(d,c,a)&&f.push(d);return f},function(){function a(a){c.util.clearArray(a),v.length-1?0:-1:a?0:-1}function g(a){var b=this.cache,c=typeof a;if("boolean"===c||null==a)b[a]=!0;else{"number"!==c&&"string"!==c&&(c="object");var d="number"===c?a:y+a,e=b[c]||(b[c]={});"object"===c?(e[d]||(e[d]=[])).push(a):e[d]=!0}}function h(a){var b=-1,c=a.length,e=a[0],f=a[c/2|0],h=a[c-1];if(e&&"object"==typeof e&&f&&"object"==typeof f&&h&&"object"==typeof h)return!1;var i=d();i["false"]=i["null"]=i["true"]=i.undefined=!1;var j=d();for(j.array=a,j.cache=i,j.push=g;++b=u&&k===c.util.indexOf,o=i||n?e():m;if(n){var p=h(o);k=f,o=p}for(;++jb;b++)d=a[b],e=i(0,++f),h[f]=h[e],h[e]=d;return h},c.util.isObject=function(a){return!(!a||!n[typeof a])},c.util.isFunction=j,c.util.isArray=Array.isArray||function(a){return a&&"object"==typeof a&&"number"==typeof a.length&&s.call(a)===p||!1};var C=RegExp("^"+String(s).replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/toString| for [^\]]+/g,".*?")+"$");c.util.isPlainObject=Object.getPrototypeOf?function(a){if(!a||s.call(a)!==q)return!1;var b=a.valueOf,c=k(b)&&(c=Object.getPrototypeOf(b))&&Object.getPrototypeOf(c);return c?a===c||Object.getPrototypeOf(a)===c:l(a)}:l,c.util.uniq=function(a,b,c){return"boolean"!=typeof b&&null!=b&&(c=b,b=!1),m(a,b,c)};var D=function(a,b,c){var d,e=a,f=e;if(!e)return f;var g,h=arguments,i=0,j="number"==typeof c?2:h.length;for(j>2&&"function"==typeof h[j-1]&&(g=h[--j]);++id;){var f=d+e>>>1;c(a[f])=b.maxScratches)throw f},a.prototype={done:function(a){this._active=!1;for(var b=0;j>b;++b)this[b]=0;return h.push(this),a}},b=function k(b){if(b)return k.fn(b);var c=h.pop()||new a;return c._active=!0,c},b.maxScratches=100,b.maxIndex=20,b.fn=function(b){for(var c=[],d=0,e=b.length;e>d;d++)c.push(d);c="a"+c.join(",a");var f=new Function("fn, scratches, Scratch","return function("+c+"){ var scratch = scratches.pop() || new Scratch( scratches );scratch._active = true;return scratch.done( fn(scratch, "+c+") );};");return f(b,h,a)},b.register=function(c,f,h){var i=a.prototype,k=j++,l="_"+c+"Stack",m=h&&h.useFactory;if(c in i)throw g;a.prototype[c]=function(){var a=this[l]||(this[l]=[]),c=0|this[k];if(this[k]=c+1,!this._active)throw d;if(c>=b.maxIndex)throw e;return a[c]||(a[c]=m?f():new f)}},b.register("vector",c.vector),b.register("transform",c.transform),b}(),function(){function a(a){return a._priority_}var b=1;c.scratchpad.register("event",function(){return{}},{useFactory:!0});var d=function e(){return this instanceof e?void 0:new e};d.prototype={on:function(d,e,f,g){var h,i,j;if(this._topics=this._topics||(this._topics={}),c.util.isObject(d)){for(var k in d)this.on(k,d[k],e,f);return this}return h=this._topics[d]||(this._topics[d]=[]),i=e,c.util.isObject(f)?(e=c.util.bind(e,f),e._bindfn_=i,e._one_=i._one_,e._scope_=f):void 0===g&&(g=f),e._priority_=void 0===g?b:g,j=c.util.sortedIndex(h,e,a),h.splice(j,0,e),this},off:function(a,b,d){var e,f;if(!this._topics)return this;if(a===!0)return this._topics={},this;if(c.util.isObject(a)){for(var g in a)this.off(g,a[g]);return this}if(e=this._topics[a],!e)return this;if(b===!0)return this._topics[a]=[],this;for(var h=0,i=e.length;i>h;h++)if(f=e[h],!(f._bindfn_!==b&&f!==b||d&&f._scope_!==d)){e.splice(h,1);break}return this},emit:function(a,b){if(!this._topics)return this;var d,e,f=this._topics[a],g=f&&f.length,h=c.scratchpad();if(!g)return h.done(this);for(e=h.event(),e.topic=a,e.handler=d;g--;)d=f[g],d(b,e),d._one_&&f.splice(g,1);return h.done(this)},one:function(a,b,d){if(c.util.isObject(a)){for(var e in a)this.one(e,a[e],b,d);return this}return b._one_=!0,this.on(a,b,d),this}},c.util.pubsub=d}(),function(a){function b(){return l&&l.now?l.now()+l.timing.navigationStart:Date.now()}function d(){var c;a.requestAnimationFrame(d),j&&(c=b(),c&&k.emit("tick",c))}function e(){return j=!0,this}function f(){return j=!1,this}function g(a){return k.on("tick",a),this}function h(a){return k.off("tick",a),this}function i(){return!!j}var j=!0,k=c.util.pubsub(),l=a.performance;a.requestAnimationFrame?d():j=!1,c.util.ticker={now:b,start:e,stop:f,on:g,off:h,isActive:i}}(this),function(){var a=function(){return!0},b=c.util.indexOf,d=function(a,b){return function(c){return a(c[b])}},e=function(a,d){return function(e){e=d?e[d]:e;var f,g=0;if(c.util.isArray(e)){if(c.util.isArray(a)){if(f=e.length,f!==a.length)return!1;for(;f>g;){if(f--,-1===b(a,e[g])||-1===b(a,e[f]))return!1;g++}return!0}return b(e,a)>-1}return e===a}},f=function(a,b){var c=e(a,b);return function(a){return!c(a)}},g=function(a,d){return function(e){e=d?e[d]:e;var f,g=0;if(c.util.isArray(e)){for(f=e.length;f>g;){if(f--,b(a,e[g])>-1||b(a,e[f])>-1)return!0;g++}return!1}return b(a,e)>-1}},h=function(a,b){var c=g(a,b);return function(a){return!c(a)}},i=function(a){return a=new c.vector(a),function(b){var d=b.aabb();return c.aabb.contains(d,a)}},j=function(a){return a.next?function(b){for(var c=a;c;){if(!c(b))return!1;c=c.next}return!0}:a},k=function(a){return a.next?function(b){for(var c=a;c;){if(c(b))return!0;c=c.next}return!1}:a},l={$eq:e,$ne:f,$in:g,$nin:h,$at:i},m=function n(b,f){var g,h,i,m,o,p;if(f){if("$or"===f||"$and"===f){for(g=0,h=b.length;h>g;++g)p=n(b[g]),o=o?o.next=p:m=p;return"$or"===f?k(m):j(m)}if(g=l[f])return g(b);throw"Unknown query operation: "+f}for(g in b)i=b[g],p="$"===g[0]?n(i,g):c.util.isPlainObject(i)?d(n(i),g):e(i,g),o=o?o.next=p:m=p;return j(m||a)};c.query=m}(this),function(){var a={priority:0};c.behavior=d("behavior",{init:function(b){this.options=c.util.options(a),this.options(b)},applyTo:function(a){return this._targets=a===!0?null:c.util.uniq(a),this},getTargets:function(){return this._targets||(this._world?this._world._bodies:[])},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},connect:function(a){this.behave&&a.on("integrate:positions",this.behave,this,this.options.priority)},disconnect:function(a){this.behave&&a.off("integrate:positions",this.behave,this)},behave:null})}(),function(){{var a={hidden:!1,treatment:"dynamic",mass:1,restitution:1,cof:.8,view:null},b=1;2*Math.PI}c.body=d("body",{init:function(d){var e=this,f=c.vector;if(this.options=c.util.options(a,this),this.options.onChange(function(a){e.offset=new f(a.offset)}),this.options(d),this.state={pos:new f(this.x,this.y),vel:new f(this.vx,this.vy),acc:new f,angular:{pos:this.angle||0,vel:this.angularVelocity||0,acc:0},old:{pos:new f,vel:new f,acc:new f,angular:{pos:0,vel:0,acc:0}}},this._sleepAngPosMean=0,this._sleepAngPosVariance=0,this._sleepPosMean=new f,this._sleepPosVariance=new f,this._sleepMeanK=0,delete this.x,delete this.y,delete this.vx,delete this.vy,delete this.angle,delete this.angularVelocity,0===this.mass)throw"Error: Bodies must have non-zero mass";this.uid=b++,this.geometry=c.geometry("point")},sleep:function(a){return a===!0?this.asleep=!0:a===!1?(this.asleep=!1,this._sleepMeanK=0,this._sleepAngPosMean=0,this._sleepAngPosVariance=0,this._sleepPosMean.zero(),this._sleepPosVariance.zero(),this.sleepIdleTime=0):a&&!this.asleep&&this.sleepCheck(a),this.asleep},sleepCheck:function(a){var b=this._world&&this._world.options;if(!(this.sleepDisabled||b&&b.sleepDisabled)){{var d,e,f,g,h,i,j=c.scratchpad();j.vector(),j.vector()}if(a=a||0,g=this.geometry.aabb(),f=Math.max(g.hw,g.hh),this.asleep&&(e=this.state.vel.norm()+Math.abs(f*this.state.angular.vel),d=this.sleepSpeedLimit||b&&b.sleepSpeedLimit||0,e>=d))return this.sleep(!1),j.done();this._sleepMeanK++,h=this._sleepMeanK>1?1/(this._sleepMeanK-1):0,c.statistics.pushRunningVectorAvg(this.state.pos,this._sleepMeanK,this._sleepPosMean,this._sleepPosVariance),i=c.statistics.pushRunningAvg(Math.sin(this.state.angular.pos),this._sleepMeanK,this._sleepAngPosMean,this._sleepAngPosVariance),this._sleepAngPosMean=i[0],this._sleepAngPosVariance=i[1],e=this._sleepPosVariance.norm()+Math.abs(f*Math.asin(i[1])),e*=h,d=this.sleepVarianceLimit||b&&b.sleepVarianceLimit||0,d>=e?(d=this.sleepTimeLimit||b&&b.sleepTimeLimit||0,this.sleepIdleTime=(this.sleepIdleTime||0)+a,this.sleepIdleTime>d&&(this.asleep=!0)):this.sleep(!1),j.done()}},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},accelerate:function(a){return"dynamic"===this.treatment&&this.state.acc.vadd(a),this},applyForce:function(a,b){if("dynamic"!==this.treatment)return this;var d,e=c.scratchpad(),f=e.vector();return b&&this.moi&&(d=this.state,f.clone(b),this.state.angular.acc-=f.cross(a)/this.moi),this.accelerate(f.clone(a).mult(1/this.mass)),e.done(),this},getGlobalOffset:function(a){return a=a||new c.vector,a.clone(this.offset).rotate(this.state.angular.pos),a},aabb:function(){var a=this.state.angular.pos,b=c.scratchpad(),d=b.vector(),e=this.geometry.aabb(a);return this.getGlobalOffset(d),e.x+=this.state.pos._[0]+d._[0],e.y+=this.state.pos._[1]+d._[1],b.done(e)},toBodyCoords:function(a){return a.vsub(this.state.pos).rotate(-this.state.angular.pos)},toWorldCoords:function(a){return a.rotate(this.state.angular.pos).vadd(this.state.pos)},recalc:function(){return this}}),c.body.getCOM=function(a,b){var d,e,f,g=a&&a.length,h=0;if(b=b||new c.vector,!g)return b.zero();if(1===g)return b.clone(a[0].state.pos);for(b.zero(),f=0;g>f;f++)d=a[f],e=d.state.pos,b.add(e._[0]*d.mass,e._[1]*d.mass),h+=d.mass;return b.mult(1/h),b}}(),function(){c.geometry=d("geometry",{init:function(a){this.options=c.util.options(),this.options(a),this._aabb=new c.aabb},aabb:function(){return c.aabb.clone(this._aabb)},getFarthestHullPoint:function(a,b){return b=b||new c.vector,b.set(0,0)},getFarthestCorePoint:function(a,b){return b=b||new c.vector,b.set(0,0)}})}(),c.geometry.regularPolygonVertices=function(a,b){var c,d=[],e=2*Math.PI/a,f=0;for(c=0;a>c;c++)d.push({x:b*Math.cos(f),y:b*Math.sin(f)}),f+=e;return d},c.geometry.isPolygonConvex=function(a){var b=c.scratchpad(),d=b.vector(),e=b.vector(),f=b.vector(),g=!0,h=!1,i=a.length;if(!a||!i)return!1;if(3>i)return b.done(),g;d.clone(a[0]).vsub(f.clone(a[i-1]));for(var j=1;i>=j;++j){if(e.clone(a[j%i]).vsub(f.clone(a[(j-1)%i])),h===!1)h=d.cross(e);else if(h>0^d.cross(e)>0){g=!1;break}e.swap(d)}return b.done(),g},c.geometry.getPolygonMOI=function(a){var b,d=c.scratchpad(),e=d.vector(),f=d.vector(),g=0,h=0,i=a.length;if(2>i)return d.done(),0;if(2===i)return b=f.clone(a[1]).distSq(e.clone(a[0])),d.done(),b/12;e.clone(a[0]);for(var j=1;i>j;++j)f.clone(a[j]),b=Math.abs(f.cross(e)),g+=b*(f.normSq()+f.dot(e)+e.normSq()),h+=b,e.swap(f);return d.done(),g/(6*h)},c.geometry.isPointInPolygon=function(a,b){var d=c.scratchpad(),e=d.vector().clone(a),f=d.vector(),g=d.vector(),h=0,i=b.length;if(2>i)return h=e.equals(f.clone(b[0])),d.done(),h;if(2===i)return h=e.angle(f.clone(b[0])),h+=e.angle(f.clone(b[1])),d.done(),Math.abs(h)===Math.PI;f.clone(b[0]).vsub(e);for(var j=1;i>=j;++j)g.clone(b[j%i]).vsub(e),h+=g.angle(f),f.swap(g);return d.done(),Math.abs(h)>1e-6},c.geometry.getPolygonArea=function(a){var b=c.scratchpad(),d=b.vector(),e=b.vector(),f=0,g=a.length;if(3>g)return b.done(),0;d.clone(a[g-1]);for(var h=0;g>h;++h)e.clone(a[h]),f+=d.cross(e),d.swap(e);return b.done(),f/2},c.geometry.getPolygonCentroid=function(a){var b,d=c.scratchpad(),e=d.vector(),f=d.vector(),g=new c.vector,h=a.length;if(2>h)return d.done(),new c.vector(a[0]);if(2===h)return d.done(),new c.vector((a[1].x+a[0].x)/2,(a[1].y+a[0].y)/2);e.clone(a[h-1]);for(var i=0;h>i;++i)f.clone(a[i]),b=e.cross(f),e.vadd(f).mult(b),g.vadd(e),e.swap(f);return b=1/(6*c.geometry.getPolygonArea(a)),d.done(),g.mult(b)},c.geometry.nearestPointOnLine=function(a,b,d){var e,f,g=c.scratchpad(),h=g.vector().clone(a),i=g.vector().clone(b).vsub(h),j=g.vector().clone(d).vsub(h).vsub(i);return j.equals(c.vector.zero)?(g.done(),new c.vector(b)):(e=-j.dot(i)/j.normSq(),f=1-e,0>=f?(g.done(),new c.vector(d)):0>=e?(g.done(),new c.vector(b)):(h=new c.vector(d).mult(e).vadd(i.clone(b).mult(f)),g.done(),h))},function(){var a={drag:0};c.integrator=d("integrator",{init:function(b){this.options=c.util.options(a),this.options(b)},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},integrate:function(a,b){var c=this._world;return this.integrateVelocities(a,b),c&&c.emit("integrate:velocities",{bodies:a,dt:b}),this.integratePositions(a,b),c&&c.emit("integrate:positions",{bodies:a,dt:b}),this},connect:null,disconnect:null,integrateVelocities:function(){throw"The integrator.integrateVelocities() method must be overriden"},integratePositions:function(){throw"The integrator.integratePositions() method must be overriden"}})}(),function(){var e={meta:!1,metaRefresh:200,width:600,height:600,autoResize:!0};c.renderer=d("renderer",{init:function(d){var f=this,g="string"==typeof d.el?b.getElementById(d.el):d.el;this.options=c.util.options(e),this.options(d),this.el=g?g:b.body,this.container=g&&g.parentNode?g.parentNode:b.body,this.drawMeta=c.util.throttle(c.util.bind(this.drawMeta,this),this.options.metaRefresh),a.addEventListener("resize",c.util.throttle(function(){f.options.autoResize&&f.resize()}),100)},resize:function(a,b){void 0===a&&void 0===b&&(a=this.container.offsetWidth,b=this.container.offsetHeight),this.width=a||0,this.height=b||0},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},render:function(a,b){var c,d;this.beforeRender&&this.beforeRender(),this._world.emit("beforeRender",{renderer:this,bodies:a,meta:b}),this.options.meta&&this.drawMeta(b),this._interpolateTime=b.interpolateTime;for(var e=0,f=a.length;f>e;++e)c=a[e],d=c.view||(c.view=this.createView(c.geometry,c.styles)),c.hidden||this.drawBody(c,d);return this},createView:function(){throw"You must override the renderer.createView() method."},drawMeta:function(){throw"You must override the renderer.drawMeta() method."},drawBody:function(){throw"You must override the renderer.drawBody() method."}})}(),function(){var a=function e(a,b,c){for(var d,f,g=function(){return e(a,b,c)};d=a.shift();)if(f=d.apply(b,c),f&&f.then)return f.then(g)},b={timestep:6,maxIPF:4,webworker:!1,integrator:"verlet",sleepDisabled:!1,sleepSpeedLimit:.05,sleepVarianceLimit:.02,sleepTimeLimit:500},d=function f(a,b){return this instanceof f?void this.init(a,b):new f(a,b)};d.prototype=c.util.extend({},c.util.pubsub.prototype,{init:function(d,e){var f=this;(c.util.isFunction(d)||c.util.isArray(d))&&(e=d,d={}),this._meta={fps:0,ipf:0},this._bodies=[],this._behaviors=[],this._integrator=null,this._renderer=null,this._paused=!1,this._warp=1,this._time=0,this.options=c.util.options(b),this.options.onChange(function(a){f.timestep(a.timestep)}),this.options(d),this.add(c.integrator(this.options.integrator)),c.util.isFunction(e)?a([e],this,[this,c]):c.util.isArray(e)&&a(e,this,[this,c])},options:null,add:function(a){var b=0,d=a&&a.length||0,e=c.util.isArray(a)?a[0]:a;if(!e)return this;do switch(e.type){case"behavior":this.addBehavior(e);break;case"integrator":this.integrator(e);break;case"renderer":this.renderer(e);break;case"body":this.addBody(e);break;default:throw'Error: failed to add item of unknown type "'+e.type+'" to world'}while(++b-1},integrator:function(a){return void 0===a?this._integrator:this._integrator===a?this:(this._integrator&&(this._integrator.setWorld(null),this.emit("remove:integrator",{integrator:this._integrator})),a&&(this._integrator=a,this._integrator.setWorld(this),this.emit("add:integrator",{integrator:this._integrator})),this)},renderer:function(a){return void 0===a?this._renderer:this._renderer===a?this:(this._renderer&&(this._renderer.setWorld(null),this.emit("remove:renderer",{renderer:this._renderer})),a&&(this._renderer=a,this._renderer.setWorld(this),this.emit("add:renderer",{renderer:this._renderer})),this)},timestep:function(a){return a?(this._dt=+a.toPrecision(4),this._maxJump=a*this.options.maxIPF,this):this._dt},wakeUpAll:function(){var a=0,b=this._bodies.length;for(a=0;b>a;a++)this._bodies[a].sleep(!1)},addBehavior:function(a){return this.has(a)?this:(a.setWorld(this),this._behaviors.push(a),this.emit("add:behavior",{behavior:a}),this)},getBehaviors:function(){return[].concat(this._behaviors)},removeBehavior:function(a){var b=this._behaviors;if(a)for(var c=0,d=b.length;d>c;++c)if(a===b[c]){b.splice(c,1),a.setWorld(null),this.emit("remove:behavior",{behavior:a});break}return this},addBody:function(a){return this.has(a)?this:(a.setWorld(this),this._bodies.push(a),this.emit("add:body",{body:a}),this)},getBodies:function(){return[].concat(this._bodies)},removeBody:function(a){var b=this._bodies;if(a)for(var c=0,d=b.length;d>c;++c)if(a===b[c]){b.splice(c,1),a.setWorld(null),this.emit("remove:body",{body:a});break}return this},findOne:function(a){var b=this,d="function"==typeof a?a:c.query(a);return c.util.find(b._bodies,d)||!1},find:function(a){var b=this,d="function"==typeof a?a:c.query(a);return c.util.filter(b._bodies,d)},iterate:function(a){this._integrator.integrate(this._bodies,a)},step:function(a){var b,d,e,f=this._time,g=this._warp,h=1/g,i=this._dt,j=i*h,k=this._maxJump*h,l=this._meta;if(this._paused||void 0===this._animTime)return this._animTime=a||this._animTime||c.util.ticker.now(),this._paused||this.emit("step",l),this;if(a=a||this._animTime+j,b=a-this._animTime,b>k&&(this._animTime=a-k,b=k),d=b*g,e=f+d-i,this.emit("beforeStep"),e>=f)for(;e>=f;)f+=i,this._animTime+=j,this._time=f,this.iterate(i);return l.fps=1e3/(a-this._lastTime),l.ipf=(d/i).toFixed(2),l.interpolateTime=i+e-f,this._lastTime=a,this.emit("step",l),this},warp:function(a){return void 0===a?this._warp:(this._warp=a||1,this)},render:function(){if(!this._renderer)throw"No renderer added to world";return this._renderer.render(this._bodies,this._meta),this.emit("render",{bodies:this._bodies,meta:this._meta,renderer:this._renderer}),this},pause:function(){return this._paused=!0,this.emit("pause"),this},unpause:function(){return this._paused=!1,this.emit("unpause"),this},isPaused:function(){return!!this._paused},destroy:function(){var a=this;a.pause(),this.emit("destroy"),a.off(!0),a.remove(a.getBodies()),a.remove(a.getBehaviors()),a.integrator(null),a.renderer(null) -}}),c.world=d}(),c.integrator("verlet",function(a){return c.body.mixin({started:function(a){return void 0!==a&&(this._started=!0),!!this._started}}),{init:function(b){a.init.call(this,b)},integrateVelocities:function(a,b){for(var c,d=b*b,e=1-this.options.drag,f=null,g=this.prevDt||b,h=.5*(d+b*g),i=0,j=a.length;j>i;++i)f=a[i],c=f.state,"static"===f.treatment||f.sleep(b)?(c.vel.zero(),c.acc.zero(),c.angular.vel=0,c.angular.acc=0):(c.vel.equals(c.old.vel)&&f.started()?c.vel.clone(c.pos).vsub(c.old.pos):(c.old.pos.clone(c.pos).vsub(c.vel),c.vel.mult(b)),e&&c.vel.mult(e),c.vel.vadd(c.acc.mult(h)),c.vel.mult(1/b),c.old.vel.clone(c.vel),c.acc.zero(),c.angular.vel===c.old.angular.vel&&f.started()?c.angular.vel=c.angular.pos-c.old.angular.pos:(c.old.angular.pos=c.angular.pos-c.angular.vel,c.angular.vel*=b),c.angular.vel+=c.angular.acc*h,c.angular.vel/=b,c.old.angular.vel=c.angular.vel,c.angular.acc=0,f.started(!0))},integratePositions:function(a,b){for(var c,d=null,e=this.prevDt||b,f=b/e,g=0,h=a.length;h>g;++g)d=a[g],c=d.state,"static"===d.treatment||d.sleep()||(c.vel.mult(b*f),c.old.pos.clone(c.pos),c.pos.vadd(c.vel),c.vel.mult(1/(b*f)),c.old.vel.clone(c.vel),c.angular.vel*=b*f,c.old.angular.pos=c.angular.pos,c.angular.pos+=c.angular.vel,c.angular.vel/=b*f,c.old.angular.vel=c.angular.vel);this.prevDt=b}}}),c.geometry("point",function(){}),c.body("point",function(a){return{init:function(b){a.init.call(this,b),this.moi=0}}}),c}); \ No newline at end of file +!function(a,b){"object"==typeof exports?module.exports=b.call(a):"function"==typeof define&&define.amd?define(function(){return b.call(a)}):a.Physics=b.call(a)}("undefined"!=typeof window?window:this,function(){"use strict";var a=this,b=a.document,c=function f(){return f.world.apply(f,arguments)};c.util={},function(){c.aabb=function(a,b,c,d){var e={x:0,y:0,hw:0,hh:0};return void 0===a?e:(a&&void 0!==a.x&&(c=b.x,d=b.y,b=a.y,a=a.x),void 0===d&&void 0!==a&&void 0!==b?(e.hw=.5*a,e.hh=.5*b,c&&void 0!==c.x&&(e.x=c.x,e.y=c.y),e):(e.hw=.5*Math.abs(c-a),e.hh=.5*Math.abs(d-b),e.x=.5*(c+a),e.y=.5*(d+b),e))},c.aabb.contains=function(a,b){return b.x>a.x-a.hw&&b.xa.y-a.hh&&b.y0?c.clone(a).negate():(c.clone(b).vsub(a),c.perp(a.cross(c)>0))},e=function(a){var b,d,e=a.length,f=a[e-2],g=a[e-3],h=c.scratchpad(),i=h.vector().clone(f.pt),j=h.vector().clone(g.pt).vsub(i);return j.equals(c.vector.zero)?h.done({a:f.a,b:f.b}):(b=-j.dot(i)/j.normSq(),d=1-b,d<=0?h.done({a:g.a,b:g.b}):b<=0?h.done({a:f.a,b:f.b}):h.done({a:i.clone(f.a).mult(d).vadd(j.clone(g.a).mult(b)).values(),b:i.clone(f.b).mult(d).vadd(j.clone(g.b).mult(b)).values()}))},f=function(f,g,h,i){var j,k,l,m,n=!1,o=!1,p=!1,q=[],r=1,s=c.scratchpad(),t=s.vector().clone(g||c.vector.axis[0]),u=s.vector(),v=s.vector(),w=s.vector(),x=s.vector(),y=0;for(m=f(t),r=q.push(m),u.clone(m.pt),t.negate();++y;){if(u.swap(v),m=f(t),r=q.push(m),u.clone(m.pt),i&&i(q),u.equals(c.vector.zero)){n=!0;break}if(!o&&u.dot(t)<=0){if(h)break;o=!0}if(2===r)t=d(u,v,t);else if(o){if(t.normalize(),m=v.dot(t),Math.abs(m-u.dot(t))0,l^u.cross(j)>0)q.shift(),j.perp(!l),t.swap(j);else{if(!(l^k.cross(u)>0)){n=!0;break}q.splice(1,1),k.perp(l),t.swap(j)}if(y>b)return s.done(),{simplex:q,iterations:y,distance:0,maxIterationsReached:!0}}return s.done(),m={overlap:n,simplex:q,iterations:y},p!==!1&&(m.distance=p,m.closest=e(q)),m};c.gjk=f}(),function(){c.statistics={pushRunningAvg:function(a,b,c,d){var e=a-c;return c+=e/b,d+=e*(a-c),[c,d]},pushRunningVectorAvg:function(a,b,c,d){var e=1/b,f=a.get(0)-c.get(0),g=a.get(1)-c.get(1);c.add(f*e,g*e),d&&(f*=a.get(0)-c.get(0),g*=a.get(1)-c.get(1),d.add(f,g))}}}(),function(){var a=function b(a,d,e){return this instanceof b?(this.v=new c.vector,this.o=new c.vector,a instanceof b?void this.clone(a):(a&&this.setTranslation(a),void this.setRotation(d||0,e))):new b(a,d)};a.prototype.setTranslation=function(a){return this.v.clone(a),this},a.prototype.setRotation=function(a,b){return this.cosA=Math.cos(a),this.sinA=Math.sin(a),b?this.o.clone(b):this.o.zero(),this},a.prototype.clone=function(b){return b?(this.setTranslation(b.v),this.cosA=b.cosA,this.sinA=b.sinA,this.o.clone(b.o),this):new a(this)},c.transform=a}(),function(a){var b=Math.sqrt,d=Math.min,e=Math.max,f=(Math.acos,Math.atan2),g=2*Math.PI,h=!!a.Float64Array,i=function j(a,b){return this instanceof j?(h?this._=new Float64Array(5):this._=[],void(a&&(void 0!==a.x||a._&&a._.length)?this.clone(a):(this.recalc=!0,this.set(a,b)))):new j(a,b)};Object.defineProperties(i.prototype,{x:{get:function(){return+this._[0]},set:function(a){a=+a||0,this.recalc=a===this._[0],this._[0]=a}},y:{get:function(){return+this._[1]},set:function(a){a=+a||0,this.recalc=a===this._[1],this._[1]=a}}}),i.prototype.set=function(a,b){return this.recalc=!0,this._[0]=+a||0,this._[1]=+b||0,this},i.prototype.get=function(a){return this._[a]},i.prototype.vadd=function(a){return this.recalc=!0,this._[0]+=a._[0],this._[1]+=a._[1],this},i.prototype.vsub=function(a){return this.recalc=!0,this._[0]-=a._[0],this._[1]-=a._[1],this},i.prototype.add=function(a,b){return this.recalc=!0,this._[0]+=+a||0,this._[1]+=+b||0,this},i.prototype.sub=function(a,b){return this.recalc=!0,this._[0]-=a,this._[1]-=void 0===b?0:b,this},i.prototype.mult=function(a){return this.recalc||(this._[4]*=a*a,this._[3]*=a),this._[0]*=a,this._[1]*=a,this},i.prototype.dot=function(a){return this._[0]*a._[0]+this._[1]*a._[1]},i.prototype.cross=function(a){return-this._[0]*a._[1]+this._[1]*a._[0]},i.prototype.proj=function(a){return this.dot(a)/a.norm()},i.prototype.vproj=function(a){var b=this.dot(a)/a.normSq();return this.clone(a).mult(b)},i.prototype.angle=function(a){var b;if(this.equals(i.zero))return a?a.angle():NaN;for(b=a&&!a.equals(i.zero)?f(this._[1]*a._[0]-this._[0]*a._[1],this._[0]*a._[0]+this._[1]*a._[1]):f(this._[1],this._[0]);b>Math.PI;)b-=g;for(;b<-Math.PI;)b+=g;return b},i.prototype.angle2=function(a,b){for(var c=a._[0]-this._[0],d=a._[1]-this._[1],e=b._[0]-this._[0],h=b._[1]-this._[1],i=f(d*e-c*h,c*e+d*h);i>Math.PI;)i-=g;for(;i<-Math.PI;)i+=g;return i},i.prototype.norm=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[3]},i.prototype.normSq=function(){return this.recalc&&(this.recalc=!1,this._[4]=this._[0]*this._[0]+this._[1]*this._[1],this._[3]=b(this._[4])),this._[4]},i.prototype.dist=function(a){var c,d;return b((c=a._[0]-this._[0])*c+(d=a._[1]-this._[1])*d)},i.prototype.distSq=function(a){var b,c;return(b=a._[0]-this._[0])*b+(c=a._[1]-this._[1])*c},i.prototype.perp=function(a){var b=this._[0];return a?(this._[0]=this._[1],this._[1]=-b):(this._[0]=-this._[1],this._[1]=b),this},i.prototype.normalize=function(){var a=this.norm();return 0===a?this:(a=1/a,this._[0]*=a,this._[1]*=a,this._[3]=1,this._[4]=1,this)},i.prototype.transform=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d,this._[1]-=e,this.set(this._[0]*c-this._[1]*b+d+a.v._[0],this._[0]*b+this._[1]*c+e+a.v._[1])},i.prototype.transformInv=function(a){var b=a.sinA,c=a.cosA,d=a.o._[0],e=a.o._[1];return this._[0]-=d+a.v._[0],this._[1]-=e+a.v._[1],this.set(this._[0]*c+this._[1]*b+d,-this._[0]*b+this._[1]*c+e)},i.prototype.rotate=function(a,b){var c,d,e=0,f=0;return"number"==typeof a?(c=Math.sin(a),d=Math.cos(a),b&&(e=b.x,f=b.y)):(c=a.sinA,d=a.cosA,e=a.o._[0],f=a.o._[1]),this._[0]-=e,this._[1]-=f,this.set(this._[0]*d-this._[1]*c+e,this._[0]*c+this._[1]*d+f)},i.prototype.rotateInv=function(a){return this.set((this._[0]-a.o._[0])*a.cosA+(this._[1]-a.o._[1])*a.sinA+a.o._[0],-(this._[0]-a.o._[0])*a.sinA+(this._[1]-a.o._[1])*a.cosA+a.o._[1])},i.prototype.translate=function(a){return this.vadd(a.v)},i.prototype.translateInv=function(a){return this.vsub(a.v)},i.prototype.clone=function(a){return a?a._?(this.recalc=a.recalc,a.recalc||(this._[3]=a._[3],this._[4]=a._[4]),this._[0]=a._[0],this._[1]=a._[1],this):this.set(a.x,a.y):new i(this)},i.prototype.swap=function(a){var b=this._;return this._=a._,a._=b,b=this.recalc,this.recalc=a.recalc,a.recalc=b,this},i.prototype.values=function(){return{x:this._[0],y:this._[1]}},i.prototype.zero=function(){return this._[3]=0,this._[4]=0,this._[0]=0,this._[1]=0,this},i.prototype.negate=function(a){return void 0!==a?(this._[a]=-this._[a],this):(this._[0]=-this._[0],this._[1]=-this._[1],this)},i.prototype.clamp=function(a,b){return this._[0]=d(e(this._[0],a.x),b.x),this._[1]=d(e(this._[1],a.y),b.y),this.recalc=!0,this},i.prototype.toString=function(){return"("+this._[0]+", "+this._[1]+")"},i.prototype.equals=function(a){return this._[0]===a._[0]&&this._[1]===a._[1]&&this._[2]===a._[2]},i.axis=[new i(1,0),new i(0,1)],i.zero=new i(0,0),c.vector=i}(this),function(a){var b=a.Physics;c.noConflict=function(){return a.Physics===c&&(a.Physics=b),c}}(this);var d=c.util.decorator=function(a,b){var d={},e={},f=function(a,b){var d,e;for(e in b)d=Object.getOwnPropertyDescriptor(b,e),d.get||d.set?Object.defineProperty(a,e,d):c.util.isFunction(d.value)&&(a[e]=d.value);return a},g=Object.getPrototypeOf;"function"!=typeof g&&(g="object"==typeof"test".__proto__?function(a){return a.__proto__}:function(a){return a.constructor.prototype});var h=Object.create;"function"!=typeof h&&(h=function(a){function b(){}return b.prototype=a,new b});var i=function(b,d){return"object"==typeof b?(e=f(e,b),void(e.type=a)):void("type"!==b&&c.util.isFunction(d)&&(e[b]=d))};i(b);var j=function(b,c,i,j){var k,l=e;if("string"!=typeof c)j=i,i=c;else{if(l=d[c],!l)throw'Error: "'+c+'" '+a+" not defined";l=l.prototype}if("function"==typeof i)k=d[b],k?k.prototype=f(k.prototype,i(g(k.prototype))):(k=d[b]=function(a){this.init&&this.init(a)},k.prototype=h(l),k.prototype=f(k.prototype,i(l,k.prototype))),k.prototype.type=a,k.prototype.name=b;else if(j=i||{},k=d[b],!k)throw'Error: "'+b+'" '+a+" not defined";if(j)return new k(j)};return j.mixin=i,j};c.util.indexOf=function(a,b){for(var c=0,d=a.length;c(0|b)?a<<16|65535&b:b<<16|65535&a)},Function.prototype.bind?c.util.bind=function(a,b,c){return c=Array.prototype.slice.call(arguments,1),Function.prototype.bind.apply(a,c)}:c.util.bind=function(a,b,c){return c=Array.prototype.slice.call(arguments,2),function(){return a.apply(b,c.concat(Array.prototype.slice.call(arguments)))}},c.util.find=function(a,b){var c,d,e=a.length;for(c=0;c-1?0:-1:a?0:-1}function g(a){var b=this.cache,c=typeof a;if("boolean"===c||null==a)b[a]=!0;else{"number"!==c&&"string"!==c&&(c="object");var d="number"===c?a:y+a,e=b[c]||(b[c]={});"object"===c?(e[d]||(e[d]=[])).push(a):e[d]=!0}}function h(a){var b=-1,c=a.length,e=a[0],f=a[c/2|0],h=a[c-1];if(e&&"object"==typeof e&&f&&"object"==typeof f&&h&&"object"==typeof h)return!1;var i=d();i["false"]=i["null"]=i["true"]=i.undefined=!1;var j=d();for(j.array=a,j.cache=i,j.push=g;++b=u&&k===c.util.indexOf,o=i||n?e():m;if(n){var p=h(o);k=f,o=p}for(;++j2&&"function"==typeof h[j-1]&&(g=h[--j]);++i>>1;c(a[f])=b.maxScratches)throw f},a.prototype={done:function(a){this._active=!1;for(var b=0;b=b.maxIndex)throw e;return a[c]||(a[c]=m?f():new f)}},b.register("vector",c.vector),b.register("transform",c.transform),b}(),function(){function a(a){return a._priority_}var b=1;c.scratchpad.register("event",function(){return{}},{useFactory:!0});var d=function e(){if(!(this instanceof e))return new e};d.prototype={on:function(d,e,f,g){var h,i,j;if(this._topics=this._topics||(this._topics={}),c.util.isObject(d)){for(var k in d)this.on(k,d[k],e,f);return this}return h=this._topics[d]||(this._topics[d]=[]),i=e,c.util.isObject(f)?(e=c.util.bind(e,f),e._bindfn_=i,e._one_=i._one_,e._scope_=f):void 0===g&&(g=f),e._priority_=void 0===g?b:g,j=c.util.sortedIndex(h,e,a),h.splice(j,0,e),this},off:function(a,b,d){var e,f;if(!this._topics)return this;if(a===!0)return this._topics={},this;if(c.util.isObject(a)){for(var g in a)this.off(g,a[g]);return this}if(e=this._topics[a],!e)return this;if(b===!0)return this._topics[a]=[],this;for(var h=0,i=e.length;h-1}return e===a}},g=function(a,b){var c=f(a,b);return function(a){return!c(a)}},h=function(a,b){return function(e){e=b?e[b]:e;var f,g=0;if(c.util.isArray(e)){for(f=e.length;g-1||d(a,e[f])>-1)return!0;g++}return!1}return d(a,e)>-1}},i=function(a,b){var c=h(a,b);return function(a){return!c(a)}},j=function(a){return a=new c.vector(a),function(b){var d=b.aabb();return c.aabb.contains(d,a)}},k=function(a){return a.next?function(b){for(var c=a;c;){if(!c(b))return!1;c=c.next}return!0}:a},l=function(a){return a.next?function(b){for(var c=a;c;){if(c(b))return!0;c=c.next}return!1}:a},m={$eq:f,$ne:g,$in:h,$nin:i,$at:j},n=function o(a,d){var g,h,i,j,n,p;if(d){if("$or"===d||"$and"===d){for(g=0,h=a.length;g=c&&this.sleep(!1))}},setWorld:function(a){return this.disconnect&&this._world&&this.disconnect(this._world),this._world=a,this.connect&&a&&this.connect(a),this},accelerate:function(a){return"dynamic"===this.treatment&&this.state.acc.vadd(a),this},applyForce:function(a,b){if("dynamic"!==this.treatment)return this;var d,e=c.scratchpad(),f=e.vector();return b&&this.moi&&(d=this.state,f.clone(b),this.state.angular.acc-=f.cross(a)/this.moi),this.accelerate(f.clone(a).mult(1/this.mass)),e.done(),this},getGlobalOffset:function(a){return a=a||new c.vector,a.clone(this.offset).rotate(this.state.angular.pos),a},aabb:function(){var a=this.state.angular.pos,b=c.scratchpad(),d=b.vector(),e=this.geometry.aabb(a);return this.getGlobalOffset(d),e.x+=this.state.pos._[0]+d._[0],e.y+=this.state.pos._[1]+d._[1],b.done(e)},toBodyCoords:function(a){return a.vsub(this.state.pos).rotate(-this.state.angular.pos)},toWorldCoords:function(a){return a.rotate(this.state.angular.pos).vadd(this.state.pos)},recalc:function(){return this}}),c.body.getCOM=function(a,b){var d,e,f,g=a&&a.length,h=0;if(b=b||new c.vector,!g)return b.zero();if(1===g)return b.clone(a[0].state.pos);for(b.zero(),f=0;f0^d.cross(e)>0){g=!1;break}e.swap(d)}return b.done(),g},c.geometry.getPolygonMOI=function(a){var b,d=c.scratchpad(),e=d.vector(),f=d.vector(),g=0,h=0,i=a.length;if(i<2)return d.done(),0;if(2===i)return b=f.clone(a[1]).distSq(e.clone(a[0])),d.done(),b/12;e.clone(a[0]);for(var j=1;j1e-6},c.geometry.getPolygonArea=function(a){var b=c.scratchpad(),d=b.vector(),e=b.vector(),f=0,g=a.length;if(g<3)return b.done(),0;d.clone(a[g-1]);for(var h=0;h-1},integrator:function(a){return void 0===a?this._integrator:this._integrator===a?this:(this._integrator&&(this._integrator.setWorld(null),this.emit("remove:integrator",{integrator:this._integrator})),a&&(this._integrator=a,this._integrator.setWorld(this),this.emit("add:integrator",{integrator:this._integrator})),this)},renderer:function(a){return void 0===a?this._renderer:this._renderer===a?this:(this._renderer&&(this._renderer.setWorld(null),this.emit("remove:renderer",{renderer:this._renderer})),a&&(this._renderer=a,this._renderer.setWorld(this),this.emit("add:renderer",{renderer:this._renderer})),this)},timestep:function(a){return a?(this._dt=+a.toPrecision(4),this._maxJump=a*this.options.maxIPF,this):this._dt},wakeUpAll:function(){var a=0,b=this._bodies.length;for(a=0;ak&&(this._animTime=a-k,b=k),d=b*g,e=f+d-i,this.emit("beforeStep"),f<=e)for(;f<=e;)f+=i,this._animTime+=j,this._time=f,this.iterate(i);return l.fps=1e3/(a-this._lastTime),l.ipf=(d/i).toFixed(2),l.interpolateTime=i+e-f,this._lastTime=a,this.emit("step",l),this},warp:function(a){return void 0===a?this._warp:(this._warp=a||1,this)},render:function(){if(!this._renderer)throw"No renderer added to world";return this._renderer.render(this._bodies,this._meta),this.emit("render",{bodies:this._bodies,meta:this._meta,renderer:this._renderer}),this},pause:function(){return this._paused=!0,this.emit("pause"),this},unpause:function(){return this._paused=!1,this.emit("unpause"),this},isPaused:function(){return!!this._paused},destroy:function(){var a=this;a.pause(),this.emit("destroy"),a.off(!0),a.remove(a.getBodies()),a.remove(a.getBehaviors()),a.integrator(null),a.renderer(null)}}),c.world=d}(),c.integrator("verlet",function(a){return c.body.mixin({started:function(a){return void 0!==a&&(this._started=!0),!!this._started}}),{init:function(b){a.init.call(this,b)},integrateVelocities:function(a,b){for(var c,d=b*b,e=1-this.options.drag,f=null,g=this.prevDt||b,h=.5*(d+b*g),i=0,j=a.length;i + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/renderers/debug.js b/dist/renderers/debug.js index e0b49de6..bf888f38 100644 --- a/dist/renderers/debug.js +++ b/dist/renderers/debug.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/renderers/dom.js b/dist/renderers/dom.js index 12d36033..742d407d 100644 --- a/dist/renderers/dom.js +++ b/dist/renderers/dom.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/dist/renderers/pixi-renderer.js b/dist/renderers/pixi-renderer.js index f795a44a..efbc1df6 100644 --- a/dist/renderers/pixi-renderer.js +++ b/dist/renderers/pixi-renderer.js @@ -1,9 +1,9 @@ /** - * PhysicsJS v0.7.0 - 2014-12-08 + * PhysicsJS v0.7.0 - 2016-08-09 * A modular, extendable, and easy-to-use physics engine for javascript * http://wellcaffeinated.net/PhysicsJS * - * Copyright (c) 2014 Jasper Palfree + * Copyright (c) 2016 Jasper Palfree * Licensed MIT */ (function (root, factory) { diff --git a/examples/Performance/index.html b/examples/Performance/index.html new file mode 100644 index 00000000..2be5f868 --- /dev/null +++ b/examples/Performance/index.html @@ -0,0 +1,21 @@ + + + + + + Physicsjs + + + + + + + + + \ No newline at end of file diff --git a/examples/Performance/index.html~ b/examples/Performance/index.html~ new file mode 100644 index 00000000..aa78cf8e --- /dev/null +++ b/examples/Performance/index.html~ @@ -0,0 +1,21 @@ + + + + + + Physicsjs + + + + + + + + + \ No newline at end of file diff --git a/examples/Performance/jquery-2.0.3.min.js b/examples/Performance/jquery-2.0.3.min.js new file mode 100644 index 00000000..2be209dd --- /dev/null +++ b/examples/Performance/jquery-2.0.3.min.js @@ -0,0 +1,6 @@ +/*! jQuery v2.0.3 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license +//@ sourceMappingURL=jquery-2.0.3.min.map +*/ +(function(e,undefined){var t,n,r=typeof undefined,i=e.location,o=e.document,s=o.documentElement,a=e.jQuery,u=e.$,l={},c=[],p="2.0.3",f=c.concat,h=c.push,d=c.slice,g=c.indexOf,m=l.toString,y=l.hasOwnProperty,v=p.trim,x=function(e,n){return new x.fn.init(e,n,t)},b=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,w=/\S+/g,T=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,C=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,k=/^-ms-/,N=/-([\da-z])/gi,E=function(e,t){return t.toUpperCase()},S=function(){o.removeEventListener("DOMContentLoaded",S,!1),e.removeEventListener("load",S,!1),x.ready()};x.fn=x.prototype={jquery:p,constructor:x,init:function(e,t,n){var r,i;if(!e)return this;if("string"==typeof e){if(r="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:T.exec(e),!r||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof x?t[0]:t,x.merge(this,x.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:o,!0)),C.test(r[1])&&x.isPlainObject(t))for(r in t)x.isFunction(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return i=o.getElementById(r[2]),i&&i.parentNode&&(this.length=1,this[0]=i),this.context=o,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):x.isFunction(e)?n.ready(e):(e.selector!==undefined&&(this.selector=e.selector,this.context=e.context),x.makeArray(e,this))},selector:"",length:0,toArray:function(){return d.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=x.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return x.each(this,e,t)},ready:function(e){return x.ready.promise().done(e),this},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(x.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:h,sort:[].sort,splice:[].splice},x.fn.init.prototype=x.fn,x.extend=x.fn.extend=function(){var e,t,n,r,i,o,s=arguments[0]||{},a=1,u=arguments.length,l=!1;for("boolean"==typeof s&&(l=s,s=arguments[1]||{},a=2),"object"==typeof s||x.isFunction(s)||(s={}),u===a&&(s=this,--a);u>a;a++)if(null!=(e=arguments[a]))for(t in e)n=s[t],r=e[t],s!==r&&(l&&r&&(x.isPlainObject(r)||(i=x.isArray(r)))?(i?(i=!1,o=n&&x.isArray(n)?n:[]):o=n&&x.isPlainObject(n)?n:{},s[t]=x.extend(l,o,r)):r!==undefined&&(s[t]=r));return s},x.extend({expando:"jQuery"+(p+Math.random()).replace(/\D/g,""),noConflict:function(t){return e.$===x&&(e.$=u),t&&e.jQuery===x&&(e.jQuery=a),x},isReady:!1,readyWait:1,holdReady:function(e){e?x.readyWait++:x.ready(!0)},ready:function(e){(e===!0?--x.readyWait:x.isReady)||(x.isReady=!0,e!==!0&&--x.readyWait>0||(n.resolveWith(o,[x]),x.fn.trigger&&x(o).trigger("ready").off("ready")))},isFunction:function(e){return"function"===x.type(e)},isArray:Array.isArray,isWindow:function(e){return null!=e&&e===e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[m.call(e)]||"object":typeof e},isPlainObject:function(e){if("object"!==x.type(e)||e.nodeType||x.isWindow(e))return!1;try{if(e.constructor&&!y.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(t){return!1}return!0},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||o;var r=C.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=x.buildFragment([e],t,i),i&&x(i).remove(),x.merge([],r.childNodes))},parseJSON:JSON.parse,parseXML:function(e){var t,n;if(!e||"string"!=typeof e)return null;try{n=new DOMParser,t=n.parseFromString(e,"text/xml")}catch(r){t=undefined}return(!t||t.getElementsByTagName("parsererror").length)&&x.error("Invalid XML: "+e),t},noop:function(){},globalEval:function(e){var t,n=eval;e=x.trim(e),e&&(1===e.indexOf("use strict")?(t=o.createElement("script"),t.text=e,o.head.appendChild(t).parentNode.removeChild(t)):n(e))},camelCase:function(e){return e.replace(k,"ms-").replace(N,E)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,s=j(e);if(n){if(s){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(s){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:function(e){return null==e?"":v.call(e)},makeArray:function(e,t){var n=t||[];return null!=e&&(j(Object(e))?x.merge(n,"string"==typeof e?[e]:e):h.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:g.call(t,e,n)},merge:function(e,t){var n=t.length,r=e.length,i=0;if("number"==typeof n)for(;n>i;i++)e[r++]=t[i];else while(t[i]!==undefined)e[r++]=t[i++];return e.length=r,e},grep:function(e,t,n){var r,i=[],o=0,s=e.length;for(n=!!n;s>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,s=j(e),a=[];if(s)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(a[a.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(a[a.length]=r);return f.apply([],a)},guid:1,proxy:function(e,t){var n,r,i;return"string"==typeof t&&(n=e[t],t=e,e=n),x.isFunction(e)?(r=d.call(arguments,2),i=function(){return e.apply(t||this,r.concat(d.call(arguments)))},i.guid=e.guid=e.guid||x.guid++,i):undefined},access:function(e,t,n,r,i,o,s){var a=0,u=e.length,l=null==n;if("object"===x.type(n)){i=!0;for(a in n)x.access(e,t,a,n[a],!0,o,s)}else if(r!==undefined&&(i=!0,x.isFunction(r)||(s=!0),l&&(s?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(x(e),n)})),t))for(;u>a;a++)t(e[a],n,s?r:r.call(e[a],a,t(e[a],n)));return i?e:l?t.call(e):u?t(e[0],n):o},now:Date.now,swap:function(e,t,n,r){var i,o,s={};for(o in t)s[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=s[o];return i}}),x.ready.promise=function(t){return n||(n=x.Deferred(),"complete"===o.readyState?setTimeout(x.ready):(o.addEventListener("DOMContentLoaded",S,!1),e.addEventListener("load",S,!1))),n.promise(t)},x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){l["[object "+t+"]"]=t.toLowerCase()});function j(e){var t=e.length,n=x.type(e);return x.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}t=x(o),function(e,undefined){var t,n,r,i,o,s,a,u,l,c,p,f,h,d,g,m,y,v="sizzle"+-new Date,b=e.document,w=0,T=0,C=st(),k=st(),N=st(),E=!1,S=function(e,t){return e===t?(E=!0,0):0},j=typeof undefined,D=1<<31,A={}.hasOwnProperty,L=[],q=L.pop,H=L.push,O=L.push,F=L.slice,P=L.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",W="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",$=W.replace("w","w#"),B="\\["+M+"*("+W+")"+M+"*(?:([*^$|!~]?=)"+M+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+$+")|)|)"+M+"*\\]",I=":("+W+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+B.replace(3,8)+")*)|.*)\\)|)",z=RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=RegExp("^"+M+"*,"+M+"*"),X=RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=RegExp(M+"*[+~]"),Y=RegExp("="+M+"*([^\\]'\"]*)"+M+"*\\]","g"),V=RegExp(I),G=RegExp("^"+$+"$"),J={ID:RegExp("^#("+W+")"),CLASS:RegExp("^\\.("+W+")"),TAG:RegExp("^("+W.replace("w","w*")+")"),ATTR:RegExp("^"+B),PSEUDO:RegExp("^"+I),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:RegExp("^(?:"+R+")$","i"),needsContext:RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Q=/^[^{]+\{\s*\[native \w/,K=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,Z=/^(?:input|select|textarea|button)$/i,et=/^h\d$/i,tt=/'|\\/g,nt=RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),rt=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:0>r?String.fromCharCode(r+65536):String.fromCharCode(55296|r>>10,56320|1023&r)};try{O.apply(L=F.call(b.childNodes),b.childNodes),L[b.childNodes.length].nodeType}catch(it){O={apply:L.length?function(e,t){H.apply(e,F.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function ot(e,t,r,i){var o,s,a,u,l,f,g,m,x,w;if((t?t.ownerDocument||t:b)!==p&&c(t),t=t||p,r=r||[],!e||"string"!=typeof e)return r;if(1!==(u=t.nodeType)&&9!==u)return[];if(h&&!i){if(o=K.exec(e))if(a=o[1]){if(9===u){if(s=t.getElementById(a),!s||!s.parentNode)return r;if(s.id===a)return r.push(s),r}else if(t.ownerDocument&&(s=t.ownerDocument.getElementById(a))&&y(t,s)&&s.id===a)return r.push(s),r}else{if(o[2])return O.apply(r,t.getElementsByTagName(e)),r;if((a=o[3])&&n.getElementsByClassName&&t.getElementsByClassName)return O.apply(r,t.getElementsByClassName(a)),r}if(n.qsa&&(!d||!d.test(e))){if(m=g=v,x=t,w=9===u&&e,1===u&&"object"!==t.nodeName.toLowerCase()){f=gt(e),(g=t.getAttribute("id"))?m=g.replace(tt,"\\$&"):t.setAttribute("id",m),m="[id='"+m+"'] ",l=f.length;while(l--)f[l]=m+mt(f[l]);x=U.test(e)&&t.parentNode||t,w=f.join(",")}if(w)try{return O.apply(r,x.querySelectorAll(w)),r}catch(T){}finally{g||t.removeAttribute("id")}}}return kt(e.replace(z,"$1"),t,r,i)}function st(){var e=[];function t(n,r){return e.push(n+=" ")>i.cacheLength&&delete t[e.shift()],t[n]=r}return t}function at(e){return e[v]=!0,e}function ut(e){var t=p.createElement("div");try{return!!e(t)}catch(n){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function lt(e,t){var n=e.split("|"),r=e.length;while(r--)i.attrHandle[n[r]]=t}function ct(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&(~t.sourceIndex||D)-(~e.sourceIndex||D);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function pt(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function ft(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function ht(e){return at(function(t){return t=+t,at(function(n,r){var i,o=e([],n.length,t),s=o.length;while(s--)n[i=o[s]]&&(n[i]=!(r[i]=n[i]))})})}s=ot.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},n=ot.support={},c=ot.setDocument=function(e){var t=e?e.ownerDocument||e:b,r=t.defaultView;return t!==p&&9===t.nodeType&&t.documentElement?(p=t,f=t.documentElement,h=!s(t),r&&r.attachEvent&&r!==r.top&&r.attachEvent("onbeforeunload",function(){c()}),n.attributes=ut(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ut(function(e){return e.appendChild(t.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=ut(function(e){return e.innerHTML="
",e.firstChild.className="i",2===e.getElementsByClassName("i").length}),n.getById=ut(function(e){return f.appendChild(e).id=v,!t.getElementsByName||!t.getElementsByName(v).length}),n.getById?(i.find.ID=function(e,t){if(typeof t.getElementById!==j&&h){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){return e.getAttribute("id")===t}}):(delete i.find.ID,i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){var n=typeof e.getAttributeNode!==j&&e.getAttributeNode("id");return n&&n.value===t}}),i.find.TAG=n.getElementsByTagName?function(e,t){return typeof t.getElementsByTagName!==j?t.getElementsByTagName(e):undefined}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},i.find.CLASS=n.getElementsByClassName&&function(e,t){return typeof t.getElementsByClassName!==j&&h?t.getElementsByClassName(e):undefined},g=[],d=[],(n.qsa=Q.test(t.querySelectorAll))&&(ut(function(e){e.innerHTML="",e.querySelectorAll("[selected]").length||d.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll(":checked").length||d.push(":checked")}),ut(function(e){var n=t.createElement("input");n.setAttribute("type","hidden"),e.appendChild(n).setAttribute("t",""),e.querySelectorAll("[t^='']").length&&d.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll(":enabled").length||d.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),d.push(",.*:")})),(n.matchesSelector=Q.test(m=f.webkitMatchesSelector||f.mozMatchesSelector||f.oMatchesSelector||f.msMatchesSelector))&&ut(function(e){n.disconnectedMatch=m.call(e,"div"),m.call(e,"[s!='']:x"),g.push("!=",I)}),d=d.length&&RegExp(d.join("|")),g=g.length&&RegExp(g.join("|")),y=Q.test(f.contains)||f.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},S=f.compareDocumentPosition?function(e,r){if(e===r)return E=!0,0;var i=r.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(r);return i?1&i||!n.sortDetached&&r.compareDocumentPosition(e)===i?e===t||y(b,e)?-1:r===t||y(b,r)?1:l?P.call(l,e)-P.call(l,r):0:4&i?-1:1:e.compareDocumentPosition?-1:1}:function(e,n){var r,i=0,o=e.parentNode,s=n.parentNode,a=[e],u=[n];if(e===n)return E=!0,0;if(!o||!s)return e===t?-1:n===t?1:o?-1:s?1:l?P.call(l,e)-P.call(l,n):0;if(o===s)return ct(e,n);r=e;while(r=r.parentNode)a.unshift(r);r=n;while(r=r.parentNode)u.unshift(r);while(a[i]===u[i])i++;return i?ct(a[i],u[i]):a[i]===b?-1:u[i]===b?1:0},t):p},ot.matches=function(e,t){return ot(e,null,null,t)},ot.matchesSelector=function(e,t){if((e.ownerDocument||e)!==p&&c(e),t=t.replace(Y,"='$1']"),!(!n.matchesSelector||!h||g&&g.test(t)||d&&d.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(i){}return ot(t,p,null,[e]).length>0},ot.contains=function(e,t){return(e.ownerDocument||e)!==p&&c(e),y(e,t)},ot.attr=function(e,t){(e.ownerDocument||e)!==p&&c(e);var r=i.attrHandle[t.toLowerCase()],o=r&&A.call(i.attrHandle,t.toLowerCase())?r(e,t,!h):undefined;return o===undefined?n.attributes||!h?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null:o},ot.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},ot.uniqueSort=function(e){var t,r=[],i=0,o=0;if(E=!n.detectDuplicates,l=!n.sortStable&&e.slice(0),e.sort(S),E){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return e},o=ot.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else for(;t=e[r];r++)n+=o(t);return n},i=ot.selectors={cacheLength:50,createPseudo:at,match:J,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(nt,rt),e[3]=(e[4]||e[5]||"").replace(nt,rt),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ot.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ot.error(e[0]),e},PSEUDO:function(e){var t,n=!e[5]&&e[2];return J.CHILD.test(e[0])?null:(e[3]&&e[4]!==undefined?e[2]=e[4]:n&&V.test(n)&&(t=gt(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(nt,rt).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=C[e+" "];return t||(t=RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&C(e,function(e){return t.test("string"==typeof e.className&&e.className||typeof e.getAttribute!==j&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=ot.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),s="last"!==e.slice(-4),a="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,p,f,h,d,g=o!==s?"nextSibling":"previousSibling",m=t.parentNode,y=a&&t.nodeName.toLowerCase(),x=!u&&!a;if(m){if(o){while(g){p=t;while(p=p[g])if(a?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;d=g="only"===e&&!d&&"nextSibling"}return!0}if(d=[s?m.firstChild:m.lastChild],s&&x){c=m[v]||(m[v]={}),l=c[e]||[],h=l[0]===w&&l[1],f=l[0]===w&&l[2],p=h&&m.childNodes[h];while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if(1===p.nodeType&&++f&&p===t){c[e]=[w,h,f];break}}else if(x&&(l=(t[v]||(t[v]={}))[e])&&l[0]===w)f=l[1];else while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if((a?p.nodeName.toLowerCase()===y:1===p.nodeType)&&++f&&(x&&((p[v]||(p[v]={}))[e]=[w,f]),p===t))break;return f-=i,f===r||0===f%r&&f/r>=0}}},PSEUDO:function(e,t){var n,r=i.pseudos[e]||i.setFilters[e.toLowerCase()]||ot.error("unsupported pseudo: "+e);return r[v]?r(t):r.length>1?(n=[e,e,"",t],i.setFilters.hasOwnProperty(e.toLowerCase())?at(function(e,n){var i,o=r(e,t),s=o.length;while(s--)i=P.call(e,o[s]),e[i]=!(n[i]=o[s])}):function(e){return r(e,0,n)}):r}},pseudos:{not:at(function(e){var t=[],n=[],r=a(e.replace(z,"$1"));return r[v]?at(function(e,t,n,i){var o,s=r(e,null,i,[]),a=e.length;while(a--)(o=s[a])&&(e[a]=!(t[a]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:at(function(e){return function(t){return ot(e,t).length>0}}),contains:at(function(e){return function(t){return(t.textContent||t.innerText||o(t)).indexOf(e)>-1}}),lang:at(function(e){return G.test(e||"")||ot.error("unsupported lang: "+e),e=e.replace(nt,rt).toLowerCase(),function(t){var n;do if(n=h?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===f},focus:function(e){return e===p.activeElement&&(!p.hasFocus||p.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!i.pseudos.empty(e)},header:function(e){return et.test(e.nodeName)},input:function(e){return Z.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:ht(function(){return[0]}),last:ht(function(e,t){return[t-1]}),eq:ht(function(e,t,n){return[0>n?n+t:n]}),even:ht(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:ht(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:ht(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:ht(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}},i.pseudos.nth=i.pseudos.eq;for(t in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})i.pseudos[t]=pt(t);for(t in{submit:!0,reset:!0})i.pseudos[t]=ft(t);function dt(){}dt.prototype=i.filters=i.pseudos,i.setFilters=new dt;function gt(e,t){var n,r,o,s,a,u,l,c=k[e+" "];if(c)return t?0:c.slice(0);a=e,u=[],l=i.preFilter;while(a){(!n||(r=_.exec(a)))&&(r&&(a=a.slice(r[0].length)||a),u.push(o=[])),n=!1,(r=X.exec(a))&&(n=r.shift(),o.push({value:n,type:r[0].replace(z," ")}),a=a.slice(n.length));for(s in i.filter)!(r=J[s].exec(a))||l[s]&&!(r=l[s](r))||(n=r.shift(),o.push({value:n,type:s,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?ot.error(e):k(e,u).slice(0)}function mt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function yt(e,t,n){var i=t.dir,o=n&&"parentNode"===i,s=T++;return t.first?function(t,n,r){while(t=t[i])if(1===t.nodeType||o)return e(t,n,r)}:function(t,n,a){var u,l,c,p=w+" "+s;if(a){while(t=t[i])if((1===t.nodeType||o)&&e(t,n,a))return!0}else while(t=t[i])if(1===t.nodeType||o)if(c=t[v]||(t[v]={}),(l=c[i])&&l[0]===p){if((u=l[1])===!0||u===r)return u===!0}else if(l=c[i]=[p],l[1]=e(t,n,a)||r,l[1]===!0)return!0}}function vt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function xt(e,t,n,r,i){var o,s=[],a=0,u=e.length,l=null!=t;for(;u>a;a++)(o=e[a])&&(!n||n(o,r,i))&&(s.push(o),l&&t.push(a));return s}function bt(e,t,n,r,i,o){return r&&!r[v]&&(r=bt(r)),i&&!i[v]&&(i=bt(i,o)),at(function(o,s,a,u){var l,c,p,f=[],h=[],d=s.length,g=o||Ct(t||"*",a.nodeType?[a]:a,[]),m=!e||!o&&t?g:xt(g,f,e,a,u),y=n?i||(o?e:d||r)?[]:s:m;if(n&&n(m,y,a,u),r){l=xt(y,h),r(l,[],a,u),c=l.length;while(c--)(p=l[c])&&(y[h[c]]=!(m[h[c]]=p))}if(o){if(i||e){if(i){l=[],c=y.length;while(c--)(p=y[c])&&l.push(m[c]=p);i(null,y=[],l,u)}c=y.length;while(c--)(p=y[c])&&(l=i?P.call(o,p):f[c])>-1&&(o[l]=!(s[l]=p))}}else y=xt(y===s?y.splice(d,y.length):y),i?i(null,s,y,u):O.apply(s,y)})}function wt(e){var t,n,r,o=e.length,s=i.relative[e[0].type],a=s||i.relative[" "],l=s?1:0,c=yt(function(e){return e===t},a,!0),p=yt(function(e){return P.call(t,e)>-1},a,!0),f=[function(e,n,r){return!s&&(r||n!==u)||((t=n).nodeType?c(e,n,r):p(e,n,r))}];for(;o>l;l++)if(n=i.relative[e[l].type])f=[yt(vt(f),n)];else{if(n=i.filter[e[l].type].apply(null,e[l].matches),n[v]){for(r=++l;o>r;r++)if(i.relative[e[r].type])break;return bt(l>1&&vt(f),l>1&&mt(e.slice(0,l-1).concat({value:" "===e[l-2].type?"*":""})).replace(z,"$1"),n,r>l&&wt(e.slice(l,r)),o>r&&wt(e=e.slice(r)),o>r&&mt(e))}f.push(n)}return vt(f)}function Tt(e,t){var n=0,o=t.length>0,s=e.length>0,a=function(a,l,c,f,h){var d,g,m,y=[],v=0,x="0",b=a&&[],T=null!=h,C=u,k=a||s&&i.find.TAG("*",h&&l.parentNode||l),N=w+=null==C?1:Math.random()||.1;for(T&&(u=l!==p&&l,r=n);null!=(d=k[x]);x++){if(s&&d){g=0;while(m=e[g++])if(m(d,l,c)){f.push(d);break}T&&(w=N,r=++n)}o&&((d=!m&&d)&&v--,a&&b.push(d))}if(v+=x,o&&x!==v){g=0;while(m=t[g++])m(b,y,l,c);if(a){if(v>0)while(x--)b[x]||y[x]||(y[x]=q.call(f));y=xt(y)}O.apply(f,y),T&&!a&&y.length>0&&v+t.length>1&&ot.uniqueSort(f)}return T&&(w=N,u=C),b};return o?at(a):a}a=ot.compile=function(e,t){var n,r=[],i=[],o=N[e+" "];if(!o){t||(t=gt(e)),n=t.length;while(n--)o=wt(t[n]),o[v]?r.push(o):i.push(o);o=N(e,Tt(i,r))}return o};function Ct(e,t,n){var r=0,i=t.length;for(;i>r;r++)ot(e,t[r],n);return n}function kt(e,t,r,o){var s,u,l,c,p,f=gt(e);if(!o&&1===f.length){if(u=f[0]=f[0].slice(0),u.length>2&&"ID"===(l=u[0]).type&&n.getById&&9===t.nodeType&&h&&i.relative[u[1].type]){if(t=(i.find.ID(l.matches[0].replace(nt,rt),t)||[])[0],!t)return r;e=e.slice(u.shift().value.length)}s=J.needsContext.test(e)?0:u.length;while(s--){if(l=u[s],i.relative[c=l.type])break;if((p=i.find[c])&&(o=p(l.matches[0].replace(nt,rt),U.test(u[0].type)&&t.parentNode||t))){if(u.splice(s,1),e=o.length&&mt(u),!e)return O.apply(r,o),r;break}}}return a(e,f)(o,t,!h,r,U.test(e)),r}n.sortStable=v.split("").sort(S).join("")===v,n.detectDuplicates=E,c(),n.sortDetached=ut(function(e){return 1&e.compareDocumentPosition(p.createElement("div"))}),ut(function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")})||lt("type|href|height|width",function(e,t,n){return n?undefined:e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ut(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||lt("value",function(e,t,n){return n||"input"!==e.nodeName.toLowerCase()?undefined:e.defaultValue}),ut(function(e){return null==e.getAttribute("disabled")})||lt(R,function(e,t,n){var r;return n?undefined:(r=e.getAttributeNode(t))&&r.specified?r.value:e[t]===!0?t.toLowerCase():null}),x.find=ot,x.expr=ot.selectors,x.expr[":"]=x.expr.pseudos,x.unique=ot.uniqueSort,x.text=ot.getText,x.isXMLDoc=ot.isXML,x.contains=ot.contains}(e);var D={};function A(e){var t=D[e]={};return x.each(e.match(w)||[],function(e,n){t[n]=!0}),t}x.Callbacks=function(e){e="string"==typeof e?D[e]||A(e):x.extend({},e);var t,n,r,i,o,s,a=[],u=!e.once&&[],l=function(p){for(t=e.memory&&p,n=!0,s=i||0,i=0,o=a.length,r=!0;a&&o>s;s++)if(a[s].apply(p[0],p[1])===!1&&e.stopOnFalse){t=!1;break}r=!1,a&&(u?u.length&&l(u.shift()):t?a=[]:c.disable())},c={add:function(){if(a){var n=a.length;(function s(t){x.each(t,function(t,n){var r=x.type(n);"function"===r?e.unique&&c.has(n)||a.push(n):n&&n.length&&"string"!==r&&s(n)})})(arguments),r?o=a.length:t&&(i=n,l(t))}return this},remove:function(){return a&&x.each(arguments,function(e,t){var n;while((n=x.inArray(t,a,n))>-1)a.splice(n,1),r&&(o>=n&&o--,s>=n&&s--)}),this},has:function(e){return e?x.inArray(e,a)>-1:!(!a||!a.length)},empty:function(){return a=[],o=0,this},disable:function(){return a=u=t=undefined,this},disabled:function(){return!a},lock:function(){return u=undefined,t||c.disable(),this},locked:function(){return!u},fireWith:function(e,t){return!a||n&&!u||(t=t||[],t=[e,t.slice?t.slice():t],r?u.push(t):l(t)),this},fire:function(){return c.fireWith(this,arguments),this},fired:function(){return!!n}};return c},x.extend({Deferred:function(e){var t=[["resolve","done",x.Callbacks("once memory"),"resolved"],["reject","fail",x.Callbacks("once memory"),"rejected"],["notify","progress",x.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return x.Deferred(function(n){x.each(t,function(t,o){var s=o[0],a=x.isFunction(e[t])&&e[t];i[o[1]](function(){var e=a&&a.apply(this,arguments);e&&x.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[s+"With"](this===r?n.promise():this,a?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?x.extend(e,r):r}},i={};return r.pipe=r.then,x.each(t,function(e,o){var s=o[2],a=o[3];r[o[1]]=s.add,a&&s.add(function(){n=a},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=s.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=d.call(arguments),r=n.length,i=1!==r||e&&x.isFunction(e.promise)?r:0,o=1===i?e:x.Deferred(),s=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?d.call(arguments):r,n===a?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},a,u,l;if(r>1)for(a=Array(r),u=Array(r),l=Array(r);r>t;t++)n[t]&&x.isFunction(n[t].promise)?n[t].promise().done(s(t,l,n)).fail(o.reject).progress(s(t,u,a)):--i;return i||o.resolveWith(l,n),o.promise()}}),x.support=function(t){var n=o.createElement("input"),r=o.createDocumentFragment(),i=o.createElement("div"),s=o.createElement("select"),a=s.appendChild(o.createElement("option"));return n.type?(n.type="checkbox",t.checkOn=""!==n.value,t.optSelected=a.selected,t.reliableMarginRight=!0,t.boxSizingReliable=!0,t.pixelPosition=!1,n.checked=!0,t.noCloneChecked=n.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!a.disabled,n=o.createElement("input"),n.value="t",n.type="radio",t.radioValue="t"===n.value,n.setAttribute("checked","t"),n.setAttribute("name","t"),r.appendChild(n),t.checkClone=r.cloneNode(!0).cloneNode(!0).lastChild.checked,t.focusinBubbles="onfocusin"in e,i.style.backgroundClip="content-box",i.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===i.style.backgroundClip,x(function(){var n,r,s="padding:0;margin:0;border:0;display:block;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box",a=o.getElementsByTagName("body")[0];a&&(n=o.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",a.appendChild(n).appendChild(i),i.innerHTML="",i.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%",x.swap(a,null!=a.style.zoom?{zoom:1}:{},function(){t.boxSizing=4===i.offsetWidth}),e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(i,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(i,null)||{width:"4px"}).width,r=i.appendChild(o.createElement("div")),r.style.cssText=i.style.cssText=s,r.style.marginRight=r.style.width="0",i.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),a.removeChild(n))}),t):t}({});var L,q,H=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,O=/([A-Z])/g;function F(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=x.expando+Math.random()}F.uid=1,F.accepts=function(e){return e.nodeType?1===e.nodeType||9===e.nodeType:!0},F.prototype={key:function(e){if(!F.accepts(e))return 0;var t={},n=e[this.expando];if(!n){n=F.uid++;try{t[this.expando]={value:n},Object.defineProperties(e,t)}catch(r){t[this.expando]=n,x.extend(e,t)}}return this.cache[n]||(this.cache[n]={}),n},set:function(e,t,n){var r,i=this.key(e),o=this.cache[i];if("string"==typeof t)o[t]=n;else if(x.isEmptyObject(o))x.extend(this.cache[i],t);else for(r in t)o[r]=t[r];return o},get:function(e,t){var n=this.cache[this.key(e)];return t===undefined?n:n[t]},access:function(e,t,n){var r;return t===undefined||t&&"string"==typeof t&&n===undefined?(r=this.get(e,t),r!==undefined?r:this.get(e,x.camelCase(t))):(this.set(e,t,n),n!==undefined?n:t)},remove:function(e,t){var n,r,i,o=this.key(e),s=this.cache[o];if(t===undefined)this.cache[o]={};else{x.isArray(t)?r=t.concat(t.map(x.camelCase)):(i=x.camelCase(t),t in s?r=[t,i]:(r=i,r=r in s?[r]:r.match(w)||[])),n=r.length;while(n--)delete s[r[n]]}},hasData:function(e){return!x.isEmptyObject(this.cache[e[this.expando]]||{})},discard:function(e){e[this.expando]&&delete this.cache[e[this.expando]]}},L=new F,q=new F,x.extend({acceptData:F.accepts,hasData:function(e){return L.hasData(e)||q.hasData(e)},data:function(e,t,n){return L.access(e,t,n)},removeData:function(e,t){L.remove(e,t)},_data:function(e,t,n){return q.access(e,t,n)},_removeData:function(e,t){q.remove(e,t)}}),x.fn.extend({data:function(e,t){var n,r,i=this[0],o=0,s=null;if(e===undefined){if(this.length&&(s=L.get(i),1===i.nodeType&&!q.get(i,"hasDataAttrs"))){for(n=i.attributes;n.length>o;o++)r=n[o].name,0===r.indexOf("data-")&&(r=x.camelCase(r.slice(5)),P(i,r,s[r]));q.set(i,"hasDataAttrs",!0)}return s}return"object"==typeof e?this.each(function(){L.set(this,e)}):x.access(this,function(t){var n,r=x.camelCase(e);if(i&&t===undefined){if(n=L.get(i,e),n!==undefined)return n;if(n=L.get(i,r),n!==undefined)return n;if(n=P(i,r,undefined),n!==undefined)return n}else this.each(function(){var n=L.get(this,r);L.set(this,r,t),-1!==e.indexOf("-")&&n!==undefined&&L.set(this,e,t)})},null,t,arguments.length>1,null,!0)},removeData:function(e){return this.each(function(){L.remove(this,e)})}});function P(e,t,n){var r;if(n===undefined&&1===e.nodeType)if(r="data-"+t.replace(O,"-$1").toLowerCase(),n=e.getAttribute(r),"string"==typeof n){try{n="true"===n?!0:"false"===n?!1:"null"===n?null:+n+""===n?+n:H.test(n)?JSON.parse(n):n}catch(i){}L.set(e,t,n)}else n=undefined;return n}x.extend({queue:function(e,t,n){var r;return e?(t=(t||"fx")+"queue",r=q.get(e,t),n&&(!r||x.isArray(n)?r=q.access(e,t,x.makeArray(n)):r.push(n)),r||[]):undefined},dequeue:function(e,t){t=t||"fx";var n=x.queue(e,t),r=n.length,i=n.shift(),o=x._queueHooks(e,t),s=function(){x.dequeue(e,t) +};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,s,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return q.get(e,n)||q.access(e,n,{empty:x.Callbacks("once memory").add(function(){q.remove(e,[t+"queue",n])})})}}),x.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),n>arguments.length?x.queue(this[0],e):t===undefined?this:this.each(function(){var n=x.queue(this,e,t);x._queueHooks(this,e),"fx"===e&&"inprogress"!==n[0]&&x.dequeue(this,e)})},dequeue:function(e){return this.each(function(){x.dequeue(this,e)})},delay:function(e,t){return e=x.fx?x.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=x.Deferred(),o=this,s=this.length,a=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=undefined),e=e||"fx";while(s--)n=q.get(o[s],e+"queueHooks"),n&&n.empty&&(r++,n.empty.add(a));return a(),i.promise(t)}});var R,M,W=/[\t\r\n\f]/g,$=/\r/g,B=/^(?:input|select|textarea|button)$/i;x.fn.extend({attr:function(e,t){return x.access(this,x.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){x.removeAttr(this,e)})},prop:function(e,t){return x.access(this,x.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[x.propFix[e]||e]})},addClass:function(e){var t,n,r,i,o,s=0,a=this.length,u="string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).addClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=x.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,s=0,a=this.length,u=0===arguments.length||"string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).removeClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?x.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e;return"boolean"==typeof t&&"string"===n?t?this.addClass(e):this.removeClass(e):x.isFunction(e)?this.each(function(n){x(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var t,i=0,o=x(this),s=e.match(w)||[];while(t=s[i++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else(n===r||"boolean"===n)&&(this.className&&q.set(this,"__className__",this.className),this.className=this.className||e===!1?"":q.get(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(W," ").indexOf(t)>=0)return!0;return!1},val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=x.isFunction(e),this.each(function(n){var i;1===this.nodeType&&(i=r?e.call(this,n,x(this).val()):e,null==i?i="":"number"==typeof i?i+="":x.isArray(i)&&(i=x.map(i,function(e){return null==e?"":e+""})),t=x.valHooks[this.type]||x.valHooks[this.nodeName.toLowerCase()],t&&"set"in t&&t.set(this,i,"value")!==undefined||(this.value=i))});if(i)return t=x.valHooks[i.type]||x.valHooks[i.nodeName.toLowerCase()],t&&"get"in t&&(n=t.get(i,"value"))!==undefined?n:(n=i.value,"string"==typeof n?n.replace($,""):null==n?"":n)}}}),x.extend({valHooks:{option:{get:function(e){var t=e.attributes.value;return!t||t.specified?e.value:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,s=o?null:[],a=o?i+1:r.length,u=0>i?a:o?i:0;for(;a>u;u++)if(n=r[u],!(!n.selected&&u!==i||(x.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&x.nodeName(n.parentNode,"optgroup"))){if(t=x(n).val(),o)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=x.makeArray(t),s=i.length;while(s--)r=i[s],(r.selected=x.inArray(x(r).val(),o)>=0)&&(n=!0);return n||(e.selectedIndex=-1),o}}},attr:function(e,t,n){var i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return typeof e.getAttribute===r?x.prop(e,t,n):(1===s&&x.isXMLDoc(e)||(t=t.toLowerCase(),i=x.attrHooks[t]||(x.expr.match.bool.test(t)?M:R)),n===undefined?i&&"get"in i&&null!==(o=i.get(e,t))?o:(o=x.find.attr(e,t),null==o?undefined:o):null!==n?i&&"set"in i&&(o=i.set(e,n,t))!==undefined?o:(e.setAttribute(t,n+""),n):(x.removeAttr(e,t),undefined))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(w);if(o&&1===e.nodeType)while(n=o[i++])r=x.propFix[n]||n,x.expr.match.bool.test(n)&&(e[r]=!1),e.removeAttribute(n)},attrHooks:{type:{set:function(e,t){if(!x.support.radioValue&&"radio"===t&&x.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{"for":"htmlFor","class":"className"},prop:function(e,t,n){var r,i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return o=1!==s||!x.isXMLDoc(e),o&&(t=x.propFix[t]||t,i=x.propHooks[t]),n!==undefined?i&&"set"in i&&(r=i.set(e,n,t))!==undefined?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){return e.hasAttribute("tabindex")||B.test(e.nodeName)||e.href?e.tabIndex:-1}}}}),M={set:function(e,t,n){return t===!1?x.removeAttr(e,n):e.setAttribute(n,n),n}},x.each(x.expr.match.bool.source.match(/\w+/g),function(e,t){var n=x.expr.attrHandle[t]||x.find.attr;x.expr.attrHandle[t]=function(e,t,r){var i=x.expr.attrHandle[t],o=r?undefined:(x.expr.attrHandle[t]=undefined)!=n(e,t,r)?t.toLowerCase():null;return x.expr.attrHandle[t]=i,o}}),x.support.optSelected||(x.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null}}),x.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){x.propFix[this.toLowerCase()]=this}),x.each(["radio","checkbox"],function(){x.valHooks[this]={set:function(e,t){return x.isArray(t)?e.checked=x.inArray(x(e).val(),t)>=0:undefined}},x.support.checkOn||(x.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})});var I=/^key/,z=/^(?:mouse|contextmenu)|click/,_=/^(?:focusinfocus|focusoutblur)$/,X=/^([^.]*)(?:\.(.+)|)$/;function U(){return!0}function Y(){return!1}function V(){try{return o.activeElement}catch(e){}}x.event={global:{},add:function(e,t,n,i,o){var s,a,u,l,c,p,f,h,d,g,m,y=q.get(e);if(y){n.handler&&(s=n,n=s.handler,o=s.selector),n.guid||(n.guid=x.guid++),(l=y.events)||(l=y.events={}),(a=y.handle)||(a=y.handle=function(e){return typeof x===r||e&&x.event.triggered===e.type?undefined:x.event.dispatch.apply(a.elem,arguments)},a.elem=e),t=(t||"").match(w)||[""],c=t.length;while(c--)u=X.exec(t[c])||[],d=m=u[1],g=(u[2]||"").split(".").sort(),d&&(f=x.event.special[d]||{},d=(o?f.delegateType:f.bindType)||d,f=x.event.special[d]||{},p=x.extend({type:d,origType:m,data:i,handler:n,guid:n.guid,selector:o,needsContext:o&&x.expr.match.needsContext.test(o),namespace:g.join(".")},s),(h=l[d])||(h=l[d]=[],h.delegateCount=0,f.setup&&f.setup.call(e,i,g,a)!==!1||e.addEventListener&&e.addEventListener(d,a,!1)),f.add&&(f.add.call(e,p),p.handler.guid||(p.handler.guid=n.guid)),o?h.splice(h.delegateCount++,0,p):h.push(p),x.event.global[d]=!0);e=null}},remove:function(e,t,n,r,i){var o,s,a,u,l,c,p,f,h,d,g,m=q.hasData(e)&&q.get(e);if(m&&(u=m.events)){t=(t||"").match(w)||[""],l=t.length;while(l--)if(a=X.exec(t[l])||[],h=g=a[1],d=(a[2]||"").split(".").sort(),h){p=x.event.special[h]||{},h=(r?p.delegateType:p.bindType)||h,f=u[h]||[],a=a[2]&&RegExp("(^|\\.)"+d.join("\\.(?:.*\\.|)")+"(\\.|$)"),s=o=f.length;while(o--)c=f[o],!i&&g!==c.origType||n&&n.guid!==c.guid||a&&!a.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(f.splice(o,1),c.selector&&f.delegateCount--,p.remove&&p.remove.call(e,c));s&&!f.length&&(p.teardown&&p.teardown.call(e,d,m.handle)!==!1||x.removeEvent(e,h,m.handle),delete u[h])}else for(h in u)x.event.remove(e,h+t[l],n,r,!0);x.isEmptyObject(u)&&(delete m.handle,q.remove(e,"events"))}},trigger:function(t,n,r,i){var s,a,u,l,c,p,f,h=[r||o],d=y.call(t,"type")?t.type:t,g=y.call(t,"namespace")?t.namespace.split("."):[];if(a=u=r=r||o,3!==r.nodeType&&8!==r.nodeType&&!_.test(d+x.event.triggered)&&(d.indexOf(".")>=0&&(g=d.split("."),d=g.shift(),g.sort()),c=0>d.indexOf(":")&&"on"+d,t=t[x.expando]?t:new x.Event(d,"object"==typeof t&&t),t.isTrigger=i?2:3,t.namespace=g.join("."),t.namespace_re=t.namespace?RegExp("(^|\\.)"+g.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=undefined,t.target||(t.target=r),n=null==n?[t]:x.makeArray(n,[t]),f=x.event.special[d]||{},i||!f.trigger||f.trigger.apply(r,n)!==!1)){if(!i&&!f.noBubble&&!x.isWindow(r)){for(l=f.delegateType||d,_.test(l+d)||(a=a.parentNode);a;a=a.parentNode)h.push(a),u=a;u===(r.ownerDocument||o)&&h.push(u.defaultView||u.parentWindow||e)}s=0;while((a=h[s++])&&!t.isPropagationStopped())t.type=s>1?l:f.bindType||d,p=(q.get(a,"events")||{})[t.type]&&q.get(a,"handle"),p&&p.apply(a,n),p=c&&a[c],p&&x.acceptData(a)&&p.apply&&p.apply(a,n)===!1&&t.preventDefault();return t.type=d,i||t.isDefaultPrevented()||f._default&&f._default.apply(h.pop(),n)!==!1||!x.acceptData(r)||c&&x.isFunction(r[d])&&!x.isWindow(r)&&(u=r[c],u&&(r[c]=null),x.event.triggered=d,r[d](),x.event.triggered=undefined,u&&(r[c]=u)),t.result}},dispatch:function(e){e=x.event.fix(e);var t,n,r,i,o,s=[],a=d.call(arguments),u=(q.get(this,"events")||{})[e.type]||[],l=x.event.special[e.type]||{};if(a[0]=e,e.delegateTarget=this,!l.preDispatch||l.preDispatch.call(this,e)!==!1){s=x.event.handlers.call(this,e,u),t=0;while((i=s[t++])&&!e.isPropagationStopped()){e.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(o.namespace))&&(e.handleObj=o,e.data=o.data,r=((x.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,a),r!==undefined&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return l.postDispatch&&l.postDispatch.call(this,e),e.result}},handlers:function(e,t){var n,r,i,o,s=[],a=t.delegateCount,u=e.target;if(a&&u.nodeType&&(!e.button||"click"!==e.type))for(;u!==this;u=u.parentNode||this)if(u.disabled!==!0||"click"!==e.type){for(r=[],n=0;a>n;n++)o=t[n],i=o.selector+" ",r[i]===undefined&&(r[i]=o.needsContext?x(i,this).index(u)>=0:x.find(i,this,null,[u]).length),r[i]&&r.push(o);r.length&&s.push({elem:u,handlers:r})}return t.length>a&&s.push({elem:this,handlers:t.slice(a)}),s},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,t){var n,r,i,s=t.button;return null==e.pageX&&null!=t.clientX&&(n=e.target.ownerDocument||o,r=n.documentElement,i=n.body,e.pageX=t.clientX+(r&&r.scrollLeft||i&&i.scrollLeft||0)-(r&&r.clientLeft||i&&i.clientLeft||0),e.pageY=t.clientY+(r&&r.scrollTop||i&&i.scrollTop||0)-(r&&r.clientTop||i&&i.clientTop||0)),e.which||s===undefined||(e.which=1&s?1:2&s?3:4&s?2:0),e}},fix:function(e){if(e[x.expando])return e;var t,n,r,i=e.type,s=e,a=this.fixHooks[i];a||(this.fixHooks[i]=a=z.test(i)?this.mouseHooks:I.test(i)?this.keyHooks:{}),r=a.props?this.props.concat(a.props):this.props,e=new x.Event(s),t=r.length;while(t--)n=r[t],e[n]=s[n];return e.target||(e.target=o),3===e.target.nodeType&&(e.target=e.target.parentNode),a.filter?a.filter(e,s):e},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==V()&&this.focus?(this.focus(),!1):undefined},delegateType:"focusin"},blur:{trigger:function(){return this===V()&&this.blur?(this.blur(),!1):undefined},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&x.nodeName(this,"input")?(this.click(),!1):undefined},_default:function(e){return x.nodeName(e.target,"a")}},beforeunload:{postDispatch:function(e){e.result!==undefined&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=x.extend(new x.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?x.event.trigger(i,null,t):x.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},x.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)},x.Event=function(e,t){return this instanceof x.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.getPreventDefault&&e.getPreventDefault()?U:Y):this.type=e,t&&x.extend(this,t),this.timeStamp=e&&e.timeStamp||x.now(),this[x.expando]=!0,undefined):new x.Event(e,t)},x.Event.prototype={isDefaultPrevented:Y,isPropagationStopped:Y,isImmediatePropagationStopped:Y,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=U,e&&e.preventDefault&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=U,e&&e.stopPropagation&&e.stopPropagation()},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=U,this.stopPropagation()}},x.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){x.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;return(!i||i!==r&&!x.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),x.support.focusinBubbles||x.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){x.event.simulate(t,e.target,x.event.fix(e),!0)};x.event.special[t]={setup:function(){0===n++&&o.addEventListener(e,r,!0)},teardown:function(){0===--n&&o.removeEventListener(e,r,!0)}}}),x.fn.extend({on:function(e,t,n,r,i){var o,s;if("object"==typeof e){"string"!=typeof t&&(n=n||t,t=undefined);for(s in e)this.on(s,t,n,e[s],i);return this}if(null==n&&null==r?(r=t,n=t=undefined):null==r&&("string"==typeof t?(r=n,n=undefined):(r=n,n=t,t=undefined)),r===!1)r=Y;else if(!r)return this;return 1===i&&(o=r,r=function(e){return x().off(e),o.apply(this,arguments)},r.guid=o.guid||(o.guid=x.guid++)),this.each(function(){x.event.add(this,e,r,n,t)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,x(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return(t===!1||"function"==typeof t)&&(n=t,t=undefined),n===!1&&(n=Y),this.each(function(){x.event.remove(this,e,n,t)})},trigger:function(e,t){return this.each(function(){x.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];return n?x.event.trigger(e,t,n,!0):undefined}});var G=/^.[^:#\[\.,]*$/,J=/^(?:parents|prev(?:Until|All))/,Q=x.expr.match.needsContext,K={children:!0,contents:!0,next:!0,prev:!0};x.fn.extend({find:function(e){var t,n=[],r=this,i=r.length;if("string"!=typeof e)return this.pushStack(x(e).filter(function(){for(t=0;i>t;t++)if(x.contains(r[t],this))return!0}));for(t=0;i>t;t++)x.find(e,r[t],n);return n=this.pushStack(i>1?x.unique(n):n),n.selector=this.selector?this.selector+" "+e:e,n},has:function(e){var t=x(e,this),n=t.length;return this.filter(function(){var e=0;for(;n>e;e++)if(x.contains(this,t[e]))return!0})},not:function(e){return this.pushStack(et(this,e||[],!0))},filter:function(e){return this.pushStack(et(this,e||[],!1))},is:function(e){return!!et(this,"string"==typeof e&&Q.test(e)?x(e):e||[],!1).length},closest:function(e,t){var n,r=0,i=this.length,o=[],s=Q.test(e)||"string"!=typeof e?x(e,t||this.context):0;for(;i>r;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(11>n.nodeType&&(s?s.index(n)>-1:1===n.nodeType&&x.find.matchesSelector(n,e))){n=o.push(n);break}return this.pushStack(o.length>1?x.unique(o):o)},index:function(e){return e?"string"==typeof e?g.call(x(e),this[0]):g.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?x(e,t):x.makeArray(e&&e.nodeType?[e]:e),r=x.merge(this.get(),n);return this.pushStack(x.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function Z(e,t){while((e=e[t])&&1!==e.nodeType);return e}x.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return x.dir(e,"parentNode")},parentsUntil:function(e,t,n){return x.dir(e,"parentNode",n)},next:function(e){return Z(e,"nextSibling")},prev:function(e){return Z(e,"previousSibling")},nextAll:function(e){return x.dir(e,"nextSibling")},prevAll:function(e){return x.dir(e,"previousSibling")},nextUntil:function(e,t,n){return x.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return x.dir(e,"previousSibling",n)},siblings:function(e){return x.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return x.sibling(e.firstChild)},contents:function(e){return e.contentDocument||x.merge([],e.childNodes)}},function(e,t){x.fn[e]=function(n,r){var i=x.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=x.filter(r,i)),this.length>1&&(K[e]||x.unique(i),J.test(e)&&i.reverse()),this.pushStack(i)}}),x.extend({filter:function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?x.find.matchesSelector(r,e)?[r]:[]:x.find.matches(e,x.grep(t,function(e){return 1===e.nodeType}))},dir:function(e,t,n){var r=[],i=n!==undefined;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&x(e).is(n))break;r.push(e)}return r},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function et(e,t,n){if(x.isFunction(t))return x.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return x.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(G.test(t))return x.filter(t,e,n);t=x.filter(t,e)}return x.grep(e,function(e){return g.call(t,e)>=0!==n})}var tt=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,nt=/<([\w:]+)/,rt=/<|&#?\w+;/,it=/<(?:script|style|link)/i,ot=/^(?:checkbox|radio)$/i,st=/checked\s*(?:[^=]|=\s*.checked.)/i,at=/^$|\/(?:java|ecma)script/i,ut=/^true\/(.*)/,lt=/^\s*\s*$/g,ct={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};ct.optgroup=ct.option,ct.tbody=ct.tfoot=ct.colgroup=ct.caption=ct.thead,ct.th=ct.td,x.fn.extend({text:function(e){return x.access(this,function(e){return e===undefined?x.text(this):this.empty().append((this[0]&&this[0].ownerDocument||o).createTextNode(e))},null,e,arguments.length)},append:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.appendChild(e)}})},prepend:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=e?x.filter(e,this):this,i=0;for(;null!=(n=r[i]);i++)t||1!==n.nodeType||x.cleanData(mt(n)),n.parentNode&&(t&&x.contains(n.ownerDocument,n)&&dt(mt(n,"script")),n.parentNode.removeChild(n));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++)1===e.nodeType&&(x.cleanData(mt(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return x.clone(this,e,t)})},html:function(e){return x.access(this,function(e){var t=this[0]||{},n=0,r=this.length;if(e===undefined&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!it.test(e)&&!ct[(nt.exec(e)||["",""])[1].toLowerCase()]){e=e.replace(tt,"<$1>");try{for(;r>n;n++)t=this[n]||{},1===t.nodeType&&(x.cleanData(mt(t,!1)),t.innerHTML=e);t=0}catch(i){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var e=x.map(this,function(e){return[e.nextSibling,e.parentNode]}),t=0;return this.domManip(arguments,function(n){var r=e[t++],i=e[t++];i&&(r&&r.parentNode!==i&&(r=this.nextSibling),x(this).remove(),i.insertBefore(n,r))},!0),t?this:this.remove()},detach:function(e){return this.remove(e,!0)},domManip:function(e,t,n){e=f.apply([],e);var r,i,o,s,a,u,l=0,c=this.length,p=this,h=c-1,d=e[0],g=x.isFunction(d);if(g||!(1>=c||"string"!=typeof d||x.support.checkClone)&&st.test(d))return this.each(function(r){var i=p.eq(r);g&&(e[0]=d.call(this,r,i.html())),i.domManip(e,t,n)});if(c&&(r=x.buildFragment(e,this[0].ownerDocument,!1,!n&&this),i=r.firstChild,1===r.childNodes.length&&(r=i),i)){for(o=x.map(mt(r,"script"),ft),s=o.length;c>l;l++)a=r,l!==h&&(a=x.clone(a,!0,!0),s&&x.merge(o,mt(a,"script"))),t.call(this[l],a,l);if(s)for(u=o[o.length-1].ownerDocument,x.map(o,ht),l=0;s>l;l++)a=o[l],at.test(a.type||"")&&!q.access(a,"globalEval")&&x.contains(u,a)&&(a.src?x._evalUrl(a.src):x.globalEval(a.textContent.replace(lt,"")))}return this}}),x.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){x.fn[e]=function(e){var n,r=[],i=x(e),o=i.length-1,s=0;for(;o>=s;s++)n=s===o?this:this.clone(!0),x(i[s])[t](n),h.apply(r,n.get());return this.pushStack(r)}}),x.extend({clone:function(e,t,n){var r,i,o,s,a=e.cloneNode(!0),u=x.contains(e.ownerDocument,e);if(!(x.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||x.isXMLDoc(e)))for(s=mt(a),o=mt(e),r=0,i=o.length;i>r;r++)yt(o[r],s[r]);if(t)if(n)for(o=o||mt(e),s=s||mt(a),r=0,i=o.length;i>r;r++)gt(o[r],s[r]);else gt(e,a);return s=mt(a,"script"),s.length>0&&dt(s,!u&&mt(e,"script")),a},buildFragment:function(e,t,n,r){var i,o,s,a,u,l,c=0,p=e.length,f=t.createDocumentFragment(),h=[];for(;p>c;c++)if(i=e[c],i||0===i)if("object"===x.type(i))x.merge(h,i.nodeType?[i]:i);else if(rt.test(i)){o=o||f.appendChild(t.createElement("div")),s=(nt.exec(i)||["",""])[1].toLowerCase(),a=ct[s]||ct._default,o.innerHTML=a[1]+i.replace(tt,"<$1>")+a[2],l=a[0];while(l--)o=o.lastChild;x.merge(h,o.childNodes),o=f.firstChild,o.textContent=""}else h.push(t.createTextNode(i));f.textContent="",c=0;while(i=h[c++])if((!r||-1===x.inArray(i,r))&&(u=x.contains(i.ownerDocument,i),o=mt(f.appendChild(i),"script"),u&&dt(o),n)){l=0;while(i=o[l++])at.test(i.type||"")&&n.push(i)}return f},cleanData:function(e){var t,n,r,i,o,s,a=x.event.special,u=0;for(;(n=e[u])!==undefined;u++){if(F.accepts(n)&&(o=n[q.expando],o&&(t=q.cache[o]))){if(r=Object.keys(t.events||{}),r.length)for(s=0;(i=r[s])!==undefined;s++)a[i]?x.event.remove(n,i):x.removeEvent(n,i,t.handle);q.cache[o]&&delete q.cache[o]}delete L.cache[n[L.expando]]}},_evalUrl:function(e){return x.ajax({url:e,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})}});function pt(e,t){return x.nodeName(e,"table")&&x.nodeName(1===t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function ft(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function ht(e){var t=ut.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function dt(e,t){var n=e.length,r=0;for(;n>r;r++)q.set(e[r],"globalEval",!t||q.get(t[r],"globalEval"))}function gt(e,t){var n,r,i,o,s,a,u,l;if(1===t.nodeType){if(q.hasData(e)&&(o=q.access(e),s=q.set(t,o),l=o.events)){delete s.handle,s.events={};for(i in l)for(n=0,r=l[i].length;r>n;n++)x.event.add(t,i,l[i][n])}L.hasData(e)&&(a=L.access(e),u=x.extend({},a),L.set(t,u))}}function mt(e,t){var n=e.getElementsByTagName?e.getElementsByTagName(t||"*"):e.querySelectorAll?e.querySelectorAll(t||"*"):[];return t===undefined||t&&x.nodeName(e,t)?x.merge([e],n):n}function yt(e,t){var n=t.nodeName.toLowerCase();"input"===n&&ot.test(e.type)?t.checked=e.checked:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}x.fn.extend({wrapAll:function(e){var t;return x.isFunction(e)?this.each(function(t){x(this).wrapAll(e.call(this,t))}):(this[0]&&(t=x(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this)},wrapInner:function(e){return x.isFunction(e)?this.each(function(t){x(this).wrapInner(e.call(this,t))}):this.each(function(){var t=x(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=x.isFunction(e);return this.each(function(n){x(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){x.nodeName(this,"body")||x(this).replaceWith(this.childNodes)}).end()}});var vt,xt,bt=/^(none|table(?!-c[ea]).+)/,wt=/^margin/,Tt=RegExp("^("+b+")(.*)$","i"),Ct=RegExp("^("+b+")(?!px)[a-z%]+$","i"),kt=RegExp("^([+-])=("+b+")","i"),Nt={BODY:"block"},Et={position:"absolute",visibility:"hidden",display:"block"},St={letterSpacing:0,fontWeight:400},jt=["Top","Right","Bottom","Left"],Dt=["Webkit","O","Moz","ms"];function At(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=Dt.length;while(i--)if(t=Dt[i]+n,t in e)return t;return r}function Lt(e,t){return e=t||e,"none"===x.css(e,"display")||!x.contains(e.ownerDocument,e)}function qt(t){return e.getComputedStyle(t,null)}function Ht(e,t){var n,r,i,o=[],s=0,a=e.length;for(;a>s;s++)r=e[s],r.style&&(o[s]=q.get(r,"olddisplay"),n=r.style.display,t?(o[s]||"none"!==n||(r.style.display=""),""===r.style.display&&Lt(r)&&(o[s]=q.access(r,"olddisplay",Rt(r.nodeName)))):o[s]||(i=Lt(r),(n&&"none"!==n||!i)&&q.set(r,"olddisplay",i?n:x.css(r,"display"))));for(s=0;a>s;s++)r=e[s],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[s]||"":"none"));return e}x.fn.extend({css:function(e,t){return x.access(this,function(e,t,n){var r,i,o={},s=0;if(x.isArray(t)){for(r=qt(e),i=t.length;i>s;s++)o[t[s]]=x.css(e,t[s],!1,r);return o}return n!==undefined?x.style(e,t,n):x.css(e,t)},e,t,arguments.length>1)},show:function(){return Ht(this,!0)},hide:function(){return Ht(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){Lt(this)?x(this).show():x(this).hide()})}}),x.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=vt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,s,a=x.camelCase(t),u=e.style;return t=x.cssProps[a]||(x.cssProps[a]=At(u,a)),s=x.cssHooks[t]||x.cssHooks[a],n===undefined?s&&"get"in s&&(i=s.get(e,!1,r))!==undefined?i:u[t]:(o=typeof n,"string"===o&&(i=kt.exec(n))&&(n=(i[1]+1)*i[2]+parseFloat(x.css(e,t)),o="number"),null==n||"number"===o&&isNaN(n)||("number"!==o||x.cssNumber[a]||(n+="px"),x.support.clearCloneStyle||""!==n||0!==t.indexOf("background")||(u[t]="inherit"),s&&"set"in s&&(n=s.set(e,n,r))===undefined||(u[t]=n)),undefined)}},css:function(e,t,n,r){var i,o,s,a=x.camelCase(t);return t=x.cssProps[a]||(x.cssProps[a]=At(e.style,a)),s=x.cssHooks[t]||x.cssHooks[a],s&&"get"in s&&(i=s.get(e,!0,n)),i===undefined&&(i=vt(e,t,r)),"normal"===i&&t in St&&(i=St[t]),""===n||n?(o=parseFloat(i),n===!0||x.isNumeric(o)?o||0:i):i}}),vt=function(e,t,n){var r,i,o,s=n||qt(e),a=s?s.getPropertyValue(t)||s[t]:undefined,u=e.style;return s&&(""!==a||x.contains(e.ownerDocument,e)||(a=x.style(e,t)),Ct.test(a)&&wt.test(t)&&(r=u.width,i=u.minWidth,o=u.maxWidth,u.minWidth=u.maxWidth=u.width=a,a=s.width,u.width=r,u.minWidth=i,u.maxWidth=o)),a};function Ot(e,t,n){var r=Tt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function Ft(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,s=0;for(;4>o;o+=2)"margin"===n&&(s+=x.css(e,n+jt[o],!0,i)),r?("content"===n&&(s-=x.css(e,"padding"+jt[o],!0,i)),"margin"!==n&&(s-=x.css(e,"border"+jt[o]+"Width",!0,i))):(s+=x.css(e,"padding"+jt[o],!0,i),"padding"!==n&&(s+=x.css(e,"border"+jt[o]+"Width",!0,i)));return s}function Pt(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=qt(e),s=x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=vt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Ct.test(i))return i;r=s&&(x.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+Ft(e,t,n||(s?"border":"content"),r,o)+"px"}function Rt(e){var t=o,n=Nt[e];return n||(n=Mt(e,t),"none"!==n&&n||(xt=(xt||x("