{
  "version": 3,
  "sources": ["../../../src/diagrams/venn/parser/venn.jison", "../../../src/diagrams/venn/vennDB.ts", "../../../src/diagrams/venn/styles.ts", "../../../../../node_modules/.pnpm/@upsetjs+venn.js@2.0.0/node_modules/@upsetjs/venn.js/build/venn.esm.js", "../../../src/diagrams/venn/vennRenderer.ts", "../../../src/diagrams/venn/vennDiagram.ts"],
  "sourcesContent": ["/* parser generated by jison 0.4.18 */\n/*\n  Returns a Parser object of the following structure:\n\n  Parser: {\n    yy: {}\n  }\n\n  Parser.prototype: {\n    yy: {},\n    trace: function(),\n    symbols_: {associative list: name ==> number},\n    terminals_: {associative list: number ==> name},\n    productions_: [...],\n    performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$),\n    table: [...],\n    defaultActions: {...},\n    parseError: function(str, hash),\n    parse: function(input),\n\n    lexer: {\n        EOF: 1,\n        parseError: function(str, hash),\n        setInput: function(input),\n        input: function(),\n        unput: function(str),\n        more: function(),\n        less: function(n),\n        pastInput: function(),\n        upcomingInput: function(),\n        showPosition: function(),\n        test_match: function(regex_match_array, rule_index),\n        next: function(),\n        lex: function(),\n        begin: function(condition),\n        popState: function(),\n        _currentRules: function(),\n        topState: function(),\n        pushState: function(condition),\n\n        options: {\n            ranges: boolean           (optional: true ==> token location info will include a .range[] member)\n            flex: boolean             (optional: true ==> flex-like lexing behaviour where the rules are tested exhaustively to find the longest match)\n            backtrack_lexer: boolean  (optional: true ==> lexer regexes are tested in order and for each matching regex the action code is invoked; the lexer terminates the scan when a token is returned by the action code)\n        },\n\n        performAction: function(yy, yy_, $avoiding_name_collisions, YY_START),\n        rules: [...],\n        conditions: {associative list: name ==> set},\n    }\n  }\n\n\n  token location info (@$, _$, etc.): {\n    first_line: n,\n    last_line: n,\n    first_column: n,\n    last_column: n,\n    range: [start_number, end_number]       (where the numbers are indexes into the input string, regular zero-based)\n  }\n\n\n  the parseError function receives a 'hash' object with these members for lexer and parser errors: {\n    text:        (matched text)\n    token:       (the produced terminal token, if any)\n    line:        (yylineno)\n  }\n  while parser (grammar) errors will also provide these members, i.e. parser errors deliver a superset of attributes: {\n    loc:         (yylloc)\n    expected:    (string describing the set of expected tokens)\n    recoverable: (boolean: TRUE when the parser has a error recovery rule available for this particular error)\n  }\n*/\nvar parser = (function(){\nvar o=function(k,v,o,l){for(o=o||{},l=k.length;l--;o[k[l]]=v);return o},$V0=[5,8],$V1=[7,8,11,12,17,19,22,24],$V2=[1,17],$V3=[1,18],$V4=[7,8,11,12,14,15,16,17,19,20,21,22,24,27],$V5=[1,31],$V6=[1,39],$V7=[7,8,11,12,17,19,22,24,27],$V8=[1,57],$V9=[1,56],$Va=[1,58],$Vb=[1,59],$Vc=[1,60],$Vd=[7,8,11,12,16,17,19,20,22,24,27,31,32,33];\nvar parser = {trace: function trace () { },\nyy: {},\nsymbols_: {\"error\":2,\"start\":3,\"optNewlines\":4,\"VENN\":5,\"document\":6,\"EOF\":7,\"NEWLINE\":8,\"line\":9,\"statement\":10,\"TITLE\":11,\"SET\":12,\"identifier\":13,\"BRACKET_LABEL\":14,\"COLON\":15,\"NUMERIC\":16,\"UNION\":17,\"identifierList\":18,\"TEXT\":19,\"IDENTIFIER\":20,\"STRING\":21,\"INDENT_TEXT\":22,\"indentedTextTail\":23,\"STYLE\":24,\"stylesOpt\":25,\"styleField\":26,\"COMMA\":27,\"styleValue\":28,\"valueTokens\":29,\"valueToken\":30,\"HEXCOLOR\":31,\"RGBCOLOR\":32,\"RGBACOLOR\":33,\"$accept\":0,\"$end\":1},\nterminals_: {2:\"error\",5:\"VENN\",7:\"EOF\",8:\"NEWLINE\",11:\"TITLE\",12:\"SET\",14:\"BRACKET_LABEL\",15:\"COLON\",16:\"NUMERIC\",17:\"UNION\",19:\"TEXT\",20:\"IDENTIFIER\",21:\"STRING\",22:\"INDENT_TEXT\",24:\"STYLE\",27:\"COMMA\",31:\"HEXCOLOR\",32:\"RGBCOLOR\",33:\"RGBACOLOR\"},\nproductions_: [0,[3,4],[4,0],[4,2],[6,0],[6,2],[9,1],[9,1],[10,1],[10,2],[10,3],[10,4],[10,5],[10,2],[10,3],[10,4],[10,5],[10,3],[10,3],[10,3],[10,4],[10,4],[10,2],[10,3],[23,1],[23,1],[23,1],[23,2],[23,2],[25,1],[25,3],[26,3],[28,1],[28,1],[29,1],[29,2],[30,1],[30,1],[30,1],[30,1],[30,1],[18,1],[18,3],[13,1],[13,1]],\nperformAction: function anonymous(yytext, yyleng, yylineno, yy, yystate /* action[1] */, $$ /* vstack */, _$ /* lstack */) {\n/* this == yyval */\n\nvar $0 = $$.length - 1;\nswitch (yystate) {\ncase 1:\n return $$[$0-1]; \nbreak;\ncase 2: case 3: case 4:\n this.$ = [] \nbreak;\ncase 5:\n $$[$0-1].push($$[$0]); this.$ = $$[$0-1] \nbreak;\ncase 6:\n this.$ = []; \nbreak;\ncase 7: case 22: case 32: case 36: case 37: case 38: case 39: case 40:\n this.$ = $$[$0]; \nbreak;\ncase 8:\n yy.setDiagramTitle($$[$0].substr(6)); this.$ = $$[$0].substr(6); \nbreak;\ncase 9:\n yy.addSubsetData([$$[$0]], undefined, undefined); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 10:\n yy.addSubsetData([$$[$0-1]], $$[$0], undefined); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 11:\n yy.addSubsetData([$$[$0-2]], undefined, parseFloat($$[$0])); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 12:\n yy.addSubsetData([$$[$0-3]], $$[$0-2], parseFloat($$[$0])); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 13:\n if ($$[$0].length < 2) { throw new Error('union requires multiple identifiers'); } if (yy.validateUnionIdentifiers) { yy.validateUnionIdentifiers($$[$0]); } yy.addSubsetData($$[$0], undefined, undefined); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 14:\n if ($$[$0-1].length < 2) { throw new Error('union requires multiple identifiers'); } if (yy.validateUnionIdentifiers) { yy.validateUnionIdentifiers($$[$0-1]); } yy.addSubsetData($$[$0-1], $$[$0], undefined); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 15:\n if ($$[$0-2].length < 2) { throw new Error('union requires multiple identifiers'); } if (yy.validateUnionIdentifiers) { yy.validateUnionIdentifiers($$[$0-2]); } yy.addSubsetData($$[$0-2], undefined, parseFloat($$[$0])); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 16:\n if ($$[$0-3].length < 2) { throw new Error('union requires multiple identifiers'); } if (yy.validateUnionIdentifiers) { yy.validateUnionIdentifiers($$[$0-3]); } yy.addSubsetData($$[$0-3], $$[$0-2], parseFloat($$[$0])); if (yy.setIndentMode) { yy.setIndentMode(true); } \nbreak;\ncase 17: case 18: case 19:\n yy.addTextData($$[$0-1], $$[$0], undefined); \nbreak;\ncase 20: case 21:\n yy.addTextData($$[$0-2], $$[$0-1], $$[$0]); \nbreak;\ncase 23:\n yy.addStyleData($$[$0-1], $$[$0]); \nbreak;\ncase 24: case 25: case 26:\n var cs = yy.getCurrentSets(); if (!cs) throw new Error('text requires set'); yy.addTextData(cs, $$[$0], undefined); \nbreak;\ncase 27: case 28:\n var cs = yy.getCurrentSets(); if (!cs) throw new Error('text requires set'); yy.addTextData(cs, $$[$0-1], $$[$0]); \nbreak;\ncase 29: case 41:\n this.$ = [$$[$0]] \nbreak;\ncase 30: case 42:\n this.$ = [...$$[$0-2], $$[$0]] \nbreak;\ncase 31:\n this.$ = [$$[$0-2], $$[$0]] \nbreak;\ncase 33:\n this.$ = $$[$0].join(' '); \nbreak;\ncase 34:\n this.$ = [$$[$0]]; \nbreak;\ncase 35:\n $$[$0-1].push($$[$0]); this.$ = $$[$0-1]; \nbreak;\ncase 43: case 44:\n this.$ = $$[$0] \nbreak;\n}\n},\ntable: [o($V0,[2,2],{3:1,4:2}),{1:[3]},{5:[1,3],8:[1,4]},o($V1,[2,4],{6:5}),o($V0,[2,3]),{7:[1,6],8:[1,8],9:7,10:9,11:[1,10],12:[1,11],17:[1,12],19:[1,13],22:[1,14],24:[1,15]},{1:[2,1]},o($V1,[2,5]),o($V1,[2,6]),o($V1,[2,7]),o($V1,[2,8]),{13:16,20:$V2,21:$V3},{13:20,18:19,20:$V2,21:$V3},{13:20,18:21,20:$V2,21:$V3},{16:[1,25],20:[1,23],21:[1,24],23:22},{13:20,18:26,20:$V2,21:$V3},o($V1,[2,9],{14:[1,27],15:[1,28]}),o($V4,[2,43]),o($V4,[2,44]),o($V1,[2,13],{14:[1,29],15:[1,30],27:$V5}),o($V4,[2,41]),{16:[1,34],20:[1,32],21:[1,33],27:$V5},o($V1,[2,22]),o($V1,[2,24],{14:[1,35]}),o($V1,[2,25],{14:[1,36]}),o($V1,[2,26]),{20:$V6,25:37,26:38,27:$V5},o($V1,[2,10],{15:[1,40]}),{16:[1,41]},o($V1,[2,14],{15:[1,42]}),{16:[1,43]},{13:44,20:$V2,21:$V3},o($V1,[2,17],{14:[1,45]}),o($V1,[2,18],{14:[1,46]}),o($V1,[2,19]),o($V1,[2,27]),o($V1,[2,28]),o($V1,[2,23],{27:[1,47]}),o($V7,[2,29]),{15:[1,48]},{16:[1,49]},o($V1,[2,11]),{16:[1,50]},o($V1,[2,15]),o($V4,[2,42]),o($V1,[2,20]),o($V1,[2,21]),{20:$V6,26:51},{16:$V8,20:$V9,21:[1,53],28:52,29:54,30:55,31:$Va,32:$Vb,33:$Vc},o($V1,[2,12]),o($V1,[2,16]),o($V7,[2,30]),o($V7,[2,31]),o($V7,[2,32]),o($V7,[2,33],{30:61,16:$V8,20:$V9,31:$Va,32:$Vb,33:$Vc}),o($Vd,[2,34]),o($Vd,[2,36]),o($Vd,[2,37]),o($Vd,[2,38]),o($Vd,[2,39]),o($Vd,[2,40]),o($Vd,[2,35])],\ndefaultActions: {6:[2,1]},\nparseError: function parseError (str, hash) {\n    if (hash.recoverable) {\n        this.trace(str);\n    } else {\n        var error = new Error(str);\n        error.hash = hash;\n        throw error;\n    }\n},\nparse: function parse(input) {\n    var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = '', yylineno = 0, yyleng = 0, recovering = 0, TERROR = 2, EOF = 1;\n    var args = lstack.slice.call(arguments, 1);\n    var lexer = Object.create(this.lexer);\n    var sharedState = { yy: {} };\n    for (var k in this.yy) {\n        if (Object.prototype.hasOwnProperty.call(this.yy, k)) {\n            sharedState.yy[k] = this.yy[k];\n        }\n    }\n    lexer.setInput(input, sharedState.yy);\n    sharedState.yy.lexer = lexer;\n    sharedState.yy.parser = this;\n    if (typeof lexer.yylloc == 'undefined') {\n        lexer.yylloc = {};\n    }\n    var yyloc = lexer.yylloc;\n    lstack.push(yyloc);\n    var ranges = lexer.options && lexer.options.ranges;\n    if (typeof sharedState.yy.parseError === 'function') {\n        this.parseError = sharedState.yy.parseError;\n    } else {\n        this.parseError = Object.getPrototypeOf(this).parseError;\n    }\n    function popStack(n) {\n        stack.length = stack.length - 2 * n;\n        vstack.length = vstack.length - n;\n        lstack.length = lstack.length - n;\n    }\n            function lex() {\n            var token;\n            token = tstack.pop() || lexer.lex() || EOF;\n            if (typeof token !== 'number') {\n                if (token instanceof Array) {\n                    tstack = token;\n                    token = tstack.pop();\n                }\n                token = self.symbols_[token] || token;\n            }\n            return token;\n        }\n    var symbol, preErrorSymbol, state, action, a, r, yyval = {}, p, len, newState, expected;\n    while (true) {\n        state = stack[stack.length - 1];\n        if (this.defaultActions[state]) {\n            action = this.defaultActions[state];\n        } else {\n            if (symbol === null || typeof symbol == 'undefined') {\n                symbol = lex();\n            }\n            action = table[state] && table[state][symbol];\n        }\n        if (typeof action === 'undefined' || !action.length || !action[0]) {\n            var errStr = '';\n            expected = [];\n            for (p in table[state]) {\n                if (this.terminals_[p] && p > TERROR) {\n                    expected.push('\\'' + this.terminals_[p] + '\\'');\n                }\n            }\n            if (lexer.showPosition) {\n                errStr = 'Parse error on line ' + (yylineno + 1) + ':\\n' + lexer.showPosition() + '\\nExpecting ' + expected.join(', ') + ', got \\'' + (this.terminals_[symbol] || symbol) + '\\'';\n            } else {\n                errStr = 'Parse error on line ' + (yylineno + 1) + ': Unexpected ' + (symbol == EOF ? 'end of input' : '\\'' + (this.terminals_[symbol] || symbol) + '\\'');\n            }\n            this.parseError(errStr, {\n                text: lexer.match,\n                token: this.terminals_[symbol] || symbol,\n                line: lexer.yylineno,\n                loc: yyloc,\n                expected: expected\n            });\n        }\n        if (action[0] instanceof Array && action.length > 1) {\n            throw new Error('Parse Error: multiple actions possible at state: ' + state + ', token: ' + symbol);\n        }\n        switch (action[0]) {\n        case 1:\n            stack.push(symbol);\n            vstack.push(lexer.yytext);\n            lstack.push(lexer.yylloc);\n            stack.push(action[1]);\n            symbol = null;\n            if (!preErrorSymbol) {\n                yyleng = lexer.yyleng;\n                yytext = lexer.yytext;\n                yylineno = lexer.yylineno;\n                yyloc = lexer.yylloc;\n                if (recovering > 0) {\n                    recovering--;\n                }\n            } else {\n                symbol = preErrorSymbol;\n                preErrorSymbol = null;\n            }\n            break;\n        case 2:\n            len = this.productions_[action[1]][1];\n            yyval.$ = vstack[vstack.length - len];\n            yyval._$ = {\n                first_line: lstack[lstack.length - (len || 1)].first_line,\n                last_line: lstack[lstack.length - 1].last_line,\n                first_column: lstack[lstack.length - (len || 1)].first_column,\n                last_column: lstack[lstack.length - 1].last_column\n            };\n            if (ranges) {\n                yyval._$.range = [\n                    lstack[lstack.length - (len || 1)].range[0],\n                    lstack[lstack.length - 1].range[1]\n                ];\n            }\n            r = this.performAction.apply(yyval, [\n                yytext,\n                yyleng,\n                yylineno,\n                sharedState.yy,\n                action[1],\n                vstack,\n                lstack\n            ].concat(args));\n            if (typeof r !== 'undefined') {\n                return r;\n            }\n            if (len) {\n                stack = stack.slice(0, -1 * len * 2);\n                vstack = vstack.slice(0, -1 * len);\n                lstack = lstack.slice(0, -1 * len);\n            }\n            stack.push(this.productions_[action[1]][0]);\n            vstack.push(yyval.$);\n            lstack.push(yyval._$);\n            newState = table[stack[stack.length - 2]][stack[stack.length - 1]];\n            stack.push(newState);\n            break;\n        case 3:\n            return true;\n        }\n    }\n    return true;\n}};\n\n/* generated by jison-lex 0.3.4 */\nvar lexer = (function(){\nvar lexer = ({\n\nEOF:1,\n\nparseError:function parseError(str, hash) {\n        if (this.yy.parser) {\n            this.yy.parser.parseError(str, hash);\n        } else {\n            throw new Error(str);\n        }\n    },\n\n// resets the lexer, sets new input\nsetInput:function (input, yy) {\n        this.yy = yy || this.yy || {};\n        this._input = input;\n        this._more = this._backtrack = this.done = false;\n        this.yylineno = this.yyleng = 0;\n        this.yytext = this.matched = this.match = '';\n        this.conditionStack = ['INITIAL'];\n        this.yylloc = {\n            first_line: 1,\n            first_column: 0,\n            last_line: 1,\n            last_column: 0\n        };\n        if (this.options.ranges) {\n            this.yylloc.range = [0,0];\n        }\n        this.offset = 0;\n        return this;\n    },\n\n// consumes and returns one char from the input\ninput:function () {\n        var ch = this._input[0];\n        this.yytext += ch;\n        this.yyleng++;\n        this.offset++;\n        this.match += ch;\n        this.matched += ch;\n        var lines = ch.match(/(?:\\r\\n?|\\n).*/g);\n        if (lines) {\n            this.yylineno++;\n            this.yylloc.last_line++;\n        } else {\n            this.yylloc.last_column++;\n        }\n        if (this.options.ranges) {\n            this.yylloc.range[1]++;\n        }\n\n        this._input = this._input.slice(1);\n        return ch;\n    },\n\n// unshifts one char (or a string) into the input\nunput:function (ch) {\n        var len = ch.length;\n        var lines = ch.split(/(?:\\r\\n?|\\n)/g);\n\n        this._input = ch + this._input;\n        this.yytext = this.yytext.substr(0, this.yytext.length - len);\n        //this.yyleng -= len;\n        this.offset -= len;\n        var oldLines = this.match.split(/(?:\\r\\n?|\\n)/g);\n        this.match = this.match.substr(0, this.match.length - 1);\n        this.matched = this.matched.substr(0, this.matched.length - 1);\n\n        if (lines.length - 1) {\n            this.yylineno -= lines.length - 1;\n        }\n        var r = this.yylloc.range;\n\n        this.yylloc = {\n            first_line: this.yylloc.first_line,\n            last_line: this.yylineno + 1,\n            first_column: this.yylloc.first_column,\n            last_column: lines ?\n                (lines.length === oldLines.length ? this.yylloc.first_column : 0)\n                 + oldLines[oldLines.length - lines.length].length - lines[0].length :\n              this.yylloc.first_column - len\n        };\n\n        if (this.options.ranges) {\n            this.yylloc.range = [r[0], r[0] + this.yyleng - len];\n        }\n        this.yyleng = this.yytext.length;\n        return this;\n    },\n\n// When called from action, caches matched text and appends it on next action\nmore:function () {\n        this._more = true;\n        return this;\n    },\n\n// When called from action, signals the lexer that this rule fails to match the input, so the next matching rule (regex) should be tested instead.\nreject:function () {\n        if (this.options.backtrack_lexer) {\n            this._backtrack = true;\n        } else {\n            return this.parseError('Lexical error on line ' + (this.yylineno + 1) + '. You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).\\n' + this.showPosition(), {\n                text: \"\",\n                token: null,\n                line: this.yylineno\n            });\n\n        }\n        return this;\n    },\n\n// retain first n characters of the match\nless:function (n) {\n        this.unput(this.match.slice(n));\n    },\n\n// displays already matched input, i.e. for error messages\npastInput:function () {\n        var past = this.matched.substr(0, this.matched.length - this.match.length);\n        return (past.length > 20 ? '...':'') + past.substr(-20).replace(/\\n/g, \"\");\n    },\n\n// displays upcoming input, i.e. for error messages\nupcomingInput:function () {\n        var next = this.match;\n        if (next.length < 20) {\n            next += this._input.substr(0, 20-next.length);\n        }\n        return (next.substr(0,20) + (next.length > 20 ? '...' : '')).replace(/\\n/g, \"\");\n    },\n\n// displays the character position where the lexing error occurred, i.e. for error messages\nshowPosition:function () {\n        var pre = this.pastInput();\n        var c = new Array(pre.length + 1).join(\"-\");\n        return pre + this.upcomingInput() + \"\\n\" + c + \"^\";\n    },\n\n// test the lexed token: return FALSE when not a match, otherwise return token\ntest_match:function(match, indexed_rule) {\n        var token,\n            lines,\n            backup;\n\n        if (this.options.backtrack_lexer) {\n            // save context\n            backup = {\n                yylineno: this.yylineno,\n                yylloc: {\n                    first_line: this.yylloc.first_line,\n                    last_line: this.last_line,\n                    first_column: this.yylloc.first_column,\n                    last_column: this.yylloc.last_column\n                },\n                yytext: this.yytext,\n                match: this.match,\n                matches: this.matches,\n                matched: this.matched,\n                yyleng: this.yyleng,\n                offset: this.offset,\n                _more: this._more,\n                _input: this._input,\n                yy: this.yy,\n                conditionStack: this.conditionStack.slice(0),\n                done: this.done\n            };\n            if (this.options.ranges) {\n                backup.yylloc.range = this.yylloc.range.slice(0);\n            }\n        }\n\n        lines = match[0].match(/(?:\\r\\n?|\\n).*/g);\n        if (lines) {\n            this.yylineno += lines.length;\n        }\n        this.yylloc = {\n            first_line: this.yylloc.last_line,\n            last_line: this.yylineno + 1,\n            first_column: this.yylloc.last_column,\n            last_column: lines ?\n                         lines[lines.length - 1].length - lines[lines.length - 1].match(/\\r?\\n?/)[0].length :\n                         this.yylloc.last_column + match[0].length\n        };\n        this.yytext += match[0];\n        this.match += match[0];\n        this.matches = match;\n        this.yyleng = this.yytext.length;\n        if (this.options.ranges) {\n            this.yylloc.range = [this.offset, this.offset += this.yyleng];\n        }\n        this._more = false;\n        this._backtrack = false;\n        this._input = this._input.slice(match[0].length);\n        this.matched += match[0];\n        token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]);\n        if (this.done && this._input) {\n            this.done = false;\n        }\n        if (token) {\n            return token;\n        } else if (this._backtrack) {\n            // recover context\n            for (var k in backup) {\n                this[k] = backup[k];\n            }\n            return false; // rule action called reject() implying the next rule should be tested instead.\n        }\n        return false;\n    },\n\n// return next match in input\nnext:function () {\n        if (this.done) {\n            return this.EOF;\n        }\n        if (!this._input) {\n            this.done = true;\n        }\n\n        var token,\n            match,\n            tempMatch,\n            index;\n        if (!this._more) {\n            this.yytext = '';\n            this.match = '';\n        }\n        var rules = this._currentRules();\n        for (var i = 0; i < rules.length; i++) {\n            tempMatch = this._input.match(this.rules[rules[i]]);\n            if (tempMatch && (!match || tempMatch[0].length > match[0].length)) {\n                match = tempMatch;\n                index = i;\n                if (this.options.backtrack_lexer) {\n                    token = this.test_match(tempMatch, rules[i]);\n                    if (token !== false) {\n                        return token;\n                    } else if (this._backtrack) {\n                        match = false;\n                        continue; // rule action called reject() implying a rule MISmatch.\n                    } else {\n                        // else: this is a lexer rule which consumes input without producing a token (e.g. whitespace)\n                        return false;\n                    }\n                } else if (!this.options.flex) {\n                    break;\n                }\n            }\n        }\n        if (match) {\n            token = this.test_match(match, rules[index]);\n            if (token !== false) {\n                return token;\n            }\n            // else: this is a lexer rule which consumes input without producing a token (e.g. whitespace)\n            return false;\n        }\n        if (this._input === \"\") {\n            return this.EOF;\n        } else {\n            return this.parseError('Lexical error on line ' + (this.yylineno + 1) + '. Unrecognized text.\\n' + this.showPosition(), {\n                text: \"\",\n                token: null,\n                line: this.yylineno\n            });\n        }\n    },\n\n// return next match that has a token\nlex:function lex () {\n        var r = this.next();\n        if (r) {\n            return r;\n        } else {\n            return this.lex();\n        }\n    },\n\n// activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)\nbegin:function begin (condition) {\n        this.conditionStack.push(condition);\n    },\n\n// pop the previously active lexer condition state off the condition stack\npopState:function popState () {\n        var n = this.conditionStack.length - 1;\n        if (n > 0) {\n            return this.conditionStack.pop();\n        } else {\n            return this.conditionStack[0];\n        }\n    },\n\n// produce the lexer rule set which is active for the currently active lexer condition state\n_currentRules:function _currentRules () {\n        if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) {\n            return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules;\n        } else {\n            return this.conditions[\"INITIAL\"].rules;\n        }\n    },\n\n// return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available\ntopState:function topState (n) {\n        n = this.conditionStack.length - 1 - Math.abs(n || 0);\n        if (n >= 0) {\n            return this.conditionStack[n];\n        } else {\n            return \"INITIAL\";\n        }\n    },\n\n// alias for begin(condition)\npushState:function pushState (condition) {\n        this.begin(condition);\n    },\n\n// return the number of states currently on the stack\nstateStackSize:function stateStackSize() {\n        return this.conditionStack.length;\n    },\noptions: {\"case-insensitive\":true},\nperformAction: function anonymous(yy,yy_,$avoiding_name_collisions,YY_START) {\nvar YYSTATE=YY_START;\nswitch($avoiding_name_collisions) {\ncase 0:/* skip comments */\nbreak;\ncase 1:/* skip comments */\nbreak;\ncase 2:/* ignore whitespace-only lines */\nbreak;\ncase 3:\n  if (yy.getIndentMode && yy.getIndentMode()) {\n    yy.consumeIndentText = true;\n    this.begin('INITIAL');\n    return 22;\n  }\n\nbreak;\ncase 4:/* ignore leading whitespace */\nbreak;\ncase 5: if (yy.setIndentMode) { yy.setIndentMode(false); } this.begin('INITIAL'); this.unput(yy_.yytext); \nbreak;\ncase 6: this.begin('bol'); return 8; \nbreak;\ncase 7:/* do nothing */\nbreak;\ncase 8:/* skip */\nbreak;\ncase 9:return 7;\nbreak;\ncase 10: return 11; \nbreak;\ncase 11: return 5; \nbreak;\ncase 12: return 12; \nbreak;\ncase 13: return 17; \nbreak;\ncase 14: if (yy.consumeIndentText) { yy.consumeIndentText = false; } else { return 19; } \nbreak;\ncase 15: return 24; \nbreak;\ncase 16: yy_.yytext = yy_.yytext.slice(2, -2); return 14; \nbreak;\ncase 17: yy_.yytext = yy_.yytext.slice(1, -1).trim(); return 14; \nbreak;\ncase 18: return 16; \nbreak;\ncase 19: return 31; \nbreak;\ncase 20: return 33; \nbreak;\ncase 21: return 32; \nbreak;\ncase 22: return 20; \nbreak;\ncase 23: return 21; \nbreak;\ncase 24: return 27; \nbreak;\ncase 25: return 15; \nbreak;\n}\n},\nrules: [/^(?:%%(?!\\{)[^\\n]*)/i,/^(?:[^\\}]%%[^\\n]*)/i,/^(?:[ \\t]+(?=[\\n\\r]))/i,/^(?:[ \\t]+(?=text\\b))/i,/^(?:[ \\t]+)/i,/^(?:[^ \\t\\n\\r])/i,/^(?:[\\n\\r]+)/i,/^(?:%%[^\\n]*)/i,/^(?:[ \\t]+)/i,/^(?:$)/i,/^(?:title\\s[^#\\n;]+)/i,/^(?:venn-beta\\b)/i,/^(?:set\\b)/i,/^(?:union\\b)/i,/^(?:text\\b)/i,/^(?:style\\b)/i,/^(?:\\[\"[^\\\"]*\"\\])/i,/^(?:\\[[^\\]\\\"]+\\])/i,/^(?:[+-]?(\\d+(\\.\\d+)?|\\.\\d+))/i,/^(?:#[0-9a-fA-F]{3,8})/i,/^(?:rgba\\(\\s*[0-9.]+\\s*[,]\\s*[0-9.]+\\s*[,]\\s*[0-9.]+\\s*[,]\\s*[0-9.]+\\s*\\))/i,/^(?:rgb\\(\\s*[0-9.]+\\s*[,]\\s*[0-9.]+\\s*[,]\\s*[0-9.]+\\s*\\))/i,/^(?:[A-Za-z_][A-Za-z0-9\\-_]*)/i,/^(?:\"[^\\\"]*\")/i,/^(?:,)/i,/^(?::)/i],\nconditions: {\"bol\":{\"rules\":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25],\"inclusive\":true},\"INITIAL\":{\"rules\":[0,1,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25],\"inclusive\":true}}\n});\nreturn lexer;\n})();\nparser.lexer = lexer;\nfunction Parser () {\n  this.yy = {};\n}\nParser.prototype = parser;parser.Parser = Parser;\nreturn new Parser;\n})(); \n\tparser.parser = parser;\n\texport { parser };\n\texport default parser;\n\t", "import type { VennDB, VennData, VennTextData, VennStyleData } from './vennTypes.js';\nimport type { VennDiagramConfig } from '../../config.type.js';\nimport { cleanAndMerge } from '../../utils.js';\nimport { getConfig as commonGetConfig } from '../../config.js';\nimport {\n  clear,\n  getAccDescription,\n  getAccTitle,\n  getDiagramTitle,\n  setAccDescription,\n  setAccTitle,\n  setDiagramTitle,\n} from '../common/commonDb.js';\nimport DEFAULT_CONFIG from '../../defaultConfig.js';\n\nconst subsets: VennData[] = [];\nconst textNodes: VennTextData[] = [];\nconst styleEntries: VennStyleData[] = [];\nconst knownSets = new Set<string>();\nlet currentSets: string[] | undefined;\nlet indentMode = false;\n\nexport const addSubsetData: VennDB['addSubsetData'] = (identifierList, label, size) => {\n  const sets = normalizeIdentifierList(identifierList).sort();\n  const resolvedSize = size ?? 10 / Math.pow(identifierList.length, 2);\n  currentSets = sets;\n  if (sets.length === 1) {\n    knownSets.add(sets[0]);\n  }\n\n  subsets.push({\n    sets,\n    size: resolvedSize,\n    label: label ? normalizeText(label) : undefined,\n  });\n};\n\nexport const getSubsetData = () => {\n  return subsets;\n};\n\nconst normalizeText = (text: string) => {\n  const trimmed = text.trim();\n  if (trimmed.length >= 2 && trimmed.startsWith('\"') && trimmed.endsWith('\"')) {\n    return trimmed.slice(1, -1);\n  }\n  return trimmed;\n};\n\nconst normalizeStyleValue = (value: string | undefined): string | undefined => {\n  return value ? normalizeText(value) : value;\n};\n\nexport const addTextData: VennDB['addTextData'] = (identifierList, id, label) => {\n  const normalizedId = normalizeText(id);\n  textNodes.push({\n    sets: normalizeIdentifierList(identifierList).sort(),\n    id: normalizedId,\n    label: label ? normalizeText(label) : undefined,\n  });\n};\n\nexport const addStyleData: VennDB['addStyleData'] = (identifierList, data) => {\n  const targets = normalizeIdentifierList(identifierList).sort();\n  const styles: Record<string, string> = {};\n  for (const [key, value] of data) {\n    styles[key] = normalizeStyleValue(value) ?? value;\n  }\n  styleEntries.push({ targets, styles });\n};\n\nexport const getStyleData = () => {\n  return styleEntries;\n};\n\nconst normalizeIdentifierList = (identifierList: string[]) => {\n  return identifierList.map((identifier) => normalizeText(identifier));\n};\n\nexport const validateUnionIdentifiers: VennDB['validateUnionIdentifiers'] = (identifierList) => {\n  const normalized = normalizeIdentifierList(identifierList);\n  const unknown = normalized.filter((identifier) => !knownSets.has(identifier));\n  if (unknown.length > 0) {\n    throw new Error(`unknown set identifier: ${unknown.join(', ')}`);\n  }\n};\n\nexport const getTextData = () => {\n  return textNodes;\n};\n\nexport const getCurrentSets: VennDB['getCurrentSets'] = () => currentSets;\nexport const getIndentMode: VennDB['getIndentMode'] = () => indentMode;\nexport const setIndentMode: VennDB['setIndentMode'] = (enabled) => {\n  indentMode = enabled;\n};\n\nconst DEFAULT_VENN_CONFIG: Required<VennDiagramConfig> = DEFAULT_CONFIG.venn;\n\nfunction getConfig(): Required<VennDiagramConfig> {\n  return cleanAndMerge(DEFAULT_VENN_CONFIG, commonGetConfig().venn);\n}\n\nconst customClear = () => {\n  clear();\n  subsets.length = 0;\n  textNodes.length = 0;\n  styleEntries.length = 0;\n  knownSets.clear();\n  currentSets = undefined;\n  indentMode = false;\n};\n\nexport const db: VennDB = {\n  getConfig,\n  clear: customClear,\n  setAccTitle,\n  getAccTitle,\n  setDiagramTitle,\n  getDiagramTitle,\n  getAccDescription,\n  setAccDescription,\n  addSubsetData,\n  getSubsetData,\n  addTextData,\n  addStyleData,\n  validateUnionIdentifiers,\n  getTextData,\n  getStyleData,\n  getCurrentSets,\n  getIndentMode,\n  setIndentMode,\n};\n", "export interface VennChartStyleOptions {\n  vennTitleTextColor: string;\n  vennSetTextColor: string;\n  fontFamily: string;\n  textColor: string;\n}\n\nconst getStyles = (options: VennChartStyleOptions) =>\n  `\n  .venn-title {\n    font-size: 32px;\n    fill: ${options.vennTitleTextColor};\n    font-family: ${options.fontFamily};\n  }\n\n  .venn-circle text {\n    font-size: 48px;\n    font-family: ${options.fontFamily};\n  }\n\n  .venn-intersection text {\n    font-size: 48px;\n    fill: ${options.vennSetTextColor};\n    font-family: ${options.fontFamily};\n  }\n\n  .venn-text-node {\n    font-family: ${options.fontFamily};\n    color: ${options.vennSetTextColor};\n  }\n`;\n\nexport default getStyles;\n", "const SMALL$1 = 1e-10;\n\n/**\n * Returns the intersection area of a bunch of circles (where each circle\n * is an object having an x,y and radius property)\n * @param {ReadonlyArray<{x: number, y: number, radius: number}>} circles\n * @param {undefined | { area?: number, arcArea?: number, polygonArea?: number, arcs?: ReadonlyArray<{ circle: {x: number, y: number, radius: number}, width: number, p1: {x: number, y: number}, p2: {x: number, y: number} }>, innerPoints: ReadonlyArray<{\n    x: number;\n    y: number;\n    parentIndex: [number, number];\n}>, intersectionPoints: ReadonlyArray<{\n  x: number;\n  y: number;\n  parentIndex: [number, number];\n}> }} stats\n * @returns {number}\n */\nfunction intersectionArea(circles, stats) {\n  // get all the intersection points of the circles\n  const intersectionPoints = getIntersectionPoints(circles);\n\n  // filter out points that aren't included in all the circles\n  const innerPoints = intersectionPoints.filter((p) => containedInCircles(p, circles));\n\n  let arcArea = 0;\n  let polygonArea = 0;\n  /** @type {{ circle: {x: number, y: number, radius: number}, width: number, p1: {x: number, y: number}, p2: {x: number, y: number} }[]} */\n  const arcs = [];\n\n  // if we have intersection points that are within all the circles,\n  // then figure out the area contained by them\n  if (innerPoints.length > 1) {\n    // sort the points by angle from the center of the polygon, which lets\n    // us just iterate over points to get the edges\n    const center = getCenter(innerPoints);\n    for (let i = 0; i < innerPoints.length; ++i) {\n      const p = innerPoints[i];\n      p.angle = Math.atan2(p.x - center.x, p.y - center.y);\n    }\n    innerPoints.sort((a, b) => b.angle - a.angle);\n\n    // iterate over all points, get arc between the points\n    // and update the areas\n    let p2 = innerPoints[innerPoints.length - 1];\n    for (let i = 0; i < innerPoints.length; ++i) {\n      const p1 = innerPoints[i];\n\n      // polygon area updates easily ...\n      polygonArea += (p2.x + p1.x) * (p1.y - p2.y);\n\n      // updating the arc area is a little more involved\n      const midPoint = { x: (p1.x + p2.x) / 2, y: (p1.y + p2.y) / 2 };\n      /** @types null | { circle: {x: number, y: number, radius: number}, width: number, p1: {x: number, y: number}, p2: {x: number, y: number} } */\n      let arc = null;\n\n      for (let j = 0; j < p1.parentIndex.length; ++j) {\n        if (p2.parentIndex.includes(p1.parentIndex[j])) {\n          // figure out the angle halfway between the two points\n          // on the current circle\n          const circle = circles[p1.parentIndex[j]];\n          const a1 = Math.atan2(p1.x - circle.x, p1.y - circle.y);\n          const a2 = Math.atan2(p2.x - circle.x, p2.y - circle.y);\n\n          let angleDiff = a2 - a1;\n          if (angleDiff < 0) {\n            angleDiff += 2 * Math.PI;\n          }\n\n          // and use that angle to figure out the width of the\n          // arc\n          const a = a2 - angleDiff / 2;\n          let width = distance(midPoint, {\n            x: circle.x + circle.radius * Math.sin(a),\n            y: circle.y + circle.radius * Math.cos(a),\n          });\n\n          // clamp the width to the largest is can actually be\n          // (sometimes slightly overflows because of FP errors)\n          if (width > circle.radius * 2) {\n            width = circle.radius * 2;\n          }\n\n          // pick the circle whose arc has the smallest width\n          if (arc == null || arc.width > width) {\n            arc = { circle, width, p1, p2, large: width > circle.radius, sweep: true };\n          }\n        }\n      }\n\n      if (arc != null) {\n        arcs.push(arc);\n        arcArea += circleArea(arc.circle.radius, arc.width);\n        p2 = p1;\n      }\n    }\n  } else {\n    // no intersection points, is either disjoint - or is completely\n    // overlapped. figure out which by examining the smallest circle\n    let smallest = circles[0];\n    for (let i = 1; i < circles.length; ++i) {\n      if (circles[i].radius < smallest.radius) {\n        smallest = circles[i];\n      }\n    }\n\n    // make sure the smallest circle is completely contained in all\n    // the other circles\n    let disjoint = false;\n    for (let i = 0; i < circles.length; ++i) {\n      if (distance(circles[i], smallest) > Math.abs(smallest.radius - circles[i].radius)) {\n        disjoint = true;\n        break;\n      }\n    }\n\n    if (disjoint) {\n      arcArea = polygonArea = 0;\n    } else {\n      arcArea = smallest.radius * smallest.radius * Math.PI;\n      arcs.push({\n        circle: smallest,\n        p1: { x: smallest.x, y: smallest.y + smallest.radius },\n        p2: { x: smallest.x - SMALL$1, y: smallest.y + smallest.radius },\n        width: smallest.radius * 2,\n        large: true,\n        sweep: true,\n      });\n    }\n  }\n\n  polygonArea /= 2;\n\n  if (stats) {\n    stats.area = arcArea + polygonArea;\n    stats.arcArea = arcArea;\n    stats.polygonArea = polygonArea;\n    stats.arcs = arcs;\n    stats.innerPoints = innerPoints;\n    stats.intersectionPoints = intersectionPoints;\n  }\n\n  return arcArea + polygonArea;\n}\n\n/**\n * returns whether a point is contained by all of a list of circles\n * @param {{x: number, y: number}} point\n * @param {ReadonlyArray<{x: number, y: number, radius: number}>} circles\n * @returns {boolean}\n */\nfunction containedInCircles(point, circles) {\n  return circles.every((circle) => distance(point, circle) < circle.radius + SMALL$1);\n}\n\n/**\n * Gets all intersection points between a bunch of circles\n * @param {ReadonlyArray<{x: number, y: number, radius: number}>} circles\n * @returns {ReadonlyArray<{x: number, y: number, parentIndex: [number, number]}>}\n */\nfunction getIntersectionPoints(circles) {\n  /** @type {{x: number, y: number, parentIndex: [number, number]}[]} */\n  const ret = [];\n  for (let i = 0; i < circles.length; ++i) {\n    for (let j = i + 1; j < circles.length; ++j) {\n      const intersect = circleCircleIntersection(circles[i], circles[j]);\n      for (const p of intersect) {\n        p.parentIndex = [i, j];\n        ret.push(p);\n      }\n    }\n  }\n  return ret;\n}\n\n/**\n * Circular segment area calculation. See http://mathworld.wolfram.com/CircularSegment.html\n * @param {number} r\n * @param {number} width\n * @returns {number}\n **/\nfunction circleArea(r, width) {\n  return r * r * Math.acos(1 - width / r) - (r - width) * Math.sqrt(width * (2 * r - width));\n}\n\n/**\n * euclidean distance between two points\n * @param {{x: number, y: number}} p1\n * @param {{x: number, y: number}} p2\n * @returns {number}\n **/\nfunction distance(p1, p2) {\n  return Math.sqrt((p1.x - p2.x) * (p1.x - p2.x) + (p1.y - p2.y) * (p1.y - p2.y));\n}\n\n/**\n * Returns the overlap area of two circles of radius r1 and r2 - that\n * have their centers separated by distance d. Simpler faster\n * circle intersection for only two circles\n * @param {number} r1\n * @param {number} r2\n * @param {number} d\n * @returns {number}\n */\nfunction circleOverlap(r1, r2, d) {\n  // no overlap\n  if (d >= r1 + r2) {\n    return 0;\n  }\n\n  // completely overlapped\n  if (d <= Math.abs(r1 - r2)) {\n    return Math.PI * Math.min(r1, r2) * Math.min(r1, r2);\n  }\n\n  const w1 = r1 - (d * d - r2 * r2 + r1 * r1) / (2 * d);\n  const w2 = r2 - (d * d - r1 * r1 + r2 * r2) / (2 * d);\n  return circleArea(r1, w1) + circleArea(r2, w2);\n}\n\n/**\n * Given two circles (containing a x/y/radius attributes),\n * returns the intersecting points if possible\n * note: doesn't handle cases where there are infinitely many\n * intersection points (circles are equivalent):, or only one intersection point\n * @param {{x: number, y: number, radius: number}} p1\n * @param {{x: number, y: number, radius: number}} p2\n * @returns {ReadonlyArray<{x: number, y: number}>}\n **/\nfunction circleCircleIntersection(p1, p2) {\n  const d = distance(p1, p2);\n  const r1 = p1.radius;\n  const r2 = p2.radius;\n\n  // if to far away, or self contained - can't be done\n  if (d >= r1 + r2 || d <= Math.abs(r1 - r2)) {\n    return [];\n  }\n\n  const a = (r1 * r1 - r2 * r2 + d * d) / (2 * d);\n  const h = Math.sqrt(r1 * r1 - a * a);\n  const x0 = p1.x + (a * (p2.x - p1.x)) / d;\n  const y0 = p1.y + (a * (p2.y - p1.y)) / d;\n  const rx = -(p2.y - p1.y) * (h / d);\n  const ry = -(p2.x - p1.x) * (h / d);\n\n  return [\n    { x: x0 + rx, y: y0 - ry },\n    { x: x0 - rx, y: y0 + ry },\n  ];\n}\n\n/**\n * Returns the center of a bunch of points\n * @param {ReadonlyArray<{x: number, y: number}>} points\n * @returns {{x: number, y: number}}\n */\nfunction getCenter(points) {\n  const center = { x: 0, y: 0 };\n  for (const point of points) {\n    center.x += point.x;\n    center.y += point.y;\n  }\n  center.x /= points.length;\n  center.y /= points.length;\n  return center;\n}\n\n/** finds the zeros of a function, given two starting points (which must\n * have opposite signs */\nfunction bisect(f, a, b, parameters) {\n    parameters = parameters || {};\n    const maxIterations = parameters.maxIterations || 100;\n    const tolerance = parameters.tolerance || 1e-10;\n    const fA = f(a);\n    const fB = f(b);\n    let delta = b - a;\n\n    if (fA * fB > 0) {\n        throw 'Initial bisect points must have opposite signs';\n    }\n\n    if (fA === 0) return a;\n    if (fB === 0) return b;\n\n    for (let i = 0; i < maxIterations; ++i) {\n        delta /= 2;\n        const mid = a + delta;\n        const fMid = f(mid);\n\n        if (fMid * fA >= 0) {\n            a = mid;\n        }\n\n        if (Math.abs(delta) < tolerance || fMid === 0) {\n            return mid;\n        }\n    }\n    return a + delta;\n}\n\n// need some basic operations on vectors, rather than adding a dependency,\n// just define here\nfunction zeros(x) {\n    const r = new Array(x);\n    for (let i = 0; i < x; ++i) {\n        r[i] = 0;\n    }\n    return r;\n}\nfunction zerosM(x, y) {\n    return zeros(x).map(() => zeros(y));\n}\n\nfunction dot(a, b) {\n    let ret = 0;\n    for (let i = 0; i < a.length; ++i) {\n        ret += a[i] * b[i];\n    }\n    return ret;\n}\n\nfunction norm2(a) {\n    return Math.sqrt(dot(a, a));\n}\n\nfunction scale(ret, value, c) {\n    for (let i = 0; i < value.length; ++i) {\n        ret[i] = value[i] * c;\n    }\n}\n\nfunction weightedSum(ret, w1, v1, w2, v2) {\n    for (let j = 0; j < ret.length; ++j) {\n        ret[j] = w1 * v1[j] + w2 * v2[j];\n    }\n}\n\n/** minimizes a function using the downhill simplex method */\nfunction nelderMead(f, x0, parameters) {\n    parameters = parameters || {};\n\n    const maxIterations = parameters.maxIterations || x0.length * 200;\n    const nonZeroDelta = parameters.nonZeroDelta || 1.05;\n    const zeroDelta = parameters.zeroDelta || 0.001;\n    const minErrorDelta = parameters.minErrorDelta || 1e-6;\n    const minTolerance = parameters.minErrorDelta || 1e-5;\n    const rho = parameters.rho !== undefined ? parameters.rho : 1;\n    const chi = parameters.chi !== undefined ? parameters.chi : 2;\n    const psi = parameters.psi !== undefined ? parameters.psi : -0.5;\n    const sigma = parameters.sigma !== undefined ? parameters.sigma : 0.5;\n    let maxDiff;\n\n    // initialize simplex.\n    const N = x0.length;\n    const simplex = new Array(N + 1);\n    simplex[0] = x0;\n    simplex[0].fx = f(x0);\n    simplex[0].id = 0;\n    for (let i = 0; i < N; ++i) {\n        const point = x0.slice();\n        point[i] = point[i] ? point[i] * nonZeroDelta : zeroDelta;\n        simplex[i + 1] = point;\n        simplex[i + 1].fx = f(point);\n        simplex[i + 1].id = i + 1;\n    }\n\n    function updateSimplex(value) {\n        for (let i = 0; i < value.length; i++) {\n            simplex[N][i] = value[i];\n        }\n        simplex[N].fx = value.fx;\n    }\n\n    const sortOrder = (a, b) => a.fx - b.fx;\n\n    const centroid = x0.slice();\n    const reflected = x0.slice();\n    const contracted = x0.slice();\n    const expanded = x0.slice();\n\n    for (let iteration = 0; iteration < maxIterations; ++iteration) {\n        simplex.sort(sortOrder);\n\n        if (parameters.history) {\n            // copy the simplex (since later iterations will mutate) and\n            // sort it to have a consistent order between iterations\n            const sortedSimplex = simplex.map((x) => {\n                const state = x.slice();\n                state.fx = x.fx;\n                state.id = x.id;\n                return state;\n            });\n            sortedSimplex.sort((a, b) => a.id - b.id);\n\n            parameters.history.push({\n                x: simplex[0].slice(),\n                fx: simplex[0].fx,\n                simplex: sortedSimplex,\n            });\n        }\n\n        maxDiff = 0;\n        for (let i = 0; i < N; ++i) {\n            maxDiff = Math.max(maxDiff, Math.abs(simplex[0][i] - simplex[1][i]));\n        }\n\n        if (Math.abs(simplex[0].fx - simplex[N].fx) < minErrorDelta && maxDiff < minTolerance) {\n            break;\n        }\n\n        // compute the centroid of all but the worst point in the simplex\n        for (let i = 0; i < N; ++i) {\n            centroid[i] = 0;\n            for (let j = 0; j < N; ++j) {\n                centroid[i] += simplex[j][i];\n            }\n            centroid[i] /= N;\n        }\n\n        // reflect the worst point past the centroid  and compute loss at reflected\n        // point\n        const worst = simplex[N];\n        weightedSum(reflected, 1 + rho, centroid, -rho, worst);\n        reflected.fx = f(reflected);\n\n        // if the reflected point is the best seen, then possibly expand\n        if (reflected.fx < simplex[0].fx) {\n            weightedSum(expanded, 1 + chi, centroid, -chi, worst);\n            expanded.fx = f(expanded);\n            if (expanded.fx < reflected.fx) {\n                updateSimplex(expanded);\n            } else {\n                updateSimplex(reflected);\n            }\n        }\n\n        // if the reflected point is worse than the second worst, we need to\n        // contract\n        else if (reflected.fx >= simplex[N - 1].fx) {\n            let shouldReduce = false;\n\n            if (reflected.fx > worst.fx) {\n                // do an inside contraction\n                weightedSum(contracted, 1 + psi, centroid, -psi, worst);\n                contracted.fx = f(contracted);\n                if (contracted.fx < worst.fx) {\n                    updateSimplex(contracted);\n                } else {\n                    shouldReduce = true;\n                }\n            } else {\n                // do an outside contraction\n                weightedSum(contracted, 1 - psi * rho, centroid, psi * rho, worst);\n                contracted.fx = f(contracted);\n                if (contracted.fx < reflected.fx) {\n                    updateSimplex(contracted);\n                } else {\n                    shouldReduce = true;\n                }\n            }\n\n            if (shouldReduce) {\n                // if we don't contract here, we're done\n                if (sigma >= 1) break;\n\n                // do a reduction\n                for (let i = 1; i < simplex.length; ++i) {\n                    weightedSum(simplex[i], 1 - sigma, simplex[0], sigma, simplex[i]);\n                    simplex[i].fx = f(simplex[i]);\n                }\n            }\n        } else {\n            updateSimplex(reflected);\n        }\n    }\n\n    simplex.sort(sortOrder);\n    return { fx: simplex[0].fx, x: simplex[0] };\n}\n\n/// searches along line 'pk' for a point that satifies the wolfe conditions\n/// See 'Numerical Optimization' by Nocedal and Wright p59-60\n/// f : objective function\n/// pk : search direction\n/// current: object containing current gradient/loss\n/// next: output: contains next gradient/loss\n/// returns a: step size taken\nfunction wolfeLineSearch(f, pk, current, next, a, c1, c2) {\n    const phi0 = current.fx;\n    const phiPrime0 = dot(current.fxprime, pk);\n    let phi = phi0;\n    let phi_old = phi0;\n    let phiPrime = phiPrime0;\n    let a0 = 0;\n\n    a = a || 1;\n    c1 = c1 || 1e-6;\n    c2 = c2 || 0.1;\n\n    function zoom(a_lo, a_high, phi_lo) {\n        for (let iteration = 0; iteration < 16; ++iteration) {\n            a = (a_lo + a_high) / 2;\n            weightedSum(next.x, 1.0, current.x, a, pk);\n            phi = next.fx = f(next.x, next.fxprime);\n            phiPrime = dot(next.fxprime, pk);\n\n            if (phi > phi0 + c1 * a * phiPrime0 || phi >= phi_lo) {\n                a_high = a;\n            } else {\n                if (Math.abs(phiPrime) <= -c2 * phiPrime0) {\n                    return a;\n                }\n\n                if (phiPrime * (a_high - a_lo) >= 0) {\n                    a_high = a_lo;\n                }\n\n                a_lo = a;\n                phi_lo = phi;\n            }\n        }\n\n        return 0;\n    }\n\n    for (let iteration = 0; iteration < 10; ++iteration) {\n        weightedSum(next.x, 1.0, current.x, a, pk);\n        phi = next.fx = f(next.x, next.fxprime);\n        phiPrime = dot(next.fxprime, pk);\n        if (phi > phi0 + c1 * a * phiPrime0 || (iteration && phi >= phi_old)) {\n            return zoom(a0, a, phi_old);\n        }\n\n        if (Math.abs(phiPrime) <= -c2 * phiPrime0) {\n            return a;\n        }\n\n        if (phiPrime >= 0) {\n            return zoom(a, a0, phi);\n        }\n\n        phi_old = phi;\n        a0 = a;\n        a *= 2;\n    }\n\n    return a;\n}\n\nfunction conjugateGradient(f, initial, params) {\n    // allocate all memory up front here, keep out of the loop for perfomance\n    // reasons\n    let current = { x: initial.slice(), fx: 0, fxprime: initial.slice() };\n    let next = { x: initial.slice(), fx: 0, fxprime: initial.slice() };\n    const yk = initial.slice();\n    let pk;\n    let temp;\n    let a = 1;\n    let maxIterations;\n\n    params = params || {};\n    maxIterations = params.maxIterations || initial.length * 20;\n\n    current.fx = f(current.x, current.fxprime);\n    pk = current.fxprime.slice();\n    scale(pk, current.fxprime, -1);\n\n    for (let i = 0; i < maxIterations; ++i) {\n        a = wolfeLineSearch(f, pk, current, next, a);\n\n        // todo: history in wrong spot?\n        if (params.history) {\n            params.history.push({\n                x: current.x.slice(),\n                fx: current.fx,\n                fxprime: current.fxprime.slice(),\n                alpha: a,\n            });\n        }\n\n        if (!a) {\n            // faiiled to find point that satifies wolfe conditions.\n            // reset direction for next iteration\n            scale(pk, current.fxprime, -1);\n        } else {\n            // update direction using Polak\u2013Ribiere CG method\n            weightedSum(yk, 1, next.fxprime, -1, current.fxprime);\n\n            const delta_k = dot(current.fxprime, current.fxprime);\n            const beta_k = Math.max(0, dot(yk, next.fxprime) / delta_k);\n\n            weightedSum(pk, beta_k, pk, -1, next.fxprime);\n\n            temp = current;\n            current = next;\n            next = temp;\n        }\n\n        if (norm2(current.fxprime) <= 1e-5) {\n            break;\n        }\n    }\n\n    if (params.history) {\n        params.history.push({\n            x: current.x.slice(),\n            fx: current.fx,\n            fxprime: current.fxprime.slice(),\n            alpha: a,\n        });\n    }\n\n    return current;\n}\n\n/**\n * given a list of set objects, and their corresponding overlaps\n * updates the (x, y, radius) attribute on each set such that their positions\n * roughly correspond to the desired overlaps\n * @param {readonly {sets: readonly string[]; size: number; weight?: number}[]} sets\n * @returns {{[setid: string]: {x: number, y: number, radius: number}}}\n */\nfunction venn(sets, parameters = {}) {\n  parameters.maxIterations = parameters.maxIterations || 500;\n\n  const initialLayout = parameters.initialLayout || bestInitialLayout;\n  const loss = parameters.lossFunction || lossFunction;\n\n  // add in missing pairwise areas as having 0 size\n  const areas = addMissingAreas(sets, parameters);\n\n  // initial layout is done greedily\n  const circles = initialLayout(areas, parameters);\n\n  // transform x/y coordinates to a vector to optimize\n  const setids = Object.keys(circles);\n  /** @type {number[]} */\n  const initial = [];\n  for (const setid of setids) {\n    initial.push(circles[setid].x);\n    initial.push(circles[setid].y);\n  }\n\n  // optimize initial layout from our loss function\n  const solution = nelderMead(\n    (values) => {\n      const current = {};\n      for (let i = 0; i < setids.length; ++i) {\n        const setid = setids[i];\n        current[setid] = {\n          x: values[2 * i],\n          y: values[2 * i + 1],\n          radius: circles[setid].radius,\n          // size : circles[setid].size\n        };\n      }\n      return loss(current, areas);\n    },\n    initial,\n    parameters\n  );\n\n  // transform solution vector back to x/y points\n  const positions = solution.x;\n  for (let i = 0; i < setids.length; ++i) {\n    const setid = setids[i];\n    circles[setid].x = positions[2 * i];\n    circles[setid].y = positions[2 * i + 1];\n  }\n\n  return circles;\n}\n\nconst SMALL = 1e-10;\n\n/**\n * Returns the distance necessary for two circles of radius r1 + r2 to\n * have the overlap area 'overlap'\n * @param {number} r1\n * @param {number} r2\n * @param {number} overlap\n * @returns {number}\n */\nfunction distanceFromIntersectArea(r1, r2, overlap) {\n  // handle complete overlapped circles\n  if (Math.min(r1, r2) * Math.min(r1, r2) * Math.PI <= overlap + SMALL) {\n    return Math.abs(r1 - r2);\n  }\n\n  return bisect((distance) => circleOverlap(r1, r2, distance) - overlap, 0, r1 + r2);\n}\n\n/**\n * Missing pair-wise intersection area data can cause problems:\n * treating as an unknown means that sets will be laid out overlapping,\n * which isn't what people expect. To reflect that we want disjoint sets\n * here, set the overlap to 0 for all missing pairwise set intersections\n * @param {ReadonlyArray<{sets: ReadonlyArray<string>, size: number}>} areas\n * @returns {ReadonlyArray<{sets: ReadonlyArray<string>, size: number}>}\n */\nfunction addMissingAreas(areas, parameters = {}) {\n  const distinct = parameters.distinct;\n  const r = areas.map((s) => Object.assign({}, s));\n\n  function toKey(arr) {\n    return arr.join(';');\n  }\n\n  if (distinct) {\n    // recreate the full ones by adding things up but just to level two since the rest doesn't matter\n    /** @types Map<string, number> */\n    const count = new Map();\n    for (const area of r) {\n      for (let i = 0; i < area.sets.length; i++) {\n        const si = String(area.sets[i]);\n        count.set(si, area.size + (count.get(si) || 0));\n        for (let j = i + 1; j < area.sets.length; j++) {\n          const sj = String(area.sets[j]);\n          const k1 = `${si};${sj}`;\n          const k2 = `${sj};${si}`;\n          count.set(k1, area.size + (count.get(k1) || 0));\n          count.set(k2, area.size + (count.get(k2) || 0));\n        }\n      }\n    }\n    for (const area of r) {\n      if (area.sets.length < 3) {\n        area.size = count.get(toKey(area.sets));\n      }\n    }\n  }\n\n  // two circle intersections that aren't defined\n  const ids = [];\n\n  /** @type {Set<string>} */\n  const pairs = new Set();\n  for (const area of r) {\n    if (area.sets.length === 1) {\n      ids.push(area.sets[0]);\n    } else if (area.sets.length === 2) {\n      const a = area.sets[0];\n      const b = area.sets[1];\n      pairs.add(toKey(area.sets));\n      pairs.add(toKey([b, a]));\n    }\n  }\n\n  ids.sort((a, b) => (a === b ? 0 : a < b ? -1 : +1));\n\n  for (let i = 0; i < ids.length; ++i) {\n    const a = ids[i];\n    for (let j = i + 1; j < ids.length; ++j) {\n      const b = ids[j];\n      if (!pairs.has(toKey([a, b]))) {\n        r.push({ sets: [a, b], size: 0 });\n      }\n    }\n  }\n  return r;\n}\n\n/**\n * Returns two matrices, one of the euclidean distances between the sets\n * and the other indicating if there are subset or disjoint set relationships\n * @param {ReadonlyArray<{sets: ReadonlyArray<number>}>} areas\n * @param {ReadonlyArray<{size: number}>} sets\n * @param {ReadonlyArray<number>} setids\n */\nfunction getDistanceMatrices(areas, sets, setids) {\n  // initialize an empty distance matrix between all the points\n  /**\n   * @type {number[][]}\n   */\n  const distances = zerosM(sets.length, sets.length);\n  /**\n   * @type {number[][]}\n   */\n  const constraints = zerosM(sets.length, sets.length);\n\n  // compute required distances between all the sets such that\n  // the areas match\n  areas\n    .filter((x) => x.sets.length === 2)\n    .forEach((current) => {\n      const left = setids[current.sets[0]];\n      const right = setids[current.sets[1]];\n      const r1 = Math.sqrt(sets[left].size / Math.PI);\n      const r2 = Math.sqrt(sets[right].size / Math.PI);\n      const distance = distanceFromIntersectArea(r1, r2, current.size);\n\n      distances[left][right] = distances[right][left] = distance;\n\n      // also update constraints to indicate if its a subset or disjoint\n      // relationship\n      let c = 0;\n      if (current.size + 1e-10 >= Math.min(sets[left].size, sets[right].size)) {\n        c = 1;\n      } else if (current.size <= 1e-10) {\n        c = -1;\n      }\n      constraints[left][right] = constraints[right][left] = c;\n    });\n\n  return { distances, constraints };\n}\n\n/// computes the gradient and loss simultaneously for our constrained MDS optimizer\nfunction constrainedMDSGradient(x, fxprime, distances, constraints) {\n  for (let i = 0; i < fxprime.length; ++i) {\n    fxprime[i] = 0;\n  }\n\n  let loss = 0;\n  for (let i = 0; i < distances.length; ++i) {\n    const xi = x[2 * i];\n    const yi = x[2 * i + 1];\n    for (let j = i + 1; j < distances.length; ++j) {\n      const xj = x[2 * j];\n      const yj = x[2 * j + 1];\n      const dij = distances[i][j];\n      const constraint = constraints[i][j];\n\n      const squaredDistance = (xj - xi) * (xj - xi) + (yj - yi) * (yj - yi);\n      const distance = Math.sqrt(squaredDistance);\n      const delta = squaredDistance - dij * dij;\n\n      if ((constraint > 0 && distance <= dij) || (constraint < 0 && distance >= dij)) {\n        continue;\n      }\n\n      loss += 2 * delta * delta;\n\n      fxprime[2 * i] += 4 * delta * (xi - xj);\n      fxprime[2 * i + 1] += 4 * delta * (yi - yj);\n\n      fxprime[2 * j] += 4 * delta * (xj - xi);\n      fxprime[2 * j + 1] += 4 * delta * (yj - yi);\n    }\n  }\n  return loss;\n}\n\n/**\n * takes the best working variant of either constrained MDS or greedy\n * @param {ReadonlyArray<{sets: ReadonlyArray<string>, size: number}>} areas\n */\nfunction bestInitialLayout(areas, params = {}) {\n  let initial = greedyLayout(areas, params);\n  const loss = params.lossFunction || lossFunction;\n\n  // greedylayout is sufficient for all 2/3 circle cases. try out\n  // constrained MDS for higher order problems, take its output\n  // if it outperforms. (greedy is aesthetically better on 2/3 circles\n  // since it axis aligns)\n  if (areas.length >= 8) {\n    const constrained = constrainedMDSLayout(areas, params);\n    const constrainedLoss = loss(constrained, areas);\n    const greedyLoss = loss(initial, areas);\n\n    if (constrainedLoss + 1e-8 < greedyLoss) {\n      initial = constrained;\n    }\n  }\n  return initial;\n}\n\n/**\n * use the constrained MDS variant to generate an initial layout\n * @param {ReadonlyArray<{sets: ReadonlyArray<string>, size: number}>} areas\n * @returns {{[key: string]: {x: number, y: number, radius: number}}}\n */\nfunction constrainedMDSLayout(areas, params = {}) {\n  const restarts = params.restarts || 10;\n\n  // bidirectionally map sets to a rowid  (so we can create a matrix)\n  const sets = [];\n  const setids = {};\n  for (const area of areas) {\n    if (area.sets.length === 1) {\n      setids[area.sets[0]] = sets.length;\n      sets.push(area);\n    }\n  }\n\n  let { distances, constraints } = getDistanceMatrices(areas, sets, setids);\n\n  // keep distances bounded, things get messed up otherwise.\n  // TODO: proper preconditioner?\n  const norm = norm2(distances.map(norm2)) / distances.length;\n  distances = distances.map((row) => row.map((value) => value / norm));\n\n  const obj = (x, fxprime) => constrainedMDSGradient(x, fxprime, distances, constraints);\n\n  let best = null;\n  for (let i = 0; i < restarts; ++i) {\n    const initial = zeros(distances.length * 2).map(Math.random);\n\n    const current = conjugateGradient(obj, initial, params);\n    if (!best || current.fx < best.fx) {\n      best = current;\n    }\n  }\n\n  const positions = best.x;\n\n  // translate rows back to (x,y,radius) coordinates\n  /** @type {{[key: string]: {x: number, y: number, radius: number}}} */\n  const circles = {};\n  for (let i = 0; i < sets.length; ++i) {\n    const set = sets[i];\n    circles[set.sets[0]] = {\n      x: positions[2 * i] * norm,\n      y: positions[2 * i + 1] * norm,\n      radius: Math.sqrt(set.size / Math.PI),\n    };\n  }\n\n  if (params.history) {\n    for (const h of params.history) {\n      scale(h.x, norm);\n    }\n  }\n  return circles;\n}\n\n/**\n * Lays out a Venn diagram greedily, going from most overlapped sets to\n * least overlapped, attempting to position each new set such that the\n * overlapping areas to already positioned sets are basically right\n * @param {ReadonlyArray<{size: number, sets: ReadonlyArray<string>}>} areas\n * @return {{[key: string]: {x: number, y: number, radius: number}}}\n */\nfunction greedyLayout(areas, params) {\n  const loss = params && params.lossFunction ? params.lossFunction : lossFunction;\n\n  // define a circle for each set\n  /** @type {{[key: string]: {x: number, y: number, radius: number}}} */\n  const circles = {};\n  /** @type {{[key: string]: {set: string, size: number, weight: number}[]}} */\n  const setOverlaps = {};\n  for (const area of areas) {\n    if (area.sets.length === 1) {\n      const set = area.sets[0];\n      circles[set] = {\n        x: 1e10,\n        y: 1e10,\n        rowid: circles.length,\n        size: area.size,\n        radius: Math.sqrt(area.size / Math.PI),\n      };\n      setOverlaps[set] = [];\n    }\n  }\n\n  areas = areas.filter((a) => a.sets.length === 2);\n\n  // map each set to a list of all the other sets that overlap it\n  for (const current of areas) {\n    let weight = current.weight != null ? current.weight : 1.0;\n    const left = current.sets[0];\n    const right = current.sets[1];\n\n    // completely overlapped circles shouldn't be positioned early here\n    if (current.size + SMALL >= Math.min(circles[left].size, circles[right].size)) {\n      weight = 0;\n    }\n\n    setOverlaps[left].push({ set: right, size: current.size, weight });\n    setOverlaps[right].push({ set: left, size: current.size, weight });\n  }\n\n  // get list of most overlapped sets\n  const mostOverlapped = [];\n  Object.keys(setOverlaps).forEach((set) => {\n    let size = 0;\n    for (let i = 0; i < setOverlaps[set].length; ++i) {\n      size += setOverlaps[set][i].size * setOverlaps[set][i].weight;\n    }\n\n    mostOverlapped.push({ set, size });\n  });\n\n  // sort by size desc\n  function sortOrder(a, b) {\n    return b.size - a.size;\n  }\n  mostOverlapped.sort(sortOrder);\n\n  // keep track of what sets have been laid out\n  const positioned = {};\n  function isPositioned(element) {\n    return element.set in positioned;\n  }\n\n  /**\n   * adds a point to the output\n   * @param {{x: number, y: number}} point\n   * @param {number} index\n   */\n  function positionSet(point, index) {\n    circles[index].x = point.x;\n    circles[index].y = point.y;\n    positioned[index] = true;\n  }\n\n  // add most overlapped set at (0,0)\n  positionSet({ x: 0, y: 0 }, mostOverlapped[0].set);\n\n  // get distances between all points. TODO, necessary?\n  // answer: probably not\n  // var distances = venn.getDistanceMatrices(circles, areas).distances;\n  for (let i = 1; i < mostOverlapped.length; ++i) {\n    const setIndex = mostOverlapped[i].set;\n    const overlap = setOverlaps[setIndex].filter(isPositioned);\n    const set = circles[setIndex];\n    overlap.sort(sortOrder);\n\n    if (overlap.length === 0) {\n      // this shouldn't happen anymore with addMissingAreas\n      throw 'ERROR: missing pairwise overlap information';\n    }\n\n    /** @type {{x: number, y: number}[]} */\n    const points = [];\n    for (var j = 0; j < overlap.length; ++j) {\n      // get appropriate distance from most overlapped already added set\n      const p1 = circles[overlap[j].set];\n      const d1 = distanceFromIntersectArea(set.radius, p1.radius, overlap[j].size);\n\n      // sample positions at 90 degrees for maximum aesthetics\n      points.push({ x: p1.x + d1, y: p1.y });\n      points.push({ x: p1.x - d1, y: p1.y });\n      points.push({ y: p1.y + d1, x: p1.x });\n      points.push({ y: p1.y - d1, x: p1.x });\n\n      // if we have at least 2 overlaps, then figure out where the\n      // set should be positioned analytically and try those too\n      for (let k = j + 1; k < overlap.length; ++k) {\n        const p2 = circles[overlap[k].set];\n        const d2 = distanceFromIntersectArea(set.radius, p2.radius, overlap[k].size);\n\n        const extraPoints = circleCircleIntersection(\n          { x: p1.x, y: p1.y, radius: d1 },\n          { x: p2.x, y: p2.y, radius: d2 }\n        );\n        points.push(...extraPoints);\n      }\n    }\n\n    // we have some candidate positions for the set, examine loss\n    // at each position to figure out where to put it at\n    let bestLoss = 1e50;\n    let bestPoint = points[0];\n    for (const point of points) {\n      circles[setIndex].x = point.x;\n      circles[setIndex].y = point.y;\n      const localLoss = loss(circles, areas);\n      if (localLoss < bestLoss) {\n        bestLoss = localLoss;\n        bestPoint = point;\n      }\n    }\n\n    positionSet(bestPoint, setIndex);\n  }\n\n  return circles;\n}\n\n/**\n * Given a bunch of sets, and the desired overlaps between these sets - computes\n * the distance from the actual overlaps to the desired overlaps. Note that\n * this method ignores overlaps of more than 2 circles\n * @param {{[key: string]: <{x: number, y: number, radius: number}>}} circles\n * @param {ReadonlyArray<{size: number, sets: ReadonlyArray<string>, weight?: number}>} overlaps\n * @returns {number}\n */\nfunction lossFunction(circles, overlaps) {\n  let output = 0;\n\n  for (const area of overlaps) {\n    if (area.sets.length === 1) {\n      continue;\n    }\n    /** @type {number} */\n    let overlap;\n    if (area.sets.length === 2) {\n      const left = circles[area.sets[0]];\n      const right = circles[area.sets[1]];\n      overlap = circleOverlap(left.radius, right.radius, distance(left, right));\n    } else {\n      overlap = intersectionArea(area.sets.map((d) => circles[d]));\n    }\n\n    const weight = area.weight != null ? area.weight : 1.0;\n    output += weight * (overlap - area.size) * (overlap - area.size);\n  }\n\n  return output;\n}\n\nfunction logRatioLossFunction(circles, overlaps) {\n  let output = 0;\n\n  for (const area of overlaps) {\n    if (area.sets.length === 1) {\n      continue;\n    }\n    /** @type {number} */\n    let overlap;\n    if (area.sets.length === 2) {\n      const left = circles[area.sets[0]];\n      const right = circles[area.sets[1]];\n      overlap = circleOverlap(left.radius, right.radius, distance(left, right));\n    } else {\n      overlap = intersectionArea(area.sets.map((d) => circles[d]));\n    }\n\n    const weight = area.weight != null ? area.weight : 1.0;\n    const differenceFromIdeal = Math.log((overlap + 1) / (area.size + 1));\n    output += weight * differenceFromIdeal * differenceFromIdeal;\n  }\n\n  return output;\n}\n\n/**\n * orientates a bunch of circles to point in orientation\n * @param {{x :number, y: number, radius: number}[]} circles\n * @param {number | undefined} orientation\n * @param {((a: {x :number, y: number, radius: number}, b: {x :number, y: number, radius: number}) => number) | undefined} orientationOrder\n */\nfunction orientateCircles(circles, orientation, orientationOrder) {\n  if (orientationOrder == null) {\n    circles.sort((a, b) => b.radius - a.radius);\n  } else {\n    circles.sort(orientationOrder);\n  }\n\n  // shift circles so largest circle is at (0, 0)\n  if (circles.length > 0) {\n    const largestX = circles[0].x;\n    const largestY = circles[0].y;\n\n    for (const circle of circles) {\n      circle.x -= largestX;\n      circle.y -= largestY;\n    }\n  }\n\n  if (circles.length === 2) {\n    // if the second circle is a subset of the first, arrange so that\n    // it is off to one side. hack for https://github.com/benfred/venn.js/issues/120\n    const dist = distance(circles[0], circles[1]);\n    if (dist < Math.abs(circles[1].radius - circles[0].radius)) {\n      circles[1].x = circles[0].x + circles[0].radius - circles[1].radius - 1e-10;\n      circles[1].y = circles[0].y;\n    }\n  }\n\n  // rotate circles so that second largest is at an angle of 'orientation'\n  // from largest\n  if (circles.length > 1) {\n    const rotation = Math.atan2(circles[1].x, circles[1].y) - orientation;\n    const c = Math.cos(rotation);\n    const s = Math.sin(rotation);\n\n    for (const circle of circles) {\n      const x = circle.x;\n      const y = circle.y;\n      circle.x = c * x - s * y;\n      circle.y = s * x + c * y;\n    }\n  }\n\n  // mirror solution if third solution is above plane specified by\n  // first two circles\n  if (circles.length > 2) {\n    let angle = Math.atan2(circles[2].x, circles[2].y) - orientation;\n    while (angle < 0) {\n      angle += 2 * Math.PI;\n    }\n    while (angle > 2 * Math.PI) {\n      angle -= 2 * Math.PI;\n    }\n    if (angle > Math.PI) {\n      const slope = circles[1].y / (1e-10 + circles[1].x);\n      for (const circle of circles) {\n        var d = (circle.x + slope * circle.y) / (1 + slope * slope);\n        circle.x = 2 * d - circle.x;\n        circle.y = 2 * d * slope - circle.y;\n      }\n    }\n  }\n}\n\n/**\n *\n * @param {ReadonlyArray<{x: number, y: number, radius: number}>} circles\n * @returns {{x: number, y: number, radius: number}[][]}\n */\nfunction disjointCluster(circles) {\n  // union-find clustering to get disjoint sets\n  circles.forEach((circle) => {\n    circle.parent = circle;\n  });\n\n  // path compression step in union find\n  function find(circle) {\n    if (circle.parent !== circle) {\n      circle.parent = find(circle.parent);\n    }\n    return circle.parent;\n  }\n\n  function union(x, y) {\n    const xRoot = find(x);\n    const yRoot = find(y);\n    xRoot.parent = yRoot;\n  }\n\n  // get the union of all overlapping sets\n  for (let i = 0; i < circles.length; ++i) {\n    for (let j = i + 1; j < circles.length; ++j) {\n      const maxDistance = circles[i].radius + circles[j].radius;\n      if (distance(circles[i], circles[j]) + 1e-10 < maxDistance) {\n        union(circles[j], circles[i]);\n      }\n    }\n  }\n\n  // find all the disjoint clusters and group them together\n  /** @type {Map<string, {x: number, y: number, radius: number}[]>} */\n  const disjointClusters = new Map();\n  for (let i = 0; i < circles.length; ++i) {\n    const setid = find(circles[i]).parent.setid;\n    if (!disjointClusters.has(setid)) {\n      disjointClusters.set(setid, []);\n    }\n    disjointClusters.get(setid).push(circles[i]);\n  }\n\n  // cleanup bookkeeping\n  circles.forEach((circle) => {\n    delete circle.parent;\n  });\n\n  // return in more usable form\n  return Array.from(disjointClusters.values());\n}\n\n/**\n * @param {ReadonlyArray<{x :number, y: number, radius: number}>} circles\n * @returns {{xRange: [number, number], yRange: [number, number]}}\n */\nfunction getBoundingBox(circles) {\n  const minMax = (d) => {\n    const hi = circles.reduce((acc, c) => Math.max(acc, c[d] + c.radius), Number.NEGATIVE_INFINITY);\n    const lo = circles.reduce((acc, c) => Math.min(acc, c[d] - c.radius), Number.POSITIVE_INFINITY);\n    return { max: hi, min: lo };\n  };\n  return { xRange: minMax('x'), yRange: minMax('y') };\n}\n\n/**\n *\n * @param {{[setid: string]: {x: number, y: number, radius: number}}} solution\n * @param {undefined | number} orientation\n * @param {((a: {x :number, y: number, radius: number}, b: {x :number, y: number, radius: number}) => number) | undefined} orientationOrder\n * @returns {{[setid: string]: {x: number, y: number, radius: number}}}\n */\nfunction normalizeSolution(solution, orientation, orientationOrder) {\n  if (orientation == null) {\n    orientation = Math.PI / 2;\n  }\n\n  // work with a list instead of a dictionary, and take a copy so we\n  // don't mutate input\n  let circles = fromObjectNotation(solution).map((d) => Object.assign({}, d));\n\n  // get all the disjoint clusters\n  const clusters = disjointCluster(circles);\n\n  // orientate all disjoint sets, get sizes\n  for (const cluster of clusters) {\n    orientateCircles(cluster, orientation, orientationOrder);\n    const bounds = getBoundingBox(cluster);\n    cluster.size = (bounds.xRange.max - bounds.xRange.min) * (bounds.yRange.max - bounds.yRange.min);\n    cluster.bounds = bounds;\n  }\n  clusters.sort((a, b) => b.size - a.size);\n\n  // orientate the largest at 0,0, and get the bounds\n  circles = clusters[0];\n  let returnBounds = circles.bounds;\n  const spacing = (returnBounds.xRange.max - returnBounds.xRange.min) / 50;\n\n  /**\n   * @param {ReadonlyArray<{x: number, y: number, radius: number, setid: string}>} cluster\n   * @param {boolean} right\n   * @param {boolean} bottom\n   */\n  function addCluster(cluster, right, bottom) {\n    if (!cluster) {\n      return;\n    }\n\n    const bounds = cluster.bounds;\n    /** @type {number} */\n    let xOffset;\n    /** @type {number} */\n    let yOffset;\n\n    if (right) {\n      xOffset = returnBounds.xRange.max - bounds.xRange.min + spacing;\n    } else {\n      xOffset = returnBounds.xRange.max - bounds.xRange.max;\n      const centreing =\n        (bounds.xRange.max - bounds.xRange.min) / 2 - (returnBounds.xRange.max - returnBounds.xRange.min) / 2;\n      if (centreing < 0) {\n        xOffset += centreing;\n      }\n    }\n\n    if (bottom) {\n      yOffset = returnBounds.yRange.max - bounds.yRange.min + spacing;\n    } else {\n      yOffset = returnBounds.yRange.max - bounds.yRange.max;\n      const centreing =\n        (bounds.yRange.max - bounds.yRange.min) / 2 - (returnBounds.yRange.max - returnBounds.yRange.min) / 2;\n      if (centreing < 0) {\n        yOffset += centreing;\n      }\n    }\n\n    for (const c of cluster) {\n      c.x += xOffset;\n      c.y += yOffset;\n      circles.push(c);\n    }\n  }\n\n  let index = 1;\n  while (index < clusters.length) {\n    addCluster(clusters[index], true, false);\n    addCluster(clusters[index + 1], false, true);\n    addCluster(clusters[index + 2], true, true);\n    index += 3;\n\n    // have one cluster (in top left). lay out next three relative\n    // to it in a grid\n    returnBounds = getBoundingBox(circles);\n  }\n\n  // convert back to solution form\n  return toObjectNotation(circles);\n}\n\n/**\n * Scales a solution from venn.venn or venn.greedyLayout such that it fits in\n * a rectangle of width/height - with padding around the borders. also\n * centers the diagram in the available space at the same time.\n * If the scale parameter is not null, this automatic scaling is ignored in favor of this custom one\n * @param {{[setid: string]: {x: number, y: number, radius: number}}} solution\n * @param {number} width\n * @param {number} height\n * @param {number} padding\n * @param {boolean} scaleToFit\n * @returns {{[setid: string]: {x: number, y: number, radius: number}}}\n */\nfunction scaleSolution(solution, width, height, padding, scaleToFit) {\n  const circles = fromObjectNotation(solution);\n\n  width -= 2 * padding;\n  height -= 2 * padding;\n\n  const { xRange, yRange } = getBoundingBox(circles);\n\n  if (xRange.max === xRange.min || yRange.max === yRange.min) {\n    console.log('not scaling solution: zero size detected');\n    return solution;\n  }\n\n  /** @type {number} */\n  let xScaling;\n  /** @type {number} */\n  let yScaling;\n  if (scaleToFit) {\n    const toScaleDiameter = Math.sqrt(scaleToFit / Math.PI) * 2;\n    xScaling = width / toScaleDiameter;\n    yScaling = height / toScaleDiameter;\n  } else {\n    xScaling = width / (xRange.max - xRange.min);\n    yScaling = height / (yRange.max - yRange.min);\n  }\n\n  const scaling = Math.min(yScaling, xScaling);\n  // while we're at it, center the diagram too\n  const xOffset = (width - (xRange.max - xRange.min) * scaling) / 2;\n  const yOffset = (height - (yRange.max - yRange.min) * scaling) / 2;\n\n  return toObjectNotation(\n    circles.map((circle) => ({\n      radius: scaling * circle.radius,\n      x: padding + xOffset + (circle.x - xRange.min) * scaling,\n      y: padding + yOffset + (circle.y - yRange.min) * scaling,\n      setid: circle.setid,\n    }))\n  );\n}\n\n/**\n * @param {readonly {x: number, y: number, radius: number, setid: string}[]} circles\n * @returns {{[setid: string]: {x: number, y: number, radius: number, setid: string}}}\n */\nfunction toObjectNotation(circles) {\n  /** @type {{[setid: string]: {x: number, y: number, radius: number, setid: string}}} */\n  const r = {};\n  for (const circle of circles) {\n    r[circle.setid] = circle;\n  }\n  return r;\n}\n/**\n * @param {{[setid: string]: {x: number, y: number, radius: number}}} solution\n * @returns {{x: number, y: number, radius: number, setid: string}[]}}\n */\nfunction fromObjectNotation(solution) {\n  const setids = Object.keys(solution);\n  return setids.map((id) => Object.assign(solution[id], { setid: id }));\n}\n\n/**\n * VennDiagram includes an optional `options` parameter containing the following option(s):\n *\n * `colourScheme: Array<String>`\n * A list of color values to be applied when coloring diagram circles.\n *\n * `symmetricalTextCentre: Boolean`\n * Whether to symmetrically center each circle's text horizontally and vertically.\n * Defaults to `false`.\n *\n * `textFill: String`\n * The color to be applied to the text within each circle.\n *\n * @param {object} options\n */\nfunction VennDiagram(options = {}) {\n  let useViewBox = false,\n    width = 600,\n    height = 350,\n    padding = 15,\n    duration = 1000,\n    orientation = Math.PI / 2,\n    normalize = true,\n    scaleToFit = null,\n    wrap = true,\n    styled = true,\n    fontSize = null,\n    orientationOrder = null,\n    distinct = false,\n    round = null,\n    symmetricalTextCentre = options && options.symmetricalTextCentre ? options.symmetricalTextCentre : false,\n    // mimic the behaviour of d3.scale.category10 from the previous\n    // version of d3\n    colourMap = {},\n    // so this is the same as d3.schemeCategory10, which is only defined in d3 4.0\n    // since we can support older versions of d3 as long as we don't force this,\n    // I'm hackily redefining below. TODO: remove this and change to d3.schemeCategory10\n    colourScheme =\n      options && options.colourScheme\n        ? options.colourScheme\n        : options && options.colorScheme\n          ? options.colorScheme\n          : [\n              '#1f77b4',\n              '#ff7f0e',\n              '#2ca02c',\n              '#d62728',\n              '#9467bd',\n              '#8c564b',\n              '#e377c2',\n              '#7f7f7f',\n              '#bcbd22',\n              '#17becf',\n            ],\n    colourIndex = 0,\n    colours = function (key) {\n      if (key in colourMap) {\n        return colourMap[key];\n      }\n      var ret = (colourMap[key] = colourScheme[colourIndex]);\n      colourIndex += 1;\n      if (colourIndex >= colourScheme.length) {\n        colourIndex = 0;\n      }\n      return ret;\n    },\n    layoutFunction = venn,\n    loss = lossFunction;\n\n  function chart(selection) {\n    let data = selection.datum();\n\n    // handle 0-sized sets by removing from input\n    const toRemove = new Set();\n    data.forEach((datum) => {\n      if (datum.size == 0 && datum.sets.length == 1) {\n        toRemove.add(datum.sets[0]);\n      }\n    });\n    data = data.filter((datum) => !datum.sets.some((set) => toRemove.has(set)));\n\n    let circles = {};\n    let textCentres = {};\n\n    if (data.length > 0) {\n      let solution = layoutFunction(data, { lossFunction: loss, distinct });\n\n      if (normalize) {\n        solution = normalizeSolution(solution, orientation, orientationOrder);\n      }\n\n      circles = scaleSolution(solution, width, height, padding, scaleToFit);\n      textCentres = computeTextCentres(circles, data, symmetricalTextCentre);\n    }\n\n    // Figure out the current label for each set. These can change\n    // and D3 won't necessarily update (fixes https://github.com/benfred/venn.js/issues/103)\n    const labels = {};\n    data.forEach((datum) => {\n      if (datum.label) {\n        labels[datum.sets] = datum.label;\n      }\n    });\n\n    function label(d) {\n      if (d.sets in labels) {\n        return labels[d.sets];\n      }\n      if (d.sets.length == 1) {\n        return '' + d.sets[0];\n      }\n    }\n\n    // create svg if not already existing\n    selection.selectAll('svg').data([circles]).enter().append('svg');\n\n    const svg = selection.select('svg');\n\n    if (useViewBox) {\n      svg.attr('viewBox', `0 0 ${width} ${height}`);\n    } else {\n      svg.attr('width', width).attr('height', height);\n    }\n\n    // to properly transition intersection areas, we need the\n    // previous circles locations. load from elements\n    const previous = {};\n    let hasPrevious = false;\n    svg.selectAll('.venn-area path').each(function (d) {\n      const path = this.getAttribute('d');\n      if (d.sets.length == 1 && path && !distinct) {\n        hasPrevious = true;\n        previous[d.sets[0]] = circleFromPath(path);\n      }\n    });\n    // interpolate intersection area paths between previous and\n    // current paths\n    function pathTween(d) {\n      return (t) => {\n        const c = d.sets.map((set) => {\n          let start = previous[set];\n          let end = circles[set];\n          if (!start) {\n            start = { x: width / 2, y: height / 2, radius: 1 };\n          }\n          if (!end) {\n            end = { x: width / 2, y: height / 2, radius: 1 };\n          }\n          return {\n            x: start.x * (1 - t) + end.x * t,\n            y: start.y * (1 - t) + end.y * t,\n            radius: start.radius * (1 - t) + end.radius * t,\n          };\n        });\n        return intersectionAreaPath(c, round);\n      };\n    }\n\n    // update data, joining on the set ids\n    const nodes = svg.selectAll('.venn-area').data(data, (d) => d.sets);\n\n    // create new nodes\n    const enter = nodes\n      .enter()\n      .append('g')\n      .attr(\n        'class',\n        (d) =>\n          `venn-area venn-${d.sets.length == 1 ? 'circle' : 'intersection'}${\n            d.colour || d.color ? ' venn-coloured' : ''\n          }`\n      )\n      .attr('data-venn-sets', (d) => d.sets.join('_'));\n\n    const enterPath = enter.append('path');\n    const enterText = enter\n      .append('text')\n      .attr('class', 'label')\n      .text((d) => label(d))\n      .attr('text-anchor', 'middle')\n      .attr('dy', '.35em')\n      .attr('x', width / 2)\n      .attr('y', height / 2);\n\n    // apply minimal style if wanted\n    if (styled) {\n      enterPath\n        .style('fill-opacity', '0')\n        .filter((d) => d.sets.length == 1)\n        .style('fill', (d) => (d.colour ? d.colour : d.color ? d.color : colours(d.sets)))\n        .style('fill-opacity', '.25');\n\n      enterText.style('fill', (d) => {\n        if (d.colour || d.color) {\n          return '#FFF';\n        }\n        if (options.textFill) {\n          return options.textFill;\n        }\n        return d.sets.length == 1 ? colours(d.sets) : '#444';\n      });\n    }\n\n    function asTransition(s) {\n      if (typeof s.transition === 'function') {\n        return s.transition('venn').duration(duration);\n      }\n      return s;\n    }\n\n    // update existing, using pathTween if necessary\n    let update = selection;\n    if (hasPrevious && typeof update.transition === 'function') {\n      update = asTransition(selection);\n      update.selectAll('path').attrTween('d', pathTween);\n    } else {\n      update.selectAll('path').attr('d', (d) => intersectionAreaPath(d.sets.map((set) => circles[set])), round);\n    }\n\n    const updateText = update\n      .selectAll('text')\n      .filter((d) => d.sets in textCentres)\n      .text((d) => label(d))\n      .attr('x', (d) => Math.floor(textCentres[d.sets].x))\n      .attr('y', (d) => Math.floor(textCentres[d.sets].y));\n\n    if (wrap) {\n      if (hasPrevious) {\n        // d3 4.0 uses 'on' for events on transitions,\n        // but d3 3.0 used 'each' instead. switch appropriately\n        if ('on' in updateText) {\n          updateText.on('end', wrapText(circles, label));\n        } else {\n          updateText.each('end', wrapText(circles, label));\n        }\n      } else {\n        updateText.each(wrapText(circles, label));\n      }\n    }\n\n    // remove old\n    const exit = asTransition(nodes.exit()).remove();\n    if (typeof nodes.transition === 'function') {\n      exit.selectAll('path').attrTween('d', pathTween);\n    }\n\n    const exitText = exit\n      .selectAll('text')\n      .attr('x', width / 2)\n      .attr('y', height / 2);\n\n    // if we've been passed a fontSize explicitly, use it to\n    // transition\n    if (fontSize !== null) {\n      enterText.style('font-size', '0px');\n      updateText.style('font-size', fontSize);\n      exitText.style('font-size', '0px');\n    }\n\n    return { circles, textCentres, nodes, enter, update, exit };\n  }\n\n  chart.wrap = function (_) {\n    if (!arguments.length) return wrap;\n    wrap = _;\n    return chart;\n  };\n\n  chart.useViewBox = function () {\n    useViewBox = true;\n    return chart;\n  };\n\n  chart.width = function (_) {\n    if (!arguments.length) return width;\n    width = _;\n    return chart;\n  };\n\n  chart.height = function (_) {\n    if (!arguments.length) return height;\n    height = _;\n    return chart;\n  };\n\n  chart.padding = function (_) {\n    if (!arguments.length) return padding;\n    padding = _;\n    return chart;\n  };\n\n  chart.distinct = function (_) {\n    if (!arguments.length) return distinct;\n    distinct = _;\n    return chart;\n  };\n\n  chart.colours = function (_) {\n    if (!arguments.length) return colours;\n    colours = _;\n    return chart;\n  };\n\n  chart.colors = function (_) {\n    if (!arguments.length) return colours;\n    colours = _;\n    return chart;\n  };\n\n  chart.fontSize = function (_) {\n    if (!arguments.length) return fontSize;\n    fontSize = _;\n    return chart;\n  };\n\n  chart.round = function (_) {\n    if (!arguments.length) return round;\n    round = _;\n    return chart;\n  };\n\n  chart.duration = function (_) {\n    if (!arguments.length) return duration;\n    duration = _;\n    return chart;\n  };\n\n  chart.layoutFunction = function (_) {\n    if (!arguments.length) return layoutFunction;\n    layoutFunction = _;\n    return chart;\n  };\n\n  chart.normalize = function (_) {\n    if (!arguments.length) return normalize;\n    normalize = _;\n    return chart;\n  };\n\n  chart.scaleToFit = function (_) {\n    if (!arguments.length) return scaleToFit;\n    scaleToFit = _;\n    return chart;\n  };\n\n  chart.styled = function (_) {\n    if (!arguments.length) return styled;\n    styled = _;\n    return chart;\n  };\n\n  chart.orientation = function (_) {\n    if (!arguments.length) return orientation;\n    orientation = _;\n    return chart;\n  };\n\n  chart.orientationOrder = function (_) {\n    if (!arguments.length) return orientationOrder;\n    orientationOrder = _;\n    return chart;\n  };\n\n  chart.lossFunction = function (_) {\n    if (!arguments.length) return loss;\n    loss = _ === 'default' ? lossFunction : _ === 'logRatio' ? logRatioLossFunction : _;\n    return chart;\n  };\n\n  return chart;\n}\n\n// sometimes text doesn't fit inside the circle, if thats the case lets wrap\n// the text here such that it fits\n// todo: looks like this might be merged into d3 (\n// https://github.com/mbostock/d3/issues/1642),\n// also worth checking out is\n// http://engineering.findthebest.com/wrapping-axis-labels-in-d3-js/\n// this seems to be one of those things that should be easy but isn't\nfunction wrapText(circles, labeller) {\n  return function (data) {\n    const text = this;\n    const width = circles[data.sets[0]].radius || 50;\n    const label = labeller(data) || '';\n\n    const words = label.split(/\\s+/).reverse();\n    const maxLines = 3;\n    const minChars = (label.length + words.length) / maxLines;\n\n    let word = words.pop();\n    let line = [word];\n    let lineNumber = 0;\n    const lineHeight = 1.1; // ems\n    text.textContent = null; // clear\n    const tspans = [];\n\n    function append(word) {\n      const tspan = text.ownerDocument.createElementNS(text.namespaceURI, 'tspan');\n      tspan.textContent = word;\n      tspans.push(tspan);\n      text.append(tspan);\n      return tspan;\n    }\n    let tspan = append(word);\n\n    while (true) {\n      word = words.pop();\n      if (!word) {\n        break;\n      }\n      line.push(word);\n      const joined = line.join(' ');\n      tspan.textContent = joined;\n      if (joined.length > minChars && tspan.getComputedTextLength() > width) {\n        line.pop();\n        tspan.textContent = line.join(' ');\n        line = [word];\n        tspan = append(word);\n        lineNumber++;\n      }\n    }\n\n    const initial = 0.35 - (lineNumber * lineHeight) / 2;\n    const x = text.getAttribute('x');\n    const y = text.getAttribute('y');\n    tspans.forEach((t, i) => {\n      t.setAttribute('x', x);\n      t.setAttribute('y', y);\n      t.setAttribute('dy', `${initial + i * lineHeight}em`);\n    });\n  };\n}\n\n/**\n *\n * @param {{x: number, y: number}} current\n * @param {ReadonlyArray<{x: number, y: number}>} interior\n * @param {ReadonlyArray<{x: number, y: number}>} exterior\n * @returns {number}\n */\nfunction circleMargin(current, interior, exterior) {\n  let margin = interior[0].radius - distance(interior[0], current);\n\n  for (let i = 1; i < interior.length; ++i) {\n    const m = interior[i].radius - distance(interior[i], current);\n    if (m <= margin) {\n      margin = m;\n    }\n  }\n\n  for (let i = 0; i < exterior.length; ++i) {\n    const m = distance(exterior[i], current) - exterior[i].radius;\n    if (m <= margin) {\n      margin = m;\n    }\n  }\n  return margin;\n}\n\n/**\n * compute the center of some circles by maximizing the margin of\n * the center point relative to the circles (interior) after subtracting\n * nearby circles (exterior)\n * @param {readonly {x: number, y: number, radius: number}[]} interior\n * @param {readonly {x: number, y: number, radius: number}[]} exterior\n * @param {boolean} symmetricalTextCentre\n * @returns {{x:number, y: number}}\n */\nfunction computeTextCentre(interior, exterior, symmetricalTextCentre) {\n  // get an initial estimate by sampling around the interior circles\n  // and taking the point with the biggest margin\n  /** @type {{x: number, y: number}[]} */\n  const points = [];\n  for (const c of interior) {\n    points.push({ x: c.x, y: c.y });\n    points.push({ x: c.x + c.radius / 2, y: c.y });\n    points.push({ x: c.x - c.radius / 2, y: c.y });\n    points.push({ x: c.x, y: c.y + c.radius / 2 });\n    points.push({ x: c.x, y: c.y - c.radius / 2 });\n  }\n\n  let initial = points[0];\n  let margin = circleMargin(points[0], interior, exterior);\n\n  for (let i = 1; i < points.length; ++i) {\n    const m = circleMargin(points[i], interior, exterior);\n    if (m >= margin) {\n      initial = points[i];\n      margin = m;\n    }\n  }\n\n  // maximize the margin numerically\n  const solution = nelderMead(\n    (p) => -1 * circleMargin({ x: p[0], y: p[1] }, interior, exterior),\n    [initial.x, initial.y],\n    { maxIterations: 500, minErrorDelta: 1e-10 }\n  ).x;\n\n  const ret = { x: symmetricalTextCentre ? 0 : solution[0], y: solution[1] };\n\n  // check solution, fallback as needed (happens if fully overlapped\n  // etc)\n  let valid = true;\n  for (const i of interior) {\n    if (distance(ret, i) > i.radius) {\n      valid = false;\n      break;\n    }\n  }\n\n  for (const e of exterior) {\n    if (distance(ret, e) < e.radius) {\n      valid = false;\n      break;\n    }\n  }\n  if (valid) {\n    return ret;\n  }\n\n  if (interior.length == 1) {\n    return { x: interior[0].x, y: interior[0].y };\n  }\n  const areaStats = {};\n  intersectionArea(interior, areaStats);\n\n  if (areaStats.arcs.length === 0) {\n    return { x: 0, y: -1000, disjoint: true };\n  }\n  if (areaStats.arcs.length == 1) {\n    return { x: areaStats.arcs[0].circle.x, y: areaStats.arcs[0].circle.y };\n  }\n  if (exterior.length) {\n    // try again without other circles\n    return computeTextCentre(interior, []);\n  }\n  // take average of all the points in the intersection\n  // polygon. this should basically never happen\n  // and has some issues:\n  // https://github.com/benfred/venn.js/issues/48#issuecomment-146069777\n  return getCenter(areaStats.arcs.map((a) => a.p1));\n}\n\n// given a dictionary of {setid : circle}, returns\n// a dictionary of setid to list of circles that completely overlap it\nfunction getOverlappingCircles(circles) {\n  const ret = {};\n  const circleids = Object.keys(circles);\n  for (const circleid of circleids) {\n    ret[circleid] = [];\n  }\n  for (let i = 0; i < circleids.length; i++) {\n    const ci = circleids[i];\n    const a = circles[ci];\n    for (let j = i + 1; j < circleids.length; ++j) {\n      const cj = circleids[j];\n      const b = circles[cj];\n      const d = distance(a, b);\n\n      if (d + b.radius <= a.radius + 1e-10) {\n        ret[cj].push(ci);\n      } else if (d + a.radius <= b.radius + 1e-10) {\n        ret[ci].push(cj);\n      }\n    }\n  }\n  return ret;\n}\n\nfunction computeTextCentres(circles, areas, symmetricalTextCentre) {\n  const ret = {};\n  const overlapped = getOverlappingCircles(circles);\n  for (let i = 0; i < areas.length; ++i) {\n    const area = areas[i].sets;\n    const areaids = {};\n    const exclude = {};\n\n    for (let j = 0; j < area.length; ++j) {\n      areaids[area[j]] = true;\n      const overlaps = overlapped[area[j]];\n      // keep track of any circles that overlap this area,\n      // and don't consider for purposes of computing the text\n      // centre\n      for (let k = 0; k < overlaps.length; ++k) {\n        exclude[overlaps[k]] = true;\n      }\n    }\n\n    const interior = [];\n    const exterior = [];\n    for (let setid in circles) {\n      if (setid in areaids) {\n        interior.push(circles[setid]);\n      } else if (!(setid in exclude)) {\n        exterior.push(circles[setid]);\n      }\n    }\n    const centre = computeTextCentre(interior, exterior, symmetricalTextCentre);\n    ret[area] = centre;\n    if (centre.disjoint && areas[i].size > 0) {\n      console.log('WARNING: area ' + area + ' not represented on screen');\n    }\n  }\n  return ret;\n}\n\n// sorts all areas in the venn diagram, so that\n// a particular area is on top (relativeTo) - and\n// all other areas are so that the smallest areas are on top\nfunction sortAreas(div, relativeTo) {\n  // figure out sets that are completely overlapped by relativeTo\n  const overlaps = getOverlappingCircles(div.selectAll('svg').datum());\n  const exclude = new Set();\n  for (const check of relativeTo.sets) {\n    for (let setid in overlaps) {\n      const overlap = overlaps[setid];\n      for (let j = 0; j < overlap.length; ++j) {\n        if (overlap[j] == check) {\n          exclude.add(setid);\n          break;\n        }\n      }\n    }\n  }\n\n  // checks that all sets are in exclude;\n  function shouldExclude(sets) {\n    return sets.every((set) => !exclude.has(set));\n  }\n\n  // need to sort div's so that Z order is correct\n  div.selectAll('g').sort((a, b) => {\n    // highest order set intersections first\n    if (a.sets.length != b.sets.length) {\n      return a.sets.length - b.sets.length;\n    }\n\n    if (a == relativeTo) {\n      return shouldExclude(b.sets) ? -1 : 1;\n    }\n    if (b == relativeTo) {\n      return shouldExclude(a.sets) ? 1 : -1;\n    }\n\n    // finally by size\n    return b.size - a.size;\n  });\n}\n\n/**\n * @param {number} x\n * @param {number} y\n * @param {number} r\n * @returns {string}\n */\nfunction circlePath(x, y, r) {\n  const ret = [];\n  ret.push('\\nM', x, y);\n  ret.push('\\nm', -r, 0);\n  ret.push('\\na', r, r, 0, 1, 0, r * 2, 0);\n  ret.push('\\na', r, r, 0, 1, 0, -r * 2, 0);\n  return ret.join(' ');\n}\n\n/**\n * inverse of the circlePath function, returns a circle object from an svg path\n * @param {string} path\n * @returns {{x: number, y: number, radius: number}}\n */\nfunction circleFromPath(path) {\n  const tokens = path.split(' ');\n  return { x: Number.parseFloat(tokens[1]), y: Number.parseFloat(tokens[2]), radius: -Number.parseFloat(tokens[4]) };\n}\n\nfunction intersectionAreaArcs(circles) {\n  if (circles.length === 0) {\n    return [];\n  }\n  const stats = {};\n  intersectionArea(circles, stats);\n  return stats.arcs;\n}\n\nfunction arcsToPath(arcs, round) {\n  if (arcs.length === 0) {\n    return 'M 0 0';\n  }\n  const rFactor = Math.pow(10, round || 0);\n  const r = round != null ? (v) => Math.round(v * rFactor) / rFactor : (v) => v;\n  if (arcs.length == 1) {\n    const circle = arcs[0].circle;\n    return circlePath(r(circle.x), r(circle.y), r(circle.radius));\n  }\n  // draw path around arcs\n  const ret = ['\\nM', r(arcs[0].p2.x), r(arcs[0].p2.y)];\n  for (const arc of arcs) {\n    const radius = r(arc.circle.radius);\n    ret.push('\\nA', radius, radius, 0, arc.large ? 1 : 0, arc.sweep ? 1 : 0, r(arc.p1.x), r(arc.p1.y));\n  }\n  return ret.join(' ');\n}\n\n/**\n * returns a svg path of the intersection area of a bunch of circles\n * @param {ReadonlyArray<{x: number, y: number, radius: number}>} circles\n * @returns {string}\n */\nfunction intersectionAreaPath(circles, round) {\n  return arcsToPath(intersectionAreaArcs(circles), round);\n}\n\nfunction layout(data, options = {}) {\n  const {\n    lossFunction: loss,\n    layoutFunction: layout = venn,\n    normalize = true,\n    orientation = Math.PI / 2,\n    orientationOrder,\n    width = 600,\n    height = 350,\n    padding = 15,\n    scaleToFit = false,\n    symmetricalTextCentre = false,\n    distinct,\n    round = 2,\n  } = options;\n\n  let solution = layout(data, {\n    lossFunction: loss === 'default' || !loss ? lossFunction : loss === 'logRatio' ? logRatioLossFunction : loss,\n    distinct,\n  });\n\n  if (normalize) {\n    solution = normalizeSolution(solution, orientation, orientationOrder);\n  }\n\n  const circles = scaleSolution(solution, width, height, padding, scaleToFit);\n  const textCentres = computeTextCentres(circles, data, symmetricalTextCentre);\n\n  const circleLookup = new Map(\n    Object.keys(circles).map((set) => [\n      set,\n      {\n        set,\n        x: circles[set].x,\n        y: circles[set].y,\n        radius: circles[set].radius,\n      },\n    ])\n  );\n  const helpers = data.map((area) => {\n    const circles = area.sets.map((s) => circleLookup.get(s));\n    const arcs = intersectionAreaArcs(circles);\n    const path = arcsToPath(arcs, round);\n    return { circles, arcs, path, area, has: new Set(area.sets) };\n  });\n\n  function genDistinctPath(sets) {\n    let r = '';\n    for (const e of helpers) {\n      if (e.has.size > sets.length && sets.every((s) => e.has.has(s))) {\n        r += ' ' + e.path;\n      }\n    }\n    return r;\n  }\n\n  return helpers.map(({ circles, arcs, path, area }) => {\n    return {\n      data: area,\n      text: textCentres[area.sets],\n      circles,\n      arcs,\n      path,\n      distinctPath: path + genDistinctPath(area.sets),\n    };\n  });\n}\n\nexport { VennDiagram, bestInitialLayout, circleArea, circleCircleIntersection, circleFromPath, circleOverlap, circlePath, computeTextCentre, computeTextCentres, disjointCluster, distance, distanceFromIntersectArea, greedyLayout, intersectionArea, intersectionAreaPath, layout, logRatioLossFunction, lossFunction, normalizeSolution, scaleSolution, sortAreas, venn, wrapText };\n", "import type { Diagram } from '../../Diagram.js';\nimport type { VennData, VennDB, VennTextData, VennStyleData } from './vennTypes.js';\nimport type { DiagramRenderer, DrawDefinition } from '../../diagram-api/types.js';\nimport type { VennDiagramConfig } from '../../config.type.js';\nimport type { Selection } from 'd3';\nimport { select as d3select } from 'd3';\n// @ts-expect-error Incorrect khroma types\nimport { isDark, lighten, darken, transparentize } from 'khroma';\nimport { getConfig } from '../../config.js';\nimport { selectSvgElement } from '../../rendering-util/selectSvgElement.js';\nimport * as venn from '@upsetjs/venn.js';\nimport { configureSvgSize } from '../../setupGraphViewbox.js';\nimport rough from 'roughjs';\n\ntype DummyD3Root = Selection<HTMLDivElement, unknown, null, undefined>;\n\nfunction buildStyleByKey(styleData: VennStyleData[]): Map<string, Record<string, string>> {\n  const map = new Map<string, Record<string, string>>();\n  for (const entry of styleData) {\n    const key = entry.targets.join('|');\n    const existing = map.get(key);\n    if (existing) {\n      Object.assign(existing, entry.styles);\n    } else {\n      map.set(key, { ...entry.styles });\n    }\n  }\n  return map;\n}\n\nexport const draw: DrawDefinition = (\n  _text: string,\n  id: string,\n  _version: string,\n  diagObj: Diagram\n): void => {\n  const db = diagObj.db as VennDB;\n  const config = db.getConfig?.();\n  const { themeVariables, look, handDrawnSeed } = getConfig();\n  const isHandDrawn = look === 'handDrawn';\n  const themeColors: string[] = [\n    themeVariables.venn1,\n    themeVariables.venn2,\n    themeVariables.venn3,\n    themeVariables.venn4,\n    themeVariables.venn5,\n    themeVariables.venn6,\n    themeVariables.venn7,\n    themeVariables.venn8,\n  ].filter(Boolean);\n  const title = db.getDiagramTitle?.();\n  const sets = db.getSubsetData();\n  const textNodes = db.getTextData();\n  const styleByKey = buildStyleByKey(db.getStyleData());\n\n  // Configurable viewBox size with scale factor for proportional rendering\n  const svgWidth = config?.width ?? 800;\n  const svgHeight = config?.height ?? 450;\n  const REFERENCE_WIDTH = 1600;\n  const scale = svgWidth / REFERENCE_WIDTH;\n  const titleHeight = title ? 48 * scale : 0;\n\n  const defaultTextColor = themeVariables.primaryTextColor ?? themeVariables.textColor;\n\n  // Prepare the target viewBox\n  const svg = selectSvgElement(id);\n  svg.attr('viewBox', `0 0 ${svgWidth} ${svgHeight}`);\n\n  if (title) {\n    svg\n      .append('text')\n      .text(title)\n      .attr('class', 'venn-title')\n      .attr('font-size', `${32 * scale}px`)\n      .attr('text-anchor', 'middle')\n      .attr('dominant-baseline', 'middle')\n      .attr('x', '50%')\n      .attr('y', 32 * scale)\n      .style('fill', themeVariables.vennTitleTextColor || themeVariables.titleColor);\n  }\n\n  // Get the original SVG output of Venn.js from a dummy root\n  const dummyD3root: DummyD3Root = d3select(document.createElement('div'));\n  const vennDiagram = venn\n    .VennDiagram()\n    .width(svgWidth)\n    .height(svgHeight - titleHeight);\n  dummyD3root.datum(sets).call(vennDiagram as never);\n\n  const roughSvg = isHandDrawn\n    ? rough.svg(dummyD3root.select('svg').node() as SVGSVGElement)\n    : undefined;\n\n  // Compute layout areas so we can position additional text nodes\n  const layoutAreas = venn.layout(sets, {\n    width: svgWidth,\n    height: svgHeight - titleHeight,\n    padding: config?.padding ?? 15,\n  });\n\n  // Build a lookup table from set key to layout area\n  const layoutByKey = new Map<string, (typeof layoutAreas)[number]>();\n  for (const area of layoutAreas) {\n    const key = stableSetsKey([...area.data.sets].sort());\n    layoutByKey.set(key, area);\n  }\n\n  if (textNodes.length > 0) {\n    renderTextNodes(config, layoutByKey, dummyD3root, textNodes, scale, styleByKey);\n  }\n\n  // Style the set circles with theme colors\n  const themeDark = isDark(themeVariables.background || '#f4f4f4');\n  dummyD3root.selectAll('.venn-circle').each(function (d, i) {\n    const group = d3select(this as Element);\n    const data = d as VennData;\n    const setsKey = stableSetsKey([...data.sets].sort());\n    const customStyle = styleByKey.get(setsKey);\n    const baseColor =\n      customStyle?.fill || themeColors[i % themeColors.length] || themeVariables.primaryColor;\n    group.classed(`venn-set-${i % 8}`, true);\n    const fillOpacity = customStyle?.['fill-opacity'] ?? 0.1;\n    const strokeColor = customStyle?.stroke || baseColor;\n    const strokeWidthVal = customStyle?.['stroke-width'] || `${5 * scale}`;\n\n    if (isHandDrawn && roughSvg) {\n      const layoutArea = layoutByKey.get(setsKey);\n      if (layoutArea && layoutArea.circles.length > 0) {\n        const c = layoutArea.circles[0];\n        const roughNode = roughSvg.circle(c.x, c.y, c.radius * 2, {\n          roughness: 0.7,\n          seed: handDrawnSeed,\n          fill: transparentize(baseColor, 0.7),\n          fillStyle: 'hachure',\n          fillWeight: 2,\n          hachureGap: 8,\n          hachureAngle: -41 + i * 60,\n          stroke: strokeColor,\n          strokeWidth: parseFloat(String(strokeWidthVal)),\n        });\n        group.select('path').remove();\n        group.node()?.insertBefore(roughNode, group.select('text').node() as Node | null);\n      }\n    } else {\n      group\n        .select('path')\n        .style('fill', baseColor)\n        .style('fill-opacity', fillOpacity)\n        .style('stroke', strokeColor)\n        .style('stroke-width', strokeWidthVal)\n        .style('stroke-opacity', 0.95);\n    }\n    // Blend border color toward black (light theme) or white (dark theme) for readable text\n    const textColor: string =\n      customStyle?.color || (themeDark ? lighten(baseColor, 30) : darken(baseColor, 30));\n    group\n      .select('text')\n      .style('font-size', `${48 * scale}px`)\n      .style('fill', textColor);\n  });\n\n  // Style the union labels\n  if (isHandDrawn && roughSvg) {\n    dummyD3root.selectAll('.venn-intersection').each(function (d) {\n      const group = d3select(this as Element);\n      const data = d as VennData;\n      const setsKey = stableSetsKey([...data.sets].sort());\n      const customStyle = styleByKey.get(setsKey);\n      const customFill = customStyle?.fill;\n\n      if (customFill) {\n        const pathEl = group.select('path');\n        const pathD = pathEl.attr('d');\n        if (pathD) {\n          const roughNode = roughSvg.path(pathD, {\n            roughness: 0.7,\n            seed: handDrawnSeed,\n            fill: transparentize(customFill, 0.3),\n            fillStyle: 'cross-hatch',\n            fillWeight: 2,\n            hachureGap: 6,\n            hachureAngle: 60,\n            stroke: 'none',\n          });\n          const existingPath = pathEl.node() as Element | null;\n          existingPath?.parentNode?.insertBefore(roughNode, existingPath);\n          pathEl.remove();\n        }\n      } else {\n        group.select('path').style('fill-opacity', 0);\n      }\n\n      group\n        .select('text')\n        .style('font-size', `${48 * scale}px`)\n        .style('fill', customStyle?.color ?? themeVariables.vennSetTextColor ?? defaultTextColor);\n    });\n  } else {\n    dummyD3root\n      .selectAll('.venn-intersection text')\n      .style('font-size', `${48 * scale}px`)\n      .style('fill', (e) => {\n        const data = e as VennData;\n        const setsKey = stableSetsKey([...data.sets].sort());\n        return (\n          styleByKey.get(setsKey)?.color ?? themeVariables.vennSetTextColor ?? defaultTextColor\n        );\n      });\n    dummyD3root\n      .selectAll('.venn-intersection path')\n      .style('fill-opacity', (e) => {\n        const data = e as VennData;\n        const setsKey = stableSetsKey([...data.sets].sort());\n        return styleByKey.get(setsKey)?.fill ? 1 : 0;\n      })\n      .style('fill', (e) => {\n        const data = e as VennData;\n        const setsKey = stableSetsKey([...data.sets].sort());\n        return styleByKey.get(setsKey)?.fill ?? 'transparent';\n      });\n  }\n\n  // Transfer the dummy SVG contents into the real SVG group\n  const vennGroup = svg.append('g').attr('transform', `translate(0, ${titleHeight})`);\n  const dummySvg = dummyD3root.select('svg').node();\n  if (dummySvg && 'childNodes' in dummySvg) {\n    for (const child of [...dummySvg.childNodes]) {\n      vennGroup.node()?.appendChild(child);\n    }\n  }\n  configureSvgSize(svg, svgHeight, svgWidth, config?.useMaxWidth ?? true);\n};\n\nfunction stableSetsKey(setIds: string[]): string {\n  return setIds.join('|');\n}\n\nfunction renderTextNodes(\n  config: Required<VennDiagramConfig>,\n  layoutByKey: Map<string, venn.IVennLayout<VennData>>,\n  dummyD3root: DummyD3Root,\n  textNodes: VennTextData[],\n  scale: number,\n  styleByKey: Map<string, Record<string, string>>\n) {\n  const useDebugLayout = config?.useDebugLayout ?? false;\n  const vennSvg = dummyD3root.select('svg');\n  const textGroup = vennSvg.append('g').attr('class', 'venn-text-nodes');\n\n  // Group text nodes by the set key they belong to\n  const nodesByArea = new Map<string, VennTextData[]>();\n  for (const node of textNodes) {\n    const key = stableSetsKey(node.sets);\n    const existing = nodesByArea.get(key);\n    if (existing) {\n      existing.push(node);\n    } else {\n      nodesByArea.set(key, [node]);\n    }\n  }\n\n  // For each area, compute a text box and place nodes in a grid.\n  for (const [key, nodes] of nodesByArea.entries()) {\n    const area = layoutByKey.get(key);\n    if (!area?.text) {\n      continue;\n    }\n    // Calculate the center point and a safe inner radius for text.\n    const centerX = area.text.x;\n    const centerY = area.text.y;\n    const minCircleRadius = Math.min(...area.circles.map((c) => c.radius));\n    const innerRadiusRaw = Math.min(\n      ...area.circles.map((c) => c.radius - Math.hypot(centerX - c.x, centerY - c.y))\n    );\n    let innerRadius = Number.isFinite(innerRadiusRaw) ? Math.max(0, innerRadiusRaw) : 0;\n    if (innerRadius === 0 && Number.isFinite(minCircleRadius)) {\n      innerRadius = minCircleRadius * 0.6;\n    }\n\n    // Render text area container\n    const areaGroup = textGroup\n      .append('g')\n      .attr('class', 'venn-text-area')\n      .attr('font-size', `${40 * scale}px`);\n    if (useDebugLayout) {\n      areaGroup\n        .append('circle')\n        .attr('class', 'venn-text-debug-circle')\n        .attr('cx', centerX)\n        .attr('cy', centerY)\n        .attr('r', innerRadius)\n        .attr('fill', 'none')\n        .attr('stroke', 'purple')\n        .attr('stroke-width', 1.5 * scale)\n        .attr('stroke-dasharray', `${6 * scale} ${4 * scale}`);\n    }\n\n    // Compute a grid within the area for placing text nodes\n    const innerWidth = Math.max(80 * scale, innerRadius * 2 * 0.95);\n    const innerHeight = Math.max(60 * scale, innerRadius * 2 * 0.95);\n    const hasLabel = area.data.label && area.data.label.length > 0;\n    const labelOffsetBase = hasLabel ? Math.min(32 * scale, innerRadius * 0.25) : 0;\n    const labelOffset = labelOffsetBase + (nodes.length <= 2 ? 30 * scale : 0);\n    const startX = centerX - innerWidth / 2;\n    const startY = centerY - innerHeight / 2 + labelOffset;\n    const cols = Math.max(1, Math.ceil(Math.sqrt(nodes.length)));\n    const rows = Math.max(1, Math.ceil(nodes.length / cols));\n    const cellWidth = innerWidth / cols;\n    const cellHeight = innerHeight / rows;\n\n    // Place each node into a grid cell\n    for (const [i, node] of nodes.entries()) {\n      const col = i % cols;\n      const row = Math.floor(i / cols);\n      const x = startX + cellWidth * (col + 0.5);\n      const y = startY + cellHeight * (row + 0.5);\n\n      if (useDebugLayout) {\n        areaGroup\n          .append('rect')\n          .attr('class', 'venn-text-debug-cell')\n          .attr('x', startX + cellWidth * col)\n          .attr('y', startY + cellHeight * row)\n          .attr('width', cellWidth)\n          .attr('height', cellHeight)\n          .attr('fill', 'none')\n          .attr('stroke', 'teal')\n          .attr('stroke-width', 1 * scale)\n          .attr('stroke-dasharray', `${4 * scale} ${3 * scale}`);\n      }\n\n      const boxWidth = cellWidth * 0.9;\n      const boxHeight = cellHeight * 0.9;\n\n      // foreignObject lets us use HTML styling for auto-wrap\n      const container = areaGroup\n        .append('foreignObject')\n        .attr('class', 'venn-text-node-fo')\n        .attr('width', boxWidth)\n        .attr('height', boxHeight)\n        .attr('x', x - boxWidth / 2)\n        .attr('y', y - boxHeight / 2)\n        .attr('overflow', 'visible');\n\n      const textColor = styleByKey.get(node.id)?.color;\n      const text = container\n        .append('xhtml:span')\n        .attr('class', 'venn-text-node')\n        .style('display', 'flex')\n        .style('width', '100%')\n        .style('height', '100%')\n        .style('white-space', 'normal')\n        .style('align-items', 'center')\n        .style('justify-content', 'center')\n        .style('text-align', 'center')\n        .style('overflow-wrap', 'normal')\n        .style('word-break', 'normal')\n        .text(node.label ?? node.id);\n\n      if (textColor) {\n        text.style('color', textColor);\n      }\n    }\n  }\n}\n\nexport const renderer: DiagramRenderer = { draw };\n", "import type { DiagramDefinition } from '../../diagram-api/types.js';\n// @ts-ignore: jison doesn't export types\nimport parser from './parser/venn.jison';\nimport { db } from './vennDB.js';\nimport flowStyles from './styles.js';\nimport { renderer } from './vennRenderer.js';\n\nexport const diagram: DiagramDefinition = {\n  parser,\n  db,\n  renderer,\n  styles: flowStyles,\n};\n"],
  "mappings": "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",
  "names": ["parser", "o", "__name", "k", "v", "l", "$V0", "$V1", "$V2", "$V3", "$V4", "$V5", "$V6", "$V7", "$V8", "$V9", "$Va", "$Vb", "$Vc", "$Vd", "yytext", "yyleng", "yylineno", "yy", "yystate", "$$", "_$", "$0", "cs", "str", "hash", "error", "input", "self", "stack", "tstack", "vstack", "lstack", "table", "recovering", "TERROR", "EOF", "args", "lexer", "sharedState", "yyloc", "ranges", "popStack", "n", "lex", "token", "symbol", "preErrorSymbol", "state", "action", "a", "r", "yyval", "p", "len", "newState", "expected", "errStr", "ch", "lines", "oldLines", "past", "next", "pre", "c", "match", "indexed_rule", "backup", "tempMatch", "index", "rules", "i", "condition", "yy_", "$avoiding_name_collisions", "YY_START", "YYSTATE", "Parser", "venn_default", "parser", "subsets", "textNodes", "styleEntries", "knownSets", "currentSets", "indentMode", "addSubsetData", "__name", "identifierList", "label", "size", "sets", "normalizeIdentifierList", "resolvedSize", "normalizeText", "getSubsetData", "text", "trimmed", "normalizeStyleValue", "value", "addTextData", "id", "normalizedId", "addStyleData", "data", "targets", "styles", "key", "getStyleData", "identifier", "validateUnionIdentifiers", "unknown", "getTextData", "getCurrentSets", "getIndentMode", "setIndentMode", "enabled", "DEFAULT_VENN_CONFIG", "defaultConfig_default", "getConfig", "cleanAndMerge", "customClear", "clear", "db", "setAccTitle", "getAccTitle", "setDiagramTitle", "getDiagramTitle", "getAccDescription", "setAccDescription", "getStyles", "__name", "options", "styles_default", "intersectionArea", "circles", "stats", "intersectionPoints", "getIntersectionPoints", "innerPoints", "p", "containedInCircles", "arcArea", "polygonArea", "arcs", "center", "getCenter", "i", "a", "b", "p2", "p1", "midPoint", "arc", "j", "circle", "a1", "a2", "angleDiff", "width", "distance", "circleArea", "smallest", "disjoint", "__name", "point", "ret", "intersect", "circleCircleIntersection", "r", "circleOverlap", "r1", "r2", "d", "w1", "w2", "h", "x0", "y0", "rx", "ry", "points", "bisect", "f", "parameters", "maxIterations", "tolerance", "fA", "fB", "delta", "mid", "fMid", "zeros", "x", "zerosM", "y", "dot", "norm2", "scale", "value", "c", "weightedSum", "v1", "v2", "nelderMead", "nonZeroDelta", "zeroDelta", "minErrorDelta", "minTolerance", "rho", "chi", "psi", "sigma", "maxDiff", "N", "simplex", "updateSimplex", "sortOrder", "centroid", "reflected", "contracted", "expanded", "iteration", "sortedSimplex", "state", "worst", "shouldReduce", "wolfeLineSearch", "pk", "current", "next", "c1", "c2", "phi0", "phiPrime0", "phi", "phi_old", "phiPrime", "a0", "zoom", "a_lo", "a_high", "phi_lo", "conjugateGradient", "initial", "params", "yk", "temp", "delta_k", "beta_k", "venn", "sets", "initialLayout", "bestInitialLayout", "loss", "lossFunction", "areas", "addMissingAreas", "setids", "setid", "positions", "values", "SMALL", "distanceFromIntersectArea", "overlap", "distinct", "s", "toKey", "arr", "count", "area", "si", "sj", "k1", "k2", "ids", "pairs", "getDistanceMatrices", "distances", "constraints", "left", "right", "constrainedMDSGradient", "fxprime", "xi", "yi", "xj", "yj", "dij", "constraint", "squaredDistance", "greedyLayout", "constrained", "constrainedMDSLayout", "constrainedLoss", "greedyLoss", "restarts", "norm", "row", "obj", "best", "set", "setOverlaps", "weight", "mostOverlapped", "size", "positioned", "isPositioned", "element", "positionSet", "index", "setIndex", "d1", "k", "d2", "extraPoints", "bestLoss", "bestPoint", "localLoss", "overlaps", "output", "logRatioLossFunction", "differenceFromIdeal", "orientateCircles", "orientation", "orientationOrder", "largestX", "largestY", "rotation", "angle", "slope", "disjointCluster", "find", "union", "xRoot", "yRoot", "maxDistance", "disjointClusters", "getBoundingBox", "minMax", "hi", "acc", "lo", "normalizeSolution", "solution", "fromObjectNotation", "clusters", "cluster", "bounds", "returnBounds", "spacing", "addCluster", "bottom", "xOffset", "yOffset", "centreing", "toObjectNotation", "scaleSolution", "height", "padding", "scaleToFit", "xRange", "yRange", "xScaling", "yScaling", "toScaleDiameter", "scaling", "id", "VennDiagram", "options", "useViewBox", "duration", "normalize", "wrap", "styled", "fontSize", "round", "symmetricalTextCentre", "colourMap", "colourScheme", "colourIndex", "colours", "key", "layoutFunction", "chart", "selection", "data", "toRemove", "datum", "textCentres", "computeTextCentres", "labels", "label", "svg", "previous", "hasPrevious", "path", "circleFromPath", "pathTween", "t", "start", "end", "intersectionAreaPath", "nodes", "enter", "enterPath", "enterText", "asTransition", "update", "updateText", "wrapText", "exit", "exitText", "_", "labeller", "text", "words", "minChars", "word", "line", "lineNumber", "lineHeight", "tspans", "append", "tspan", "joined", "circleMargin", "interior", "exterior", "margin", "m", "computeTextCentre", "valid", "e", "areaStats", "getOverlappingCircles", "circleids", "circleid", "ci", "cj", "overlapped", "areaids", "exclude", "centre", "circlePath", "x", "y", "r", "ret", "__name", "circleFromPath", "path", "tokens", "intersectionAreaArcs", "circles", "stats", "intersectionArea", "arcsToPath", "arcs", "round", "rFactor", "v", "circle", "arc", "radius", "intersectionAreaPath", "layout", "data", "options", "loss", "venn", "normalize", "orientation", "orientationOrder", "width", "height", "padding", "scaleToFit", "symmetricalTextCentre", "distinct", "solution", "lossFunction", "logRatioLossFunction", "normalizeSolution", "scaleSolution", "textCentres", "computeTextCentres", "circleLookup", "set", "helpers", "area", "s", "genDistinctPath", "sets", "e", "buildStyleByKey", "styleData", "map", "entry", "key", "existing", "__name", "draw", "_text", "id", "_version", "diagObj", "db", "config", "themeVariables", "look", "handDrawnSeed", "getConfig", "isHandDrawn", "themeColors", "title", "sets", "textNodes", "styleByKey", "svgWidth", "svgHeight", "scale", "titleHeight", "defaultTextColor", "svg", "selectSvgElement", "dummyD3root", "select_default", "vennDiagram", "VennDiagram", "roughSvg", "at", "layoutAreas", "layout", "layoutByKey", "area", "stableSetsKey", "renderTextNodes", "themeDark", "is_dark_default", "d", "i", "group", "setsKey", "customStyle", "baseColor", "fillOpacity", "strokeColor", "strokeWidthVal", "layoutArea", "c", "roughNode", "transparentize_default", "textColor", "lighten_default", "darken_default", "customFill", "pathEl", "pathD", "existingPath", "e", "vennGroup", "dummySvg", "child", "configureSvgSize", "setIds", "useDebugLayout", "textGroup", "nodesByArea", "node", "nodes", "centerX", "centerY", "minCircleRadius", "innerRadiusRaw", "innerRadius", "areaGroup", "innerWidth", "innerHeight", "labelOffset", "startX", "startY", "cols", "rows", "cellWidth", "cellHeight", "col", "row", "x", "y", "boxWidth", "boxHeight", "container", "text", "renderer", "diagram", "venn_default", "db", "renderer", "styles_default"]
}
