2014-11-13 19:53:31 +01:00
! function ( ) { function n ( n , t ) { return t > n ? - 1 : n > t ? 1 : n >= t ? 0 : 0 / 0 } function t ( n ) { return null === n ? 0 / 0 : + n } function e ( n ) { return ! isNaN ( n ) } function r ( n ) { return { left : function ( t , e , r , u ) { for ( arguments . length < 3 && ( r = 0 ) , arguments . length < 4 && ( u = t . length ) ; u > r ; ) { var i = r + u >>> 1 ; n ( t [ i ] , e ) < 0 ? r = i + 1 : u = i } return r } , right : function ( t , e , r , u ) { for ( arguments . length < 3 && ( r = 0 ) , arguments . length < 4 && ( u = t . length ) ; u > r ; ) { var i = r + u >>> 1 ; n ( t [ i ] , e ) > 0 ? u = i : r = i + 1 } return r } } } function u ( n ) { return n . length } function i ( n ) { for ( var t = 1 ; n * t % 1 ; ) t *= 10 ; return t } function o ( n , t ) { for ( var e in t ) Object . defineProperty ( n . prototype , e , { value : t [ e ] , enumerable : ! 1 } ) } function a ( ) { this . _ = Object . create ( null ) } function c ( n ) { return ( n += "" ) === la || n [ 0 ] === sa ? sa + n : n } function l ( n ) { return ( n += "" ) [ 0 ] === sa ? n . slice ( 1 ) : n } function s ( n ) { return c ( n ) in this . _ } function f ( n ) { return ( n = c ( n ) ) in this . _ && delete this . _ [ n ] } function h ( ) { var n = [ ] ; for ( var t in this . _ ) n . push ( l ( t ) ) ; return n } function g ( ) { var n = 0 ; for ( var t in this . _ ) ++ n ; return n } function p ( ) { for ( var n in this . _ ) return ! 1 ; return ! 0 } function v ( ) { this . _ = Object . create ( null ) } function d ( n , t , e ) { return function ( ) { var r = e . apply ( t , arguments ) ; return r === t ? n : r } } function m ( n , t ) { if ( t in n ) return t ; t = t . charAt ( 0 ) . toUpperCase ( ) + t . slice ( 1 ) ; for ( var e = 0 , r = fa . length ; r > e ; ++ e ) { var u = fa [ e ] + t ; if ( u in n ) return u } } function y ( ) { } function x ( ) { } function M ( n ) { function t ( ) { for ( var t , r = e , u = - 1 , i = r . length ; ++ u < i ; ) ( t = r [ u ] . on ) && t . apply ( this , arguments ) ; return n } var e = [ ] , r = new a ; return t . on = function ( t , u ) { var i , o = r . get ( t ) ; return arguments . length < 2 ? o && o . on : ( o && ( o . on = null , e = e . slice ( 0 , i = e . indexOf ( o ) ) . concat ( e . slice ( i + 1 ) ) , r . remove ( t ) ) , u && e . push ( r . set ( t , { on : u } ) ) , n ) } , t } function _ ( ) { Bo . event . preventDefault ( ) } function b ( ) { for ( var n , t = Bo . event ; n = t . sourceEvent ; ) t = n ; return t } function w ( n ) { for ( var t = new x , e = 0 , r = arguments . length ; ++ e < r ; ) t [ arguments [ e ] ] = M ( t ) ; return t . of = function ( e , r ) { return function ( u ) { try { var i = u . sourceEvent = Bo . event ; u . target = n , Bo . event = u , t [ u . type ] . apply ( e , r ) } finally { Bo . event = i } } } , t } function S ( n ) { return ga ( n , ya ) , n } function k ( n ) { return "function" == typeof n ? n : function ( ) { return pa ( n , this ) } } function E ( n ) { return "function" == typeof n ? n : function ( ) { return va ( n , this ) } } function A ( n , t ) { function e ( ) { this . removeAttribute ( n ) } function r ( ) { this . removeAttributeNS ( n . space , n . local ) } function u ( ) { this . setAttribute ( n , t ) } function i ( ) { this . setAttributeNS ( n . space , n . local , t ) } function o ( ) { var e = t . apply ( this , arguments ) ; null == e ? this . removeAttribute ( n ) : this . setAttribute ( n , e ) } function a ( ) { var e = t . apply ( this , arguments ) ; null == e ? this . removeAttributeNS ( n . space , n . local ) : this . setAttributeNS ( n . space , n . local , e ) } return n = Bo . ns . qualify ( n ) , null == t ? n . local ? r : e : "function" == typeof t ? n . local ? a : o : n . local ? i : u } function C ( n ) { return n . trim ( ) . replace ( /\s+/g , " " ) } function N ( n ) { return new RegExp ( "(?:^|\\s+)" + Bo . requote ( n ) + "(?:\\s+|$)" , "g" ) } function z ( n ) { return ( n + "" ) . trim ( ) . split ( /^|\s+/ ) } function L ( n , t ) { function e ( ) { for ( var e = - 1 ; ++ e < u ; ) n [ e ] ( this , t ) } function r ( ) { for ( var e = - 1 , r = t . apply ( this , arguments ) ; ++ e < u ; ) n [ e ] ( this , r ) } n = z ( n ) . map ( T ) ; var u = n . length ; return "function" == typeof t ? r : e } function T ( n ) { var t = N ( n ) ; return function ( e , r ) { if ( u = e . classList ) return r ? u . add ( n ) : u . remove ( n ) ; var u = e . getAttribute ( "class" ) || "" ; r ? ( t . lastIndex = 0 , t . test ( u ) || e . setAttribute ( "class" , C ( u + " " + n ) ) ) : e . setAttribute ( "class" , C ( u . replace ( t , " " ) ) ) } } function q ( n , t , e ) { function r ( ) { this . style . removeProperty ( n ) } function u ( ) { this . style . setProperty ( n , t , e ) } function i ( ) { var r = t . apply ( this , arguments ) ; null == r ? this . style . removeProperty ( n ) : this . style . setProperty ( n , r , e ) } return null == t ? r : "function" == typeof t ? i : u } function R ( n , t ) { function e ( ) { delete this [ n ] } function r ( ) { this [ n ] = t } function u ( ) { var e = t . apply ( this , arguments ) ; null == e ? delete this [ n ] : this [ n ] = e } return null == t ? e : "function" == typeof t ? u : r } function D ( n ) { return "function" == typeof n ? n : ( n = Bo . ns . qualify ( n ) ) . local ? function ( ) { return this . ownerDocument . createElementNS ( n . space , n . local ) } : function ( ) { return this . ownerDocument . createElementNS ( this . namespaceURI , n ) } } function P ( n ) { return { _ _data _ _ : n } } function U ( n ) { return function ( ) { return ma ( this , n ) } } function j ( t ) { return arguments . length || ( t = n ) , function ( n , e ) { return n && e ? t ( n . _ _data _ _ , e . _ _data _ _ ) : ! n - ! e } } function F ( n , t ) { for ( var
( T * T / M > i || ca ( ( y * z + x * L ) / M - . 5 ) > . 3 || o > a * g + c * p + l * v ) && ( u ( t , e , r , a , c , l , C , N , E , _ /= S , b /= S , w , d , m ) , m . point ( C , N ) , u ( C , N , E , _ , b , w , s , f , h , g , p , v , d , m ) ) } } var i = . 5 , o = Math . cos ( 30 * La ) , a = 16 ; return t . precision = function ( n ) { return arguments . length ? ( a = ( i = n * n ) > 0 && 16 , t ) : Math . sqrt ( i ) } , t } function tr ( n ) { var t = nr ( function ( t , e ) { return n ( [ t * Ta , e * Ta ] ) } ) ; return function ( n ) { return or ( t ( n ) ) } } function er ( n ) { this . stream = n } function rr ( n , t ) { return { point : t , sphere : function ( ) { n . sphere ( ) } , lineStart : function ( ) { n . lineStart ( ) } , lineEnd : function ( ) { n . lineEnd ( ) } , polygonStart : function ( ) { n . polygonStart ( ) } , polygonEnd : function ( ) { n . polygonEnd ( ) } } } function ur ( n ) { return ir ( function ( ) { return n } ) ( ) } function ir ( n ) { function t ( n ) { return n = a ( n [ 0 ] * La , n [ 1 ] * La ) , [ n [ 0 ] * h + c , l - n [ 1 ] * h ] } function e ( n ) { return n = a . invert ( ( n [ 0 ] - c ) / h , ( l - n [ 1 ] ) / h ) , n && [ n [ 0 ] * Ta , n [ 1 ] * Ta ] } function r ( ) { a = Ye ( o = lr ( m , y , x ) , i ) ; var n = i ( v , d ) ; return c = g - n [ 0 ] * h , l = p + n [ 1 ] * h , u ( ) } function u ( ) { return s && ( s . valid = ! 1 , s = null ) , t } var i , o , a , c , l , s , f = nr ( function ( n , t ) { return n = i ( n , t ) , [ n [ 0 ] * h + c , l - n [ 1 ] * h ] } ) , h = 150 , g = 480 , p = 250 , v = 0 , d = 0 , m = 0 , y = 0 , x = 0 , M = Cc , _ = Et , b = null , w = null ; return t . stream = function ( n ) { return s && ( s . valid = ! 1 ) , s = or ( M ( o , f ( _ ( n ) ) ) ) , s . valid = ! 0 , s } , t . clipAngle = function ( n ) { return arguments . length ? ( M = null == n ? ( b = n , Cc ) : Fe ( ( b = + n ) * La ) , u ( ) ) : b } , t . clipExtent = function ( n ) { return arguments . length ? ( w = n , _ = n ? Oe ( n [ 0 ] [ 0 ] , n [ 0 ] [ 1 ] , n [ 1 ] [ 0 ] , n [ 1 ] [ 1 ] ) : Et , u ( ) ) : w } , t . scale = function ( n ) { return arguments . length ? ( h = + n , r ( ) ) : h } , t . translate = function ( n ) { return arguments . length ? ( g = + n [ 0 ] , p = + n [ 1 ] , r ( ) ) : [ g , p ] } , t . center = function ( n ) { return arguments . length ? ( v = n [ 0 ] % 360 * La , d = n [ 1 ] % 360 * La , r ( ) ) : [ v * Ta , d * Ta ] } , t . rotate = function ( n ) { return arguments . length ? ( m = n [ 0 ] % 360 * La , y = n [ 1 ] % 360 * La , x = n . length > 2 ? n [ 2 ] % 360 * La : 0 , r ( ) ) : [ m * Ta , y * Ta , x * Ta ] } , Bo . rebind ( t , f , "precision" ) , function ( ) { return i = n . apply ( this , arguments ) , t . invert = i . invert && e , r ( ) } } function or ( n ) { return rr ( n , function ( t , e ) { n . point ( t * La , e * La ) } ) } function ar ( n , t ) { return [ n , t ] } function cr ( n , t ) { return [ n > Ea ? n - Aa : - Ea > n ? n + Aa : n , t ] } function lr ( n , t , e ) { return n ? t || e ? Ye ( fr ( n ) , hr ( t , e ) ) : fr ( n ) : t || e ? hr ( t , e ) : cr } function sr ( n ) { return function ( t , e ) { return t += n , [ t > Ea ? t - Aa : - Ea > t ? t + Aa : t , e ] } } function fr ( n ) { var t = sr ( n ) ; return t . invert = sr ( - n ) , t } function hr ( n , t ) { function e ( n , t ) { var e = Math . cos ( t ) , a = Math . cos ( n ) * e , c = Math . sin ( n ) * e , l = Math . sin ( t ) , s = l * r + a * u ; return [ Math . atan2 ( c * i - s * o , a * r - l * u ) , nt ( s * i + c * o ) ] } var r = Math . cos ( n ) , u = Math . sin ( n ) , i = Math . cos ( t ) , o = Math . sin ( t ) ; return e . invert = function ( n , t ) { var e = Math . cos ( t ) , a = Math . cos ( n ) * e , c = Math . sin ( n ) * e , l = Math . sin ( t ) , s = l * i - c * o ; return [ Math . atan2 ( c * i + l * o , a * r + s * u ) , nt ( s * r - a * u ) ] } , e } function gr ( n , t ) { var e = Math . cos ( n ) , r = Math . sin ( n ) ; return function ( u , i , o , a ) { var c = o * t ; null != u ? ( u = pr ( e , u ) , i = pr ( e , i ) , ( o > 0 ? i > u : u > i ) && ( u += o * Aa ) ) : ( u = n + o * Aa , i = n - . 5 * c ) ; for ( var l , s = u ; o > 0 ? s > i : i > s ; s -= c ) a . point ( ( l = Me ( [ e , - r * Math . cos ( s ) , - r * Math . sin ( s ) ] ) ) [ 0 ] , l [ 1 ] ) } } function pr ( n , t ) { var e = pe ( t ) ; e [ 0 ] -= n , xe ( e ) ; var r = Q ( - e [ 1 ] ) ; return ( ( - e [ 2 ] < 0 ? - r : r ) + 2 * Math . PI - Na ) % ( 2 * Math . PI ) } function vr ( n , t , e ) { var r = Bo . range ( n , t - Na , e ) . concat ( t ) ; return function ( n ) { return r . map ( function ( t ) { return [ n , t ] } ) } } function dr ( n , t , e ) { var r = Bo . range ( n , t - Na , e ) . concat ( t ) ; return function ( n ) { return r . map ( function ( t ) { return [ t , n ] } ) } } function mr ( n ) { return n . source } function yr ( n ) { return n . target } function xr ( n , t , e , r ) { var u = Math . cos ( t ) , i = Math . sin ( t ) , o = Math . cos ( r ) , a = Math . sin ( r ) , c = u * Math . cos ( n ) , l = u * Math . sin ( n ) , s = o * Math . cos ( e ) , f = o * Math . sin ( e ) , h = 2 * Math . asin ( Math . sqrt ( ut ( r - t ) + u * o * ut ( e - n ) ) ) , g = 1 / Math . sin ( h ) , p = h ? function ( n ) { var t = Math . sin ( n *= h ) * g , e = Math . sin ( h - n ) * g , r = e * c + t * s , u = e * l + t * f , o = e * i + t * a ; return [ Math . atan2 ( u , r ) * Ta , Math . atan2 ( o , Math . sqrt ( r * r + u * u ) ) * Ta ] } : function ( ) { return [ n * Ta , t * Ta ] } ; return p . distance = h , p } function Mr ( ) { function n ( n , u ) { var i = Math . sin ( u *= La ) , o = Math . cos ( u ) , a = ca ( ( n *= La ) - t ) , c = Math . cos ( a ) ; Fc += Math . atan2 ( Math . sqrt ( ( a = o * Math . sin ( a ) ) * a + ( a = r * i - e * o * c ) * a ) , e * i + r * o * c ) , t = n , e = i , r = o } var t , e , r ; Hc . point = function ( u , i ) { t = u * La , e = Math . sin ( i *= La ) , r = Math . cos ( i ) , Hc . point = n } , Hc . lineEnd = function ( ) { Hc . point = Hc . lineEnd = y } } function _r ( n , t ) { function e ( t , e ) { var r = Math . cos ( t ) , u = Math . cos ( e ) , i = n ( r * u ) ; return [ i * u * Math . sin ( t ) , i * Math . sin ( e ) ] } return e . invert = function ( n , e ) { var r = Math . sqrt ( n * n + e * e ) , u = t ( r ) , i = Math . sin ( u ) , o = Math . cos ( u ) ; return [ Math . atan2 ( n * i , r * o ) , Math . asi
} ) , Bo . timer ( function ( ) { return p . c = c ( r || 1 ) ? Ae : c , 1 } , 0 , o ) , void 0 ) } function c ( r ) { if ( u . active !== e ) return l ( ) ; for ( var o = r / g , a = f ( o ) , c = v . length ; c > 0 ; ) v [ -- c ] . call ( n , a ) ; return o >= 1 ? ( i . event && i . event . end . call ( n , s , t ) , l ( ) ) : void 0 } function l ( ) { return -- u . count ? delete u [ e ] : delete n . _ _transition _ _ , 1 } var s = n . _ _data _ _ , f = i . ease , h = i . delay , g = i . duration , p = Ka , v = [ ] ; return p . t = h + o , r >= h ? a ( r - h ) : ( p . c = a , void 0 ) } , 0 , o ) } } function Oo ( n , t , e ) { n . attr ( "transform" , function ( n ) { var r = t ( n ) ; return "translate(" + ( isFinite ( r ) ? r : e ( n ) ) + ",0)" } ) } function Yo ( n , t , e ) { n . attr ( "transform" , function ( n ) { var r = t ( n ) ; return "translate(0," + ( isFinite ( r ) ? r : e ( n ) ) + ")" } ) } function Io ( n ) { return n . toISOString ( ) } function Zo ( n , t , e ) { function r ( t ) { return n ( t ) } function u ( n , e ) { var r = n [ 1 ] - n [ 0 ] , u = r / e , i = Bo . bisect ( Ol , u ) ; return i == Ol . length ? [ t . year , Zi ( n . map ( function ( n ) { return n / 31536e6 } ) , e ) [ 2 ] ] : i ? t [ u / Ol [ i - 1 ] < Ol [ i ] / u ? i - 1 : i ] : [ Zl , Zi ( n , e ) [ 2 ] ] } return r . invert = function ( t ) { return Vo ( n . invert ( t ) ) } , r . domain = function ( t ) { return arguments . length ? ( n . domain ( t ) , r ) : n . domain ( ) . map ( Vo ) } , r . nice = function ( n , t ) { function e ( e ) { return ! isNaN ( e ) && ! n . range ( e , Vo ( + e + 1 ) , t ) . length } var i = r . domain ( ) , o = Di ( i ) , a = null == n ? u ( o , 10 ) : "number" == typeof n && u ( o , n ) ; return a && ( n = a [ 0 ] , t = a [ 1 ] ) , r . domain ( ji ( i , t > 1 ? { floor : function ( t ) { for ( ; e ( t = n . floor ( t ) ) ; ) t = Vo ( t - 1 ) ; return t } , ceil : function ( t ) { for ( ; e ( t = n . ceil ( t ) ) ; ) t = Vo ( + t + 1 ) ; return t } } : n ) ) } , r . ticks = function ( n , t ) { var e = Di ( r . domain ( ) ) , i = null == n ? u ( e , 10 ) : "number" == typeof n ? u ( e , n ) : ! n . range && [ { range : n } , t ] ; return i && ( n = i [ 0 ] , t = i [ 1 ] ) , n . range ( e [ 0 ] , Vo ( + e [ 1 ] + 1 ) , 1 > t ? 1 : t ) } , r . tickFormat = function ( ) { return e } , r . copy = function ( ) { return Zo ( n . copy ( ) , t , e ) } , Yi ( r , n ) } function Vo ( n ) { return new Date ( n ) } function Xo ( n ) { return JSON . parse ( n . responseText ) } function $o ( n ) { var t = Go . createRange ( ) ; return t . selectNode ( Go . body ) , t . createContextualFragment ( n . responseText ) } var Bo = { version : "3.4.13" } ; Date . now || ( Date . now = function ( ) { return + new Date } ) ; var Wo = [ ] . slice , Jo = function ( n ) { return Wo . call ( n ) } , Go = document , Ko = Go . documentElement , Qo = window ; try { Jo ( Ko . childNodes ) [ 0 ] . nodeType } catch ( na ) { Jo = function ( n ) { for ( var t = n . length , e = new Array ( t ) ; t -- ; ) e [ t ] = n [ t ] ; return e } } try { Go . createElement ( "div" ) . style . setProperty ( "opacity" , 0 , "" ) } catch ( ta ) { var ea = Qo . Element . prototype , ra = ea . setAttribute , ua = ea . setAttributeNS , ia = Qo . CSSStyleDeclaration . prototype , oa = ia . setProperty ; ea . setAttribute = function ( n , t ) { ra . call ( this , n , t + "" ) } , ea . setAttributeNS = function ( n , t , e ) { ua . call ( this , n , t , e + "" ) } , ia . setProperty = function ( n , t , e ) { oa . call ( this , n , t + "" , e ) } } Bo . ascending = n , Bo . descending = function ( n , t ) { return n > t ? - 1 : t > n ? 1 : t >= n ? 0 : 0 / 0 } , Bo . min = function ( n , t ) { var e , r , u = - 1 , i = n . length ; if ( 1 === arguments . length ) { for ( ; ++ u < i && ! ( null != ( e = n [ u ] ) && e >= e ) ; ) e = void 0 ; for ( ; ++ u < i ; ) null != ( r = n [ u ] ) && e > r && ( e = r ) } else { for ( ; ++ u < i && ! ( null != ( e = t . call ( n , n [ u ] , u ) ) && e >= e ) ; ) e = void 0 ; for ( ; ++ u < i ; ) null != ( r = t . call ( n , n [ u ] , u ) ) && e > r && ( e = r ) } return e } , Bo . max = function ( n , t ) { var e , r , u = - 1 , i = n . length ; if ( 1 === arguments . length ) { for ( ; ++ u < i && ! ( null != ( e = n [ u ] ) && e >= e ) ; ) e = void 0 ; for ( ; ++ u < i ; ) null != ( r = n [ u ] ) && r > e && ( e = r ) } else { for ( ; ++ u < i && ! ( null != ( e = t . call ( n , n [ u ] , u ) ) && e >= e ) ; ) e = void 0 ; for ( ; ++ u < i ; ) null != ( r = t . call ( n , n [ u ] , u ) ) && r > e && ( e = r ) } return e } , Bo . extent = function ( n , t ) { var e , r , u , i = - 1 , o = n . length ; if ( 1 === arguments . length ) { for ( ; ++ i < o && ! ( null != ( e = u = n [ i ] ) && e >= e ) ; ) e = u = void 0 ; for ( ; ++ i < o ; ) null != ( r = n [ i ] ) && ( e > r && ( e = r ) , r > u && ( u = r ) ) } else { for ( ; ++ i < o && ! ( null != ( e = u = t . call ( n , n [ i ] , i ) ) && e >= e ) ; ) e = void 0 ; for ( ; ++ i < o ; ) null != ( r = t . call ( n , n [ i ] , i ) ) && ( e > r && ( e = r ) , r > u && ( u = r ) ) } return [ e , u ] } , Bo . sum = function ( n , t ) { var r , u = 0 , i = n . length , o = - 1 ; if ( 1 === arguments . length ) for ( ; ++ o < i ; ) e ( r = + n [ o ] ) && ( u += r ) ; else for ( ; ++ o < i ; ) e ( r = + t . call ( n , n [ o ] , o ) ) && ( u += r ) ; return u } , Bo . mean = function ( n , r ) { var u , i = 0 , o = n . length , a = - 1 , c = o ; if ( 1 === arguments . length ) for ( ; ++ a < o ; ) e ( u = t ( n [ a ] ) ) ? i += u : -- c ; else for ( ; ++ a < o ; ) e ( u = t ( r . call ( n , n [ a ] , a ) ) ) ? i += u : -- c ; return c ? i / c : void 0 } , Bo . quantile = function ( n , t ) { var e = ( n . length - 1 ) * t + 1 , r = Math . floor ( e ) , u = + n [ r - 1 ] , i = e - r ; return i ? u + i * ( n [ r ] - u ) : u } , Bo . median = function ( r , u ) { var i , o = [ ] , a = r . length , c = - 1 ; if ( 1 === arguments . length ) for ( ; ++ c < a ; ) e ( i = t ( r [ c ] ) ) && o . push ( i ) ; else for ( ; ++ c < a ; ) e ( i = t ( u . call ( r , r [ c ] , c ) ) ) && o . push ( i ) ; return o . length ? Bo . quantile ( o . sort ( n ) , . 5 ) : void 0 } ; var aa = r ( n ) ; Bo . bisectLeft = aa . left , Bo . bisect = Bo . bisectRight = aa .
var t = x . length ; if ( t ) { x . sort ( c ) ; for ( var e , r = 1 , u = x [ 0 ] , i = [ u ] ; t > r ; ++ r ) e = x [ r ] , l ( e [ 0 ] , u ) || l ( e [ 1 ] , u ) ? ( a ( u [ 0 ] , e [ 1 ] ) > a ( u [ 0 ] , u [ 1 ] ) && ( u [ 1 ] = e [ 1 ] ) , a ( e [ 0 ] , u [ 1 ] ) > a ( u [ 0 ] , u [ 1 ] ) && ( u [ 0 ] = e [ 0 ] ) ) : i . push ( u = e ) ; for ( var o , e , p = - 1 / 0 , t = i . length - 1 , r = 0 , u = i [ t ] ; t >= r ; u = e , ++ r ) e = i [ r ] , ( o = a ( u [ 1 ] , e [ 0 ] ) ) > p && ( p = o , s = e [ 0 ] , h = u [ 1 ] ) } return x = M = null , 1 / 0 === s || 1 / 0 === f ? [ [ 0 / 0 , 0 / 0 ] , [ 0 / 0 , 0 / 0 ] ] : [ [ s , f ] , [ h , g ] ] } } ( ) , Bo . geo . centroid = function ( n ) { dc = mc = yc = xc = Mc = _c = bc = wc = Sc = kc = Ec = 0 , Bo . geo . stream ( n , Ac ) ; var t = Sc , e = kc , r = Ec , u = t * t + e * e + r * r ; return za > u && ( t = _c , e = bc , r = wc , Na > mc && ( t = yc , e = xc , r = Mc ) , u = t * t + e * e + r * r , za > u ) ? [ 0 / 0 , 0 / 0 ] : [ Math . atan2 ( e , t ) * Ta , nt ( r / Math . sqrt ( u ) ) * Ta ] } ; var dc , mc , yc , xc , Mc , _c , bc , wc , Sc , kc , Ec , Ac = { sphere : y , point : be , lineStart : Se , lineEnd : ke , polygonStart : function ( ) { Ac . lineStart = Ee } , polygonEnd : function ( ) { Ac . lineStart = Se } } , Cc = Le ( Ae , De , Ue , [ - Ea , - Ea / 2 ] ) , Nc = 1e9 ; Bo . geo . clipExtent = function ( ) { var n , t , e , r , u , i , o = { stream : function ( n ) { return u && ( u . valid = ! 1 ) , u = i ( n ) , u . valid = ! 0 , u } , extent : function ( a ) { return arguments . length ? ( i = Oe ( n = + a [ 0 ] [ 0 ] , t = + a [ 0 ] [ 1 ] , e = + a [ 1 ] [ 0 ] , r = + a [ 1 ] [ 1 ] ) , u && ( u . valid = ! 1 , u = null ) , o ) : [ [ n , t ] , [ e , r ] ] } } ; return o . extent ( [ [ 0 , 0 ] , [ 960 , 500 ] ] ) } , ( Bo . geo . conicEqualArea = function ( ) { return Ie ( Ze ) } ) . raw = Ze , Bo . geo . albers = function ( ) { return Bo . geo . conicEqualArea ( ) . rotate ( [ 96 , 0 ] ) . center ( [ - . 6 , 38.7 ] ) . parallels ( [ 29.5 , 45.5 ] ) . scale ( 1070 ) } , Bo . geo . albersUsa = function ( ) { function n ( n ) { var i = n [ 0 ] , o = n [ 1 ] ; return t = null , e ( i , o ) , t || ( r ( i , o ) , t ) || u ( i , o ) , t } var t , e , r , u , i = Bo . geo . albers ( ) , o = Bo . geo . conicEqualArea ( ) . rotate ( [ 154 , 0 ] ) . center ( [ - 2 , 58.5 ] ) . parallels ( [ 55 , 65 ] ) , a = Bo . geo . conicEqualArea ( ) . rotate ( [ 157 , 0 ] ) . center ( [ - 3 , 19.9 ] ) . parallels ( [ 8 , 18 ] ) , c = { point : function ( n , e ) { t = [ n , e ] } } ; return n . invert = function ( n ) { var t = i . scale ( ) , e = i . translate ( ) , r = ( n [ 0 ] - e [ 0 ] ) / t , u = ( n [ 1 ] - e [ 1 ] ) / t ; return ( u >= . 12 && . 234 > u && r >= - . 425 && - . 214 > r ? o : u >= . 166 && . 234 > u && r >= - . 214 && - . 115 > r ? a : i ) . invert ( n ) } , n . stream = function ( n ) { var t = i . stream ( n ) , e = o . stream ( n ) , r = a . stream ( n ) ; return { point : function ( n , u ) { t . point ( n , u ) , e . point ( n , u ) , r . point ( n , u ) } , sphere : function ( ) { t . sphere ( ) , e . sphere ( ) , r . sphere ( ) } , lineStart : function ( ) { t . lineStart ( ) , e . lineStart ( ) , r . lineStart ( ) } , lineEnd : function ( ) { t . lineEnd ( ) , e . lineEnd ( ) , r . lineEnd ( ) } , polygonStart : function ( ) { t . polygonStart ( ) , e . polygonStart ( ) , r . polygonStart ( ) } , polygonEnd : function ( ) { t . polygonEnd ( ) , e . polygonEnd ( ) , r . polygonEnd ( ) } } } , n . precision = function ( t ) { return arguments . length ? ( i . precision ( t ) , o . precision ( t ) , a . precision ( t ) , n ) : i . precision ( ) } , n . scale = function ( t ) { return arguments . length ? ( i . scale ( t ) , o . scale ( . 35 * t ) , a . scale ( t ) , n . translate ( i . translate ( ) ) ) : i . scale ( ) } , n . translate = function ( t ) { if ( ! arguments . length ) return i . translate ( ) ; var l = i . scale ( ) , s = + t [ 0 ] , f = + t [ 1 ] ; return e = i . translate ( t ) . clipExtent ( [ [ s - . 455 * l , f - . 238 * l ] , [ s + . 455 * l , f + . 238 * l ] ] ) . stream ( c ) . point , r = o . translate ( [ s - . 307 * l , f + . 201 * l ] ) . clipExtent ( [ [ s - . 425 * l + Na , f + . 12 * l + Na ] , [ s - . 214 * l - Na , f + . 234 * l - Na ] ] ) . stream ( c ) . point , u = a . translate ( [ s - . 205 * l , f + . 212 * l ] ) . clipExtent ( [ [ s - . 214 * l + Na , f + . 166 * l + Na ] , [ s - . 115 * l - Na , f + . 234 * l - Na ] ] ) . stream ( c ) . point , n } , n . scale ( 1070 ) } ; var zc , Lc , Tc , qc , Rc , Dc , Pc = { point : y , lineStart : y , lineEnd : y , polygonStart : function ( ) { Lc = 0 , Pc . lineStart = Ve } , polygonEnd : function ( ) { Pc . lineStart = Pc . lineEnd = Pc . point = y , zc += ca ( Lc / 2 ) } } , Uc = { point : Xe , lineStart : y , lineEnd : y , polygonStart : y , polygonEnd : y } , jc = { point : We , lineStart : Je , lineEnd : Ge , polygonStart : function ( ) { jc . lineStart = Ke } , polygonEnd : function ( ) { jc . point = We , jc . lineStart = Je , jc . lineEnd = Ge } } ; Bo . geo . path = function ( ) { function n ( n ) { return n && ( "function" == typeof a && i . pointRadius ( + a . apply ( this , arguments ) ) , o && o . valid || ( o = u ( i ) ) , Bo . geo . stream ( n , o ) ) , i . result ( ) } function t ( ) { return o = null , n } var e , r , u , i , o , a = 4.5 ; return n . area = function ( n ) { return zc = 0 , Bo . geo . stream ( n , u ( Pc ) ) , zc } , n . centroid = function ( n ) { return yc = xc = Mc = _c = bc = wc = Sc = kc = Ec = 0 , Bo . geo . stream ( n , u ( jc ) ) , Ec ? [ Sc / Ec , kc / Ec ] : wc ? [ _c / wc , bc / wc ] : Mc ? [ yc / Mc , xc / Mc ] : [ 0 / 0 , 0 / 0 ] } , n . bounds = function ( n ) { return Rc = Dc = - ( Tc = qc = 1 / 0 ) , Bo . geo . stream ( n , u ( Uc ) ) , [ [ Tc , qc ] , [ Rc , Dc ] ] } , n . projection = function ( n ) { return arguments . length ? ( u = ( e = n ) ? n . stream || tr ( n ) : Et , t ( ) ) : e } , n . context = function ( n ) { return arguments . length ? ( i = null == ( r = n ) ? new $e : new Qe ( n ) , "function" != typeof a && i . pointRadius ( a ) , t ( ) ) : r } , n . pointRadius = function ( t ) { return arguments . length ? ( a = "function" == typeof t ? t : ( i . pointR
} , Bo . scale . quantize = function ( ) { return no ( 0 , 1 , [ 0 , 1 ] ) } , Bo . scale . threshold = function ( ) { return to ( [ . 5 ] , [ 0 , 1 ] ) } , Bo . scale . identity = function ( ) { return eo ( [ 0 , 1 ] ) } , Bo . svg = { } , Bo . svg . arc = function ( ) { function n ( ) { var n = t . apply ( this , arguments ) , i = e . apply ( this , arguments ) , o = r . apply ( this , arguments ) + _l , a = u . apply ( this , arguments ) + _l , c = ( o > a && ( c = o , o = a , a = c ) , a - o ) , l = Ea > c ? "0" : "1" , s = Math . cos ( o ) , f = Math . sin ( o ) , h = Math . cos ( a ) , g = Math . sin ( a ) ; return c >= bl ? n ? "M0," + i + "A" + i + "," + i + " 0 1,1 0," + - i + "A" + i + "," + i + " 0 1,1 0," + i + "M0," + n + "A" + n + "," + n + " 0 1,0 0," + - n + "A" + n + "," + n + " 0 1,0 0," + n + "Z" : "M0," + i + "A" + i + "," + i + " 0 1,1 0," + - i + "A" + i + "," + i + " 0 1,1 0," + i + "Z" : n ? "M" + i * s + "," + i * f + "A" + i + "," + i + " 0 " + l + ",1 " + i * h + "," + i * g + "L" + n * h + "," + n * g + "A" + n + "," + n + " 0 " + l + ",0 " + n * s + "," + n * f + "Z" : "M" + i * s + "," + i * f + "A" + i + "," + i + " 0 " + l + ",1 " + i * h + "," + i * g + "L0,0" + "Z" } var t = ro , e = uo , r = io , u = oo ; return n . innerRadius = function ( e ) { return arguments . length ? ( t = kt ( e ) , n ) : t } , n . outerRadius = function ( t ) { return arguments . length ? ( e = kt ( t ) , n ) : e } , n . startAngle = function ( t ) { return arguments . length ? ( r = kt ( t ) , n ) : r } , n . endAngle = function ( t ) { return arguments . length ? ( u = kt ( t ) , n ) : u } , n . centroid = function ( ) { var n = ( t . apply ( this , arguments ) + e . apply ( this , arguments ) ) / 2 , i = ( r . apply ( this , arguments ) + u . apply ( this , arguments ) ) / 2 + _l ; return [ Math . cos ( i ) * n , Math . sin ( i ) * n ] } , n } ; var _l = - Ca , bl = Aa - Na ; Bo . svg . line = function ( ) { return ao ( Et ) } ; var wl = Bo . map ( { linear : co , "linear-closed" : lo , step : so , "step-before" : fo , "step-after" : ho , basis : xo , "basis-open" : Mo , "basis-closed" : _o , bundle : bo , cardinal : vo , "cardinal-open" : go , "cardinal-closed" : po , monotone : Co } ) ; wl . forEach ( function ( n , t ) { t . key = n , t . closed = /-closed$/ . test ( n ) } ) ; var Sl = [ 0 , 2 / 3 , 1 / 3 , 0 ] , kl = [ 0 , 1 / 3 , 2 / 3 , 0 ] , El = [ 0 , 1 / 6 , 2 / 3 , 1 / 6 ] ; Bo . svg . line . radial = function ( ) { var n = ao ( No ) ; return n . radius = n . x , delete n . x , n . angle = n . y , delete n . y , n } , fo . reverse = ho , ho . reverse = fo , Bo . svg . area = function ( ) { return zo ( Et ) } , Bo . svg . area . radial = function ( ) { var n = zo ( No ) ; return n . radius = n . x , delete n . x , n . innerRadius = n . x0 , delete n . x0 , n . outerRadius = n . x1 , delete n . x1 , n . angle = n . y , delete n . y , n . startAngle = n . y0 , delete n . y0 , n . endAngle = n . y1 , delete n . y1 , n } , Bo . svg . chord = function ( ) { function n ( n , a ) { var c = t ( this , i , n , a ) , l = t ( this , o , n , a ) ; return "M" + c . p0 + r ( c . r , c . p1 , c . a1 - c . a0 ) + ( e ( c , l ) ? u ( c . r , c . p1 , c . r , c . p0 ) : u ( c . r , c . p1 , l . r , l . p0 ) + r ( l . r , l . p1 , l . a1 - l . a0 ) + u ( l . r , l . p1 , c . r , c . p0 ) ) + "Z" } function t ( n , t , e , r ) { var u = t . call ( n , e , r ) , i = a . call ( n , u , r ) , o = c . call ( n , u , r ) + _l , s = l . call ( n , u , r ) + _l ; return { r : i , a0 : o , a1 : s , p0 : [ i * Math . cos ( o ) , i * Math . sin ( o ) ] , p1 : [ i * Math . cos ( s ) , i * Math . sin ( s ) ] } } function e ( n , t ) { return n . a0 == t . a0 && n . a1 == t . a1 } function r ( n , t , e ) { return "A" + n + "," + n + " 0 " + + ( e > Ea ) + ",1 " + t } function u ( n , t , e , r ) { return "Q 0,0 " + r } var i = mr , o = yr , a = Lo , c = io , l = oo ; return n . radius = function ( t ) { return arguments . length ? ( a = kt ( t ) , n ) : a } , n . source = function ( t ) { return arguments . length ? ( i = kt ( t ) , n ) : i } , n . target = function ( t ) { return arguments . length ? ( o = kt ( t ) , n ) : o } , n . startAngle = function ( t ) { return arguments . length ? ( c = kt ( t ) , n ) : c } , n . endAngle = function ( t ) { return arguments . length ? ( l = kt ( t ) , n ) : l } , n } , Bo . svg . diagonal = function ( ) { function n ( n , u ) { var i = t . call ( this , n , u ) , o = e . call ( this , n , u ) , a = ( i . y + o . y ) / 2 , c = [ i , { x : i . x , y : a } , { x : o . x , y : a } , o ] ; return c = c . map ( r ) , "M" + c [ 0 ] + "C" + c [ 1 ] + " " + c [ 2 ] + " " + c [ 3 ] } var t = mr , e = yr , r = To ; return n . source = function ( e ) { return arguments . length ? ( t = kt ( e ) , n ) : t } , n . target = function ( t ) { return arguments . length ? ( e = kt ( t ) , n ) : e } , n . projection = function ( t ) { return arguments . length ? ( r = t , n ) : r } , n } , Bo . svg . diagonal . radial = function ( ) { var n = Bo . svg . diagonal ( ) , t = To , e = n . projection ; return n . projection = function ( n ) { return arguments . length ? e ( qo ( t = n ) ) : t } , n } , Bo . svg . symbol = function ( ) { function n ( n , r ) { return ( Al . get ( t . call ( this , n , r ) ) || Po ) ( e . call ( this , n , r ) ) } var t = Do , e = Ro ; return n . type = function ( e ) { return arguments . length ? ( t = kt ( e ) , n ) : t } , n . size = function ( t ) { return arguments . length ? ( e = kt ( t ) , n ) : e } , n } ; var Al = Bo . map ( { circle : Po , cross : function ( n ) { var t = Math . sqrt ( n / 5 ) / 2 ; return "M" + - 3 * t + "," + - t + "H" + - t + "V" + - 3 * t + "H" + t + "V" + - t + "H" + 3 * t + "V" + t + "H" + t + "V" + 3 * t + "H" + - t + "V" + t + "H" + - 3 * t + "Z" } , diamond : function ( n ) { var t = Math . sqrt ( n / ( 2 * Ll ) ) , e = t * Ll ; return "M0," + - t + "L" + e + ",0" + " 0," + t + " " + - e + ",0" + "Z" } , square : function ( n ) { var t = Math . sqrt ( n ) / 2 ; return "M" + - t + "," + - t + "L" + t + "," + - t + " " + t + "," + t + " " + - t + "," + t + "Z" } , "triangle-down" : function ( n ) {
! function ( e ) { if ( "object" == typeof exports && "undefined" != typeof module ) module . exports = e ( ) ; else if ( "function" == typeof define && define . amd ) define ( [ ] , e ) ; else { var f ; "undefined" != typeof window ? f = window : "undefined" != typeof global ? f = global : "undefined" != typeof self && ( f = self ) , f . dagreD3 = e ( ) } } ( function ( ) { var define , module , exports ; return function e ( t , n , r ) { function s ( o , u ) { if ( ! n [ o ] ) { if ( ! t [ o ] ) { var a = typeof require == "function" && require ; if ( ! u && a ) return a ( o , ! 0 ) ; if ( i ) return i ( o , ! 0 ) ; var f = new Error ( "Cannot find module '" + o + "'" ) ; throw f . code = "MODULE_NOT_FOUND" , f } var l = n [ o ] = { exports : { } } ; t [ o ] [ 0 ] . call ( l . exports , function ( e ) { var n = t [ o ] [ 1 ] [ e ] ; return s ( n ? n : e ) } , l , l . exports , e , t , n , r ) } return n [ o ] . exports } var i = typeof require == "function" && require ; for ( var o = 0 ; o < r . length ; o ++ ) s ( r [ o ] ) ; return s } ( { 1 : [ function ( require , module , exports ) { / * *
* @ license
* Copyright ( c ) 2012 - 2013 Chris Pettitt
*
* Permission is hereby granted , free of charge , to any person obtaining a copy
* of this software and associated documentation files ( the "Software" ) , to deal
* in the Software without restriction , including without limitation the rights
* to use , copy , modify , merge , publish , distribute , sublicense , and / or sell
* copies of the Software , and to permit persons to whom the Software is
* furnished to do so , subject to the following conditions :
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software .
*
* THE SOFTWARE IS PROVIDED "AS IS" , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
* IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT . IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM , DAMAGES OR OTHER
* LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR OTHERWISE , ARISING FROM ,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE .
* /
module . exports = { graphlib : require ( "./lib/graphlib" ) , dagre : require ( "./lib/dagre" ) , intersect : require ( "./lib/intersect" ) , render : require ( "./lib/render" ) , util : require ( "./lib/util" ) , version : require ( "./lib/version" ) } } , { "./lib/dagre" : 8 , "./lib/graphlib" : 9 , "./lib/intersect" : 10 , "./lib/render" : 23 , "./lib/util" : 25 , "./lib/version" : 26 } ] , 2 : [ function ( require , module , exports ) { var util = require ( "./util" ) ; module . exports = { "default" : normal , normal : normal , vee : vee } ; function normal ( parent , id , edge , type ) { var marker = parent . append ( "marker" ) . attr ( "id" , id ) . attr ( "viewBox" , "0 0 10 10" ) . attr ( "refX" , 9 ) . attr ( "refY" , 5 ) . attr ( "markerUnits" , "strokeWidth" ) . attr ( "markerWidth" , 8 ) . attr ( "markerHeight" , 6 ) . attr ( "orient" , "auto" ) ; var path = marker . append ( "path" ) . attr ( "d" , "M 0 0 L 10 5 L 0 10 z" ) . style ( "stroke-width" , 1 ) . style ( "stroke-dasharray" , "1,0" ) ; util . applyStyle ( path , edge [ type + "Style" ] ) } function vee ( parent , id , edge , type ) { var marker = parent . append ( "marker" ) . attr ( "id" , id ) . attr ( "viewBox" , "0 0 10 10" ) . attr ( "refX" , 9 ) . attr ( "refY" , 5 ) . attr ( "markerUnits" , "strokeWidth" ) . attr ( "markerWidth" , 8 ) . attr ( "markerHeight" , 6 ) . attr ( "orient" , "auto" ) ; var path = marker . append ( "path" ) . attr ( "d" , "M 0 0 L 10 5 L 0 10 L 4 5 z" ) . style ( "stroke-width" , 1 ) . style ( "stroke-dasharray" , "1,0" ) ; util . applyStyle ( path , edge [ type + "Style" ] ) } } , { "./util" : 25 } ] , 3 : [ function ( require , module , exports ) { var util = require ( "./util" ) ; module . exports = createClusters ; function createClusters ( selection , g ) { var clusters = g . nodes ( ) . filter ( function ( v ) { return util . isSubgraph ( g , v ) } ) , svgClusters = selection . selectAll ( "g.cluster" ) . data ( clusters , function ( v ) { return v } ) ; svgClusters . enter ( ) . append ( "g" ) . attr ( "class" , "cluster" ) . style ( "opacity" , 0 ) . append ( "rect" ) ; util . applyTransition ( svgClusters . exit ( ) , g ) . style ( "opacity" , 0 ) . remove ( ) ; util . applyTransition ( svgClusters , g ) . style ( "opacity" , 1 ) ; util . applyTransition ( svgClusters . selectAll ( "rect" ) , g ) . attr ( "width" , function ( v ) { return g . node ( v ) . width } ) . attr ( "height" , function ( v ) { return g . node ( v ) . height } ) . attr ( "x" , function ( v ) { var node = g . node ( v ) ; return node . x - node . width / 2 } ) . attr ( "y" , function ( v ) { var node = g . node ( v ) ; return node . y - node . height / 2 } ) } } , { "./util" : 25 } ] , 4 : [ function ( require , module , exports ) { "use strict" ; var _ = require ( "./lodash" ) , addLabel = require ( "./label/add-label" ) , util = require ( "./util" ) , d3 = require ( "./d3" ) ; module . exports = createEdgeLabels ; function createEdgeLabels ( selection , g ) { var svgEdgeLabels = selection . selectAll ( "g.edgeLabel" ) . data ( g . edges ( ) , function ( e ) { return util . edgeToId ( e ) } ) . classed ( "update" , true ) ; svgEdgeLabels . selectAll ( "*" ) . remove ( ) ; svgEdgeLabels . enter ( ) . append ( "g" ) . classed ( "edgeLabel" , true ) . style ( "opacity" , 0 ) ; svgEdgeLabels . each ( function ( e ) { var edge = g . edge ( e ) , label = addLabel ( d3 . select ( this ) , g . edge ( e ) , 0 , 0 ) . classed ( "label" , true ) , bbox = label . node ( ) . getBBox ( ) ; if ( edge . labelId ) { label . attr ( "id" , edge . labelId ) } if ( ! _ . has ( edge , "width" ) ) { edge . width = bbox . width } if ( ! _ . has ( edge , "height" ) ) { edge . height = bbox . height } } ) ; util . applyTransition ( svgEdgeLabels . exit ( ) , g ) . style ( "opacity" , 0 ) . remove ( ) ; return svgEdgeLabels } } , { "./d3" : 7 , "./label/add-label" : 18 , "./lodash" : 20 , "./util" : 25 } ] , 5 : [ function ( require , module , exports ) { "use strict" ; var _ = require ( "./lodash" ) , intersectNode = require ( "./intersect/intersect-node" ) , util = require ( "./util" ) , d3 = require ( "./d3" ) ; module . exports = createEdgePaths ; function createEdgePaths ( selection , g , arrows ) { var svgPaths = selection . selectAll ( "g.edgePath" ) . data ( g . edges ( ) , function ( e ) { return util . edgeToId ( e ) } ) . classed ( "update" , true ) ; enter ( svgPaths , g ) ; exit ( svgPaths , g ) ; util . applyTransition ( svgPaths , g ) . style ( "opacity" , 1 ) ; svgPaths . selectAll ( "path.path" ) . each ( function ( e ) { var edge = g . edge ( e ) ; edge . arrowheadId = _ . uniqueId ( "arrowhead" ) ; var domEdge = d3 . select ( this ) . attr ( "marker-end" , function ( ) { return "url(#" + edge . arrowheadId + ")" } ) . style ( "fill" , "none" ) ; util . applyTransition ( domEdge , g ) . attr ( "d" , function ( e ) { return calcPoints ( g , e ) } ) ; if ( edge . id ) { domEdge . attr ( "id" , edge . id ) } util . applyStyle ( domEdge , edge . style ) } ) ; svgPaths . selectAll ( "defs *" ) . remove ( ) ; svgPaths . selectAll ( "defs" ) . each ( function ( e ) { var edge = g . edge ( e ) , arrowhead = arrows [ edge . arrowhead ] ; arrowhead ( d3 . select ( this ) , edge . arrowheadId , edge , "arrowhead" ) } ) ; return svgPaths } function calcPoints ( g , e ) { var edge = g . edg
} _ . each ( g . nodes ( ) , function ( v ) { getExtremes ( g . node ( v ) ) } ) ; _ . each ( g . edges ( ) , function ( e ) { var edge = g . edge ( e ) ; if ( _ . has ( edge , "x" ) ) { getExtremes ( edge ) } } ) ; minX -= marginX ; minY -= marginY ; _ . each ( g . nodes ( ) , function ( v ) { var node = g . node ( v ) ; node . x -= minX ; node . y -= minY } ) ; _ . each ( g . edges ( ) , function ( e ) { var edge = g . edge ( e ) ; _ . each ( edge . points , function ( p ) { p . x -= minX ; p . y -= minY } ) ; if ( _ . has ( edge , "x" ) ) { edge . x -= minX } if ( _ . has ( edge , "y" ) ) { edge . y -= minY } } ) ; graphLabel . width = maxX - minX + marginX ; graphLabel . height = maxY - minY + marginY } function assignNodeIntersects ( g ) { _ . each ( g . edges ( ) , function ( e ) { var edge = g . edge ( e ) , nodeV = g . node ( e . v ) , nodeW = g . node ( e . w ) , p1 , p2 ; if ( ! edge . points ) { edge . points = [ ] ; p1 = nodeW ; p2 = nodeV } else { p1 = edge . points [ 0 ] ; p2 = edge . points [ edge . points . length - 1 ] } edge . points . unshift ( util . intersectRect ( nodeV , p1 ) ) ; edge . points . push ( util . intersectRect ( nodeW , p2 ) ) } ) } function fixupEdgeLabelCoords ( g ) { _ . each ( g . edges ( ) , function ( e ) { var edge = g . edge ( e ) ; if ( _ . has ( edge , "x" ) ) { if ( edge . labelpos === "l" || edge . labelpos === "r" ) { edge . width -= edge . labeloffset } switch ( edge . labelpos ) { case "l" : edge . x -= edge . width / 2 + edge . labeloffset ; break ; case "r" : edge . x += edge . width / 2 + edge . labeloffset ; break } } } ) } function reversePointsForReversedEdges ( g ) { _ . each ( g . edges ( ) , function ( e ) { var edge = g . edge ( e ) ; if ( edge . reversed ) { edge . points . reverse ( ) } } ) } function removeBorderNodes ( g ) { _ . each ( g . nodes ( ) , function ( v ) { if ( g . children ( v ) . length ) { var node = g . node ( v ) , t = g . node ( node . borderTop ) , b = g . node ( node . borderBottom ) , l = g . node ( _ . last ( node . borderLeft ) ) , r = g . node ( _ . last ( node . borderRight ) ) ; node . width = Math . abs ( r . x - l . x ) ; node . height = Math . abs ( b . y - t . y ) ; node . x = l . x + node . width / 2 ; node . y = t . y + node . height / 2 } } ) ; _ . each ( g . nodes ( ) , function ( v ) { if ( g . node ( v ) . dummy === "border" ) { g . removeNode ( v ) } } ) } function removeSelfEdges ( g ) { _ . each ( g . edges ( ) , function ( e ) { if ( e . v === e . w ) { var node = g . node ( e . v ) ; if ( ! node . selfEdges ) { node . selfEdges = [ ] } node . selfEdges . push ( { e : e , label : g . edge ( e ) } ) ; g . removeEdge ( e ) } } ) } function insertSelfEdges ( g ) { var layers = util . buildLayerMatrix ( g ) ; _ . each ( layers , function ( layer ) { var orderShift = 0 ; _ . each ( layer , function ( v , i ) { var node = g . node ( v ) ; node . order = i + orderShift ; _ . each ( node . selfEdges , function ( selfEdge ) { util . addDummyNode ( g , "selfedge" , { width : selfEdge . label . width , height : selfEdge . label . height , rank : node . rank , order : i + ++ orderShift , e : selfEdge . e , label : selfEdge . label } , "_se" ) } ) ; delete node . selfEdges } ) } ) } function positionSelfEdges ( g ) { _ . each ( g . nodes ( ) , function ( v ) { var node = g . node ( v ) ; if ( node . dummy === "selfedge" ) { var selfNode = g . node ( node . e . v ) , x = selfNode . x + selfNode . width / 2 , y = selfNode . y , dx = node . x - x , dy = selfNode . height / 2 ; g . setEdge ( node . e , node . label ) ; g . removeNode ( v ) ; node . label . points = [ { x : x + 2 * dx / 3 , y : y - dy } , { x : x + 5 * dx / 6 , y : y - dy } , { x : x + dx , y : y } , { x : x + 5 * dx / 6 , y : y + dy } , { x : x + 2 * dx / 3 , y : y + dy } ] ; node . label . x = node . x ; node . label . y = node . y } } ) } function selectNumberAttrs ( obj , attrs ) { return _ . mapValues ( _ . pick ( obj , attrs ) , Number ) } function canonicalize ( attrs ) { var newAttrs = { } ; _ . each ( attrs , function ( v , k ) { newAttrs [ k . toLowerCase ( ) ] = v } ) ; return newAttrs } } , { "./acyclic" : 28 , "./add-border-segments" : 29 , "./coordinate-system" : 30 , "./graphlib" : 33 , "./lodash" : 36 , "./nesting-graph" : 37 , "./normalize" : 38 , "./order" : 43 , "./parent-dummy-chains" : 48 , "./position" : 50 , "./rank" : 52 , "./util" : 55 } ] , 36 : [ function ( require , module , exports ) { module . exports = require ( 20 ) } , { "/Users/cpettitt/projects/dagre-d3/lib/lodash.js" : 20 , lodash : 77 } ] , 37 : [ function ( require , module , exports ) { var _ = require ( "./lodash" ) , util = require ( "./util" ) ; module . exports = { run : run , cleanup : cleanup } ; function run ( g ) { var root = util . addDummyNode ( g , "root" , { } , "_root" ) , depths = treeDepths ( g ) , height = _ . max ( depths ) - 1 , nodeSep = 2 * height + 1 ; g . graph ( ) . nestingRoot = root ; _ . each ( g . edges ( ) , function ( e ) { g . edge ( e ) . minlen *= nodeSep } ) ; var weight = sumWeights ( g ) + 1 ; _ . each ( g . children ( ) , function ( child ) { dfs ( g , root , nodeSep , weight , height , depths , child ) } ) ; g . graph ( ) . nodeRankFactor = nodeSep } function dfs ( g , root , nodeSep , weight , height , depths , v ) { var children = g . children ( v ) ; if ( ! children . length ) { if ( v !== root ) { g . setEdge ( root , v , { weight : 0 , minlen : nodeSep } ) } return } var top = util . addBorderNode ( g , "_bt" ) , bottom = util . addBorderNode ( g , "_bb" ) , label = g . node ( v ) ; g . setParent ( top , v ) ; label . borderTop = top ; g . setParent ( bottom , v ) ; label . borderBottom = bottom ; _ . each ( children , function ( c
} ) ) ; _ . each ( g . nodes ( ) , function ( v ) { var node = g . node ( v ) ; if ( _ . has ( node , "rank" ) ) { node . rank -= min } } ) } function removeEmptyRanks ( g ) { var offset = _ . min ( _ . map ( g . nodes ( ) , function ( v ) { return g . node ( v ) . rank } ) ) ; var layers = [ ] ; _ . each ( g . nodes ( ) , function ( v ) { var rank = g . node ( v ) . rank - offset ; if ( ! _ . has ( layers , rank ) ) { layers [ rank ] = [ ] } layers [ rank ] . push ( v ) } ) ; var delta = 0 , nodeRankFactor = g . graph ( ) . nodeRankFactor ; _ . each ( layers , function ( vs , i ) { if ( _ . isUndefined ( vs ) && i % nodeRankFactor !== 0 ) { -- delta } else if ( delta ) { _ . each ( vs , function ( v ) { g . node ( v ) . rank += delta } ) } } ) } function addBorderNode ( g , prefix , rank , order ) { var node = { width : 0 , height : 0 } ; if ( arguments . length >= 4 ) { node . rank = rank ; node . order = order } return addDummyNode ( g , "border" , node , prefix ) } function maxRank ( g ) { return _ . max ( _ . map ( g . nodes ( ) , function ( v ) { var rank = g . node ( v ) . rank ; if ( ! _ . isUndefined ( rank ) ) { return rank } } ) ) } function partition ( collection , fn ) { var result = { lhs : [ ] , rhs : [ ] } ; _ . each ( collection , function ( value ) { if ( fn ( value ) ) { result . lhs . push ( value ) } else { result . rhs . push ( value ) } } ) ; return result } function time ( name , fn ) { var start = _ . now ( ) ; try { return fn ( ) } finally { console . log ( name + " time: " + ( _ . now ( ) - start ) + "ms" ) } } function notime ( name , fn ) { return fn ( ) } } , { "./graphlib" : 33 , "./lodash" : 36 } ] , 56 : [ function ( require , module , exports ) { module . exports = "0.6.2" } , { } ] , 57 : [ function ( require , module , exports ) { var lib = require ( "./lib" ) ; module . exports = { Graph : lib . Graph , json : require ( "./lib/json" ) , alg : require ( "./lib/alg" ) , version : lib . version } } , { "./lib" : 73 , "./lib/alg" : 64 , "./lib/json" : 74 } ] , 58 : [ function ( require , module , exports ) { var _ = require ( "../lodash" ) ; module . exports = components ; function components ( g ) { var visited = { } , cmpts = [ ] , cmpt ; function dfs ( v ) { if ( _ . has ( visited , v ) ) return ; visited [ v ] = true ; cmpt . push ( v ) ; _ . each ( g . successors ( v ) , dfs ) ; _ . each ( g . predecessors ( v ) , dfs ) } _ . each ( g . nodes ( ) , function ( v ) { cmpt = [ ] ; dfs ( v ) ; if ( cmpt . length ) { cmpts . push ( cmpt ) } } ) ; return cmpts } } , { "../lodash" : 75 } ] , 59 : [ function ( require , module , exports ) { var _ = require ( "../lodash" ) ; module . exports = dfs ; function dfs ( g , vs , order ) { if ( ! _ . isArray ( vs ) ) { vs = [ vs ] } var acc = [ ] , visited = { } ; _ . each ( vs , function ( v ) { if ( ! g . hasNode ( v ) ) { throw new Error ( "Graph does not have node: " + v ) } doDfs ( g , v , order === "post" , visited , acc ) } ) ; return acc } function doDfs ( g , v , postorder , visited , acc ) { if ( ! _ . has ( visited , v ) ) { visited [ v ] = true ; if ( ! postorder ) { acc . push ( v ) } _ . each ( g . neighbors ( v ) , function ( w ) { doDfs ( g , w , postorder , visited , acc ) } ) ; if ( postorder ) { acc . push ( v ) } } } } , { "../lodash" : 75 } ] , 60 : [ function ( require , module , exports ) { var dijkstra = require ( "./dijkstra" ) , _ = require ( "../lodash" ) ; module . exports = dijkstraAll ; function dijkstraAll ( g , weightFunc , edgeFunc ) { return _ . transform ( g . nodes ( ) , function ( acc , v ) { acc [ v ] = dijkstra ( g , v , weightFunc , edgeFunc ) } , { } ) } } , { "../lodash" : 75 , "./dijkstra" : 61 } ] , 61 : [ function ( require , module , exports ) { var _ = require ( "../lodash" ) , PriorityQueue = require ( "../data/priority-queue" ) ; module . exports = dijkstra ; var DEFAULT _WEIGHT _FUNC = _ . constant ( 1 ) ; function dijkstra ( g , source , weightFn , edgeFn ) { return runDijkstra ( g , String ( source ) , weightFn || DEFAULT _WEIGHT _FUNC , edgeFn || function ( v ) { return g . outEdges ( v ) } ) } function runDijkstra ( g , source , weightFn , edgeFn ) { var results = { } , pq = new PriorityQueue , v , vEntry ; var updateNeighbors = function ( edge ) { var w = edge . v !== v ? edge . v : edge . w , wEntry = results [ w ] , weight = weightFn ( edge ) , distance = vEntry . distance + weight ; if ( weight < 0 ) { throw new Error ( "dijkstra does not allow negative edge weights. " + "Bad edge: " + edge + " Weight: " + weight ) } if ( distance < wEntry . distance ) { wEntry . distance = distance ; wEntry . predecessor = v ; pq . decrease ( w , distance ) } } ; g . nodes ( ) . forEach ( function ( v ) { var distance = v === source ? 0 : Number . POSITIVE _INFINITY ; results [ v ] = { distance : distance } ; pq . add ( v , distance ) } ) ; while ( pq . size ( ) > 0 ) { v = pq . removeMin ( ) ; vEntry = results [ v ] ; if ( vEntry . distance === Number . POSITIVE _INFINITY ) { break } edgeFn ( v ) . forEach ( updateNeighbors ) } return results } } , { "../data/priority-queue" : 71 , "../lodash" : 75 } ] , 62 : [ function ( require , module , exports ) { var _ = require ( "../lodash" ) , tarjan = require ( "./tarjan" ) ; module . exports = findCycles ; function findCycles ( g ) { return _ . filter ( tarjan ( g ) , function ( cmpt ) { return cmpt . length > 1 } ) } } , { "../lodash" : 75 , "./tarjan" : 69 } ] , 63 : [ function ( require , module , exports ) { var _ = require ( "../lodash" ) ; module . exports = f
} var ctorA = a . constructor , ctorB = b . constructor ; if ( ctorA != ctorB && ! ( isFunction ( ctorA ) && ctorA instanceof ctorA && isFunction ( ctorB ) && ctorB instanceof ctorB ) && ( "constructor" in a && "constructor" in b ) ) { return false } } var initedStack = ! stackA ; stackA || ( stackA = getArray ( ) ) ; stackB || ( stackB = getArray ( ) ) ; var length = stackA . length ; while ( length -- ) { if ( stackA [ length ] == a ) { return stackB [ length ] == b } } var size = 0 ; result = true ; stackA . push ( a ) ; stackB . push ( b ) ; if ( isArr ) { length = a . length ; size = b . length ; result = size == length ; if ( result || isWhere ) { while ( size -- ) { var index = length , value = b [ size ] ; if ( isWhere ) { while ( index -- ) { if ( result = baseIsEqual ( a [ index ] , value , callback , isWhere , stackA , stackB ) ) { break } } } else if ( ! ( result = baseIsEqual ( a [ size ] , value , callback , isWhere , stackA , stackB ) ) ) { break } } } } else { forIn ( b , function ( value , key , b ) { if ( hasOwnProperty . call ( b , key ) ) { size ++ ; return result = hasOwnProperty . call ( a , key ) && baseIsEqual ( a [ key ] , value , callback , isWhere , stackA , stackB ) } } ) ; if ( result && ! isWhere ) { forIn ( a , function ( value , key , a ) { if ( hasOwnProperty . call ( a , key ) ) { return result = -- size > - 1 } } ) } } stackA . pop ( ) ; stackB . pop ( ) ; if ( initedStack ) { releaseArray ( stackA ) ; releaseArray ( stackB ) } return result } function baseMerge ( object , source , callback , stackA , stackB ) { ( isArray ( source ) ? forEach : forOwn ) ( source , function ( source , key ) { var found , isArr , result = source , value = object [ key ] ; if ( source && ( ( isArr = isArray ( source ) ) || isPlainObject ( source ) ) ) { var stackLength = stackA . length ; while ( stackLength -- ) { if ( found = stackA [ stackLength ] == source ) { value = stackB [ stackLength ] ; break } } if ( ! found ) { var isShallow ; if ( callback ) { result = callback ( value , source ) ; if ( isShallow = typeof result != "undefined" ) { value = result } } if ( ! isShallow ) { value = isArr ? isArray ( value ) ? value : [ ] : isPlainObject ( value ) ? value : { } } stackA . push ( source ) ; stackB . push ( value ) ; if ( ! isShallow ) { baseMerge ( value , source , callback , stackA , stackB ) } } } else { if ( callback ) { result = callback ( value , source ) ; if ( typeof result == "undefined" ) { result = source } } if ( typeof result != "undefined" ) { value = result } } object [ key ] = value } ) } function baseRandom ( min , max ) { return min + floor ( nativeRandom ( ) * ( max - min + 1 ) ) } function baseUniq ( array , isSorted , callback ) { var index = - 1 , indexOf = getIndexOf ( ) , length = array ? array . length : 0 , result = [ ] ; var isLarge = ! isSorted && length >= largeArraySize && indexOf === baseIndexOf , seen = callback || isLarge ? getArray ( ) : result ; if ( isLarge ) { var cache = createCache ( seen ) ; indexOf = cacheIndexOf ; seen = cache } while ( ++ index < length ) { var value = array [ index ] , computed = callback ? callback ( value , index , array ) : value ; if ( isSorted ? ! index || seen [ seen . length - 1 ] !== computed : indexOf ( seen , computed ) < 0 ) { if ( callback || isLarge ) { seen . push ( computed ) } result . push ( value ) } } if ( isLarge ) { releaseArray ( seen . array ) ; releaseObject ( seen ) } else if ( callback ) { releaseArray ( seen ) } return result } function createAggregator ( setter ) { return function ( collection , callback , thisArg ) { var result = { } ; callback = lodash . createCallback ( callback , thisArg , 3 ) ; var index = - 1 , length = collection ? collection . length : 0 ; if ( typeof length == "number" ) { while ( ++ index < length ) { var value = collection [ index ] ; setter ( result , value , callback ( value , index , collection ) , collection ) } } else { forOwn ( collection , function ( value , key , collection ) { setter ( result , value , callback ( value , key , collection ) , collection ) } ) } return result } } function createWrapper ( func , bitmask , partialArgs , partialRightArgs , thisArg , arity ) { var isBind = bitmask & 1 , isBindKey = bitmask & 2 , isCurry = bitmask & 4 , isCurryBound = bitmask & 8 , isPartial = bitmask & 16 , isPartialRight = bitmask & 32 ; if ( ! isBindKey && ! isFunction ( func ) ) { throw new TypeError } if ( isPartial && ! partialArgs . length ) { bitmask &= ~ 16 ; isPartial = partialArgs = false } if ( isPartialRight && ! partialRightArgs . length ) { bitmask &= ~ 32 ; isPartialRight = partialRightArgs = false } var bindData = func && func . _ _bindData _ _ ; if ( bindData && bindData !== true ) { bindData = slice ( bindData ) ; if ( bindData [ 2 ] ) { bindData [ 2 ] = slice ( bindData [ 2 ] ) } if ( bindData [ 3 ] ) { bindData [ 3 ] = slice ( bindData [ 3 ] ) } if ( isBind && ! ( bindData [ 1 ] & 1 ) ) { bindData [ 4 ] = thisArg } if ( ! isBind && bindData [ 1 ] & 1 ) { bitmask |= 8 } if ( isCurry && ! ( bindData [ 1 ] & 4 ) ) { bindData [ 5 ] = arity } if ( isPartial ) { push . apply ( bindData [ 2 ] || ( bindData [ 2 ] = [ ] ) , partialArgs ) } if ( isPartialRight ) { unshift . apply ( bindData [ 3 ] || ( bindData [ 3 ] = [ ] ) , partialRightArgs ) } bindData [ 1 ] |= bitmask ; return createWrapper . apply ( null , bindData
} ; memoized . cache = { } ; return memoized } function once ( func ) { var ran , result ; if ( ! isFunction ( func ) ) { throw new TypeError } return function ( ) { if ( ran ) { return result } ran = true ; result = func . apply ( this , arguments ) ; func = null ; return result } } function partial ( func ) { return createWrapper ( func , 16 , slice ( arguments , 1 ) ) } function partialRight ( func ) { return createWrapper ( func , 32 , null , slice ( arguments , 1 ) ) } function throttle ( func , wait , options ) { var leading = true , trailing = true ; if ( ! isFunction ( func ) ) { throw new TypeError } if ( options === false ) { leading = false } else if ( isObject ( options ) ) { leading = "leading" in options ? options . leading : leading ; trailing = "trailing" in options ? options . trailing : trailing } debounceOptions . leading = leading ; debounceOptions . maxWait = wait ; debounceOptions . trailing = trailing ; return debounce ( func , wait , debounceOptions ) } function wrap ( value , wrapper ) { return createWrapper ( wrapper , 16 , [ value ] ) } function constant ( value ) { return function ( ) { return value } } function createCallback ( func , thisArg , argCount ) { var type = typeof func ; if ( func == null || type == "function" ) { return baseCreateCallback ( func , thisArg , argCount ) } if ( type != "object" ) { return property ( func ) } var props = keys ( func ) , key = props [ 0 ] , a = func [ key ] ; if ( props . length == 1 && a === a && ! isObject ( a ) ) { return function ( object ) { var b = object [ key ] ; return a === b && ( a !== 0 || 1 / a == 1 / b ) } } return function ( object ) { var length = props . length , result = false ; while ( length -- ) { if ( ! ( result = baseIsEqual ( object [ props [ length ] ] , func [ props [ length ] ] , null , true ) ) ) { break } } return result } } function escape ( string ) { return string == null ? "" : String ( string ) . replace ( reUnescapedHtml , escapeHtmlChar ) } function identity ( value ) { return value } function mixin ( object , source , options ) { var chain = true , methodNames = source && functions ( source ) ; if ( ! source || ! options && ! methodNames . length ) { if ( options == null ) { options = source } ctor = lodashWrapper ; source = object ; object = lodash ; methodNames = functions ( source ) } if ( options === false ) { chain = false } else if ( isObject ( options ) && "chain" in options ) { chain = options . chain } var ctor = object , isFunc = isFunction ( ctor ) ; forEach ( methodNames , function ( methodName ) { var func = object [ methodName ] = source [ methodName ] ; if ( isFunc ) { ctor . prototype [ methodName ] = function ( ) { var chainAll = this . _ _chain _ _ , value = this . _ _wrapped _ _ , args = [ value ] ; push . apply ( args , arguments ) ; var result = func . apply ( object , args ) ; if ( chain || chainAll ) { if ( value === result && isObject ( result ) ) { return this } result = new ctor ( result ) ; result . _ _chain _ _ = chainAll } return result } } } ) } function noConflict ( ) { context . _ = oldDash ; return this } function noop ( ) { } var now = isNative ( now = Date . now ) && now || function ( ) { return ( new Date ) . getTime ( ) } ; var parseInt = nativeParseInt ( whitespace + "08" ) == 8 ? nativeParseInt : function ( value , radix ) { return nativeParseInt ( isString ( value ) ? value . replace ( reLeadingSpacesAndZeros , "" ) : value , radix || 0 ) } ; function property ( key ) { return function ( object ) { return object [ key ] } } function random ( min , max , floating ) { var noMin = min == null , noMax = max == null ; if ( floating == null ) { if ( typeof min == "boolean" && noMax ) { floating = min ; min = 1 } else if ( ! noMax && typeof max == "boolean" ) { floating = max ; noMax = true } } if ( noMin && noMax ) { max = 1 } min = + min || 0 ; if ( noMax ) { max = min ; min = 0 } else { max = + max || 0 } if ( floating || min % 1 || max % 1 ) { var rand = nativeRandom ( ) ; return nativeMin ( min + rand * ( max - min + parseFloat ( "1e-" + ( ( rand + "" ) . length - 1 ) ) ) , max ) } return baseRandom ( min , max ) } function result ( object , key ) { if ( object ) { var value = object [ key ] ; return isFunction ( value ) ? object [ key ] ( ) : value } } function template ( text , data , options ) { var settings = lodash . templateSettings ; text = String ( text || "" ) ; options = defaults ( { } , options , settings ) ; var imports = defaults ( { } , options . imports , settings . imports ) , importsKeys = keys ( imports ) , importsValues = values ( imports ) ; var isEvaluating , index = 0 , interpolate = options . interpolate || reNoMatch , source = "__p += '" ; var reDelimiters = RegExp ( ( options . escape || reNoMatch ) . source + "|" + interpolate . source + "|" + ( interpolate === reInterpolate ? reEsTemplate : reNoMatch ) . source + "|" + ( options . evaluate || reNoMatch ) . source + "|$" , "g" ) ; text . replace ( reDelimiters , function ( match , escapeValue , interpolateValue , esTemplateValue , evaluateValue , offset ) { interpolateValue || ( interpolateValue = esTemplateValue ) ; source += text . slice ( index , offset ) . replace ( reUnescapedString , escapeStringChar ) ; if ( escapeValue
2014-11-17 07:55:02 +01:00
var parser = function ( ) { function t ( ) { this . yy = { } } var e = function ( t , e , r , n ) { for ( r = r || { } , n = t . length ; n -- ; r [ t [ n ] ] = e ) ; return r } , r = [ 1 , 7 ] , n = [ 2 , 10 ] , i = [ 1 , 15 ] , s = [ 1 , 16 ] , a = [ 1 , 11 ] , o = [ 6 , 9 ] , h = [ 11 , 27 , 28 , 29 , 37 ] , l = [ 2 , 7 ] , c = [ 11 , 32 , 33 , 34 , 35 ] , u = [ 9 , 11 , 18 , 20 , 21 , 22 , 23 , 24 , 32 , 33 , 34 , 35 , 36 ] , y = [ 9 , 11 , 18 , 20 , 21 , 22 , 23 , 24 , 28 , 29 , 32 , 33 , 34 , 35 , 36 ] , d = [ 9 , 11 , 18 , 20 , 21 , 22 , 23 , 24 , 27 , 28 , 29 , 32 , 33 , 34 , 35 , 36 ] , p = [ 28 , 29 ] , f = [ 28 , 29 , 36 ] , m = [ 20 , 22 , 24 , 36 ] , g = [ 1 , 67 ] , _ = [ 1 , 64 ] , k = [ 1 , 62 ] , x = [ 1 , 65 ] , b = [ 1 , 68 ] , v = [ 1 , 63 ] , S = [ 1 , 66 ] , E = [ 1 , 72 ] , w = [ 11 , 41 ] , I = [ 9 , 11 , 27 , 28 , 29 , 39 , 41 , 43 , 44 ] , O = { trace : function ( ) { } , yy : { } , symbols _ : { error : 2 , expressions : 3 , graphConfig : 4 , statements : 5 , EOF : 6 , spaceList : 7 , GRAPH : 8 , SPACE : 9 , DIR : 10 , SEMI : 11 , statement : 12 , verticeStatement : 13 , styleStatement : 14 , vertex : 15 , link : 16 , alphaNum : 17 , SQS : 18 , text : 19 , SQE : 20 , PS : 21 , PE : 22 , DIAMOND _START : 23 , DIAMOND _STOP : 24 , alphaNumStatement : 25 , alphaNumToken : 26 , MINUS : 27 , ALPHA : 28 , NUM : 29 , linkStatement : 30 , arrowText : 31 , ARROW _POINT : 32 , ARROW _CIRCLE : 33 , ARROW _CROSS : 34 , ARROW _OPEN : 35 , PIPE : 36 , STYLE : 37 , stylesOpt : 38 , HEX : 39 , style : 40 , COMMA : 41 , styleComponent : 42 , COLON : 43 , UNIT : 44 , $accept : 0 , $end : 1 } , terminals _ : { 2 : "error" , 6 : "EOF" , 8 : "GRAPH" , 9 : "SPACE" , 10 : "DIR" , 11 : "SEMI" , 18 : "SQS" , 20 : "SQE" , 21 : "PS" , 22 : "PE" , 23 : "DIAMOND_START" , 24 : "DIAMOND_STOP" , 27 : "MINUS" , 28 : "ALPHA" , 29 : "NUM" , 32 : "ARROW_POINT" , 33 : "ARROW_CIRCLE" , 34 : "ARROW_CROSS" , 35 : "ARROW_OPEN" , 36 : "PIPE" , 37 : "STYLE" , 39 : "HEX" , 41 : "COMMA" , 43 : "COLON" , 44 : "UNIT" } , productions _ : [ 0 , [ 3 , 3 ] , [ 3 , 4 ] , [ 4 , 4 ] , [ 5 , 3 ] , [ 5 , 1 ] , [ 7 , 2 ] , [ 7 , 1 ] , [ 12 , 2 ] , [ 12 , 2 ] , [ 13 , 0 ] , [ 13 , 3 ] , [ 13 , 1 ] , [ 15 , 4 ] , [ 15 , 4 ] , [ 15 , 4 ] , [ 15 , 1 ] , [ 17 , 1 ] , [ 17 , 2 ] , [ 25 , 1 ] , [ 25 , 3 ] , [ 26 , 1 ] , [ 26 , 1 ] , [ 16 , 2 ] , [ 16 , 1 ] , [ 30 , 1 ] , [ 30 , 1 ] , [ 30 , 1 ] , [ 30 , 1 ] , [ 31 , 3 ] , [ 19 , 3 ] , [ 19 , 5 ] , [ 19 , 1 ] , [ 14 , 5 ] , [ 14 , 5 ] , [ 38 , 1 ] , [ 38 , 3 ] , [ 40 , 1 ] , [ 40 , 2 ] , [ 42 , 1 ] , [ 42 , 1 ] , [ 42 , 1 ] , [ 42 , 1 ] , [ 42 , 1 ] , [ 42 , 1 ] , [ 42 , 1 ] ] , performAction : function ( t , e , r , n , i , s ) { var a = s . length - 1 ; switch ( i ) { case 2 : this . $ = s [ a - 3 ] ; break ; case 3 : console . log ( "In graph config" ) , n . setDirection ( s [ a - 1 ] ) , this . $ = s [ a - 1 ] ; break ; case 11 : console . log ( "In vertexStatement" ) , n . addLink ( s [ a - 2 ] , s [ a ] , s [ a - 1 ] ) , this . $ = "oy" ; break ; case 12 : console . log ( "In vertexStatement ... " ) , this . $ = "yo" ; break ; case 13 : this . $ = s [ a - 3 ] , n . addVertex ( s [ a - 3 ] , s [ a - 1 ] , "square" ) ; break ; case 14 : this . $ = s [ a - 3 ] , n . addVertex ( s [ a - 3 ] , s [ a - 1 ] , "round" ) ; break ; case 15 : this . $ = s [ a - 3 ] , n . addVertex ( s [ a - 3 ] , s [ a - 1 ] , "diamond" ) ; break ; case 16 : console . log ( "In vertex:" + s [ a ] ) , this . $ = s [ a ] , n . addVertex ( s [ a ] ) ; break ; case 17 : case 21 : case 22 : case 37 : this . $ = s [ a ] ; break ; case 18 : this . $ = s [ a - 1 ] + "" + s [ a ] ; break ; case 19 : console . log ( "Found token (statement): " + s [ a ] ) , this . $ = s [ a ] ; break ; case 20 : this . $ = s [ a - 2 ] + "-" + s [ a ] ; break ; case 23 : s [ a - 1 ] . text = s [ a ] , this . $ = s [ a - 1 ] ; break ; case 24 : case 32 : this . $ = s [ a ] ; break ; case 25 : this . $ = { type : "arrow" } ; break ; case 26 : this . $ = { type : "arrow_circle" } ; break ; case 27 : this . $ = { type : "arrow_cross" } ; break ; case 28 : this . $ = { type : "arrow_open" } ; break ; case 29 : console . log ( "Nice link text here: " + s [ a - 1 ] ) , this . $ = s [ a - 1 ] ; break ; case 30 : this . $ = s [ a - 2 ] + " " + s [ a ] ; break ; case 31 : this . $ = s [ a - 4 ] + " - " + s [ a ] ; break ; case 33 : this . $ = s [ a - 4 ] , n . addVertex ( s [ a - 2 ] , void 0 , void 0 , s [ a ] ) ; break ; case 34 : console . log ( "In parser - style: " + s [ a ] ) , this . $ = s [ a - 4 ] , n . updateLink ( s [ a - 2 ] , s [ a ] ) ; break ; case 35 : this . $ = [ s [ a ] ] ; break ; case 36 : s [ a - 2 ] . push ( s [ a ] ) , this . $ = s [ a - 2 ] ; break ; case 38 : this . $ = s [ a - 1 ] + s [ a ] ; break ; case 39 : case 40 : case 41 : case 42 : case 43 : case 44 : case 45 : this . $ = s [ a ] } } , table : [ { 3 : 1 , 4 : 2 , 8 : [ 1 , 3 ] } , { 1 : [ 3 ] } , { 5 : 4 , 7 : 5 , 9 : r , 11 : n , 12 : 6 , 13 : 8 , 14 : 9 , 15 : 10 , 17 : 12 , 25 : 13 , 26 : 14 , 28 : i , 29 : s , 37 : a } , { 9 : [ 1 , 17 ] } , { 6 : [ 1 , 18 ] , 7 : 19 , 9 : r } , { 5 : 20 , 11 : n , 12 : 6 , 13 : 8 , 14 : 9 , 15 : 10 , 17 : 12 , 25 : 13 , 26 : 14 , 28 : i , 29 : s , 37 : a } , e ( o , [ 2 , 5 ] ) , e ( h , l , { 7 : 21 , 9 : r } ) , { 11 : [ 1 , 22 ] } , { 11 : [ 1 , 23 ] } , { 11 : [ 2 , 12 ] , 16 : 24 , 30 : 25 , 32 : [ 1 , 26 ] , 33 : [ 1 , 27 ] , 34 : [ 1 , 28 ] , 35 : [ 1 , 29 ] } , { 9 : [ 1 , 30 ] } , e ( c , [ 2 , 16 ] , { 18 : [ 1 , 31 ] , 21 : [ 1 , 32 ] , 23 : [ 1 , 33 ] } ) , e ( u , [ 2 , 17 ] , { 25 : 13 , 26 : 14 , 17 : 34 , 28 : i , 29 : s } ) , e ( y , [ 2 , 19 ] , { 27 : [ 1 , 35 ] } ) , e ( d , [ 2 , 21 ] ) , e ( d , [ 2 , 22 ] ) , { 10 : [ 1 , 36 ] } , { 1 : [ 2 , 1 ] } , { 11 : n , 12 : 37 , 13 : 8 , 14 : 9 , 15 : 10 , 17 : 12 , 25 : 13 , 26 : 14 , 28 : i , 29 : s , 37 : a } , { 6 : [ 1 , 38 ] , 7 : 19 , 9 : r } , e ( h , [ 2 , 6 ] ) , e ( o , [ 2 , 8 ] ) , e ( o , [ 2 , 9 ] ) , { 15 : 39 , 17 : 12 , 25 : 13 , 26 : 14 , 28 : i , 29 : s } , e ( p , [ 2 , 24 ] , { 31 : 40 , 36 : [ 1 , 41 ] } ) , e ( f , [ 2 , 25 ] ) , e ( f , [ 2 , 26 ] ) , e ( f , [ 2 , 27 ] ) , e ( f , [ 2 , 28 ] ) , { 17 : 42 , 25 : 13 , 26 : 14 , 28 : i , 29 : s , 39 : [ 1 , 43 ] } , { 17 : 45 , 19 : 44 , 25 : 13 , 26 : 14 , 28 : i , 29 : s } , { 17 : 45 , 19 : 46 , 25 : 13 , 26 : 14 , 28 : i , 29 : s } , { 17 : 45 , 19 : 47 , 25 : 13 , 26 : 14 , 28 : i , 29 : s } , e ( u , [ 2 , 18 ] ) , { 26 : 48 , 28 : i , 29 : s } , { 11 : [ 1