
<div id='dropdown-container'></div>

<div class='grid-container'>
        <div id='column-0' class="grid-column" style='max-height: 750px; '>
        <!-- Feature Info Tables -->
        <div class="feature-tables" id="feature-tables-0"></div></div>
    
    <div id='column-1' class="grid-column" style='max-height: 750px; '>
        <!-- Activation densities histogram -->
        <div class="plotly-hist" id="histogram-acts-0" style="height: 150px; margin-top: 0px;"></div>
        <!-- Logits table -->
        <div class="logits-table" id="logits-table-0"></div>
        <!-- Logits histogram -->
        <div class="plotly-hist" id="histogram-logits-0" style="height: 150px; margin-top: 0px;"></div></div>
    
    <div id='column-2-0' class="grid-column" style='max-height: 750px; '>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-0"></div></div>
    
    <div id='column-2-1' class="grid-column" style='max-height: 750px; '>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-1"></div>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-2"></div>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-3"></div></div>
    
    <div id='column-2-2' class="grid-column" style='max-height: 750px; '>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-4"></div>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-5"></div>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-6"></div></div>
    
    <div id='column-2-3' class="grid-column" style='max-height: 750px; '>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-7"></div>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-8"></div>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-9"></div></div>
    
    <div id='column-2-4' class="grid-column" style='max-height: 750px; '>
        <!-- Sequence group -->
        <div class="seq-group" id="seq-group-2-10"></div></div>
</div>

<style>
/* Styling of the dropdowns */
select {
    appearance: none;
    border: 0;
    flex: 1;
    padding: 0 1em;
    background-color: #eee;
    cursor: pointer;
}
.select {
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.25);
    cursor: pointer;
    display: flex;
    width: 100px;
    height: 25px;
    border-radius: .25em;
    overflow: hidden;
    position: relative;
    margin-right: 15px;
}
.select::after {
    position: absolute;
    content: '\25BC';
    font-size: 9px;
    top: 0;
    right: 0;
    padding: 1em;
    background-color: #ddd;
    transition: .25s all ease;
    pointer-events: none;
}
.select:hover::after {
    color: black;
}
#dropdown-container {
    margin-left: 10px;
    margin-top: 20px;
    display: flex;
    flex-wrap: wrap;
}
table {
    border: unset;
    color: black;
    border-collapse: collapse;
    width: -moz-fit-content;
    width: -webkit-fit-content;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    font-size: 0.8em;
}
table.table-left tr {
    border-bottom: 1px solid #eee;
    padding: 15px;
}
table.table-left td {
    padding: 3px 4px;
}
table.table-left {
    width: 100%;
}
table.table-left td.left-aligned {
    max-width: 120px;
    overflow-x: hidden;
}
td {
    border: none;
    padding: 2px 4px;
    white-space: nowrap;
}
.right-aligned {
    text-align: right;
}
.left-aligned {
    text-align: left;
}
.center-aligned {
    text-align: center;
    padding-bottom: 8px;
}
table code {
    background-color: #ddd;
    padding: 2px;
    border-radius: 3px;
}
.table-container {
    width: 100%;
}
.half-width-container {
    display: flex;
}
.half-width {
    width: 50%;
    margin-right: -4px;
}

/* Feature tables should have space below them, also they should have a min column width */
div.feature-tables table {
    margin-bottom: 25px;
    min-width: 250px;
}
/* Configure logits table container (i.e. the thing containing the smaller and larger tables) */
div.logits-table {
    min-width: 375px;
    display: flex;
    overflow-x: hidden;
    margin-bottom: 20px;
}
/* Code is always bold in this table (this is just the neg/pos string tokens) */
div.logits-table code {
    font-weight: bold;
}
/* Set width of the tables inside the container (so they can stack horizontally), also put a gap between them */
div.logits-table > div.positive {
    width: 47%;
}
div.logits-table > div.negative {
    width: 47%;
    margin-right: 5%;
}


/* Default font & appearance for the words in the sequence, before being hovered over */
code {
    font-family: Consolas, Menlo, Monaco;
}
/* Margin at the bottom of every sequence group, plus handle how overflow works (maybe not necessary) */
.seq-group {
    overflow-x: auto;
    overflow-y: visible;
    padding-top: 5px;
    padding-bottom: 10px;
    margin-bottom: 10px;
}
/* Margin between single sequences */
.seq {
    margin-bottom: 11px;
}
/* Styling for each token in a sequence */
.token {
    font-family: Consolas, Menlo, Monaco;
    font-size: 0.9em;
    border-top-left-radius: 3px;
    border-top-right-radius: 3px;
    padding: 1px;
    color: black;
    display: inline;
    white-space: pre-wrap;
}
/* All the messy hovering stuff! */
.hover-text {
    position: relative;
    cursor: pointer;
    display: inline-block; /* Needed to contain the tooltip */
    box-sizing: border-box;
}
.tooltip {
    background-color: #fff;
    color: #333;
    text-align: center;
    border-radius: 10px;
    padding: 5px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-family: 'system-ui';
    font-size: 1.1em;
    display: none;
    position: fixed;
    z-index: 1000;
}
.token:hover {
    border-top: 3px solid black;
}
.tooltip-container {
    position: absolute;
    pointer-events: none;
}
.hover-text:hover + .tooltip-container .tooltip {
    display: block;
}


/* Styling of the top-level container */
.grid-container {
    font-family: 'system-ui';
    border: 1px solid #e6e6e6;
    background-color: #fff;
    margin: 30px 10px;
    box-shadow: 0 5px 5px rgba(0, 0, 0, 0.25);
    display: grid;
    justify-content: start;
    grid-template-columns: auto;
    overflow-x: auto;
    overflow-y: visible;
    grid-auto-flow: column;
    white-space: nowrap;
    padding-bottom: 12px;
    padding-top: 35px;
    padding-left: 20px;
}
/* Styling each grid column (note, the max-height controls height of grid-container) */
.grid-column {
    margin-left: 20px;
    padding-right: 20px;
    width: max-content;
    overflow-y: auto;
    max-height: 750px;
}
/* Styling the scrollbars */
::-webkit-scrollbar {
    height: 10px;
    width: 10px;
}
::-webkit-scrollbar-track {
    background: #f1f1f1;
}
::-webkit-scrollbar-thumb {
    background: #999;
}
::-webkit-scrollbar-thumb:hover {
    background: #555;
}
/* Margin at the bottom of each histogram */
.plotly-hist {
    margin-bottom: 25px;
}
/* Margins below the titles (most subtitles are h4, except for the prompt-centric view which has h2 titles) */
h4 {
    margin-top: 0px;
    margin-bottom: 10px;
}
/* Some space below the <hr> line in prompt-centric vis */
hr {
    margin-bottom: 35px;
}
</style>

<script src="https://d3js.org/d3.v6.min.js"></script>
<script src="https://cdn.plot.ly/plotly-latest.min.js"></script>

<script>

document.addEventListener("DOMContentLoaded", function(event) {
    const ALL_DATA = defineData();
    setupPage(ALL_DATA['DASHBOARD_DATA'], ALL_DATA['AGGDATA']);
});

function setupPage(DASHBOARD_DATA, AGGDATA) {
    // Dynamically creates dropdowns from the data (by parsing its keys), and causes `createVis` to be called whenever
    // the dropdowns change. This includes the initial call to `createVis` with the first key, which is START_KEY.

    const START_KEY = "18578";
        // The start key has already been user-defined, we need to check it's present in DASHBOARD_DATA
    if (!Object.keys(DASHBOARD_DATA).includes(START_KEY)) {
        console.error(`No data available for key: ${START_KEY}`);
    }
    const startParts = START_KEY.split('|');
    
    // Function which will measure the width of a key (used for dynamically setting the width of our dropdowns)
    function measureTextWidth(text, font) {
        // Create a temporary span element
        const span = document.createElement("span");
        span.style.visibility = "hidden"; // Make sure it's not visible
        span.style.position = "absolute"; // Take it out of document flow
        span.style.font = font; // Apply font styling similar to the select options
        span.textContent = text;
        document.body.appendChild(span);
        const width = span.offsetWidth; // Get the width of the span
        document.body.removeChild(span); // Remove the span from the body
        return width;
    }
    
    // Check if there's only one key, in which case we have no selection to make
    if (Object.keys(DASHBOARD_DATA).length === 1) {
    
        const onlyKey = Object.keys(DASHBOARD_DATA)[0];
        createVis(DASHBOARD_DATA[onlyKey]);
    
    } else {
    
        // Assuming `DASHBOARD_DATA` is available and d3 has been included
        const parsedKeys = Object.keys(DASHBOARD_DATA).map(key => key.split("|"));
    
        // Determine `n` - the number of dropdowns needed
        const n = parsedKeys[0].length;
    
        // Create a structure to store options for each dropdown
        const options = Array.from({ length: n }, () => new Set());
    
        // Populate options for each dropdown
        parsedKeys.forEach(parts => {
            parts.forEach((part, index) => options[index].add(part));
        });
    
        // Select the container for the dropdowns
        const container = d3.select('#dropdown-container');
    
        // Create the dropdowns
        options.forEach((opts, i) => {
            // We wrap each `select` element in a `.select` div, for styling reasons)
            const selectDiv = container.append('div').attr('class', 'select');
            const selectElem = selectDiv.append('select').attr('id', `select-${i}`);
            let maxWidth = 0;
    
            // Set the title of this dropdown
            
    
            opts.forEach(opt => {
                // Add this as an option
                const optionElem = selectElem.append('option').text(opt).attr('value', opt);
    
                // If it matches the start key, set it to true
                if (startParts[i] === opt) {
                    optionElem.attr('selected', true);
                }
    
                // Calculate the width of this option, and possibly update the max width (for the select div)
                const width = measureTextWidth(opt, "1em system-ui");
                if (width > maxWidth) {
                    maxWidth = width;
                }
            });
    
            // Set the width of the select div to the max width + 45px (for the dropdown arrow)
            selectDiv.style('width', `${maxWidth + 45}px`);
    
            // Add event listener to update the visualization (and the selection options) when the dropdown changes
            selectElem.on('change', function() {
                updateDropdowns();
            });
        });
    
        // This gets called every time the dropdowns are updated
        function updateDropdowns() {
    
            // Empty all grid-column elements
            d3.selectAll(".grid-column").each(function() {
                d3.select(this).selectAll("*").html(""); 
            });
    
            // Get the current value of each dropdown
            const currentSelections = options.map((_, i) => d3.select(`#select-${i}`).property('value'));
    
            // Disable options that are not available based on the current selections
            options.forEach((opts, i) => {
                const select = d3.select(`#select-${i}`);
                select.selectAll('option').each(function() {
                    const optionValue = d3.select(this).attr('value');
                    const potentialKey = [...currentSelections.slice(0, i), optionValue, ...currentSelections.slice(i + 1)].join('|');
                    d3.select(this).attr('disabled', !DASHBOARD_DATA.hasOwnProperty(potentialKey) ? true : null);
                });
            });
    
            // Parse these options into the key for our DASHBOARD_DATA object
            const selectedKey = currentSelections.join('|');
    
            // Create vis using that data
            createVis(DASHBOARD_DATA[selectedKey]);
        }
    
        // Initial trigger
        updateDropdowns();
    }
}

function createVis(DATA) {
    // Create the vis from the data (this is where all the JavaScript files in this repo get dumped into). The DATA
    // object here will be DASHBOARD_DATA["8"] in the feature-centric vis, or DASHBOARD_DATA["act_quantile|'first' (6)"]
    // in the prompt-centric vis).

        // ! Using `DATA.actsHistogramData` to fill in the activations histogram
    
    function createActsLine(color, width, height) {
        return {
            type: 'line', line: {color: color, width: width},
            x0: 0, x1: 0, xref: 'x',
            y0: 0, y1: height, yref: 'paper',
            visible: false,
        }
    }
    
    function createActsAnnotation() {
        return {
            text: '', showarrow: false,
            x: 0, xref: 'x', 
            y: 0.9, yref: 'paper',
            xshift: 3, align: 'left', xanchor: 'left',
            visible: false,
        }
    }
    
    function setupActsHistogram(histId, histData) {
    
        // Create layout. This has 2 lines with annotations, both initially set to invisible (first is for dynamic on-hover
        // and second is for static, for the prompt-centric vis). We need to define them both so that when JavaScript alters
        // 'shapes[0]' or 'shapes[1]' we get no error
        var layout = {
            paper_bgcolor: 'white',
            plot_bgcolor: 'white',
            xaxis: {
                gridcolor: '#eee',
                zerolinecolor: '#eee',
                tickvals: histData.ticks,
                range: [0, 1.2 * Math.max(...histData.x)],
            },
            yaxis: {gridcolor: '#eee', zerolinecolor: '#eee'},
            barmode: 'relative',
            bargap: 0.01,
            showlegend: false,
            margin: {l: 50, r: 25, b: 25, t: 25, pad: 4},
            paper_bgcolor: 'rgba(0,0,0,0)',
            plot_bgcolor: 'rgba(0,0,0,0)',
            responsive: true,
            shapes: [createActsLine('black', 2, 1.0), createActsLine('black', 1, 0.9)],
            annotations: [createActsAnnotation(), createActsAnnotation()],
        };
    
        // Create traces (this is simple)
        var traces = [{
            x: histData.x,
            y: histData.y,
            type: 'bar',
            marker: {color: histData.colors},
        }];
    
        // Plot the histogram
        Plotly.newPlot(histId, traces, layout, {responsive: true, displayModeBar: false});
    
        // Maybe add title (if the title already existed then we update it, otherwise we create a new one)
        if(histData.title) {
            var histogramElement = document.getElementById(histId);
            var existingTitleElement = histogramElement.previousSibling;
            if (existingTitleElement && existingTitleElement.tagName === 'H4') {
                existingTitleElement.innerHTML = histData.title;
            } else {
                var titleElement = document.createElement('h4');
                titleElement.innerHTML = histData.title;
                histogramElement.parentNode.insertBefore(titleElement, histogramElement);
            }
        }
    }
    
    // 'actsHistogramData' is a dictionary mapping suffixes to histogram data (to make each histogram unique)
    // We iterate over it, and create a histogram for each one
    Object.entries(DATA.actsHistogramData).forEach(([suffix, histData]) => {
        var t0 = performance.now();
    
        histId = `histogram-acts-${suffix}`;
        setupActsHistogram(histId, histData);
    
        var t1 = performance.now();
        console.log(`HTML for ${histId} generated in ${(t1 - t0).toFixed(1)} ms`);
    });
    
    
    
    
    // ! Using `DATA.logitsHistogramData` to fill in the feature tables
    
    function createLogitsLine(color, width, height) {
        return {
            type: 'line', line: {color: color, width: width},
            x0: 0, x1: 0, xref: 'x',
            y0: 0, y1: height, yref: 'paper',
            visible: false,
        }
    }
    
    function createLogitsAnnotation() {
        return {
            text: '', showarrow: false,
            x: 0, xref: 'x', 
            y: 0.9, yref: 'paper',
            xshift: 3, align: 'left', xanchor: 'left',
            visible: false,
        }
    }
    
    function setupLogitsHistogram(histId, histData) {
    
        // Create layout. This has 2 lines with annotations, both initially set to invisible (first is for dynamic on-hover
        // and second is for static, for the prompt-centric vis). We need to define them both so that when JavaScript
        // alters 'shapes[0]' or 'shapes[1]' we get no error
        var layout = {
            paper_bgcolor: 'white',
            plot_bgcolor: 'white',
            xaxis: {
                gridcolor: '#eee',
                zerolinecolor: '#eee',
                tickvals: histData.ticks,
                range: [1.2 * Math.min(...histData.x), 1.2 * Math.max(...histData.x)],
            },
            yaxis: {gridcolor: '#eee', zerolinecolor: '#eee'},
            barmode: 'relative',
            bargap: 0.01,
            showlegend: false,
            margin: {l: 50, r: 25, b: 25, t: 25, pad: 4},
            paper_bgcolor: 'rgba(0,0,0,0)',
            plot_bgcolor: 'rgba(0,0,0,0)',
            responsive: true,
            shapes: [createActsLine('black', 2, 1.0), createActsLine('black', 1, 0.9)],
            annotations: [createLogitsAnnotation(), createLogitsAnnotation()],
        };
    
        // Create traces. This is a bit messier than for acts_histogram_script.js, because we have 2 different colors
        traces = [
            {
                x: histData.x.filter(value => value >= 0),
                y: histData.y.filter((_, i) => histData.x[i] >= 0),
                type: 'bar',
                marker: {color: 'rgba(0,0,255,0.5)'}
            },
            {
                x: histData.x.filter(value => value < 0),
                y: histData.y.filter((_, i) => histData.x[i] < 0),
                type: 'bar',
                marker: {color: 'rgba(255,0,0,0.5)'}
            }
        ];
    
        // Plot the histogram
        Plotly.newPlot(histId, traces, layout, {responsive: true, displayModeBar: false});
    
        // Maybe add title (if the title already existed then we update it, otherwise we create a new one)
        if(histData.title) {
            var histogramElement = document.getElementById(histId);
            var existingTitleElement = histogramElement.previousSibling;
            if (existingTitleElement && existingTitleElement.tagName === 'H4') {
                existingTitleElement.innerHTML = histData.title;
            } else {
                var titleElement = document.createElement('h4');
                titleElement.innerHTML = histData.title;
                histogramElement.parentNode.insertBefore(titleElement, histogramElement);
            }
        }
    }
    
    // 'DATA.ogitsHistogramData' is a dictionary mapping suffixes to histogram data (to make each histogram unique)
    // We iterate over it, and create a histogram for each one
    Object.entries(DATA.logitsHistogramData).forEach(([suffix, histData]) => {
        var t0 = performance.now();
    
        histId = `histogram-logits-${suffix}`;
        setupLogitsHistogram(histId, histData);
    
        var t1 = performance.now();
        console.log(`HTML for ${histId} generated in ${(t1 - t0).toFixed(1)} ms`);
    });
    
    
    
    
    // ! Using `DATA.featureTablesData` to create & fill in the feature tables
    
    function setupFeatureTables(tablesContainerId, tablesData, tableMetaData) {
        
        // Fetch table data (singular), if it doesn't exist then return early
        const tableData = tablesData[tableMetaData.dataKey] || null;
        if (tableData === null) {
            return;
        }
    
        // Get table container from its ID
        const featureTablesDiv = d3.select(`#${tablesContainerId}`);
    
        // Add a div to hold the header and table, give it a unique ID, and empty it (if that div already existed)
        const tableContainerId = `${tableMetaData.dataKey}-${tablesContainerId}`;
        const tableContainer = featureTablesDiv.append("div").attr("id", tableContainerId);
        tableContainer.selectAll("*").remove();
    
        // Add the title
        tableContainer.append("h4").html(tableMetaData.title);
    
        // Create the table, and header / body
        const table = tableContainer.append("table").attr("class", "table-left");
        const thead = table.append("thead");
        const tbody = table.append("tbody");
        const headerRow = thead.append("tr");
    
        // Append the 3 columns to this table's header row
        tableMetaData.columns.forEach(col => {
            headerRow.append("td")
            .attr("class", col === "Index" ? "left-aligned" : "right-aligned")
            .html(col);
        });
    
        // Append our data to the tbody
        const rows = tbody.selectAll('tr')
            .data(tableData)
            .enter()
            .append('tr');
    
        rows.selectAll('td')
            .data(row => Object.values(row))
            .enter()
            .append('td')
            .attr('class', (d, i) => i === 0 ? 'left-aligned' : 'right-aligned')
            .html(d => d);
    }
        
    // Define some data which will tell us how to create our tables (this isn't a function of data, it's always the same)
    const featureTablesMetaData = [
        {title: "NEURON ALIGNMENT", columns: ["Index", "Value", "% of L<sub>1</sub>"], dataKey: "neuronAlignment"},
        {title: "CORRELATED NEURONS", columns: ["Index", "Pearson Corr.", "Cosine Sim."], dataKey: "correlatedNeurons"},
        {title: "CORRELATED FEATURES", columns: ["Index", "Pearson Corr.", "Cosine Sim."], dataKey: "correlatedFeatures"},
        {title: "CORRELATED FEATURES (B-ENCODER)", columns: ["Index", "Pearson Corr.", "Cosine Sim."], dataKey: "correlatedFeaturesB"},
    ]
    
    // 'featureTablesData' is a dictionary mapping suffixes to feature tables data (to make each table unique)
    // We iterate over it, and create a table for each one
    Object.entries(DATA.featureTablesData).forEach(([suffix, tablesData]) => {
        var t0 = performance.now();
    
        // For each set of tables, we need to empty it, then create each of the new tables (up to 3)
        tablesContainerId = `feature-tables-${suffix}`;
        featureTablesMetaData.forEach(tableMetaData => {
            setupFeatureTables(tablesContainerId, tablesData, tableMetaData);
        });
        
        var t1 = performance.now();
        console.log(`HTML for ${tablesContainerId} generated in ${(t1 - t0).toFixed(1)} ms`);
    });
    
    
    
    
    // ! Using `DATA.logitsTableData` to fill in the pos/neg logit tables
    
    function setupLogitTables(logitsTableId, tablesData, tableMetaData) {
    
        // Fetch table data (singular)
        const tableData = tablesData[tableMetaData.dataKey];
    
        // Select the table container by its ID
        const tablesContainer = d3.select(`#${logitsTableId}`);
    
        // Select the object that contains this particular table (negative or positive)
        const tableId = `${tableMetaData.class}-${logitsTableId}`;
        const tableContainer = tablesContainer.select(`#${tableId}`);
        
        // If this table container doesn't exist, create it
        if (tableContainer.empty()) {
            const section = tablesContainer.append("div").attr("class", tableMetaData.class);
            section.append("h4").html(tableMetaData.title);
            section.append("table").attr("id", tableId).attr("class", "table-left");
        }
    
        // Now we can select the table by its ID, empty data, and add new data
        const table = tablesContainer.select(`#${tableId}`);
        table.selectAll('tr').remove();
    
        // Bind logits data to rows
        const rows = table.selectAll('tr')
            .data(tableData)
            .enter()
            .append('tr');
        
        // Append token cell
        rows.append('td')
            .attr('class', 'left-aligned')
            .append('code')
            .style('background-color', d => d.color)
            .text(d => d.symbol);
        
        // Append value cell
        rows.append('td')
            .attr('class', 'right-aligned')
            .text(d => d.value.toFixed(2));
    }
    
    // Define some data which will tell us how to create our tables (this isn't a function of data, it's always the same)
    var logitTablesMetaData = [
        {title: "NEGATIVE LOGITS", dataKey: "negLogits", class: "negative"},
        {title: "POSITIVE LOGITS", dataKey: "posLogits", class: "positive"},
    ]
    
    // 'logitsTableData' is a dictionary mapping suffixes to logits table data (to make each logits table unique)
    // We iterate over it, and create a logits table for each one
    Object.entries(DATA.logitsTableData).forEach(([suffix, tablesData]) => {
        var t0 = performance.now();
    
        // For each set of (pos / neg) table pairs, we need to empty each of them, then create them again
        // tablesContainerId = `feature-tables-${suffix}`;
        // setupLogitTables(logitsTableId, "negative", tableData.negLogits);
        // setupLogitTables(logitsTableId, "positive", tableData.posLogits);
        
        logitsTableId = `logits-table-${suffix}`;
        logitTablesMetaData.forEach(tableMetaData => {
            setupLogitTables(logitsTableId, tablesData, tableMetaData);
        });
    
        var t1 = performance.now();
        console.log(`HTML for ${logitsTableId} generated in ${(t1 - t0).toFixed(1)} ms`);
    });
    
    
    
    
    
    function addLineHistogram(histogramID, shapeIndex, tok, xValue) {
        // Updates histogram with a line (if the histogram exists)
        // shapeIndex 0 is for on-hover, 1 is for permanent line
        if (document.getElementById(histogramID)) {
            Plotly.relayout(histogramID, {
                [`shapes[${shapeIndex}].x0`]: xValue,
                [`shapes[${shapeIndex}].x1`]: xValue,
                [`shapes[${shapeIndex}].visible`]: true,
                [`annotations[${shapeIndex}].x`]: xValue,
                [`annotations[${shapeIndex}].text`]: `|${tok}|<br>${xValue.toFixed(3)}`,
                [`annotations[${shapeIndex}].visible`]: true,
            });
        }
    }
    
    function removeLineHistogram(histogramID, shapeIndex) {
        if (document.getElementById(histogramID)) {
            Plotly.relayout(histogramID, {
                [`shapes[${shapeIndex}].visible`]: false,
                [`annotations[${shapeIndex}].visible`]: false,
            });
        }
    }
    
    function generateTokHtmlElement(
        parent, tok, tokID, uColor, bgColor, isBold, featAct, tokenLogit, lossEffect, posToks, posVal, negToks, negVal, permanentLine, hide, idSuffix,
    ) {
        // Figure out if previous token was active (this affects the construction of the tooltip)
        let prevTokenActive = posToks.length + negToks.length > 0;
    
        // Create the token span (this will contain just the token, not the hoverdata)
        let tokenSpan = parent.append("span")
            .attr("class", "hover-text");
    
        // Get the histogram ids
        let histogramActsID = `histogram-acts-${idSuffix}`;
        let histogramLogitsID = `histogram-logits-${idSuffix}`;
    
        // Put actual token in the tokenSpan object (i.e. the thing we see without hovering)    
        tokenSpan.append("span")
            .attr("class", "token")
            .style("background-color", bgColor)
            .style("border-bottom", `4px solid ${uColor}`)
            .style("font-weight", isBold ? "bold" : "normal")
            .text(tok);
    
        // If hide is true, then we just show a box saying "no information was calculated for this token"
        if (hide) {
            // First define the tooltip div (added to the parent element, i.e. it's a sibling of the token span)
            let tooltipHeight = 70;
            let tooltipWidth = 150;
            let tooltipDiv = parent.append("div")
                .attr("class", "tooltip")
                .style("height", tooltipHeight + "px")
                .style("width", tooltipWidth + "px")
                .style("font-size", "0.85em")
                .style("white-space", "pre-wrap")
                .style("align-items", "center")
                .style("text-align", "center")
                .style("padding", "15px")
                .html("No information was calculated for this token, since you used compute_buffer=False.");
    
            // Add dynamic behaviour: show the tooltip on hover, and also add lines to the two histograms
            tokenSpan.on('mouseover', function() {
                tooltipDiv.style('display', 'flex');
                tooltipDiv.style('position', 'fixed');
            })
            tokenSpan.on('mousemove', function(event) {
                tooltipDiv.style('left', `${event.clientX - tooltipWidth / 2}px`);
                tooltipDiv.style('top', `${event.clientY + 20}px`);
            });
            tokenSpan.on('mouseout', function() {
                tooltipDiv.style('display', 'none');
            });
            
        // If we're not hiding (because we only generated data for the bolded tokens), then create tooltip & add it on hover
        } else { 
    
            // First define the tooltip div (added to the parent element, i.e. it's a sibling of the token span)
            let tooltipHeight = prevTokenActive ? 270 : 160;
            let tooltipWidth = prevTokenActive ? 350 : 250;
            let tooltipDiv = parent.append("div")
                .attr("class", "tooltip")
                .style("height", tooltipHeight + "px")
                .style("width", tooltipWidth + "px")
                .style("align-items", "center")
                .style("text-align", "center");
    
            // Next, create a table container, to contain 2 tables: one with basics (acts & loss effect), one with per-token logits
            let tableContainer = tooltipDiv.append("div").attr("class", "table-container");
    
            // Creat the first table
            let tokRow = `<td class="right-aligned">Token</td><td class="left-aligned"><code>${tok}</code> (${tokID})</td>`;
            let featActRow = `<td class="right-aligned">Feature activation</td><td class="left-aligned">${featAct >= 0 ? '+' : ''}${featAct.toFixed(3)}</td>`;
            let lossRow = `<td class="right-aligned">Loss contribution</td><td class="left-aligned">${lossEffect >= 0 ? '+' : ''}${lossEffect.toFixed(3)}</td>`;
            let firstTable = tableContainer.append("table");
            firstTable.append("tr").html(tokRow);
            firstTable.append("tr").html(featActRow);
            firstTable.append("tr").html(lossRow);
            tableContainer.append("br");
            
            // If previous token is active, we add logit table
            if (prevTokenActive) {
                
                // Create container for top & bottom logits tables
                let logitsTableContainer = tableContainer.append("div").attr("class", "half-width-container")
    
                // Create the positive table, and fill it with values
                let posLogitsTable = logitsTableContainer.append("table").attr("class", "half-width")
                posLogitsTable.append("tr").html(`<td class="center-aligned" colspan="2">Pos logit contributions</td>`);
                posToks.forEach((tok, index) => {
                    posLogitsTable.append("tr").html(`
                        <td class="right-aligned"><code>${tok}</code></td>
                        <td class="left-aligned">${posVal[index] > 0 ? '+' : ''}${posVal[index].toFixed(3)}</td>
                    `);
                });
    
                // Create the negative table, and fill it with values
                let negLogitsTable = logitsTableContainer.append("table").attr("class", "half-width")
                negLogitsTable.append("tr").html(`<td class="center-aligned" colspan="2">Neg logit contributions</td>`);
                negToks.forEach((tok, index) => {
                    negLogitsTable.append("tr").html(`
                        <td class="right-aligned"><code>${tok}</code></td>
                        <td class="left-aligned">${negVal[index] > 0 ? '+' : ''}${negVal[index].toFixed(3)}</td>
                    `);
                });
    
            // If previous token is not active, we add a message instead
            } else {
                tableContainer.append("div")
                    .style("font-size", "0.85em")
                    .html("Feature not active on prev token;<br>no predictions were affected.");
            }
    
            // Add dynamic behaviour: show the tooltip on hover, and also add lines to the two histograms
            tokenSpan.on('mouseover', function() {
                tooltipDiv.style('display', 'flex');
                tooltipDiv.style('position', 'fixed');
                addLineHistogram(histogramActsID, 0, tok, featAct);
                addLineHistogram(histogramLogitsID, 0, tok, tokenLogit);
            })
            tokenSpan.on('mousemove', function(event) {
                tooltipDiv.style('left', `${event.clientX - tooltipWidth / 2}px`);
                tooltipDiv.style('top', `${event.clientY + 20}px`);
            });
            tokenSpan.on('mouseout', function() {
                tooltipDiv.style('display', 'none');
                removeLineHistogram(histogramActsID, 0);
                removeLineHistogram(histogramLogitsID, 0);
            });
    
            // Add static behaviour: if required, then show the permanent line on the histograms, as shapes[1]
            if (permanentLine & isBold) {
                addLineHistogram(histogramActsID, 1, tok, featAct);
                addLineHistogram(histogramLogitsID, 1, tok, tokenLogit);
            }
        }
    }
    
    Object.entries(DATA.tokenData).forEach(([seqGroupID, seqGroupData]) => {
        const t0 = performance.now();
    
        // Find the sequence group container (this is the only thing that already exists)
        const seqGroupContainer = d3.select(`#${seqGroupID}`);
    
        // Empty this container of title & all sequences
        seqGroupContainer.selectAll('*').remove();
    
        // If title exists, add the title to this sequence group (we need .html not .text, because it could have <br>)
        if ("title" in seqGroupData) {
            seqGroupContainer.append('h4').html(seqGroupData.title);
        }
    
        // Get the ID suffix for this sequence group
        const idSuffix = seqGroupData.idSuffix;
    
        // Select all sequences (initially empty), and then add our sequences & bind them to the elems in seqGroupData.data
        const seqGroup = seqGroupContainer.selectAll('.seq')
            .data(seqGroupData.data)
            .enter()
            .append('div')
            .attr('class', 'seq');
    
        // For each sequence, we iterate over & add all its tokens
        seqGroup.each(function(seqData) {
    
            // Get `seq`, which is the individual `seq` element in seqGroup (i.e. the sequence container)
            const seq = d3.select(this);
    
            // Iterate through each token data dict in `seqData`, and add this token to the sequence
            seqData.forEach(tokData => {
    
                generateTokHtmlElement(
                    seq,                                // object we'll append the token to
                    tokData.tok,                        // string token
                    tokData.tokID,                      // token ID (shown on hover, after PR request)
                    tokData["uColor"] || "#fff",        // underline color (derived from loss effect)
                    tokData["bgColor"] || "#fff",       // background color (derived from feature activation)
                    tokData["isBold"] || false,         // is this token bolded?
                    tokData["featAct"] || 0.0,          // feature activation at this token (used for acts histogram line)
                    tokData["tokenLogit"] || 0.0,       // raw logit effect on this token (used for logits histogram line)
                    tokData["lossEffect"] || 0.0,       // effect on loss (used for histogram line), if prev token active
                    tokData["posToks"] || [],           // most-positive tokens (strings)
                    tokData["posVal"] || [],            // most-positive token values
                    tokData["negToks"] || [],           // most-negative tokens (strings)
                    tokData["negVal"] || [],            // most-negative token values
                    tokData["permanentLine"] || false,  // do we show a permanent line on histogram?
                    tokData["hide"] || false,           // do we suppress hoverdata for this token?
                    idSuffix,                           // suffix for the histogram ID which the hoverline will be added to
                );
            });
        });
    
        const t1 = performance.now(); // End timing
        console.log(`HTML for ${seqGroupID} generated in ${(t1 - t0).toFixed(1)} ms`);
    });
}

function defineData() {
    // Returns the data - see the docstring of the Python HTML class to understand the structure of this object.

    return {"AGGDATA": {"max": [27.84594], "frac_nonzero": [0.44821], "skew": [], "kurtosis": []}, "DASHBOARD_DATA": {"18578": {"featureTablesData": {"0": {"neuronAlignment": [{"index": 896, "value": "+0.082", "percentageL1": "0.3%"}, {"index": 277, "value": "+0.081", "percentageL1": "0.3%"}, {"index": 686, "value": "+0.078", "percentageL1": "0.3%"}], "correlatedNeurons": [{"index": 1421, "value": "+0.339", "percentageL1": "+0.142"}, {"index": 335, "value": "+0.325", "percentageL1": "+0.329"}, {"index": 901, "value": "+0.296", "percentageL1": "+0.179"}], "correlatedFeatures": [{"index": 18578, "value": "+0.000", "percentageL1": "+0.000"}]}}, "actsHistogramData": {"0": {"y": [10618, 6671, 3111, 1091, 449, 177, 101, 46, 48, 38, 46, 105, 51, 40, 37, 30, 11, 10, 8, 6, 3, 0, 1, 3, 1, 5, 0, 0, 0, 0, 1, 2, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 3, 2, 0, 0, 0, 1], "x": [0.27855, 0.83546, 1.39238, 1.9493, 2.50622, 3.06313, 3.62005, 4.17697, 4.73388, 5.2908, 5.84772, 6.40464, 6.96155, 7.51847, 8.07539, 8.6323, 9.18922, 9.74614, 10.30305, 10.85997, 11.41689, 11.97381, 12.53072, 13.08764, 13.64456, 14.20148, 14.75839, 15.31531, 15.87223, 16.42914, 16.98606, 17.54298, 18.09989, 18.65681, 19.21373, 19.77065, 20.32756, 20.88448, 21.4414, 21.99831, 22.55523, 23.11215, 23.66906, 24.22598, 24.7829, 25.33982, 25.89673, 26.45365, 27.01057, 27.56748], "ticks": [0, 9.2, 18.4, 27.6], "colors": ["#ffd198", "#ffcf94", "#ffcd91", "#ffcc8e", "#ffcb8b", "#ffc988", "#ffc885", "#ffc782", "#ffc57f", "#ffc47c", "#ffc379", "#ffc175", "#ffbf72", "#ffbe6f", "#ffbd6c", "#ffbb69", "#ffba66", "#ffb963", "#ffb760", "#ffb65d", "#ffb459", "#ffb356", "#ffb153", "#ffb050", "#ffaf4d", "#ffad4a", "#ffac47", "#ffab44", "#ffa941", "#ffa83e", "#ffa63a", "#ffa537", "#ffa334", "#ffa231", "#ffa12e", "#ff9f2b", "#ff9e28", "#ff9d25", "#ff9b22", "#ff9a1f", "#ff981b", "#ff9718", "#ff9515", "#ff9412", "#ff930f", "#ff910c", "#ff9009", "#ff8f06", "#ff8d03", "#ff8c00"], "title": "ACTIVATIONS<br>DENSITY = 44.821%"}}, "logitsTableData": {"0": {"negLogits": [{"symbol": "\\\\", "value": -0.43, "color": "rgba(255,0,0,0.5)"}, {"symbol": " \\\\", "value": -0.37, "color": "rgba(255,33,33,0.5)"}, {"symbol": "}\\\\", "value": -0.36, "color": "rgba(255,39,39,0.5)"}, {"symbol": "]\\\\", "value": -0.36, "color": "rgba(255,42,42,0.5)"}, {"symbol": ":\\\\", "value": -0.33, "color": "rgba(255,59,59,0.5)"}, {"symbol": "\\\\.", "value": -0.27, "color": "rgba(255,97,97,0.5)"}, {"symbol": "\\\\\"", "value": -0.25, "color": "rgba(255,106,106,0.5)"}, {"symbol": "(\"\\\\", "value": -0.22, "color": "rgba(255,122,122,0.5)"}, {"symbol": " \"\\\\", "value": -0.22, "color": "rgba(255,123,123,0.5)"}, {"symbol": " '\\\\", "value": -0.22, "color": "rgba(255,124,124,0.5)"}], "posLogits": [{"symbol": "...\\", "value": 0.21, "color": "rgba(130,130,255,0.5)"}, {"symbol": " ...\\", "value": 0.19, "color": "rgba(140,140,255,0.5)"}, {"symbol": "\\n", "value": 0.19, "color": "rgba(141,141,255,0.5)"}, {"symbol": ".\\", "value": 0.19, "color": "rgba(145,145,255,0.5)"}, {"symbol": ")\\", "value": 0.18, "color": "rgba(149,149,255,0.5)"}, {"symbol": "?\\", "value": 0.17, "color": "rgba(153,153,255,0.5)"}, {"symbol": "!\\", "value": 0.17, "color": "rgba(154,154,255,0.5)"}, {"symbol": "()\\", "value": 0.17, "color": "rgba(155,155,255,0.5)"}, {"symbol": " {}\\", "value": 0.17, "color": "rgba(156,156,255,0.5)"}, {"symbol": "\u00e3\u0122\u0124\\", "value": 0.17, "color": "rgba(156,156,255,0.5)"}]}}, "logitsHistogramData": {"0": {"y": [1, 0, 0, 0, 1, 2, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 3, 3, 1, 0, 0, 1, 1, 2, 9, 35, 182, 711, 2610, 6938, 14749, 24418, 34511, 28999, 20456, 11171, 4738, 1699, 505, 121, 24, 13, 5, 5, 2, 5, 6, 2, 3, 1], "x": [-0.42467, -0.41184, -0.39901, -0.38618, -0.37335, -0.36053, -0.3477, -0.33487, -0.32204, -0.30922, -0.29639, -0.28356, -0.27073, -0.2579, -0.24508, -0.23225, -0.21942, -0.20659, -0.19376, -0.18094, -0.16811, -0.15528, -0.14245, -0.12963, -0.1168, -0.10397, -0.09114, -0.07831, -0.06549, -0.05266, -0.03983, -0.027, -0.01417, -0.00135, 0.01148, 0.02431, 0.03714, 0.04996, 0.06279, 0.07562, 0.08845, 0.10128, 0.1141, 0.12693, 0.13976, 0.15259, 0.16541, 0.17824, 0.19107, 0.2039], "ticks": [-0.3, -0.2, -0.1, 0, 0.1, 0.2]}}, "tokenData": {"seq-group-2-0": {"data": [[{"tok": "_HOME", "tokID": 28466, "tokenLogit": -0.0774, "isBold": false, "featAct": 8.0872, "bgColor": "#ffdeb5"}, {"tok": "%\\", "tokID": 69616, "tokenLogit": 0.0949, "isBold": false, "featAct": 3.3033, "bgColor": "#fff1e1"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.1832, "bgColor": "#fff6eb"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": false, "featAct": 17.1982, "bgColor": "#ffb861"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.861, "bgColor": "#fff3e5"}, {"tok": "wrapper", "tokID": 21364, "tokenLogit": -0.0404, "isBold": true, "featAct": 27.8459, "bgColor": "#ff8c00"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.9645, "bgColor": "#fff7ed"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.0885, "bgColor": "#fff6ec"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": false, "featAct": 5.6494, "bgColor": "#ffe8cc"}, {"tok": "-wrapper", "tokID": 17388, "tokenLogit": -0.011, "isBold": false, "featAct": 8.6936, "bgColor": "#ffdbb0"}, {"tok": ".jar", "tokID": 27628, "tokenLogit": 0.0064, "isBold": false, "featAct": 7.049, "bgColor": "#ffe2bf"}], [{"tok": "Class", "tokID": 1957, "tokenLogit": -0.0087, "isBold": false, "featAct": 0.9343, "bgColor": "#fffbf7"}, {"tok": "'", "tokID": 6, "tokenLogit": 0.0327, "isBold": false, "featAct": 0.1268, "bgColor": "#fffffe"}, {"tok": " =>", "tokID": 589, "tokenLogit": 0.0385, "isBold": false, "featAct": 6.9439, "bgColor": "#ffe3c0"}, {"tok": " '\\", "tokID": 5196, "tokenLogit": 0.0405, "isBold": false, "featAct": 3.2736, "bgColor": "#fff1e1"}, {"tok": "l", "tokID": 75, "tokenLogit": 0.0307, "isBold": false, "featAct": 1.3937, "bgColor": "#fffaf3"}, {"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": true, "featAct": 25.4571, "bgColor": "#ff9515"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.0015, "bgColor": "#fff7ed"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.5969, "bgColor": "#fffdfa"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 17.6784, "bgColor": "#ffb65d"}], [{"tok": "Class", "tokID": 1957, "tokenLogit": -0.0087, "isBold": false}, {"tok": "'", "tokID": 6, "tokenLogit": 0.0327, "isBold": false}, {"tok": " =>", "tokID": 589, "tokenLogit": 0.0385, "isBold": false, "featAct": 2.9458, "bgColor": "#fff3e4"}, {"tok": " '\\", "tokID": 5196, "tokenLogit": 0.0405, "isBold": false, "featAct": 2.9763, "bgColor": "#fff3e4"}, {"tok": "l", "tokID": 75, "tokenLogit": 0.0307, "isBold": false, "featAct": 2.2216, "bgColor": "#fff6eb"}, {"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": true, "featAct": 25.0924, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.3502, "bgColor": "#fff6ea"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.4215, "bgColor": "#fffefc"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 24.5121, "bgColor": "#ff9a1e"}], [{"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.3502, "bgColor": "#fff6ea"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.4215, "bgColor": "#fffefc"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 24.5121, "bgColor": "#ff9a1e"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": true, "featAct": 25.0271, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.943, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 2.3659, "bgColor": "#fff6ea"}, {"tok": "Source", "tokID": 3608, "tokenLogit": 0.0077, "isBold": false, "featAct": 1.4075, "bgColor": "#fffaf3"}, {"tok": "'],\\n", "tokID": 4380, "tokenLogit": 0.004, "isBold": false}, {"tok": "           ", "tokID": 310, "tokenLogit": -0.0126, "isBold": false}], [{"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false}, {"tok": "\\n", "tokID": 198, "tokenLogit": 0.0101, "isBold": false}, {"tok": " */\\n\\n", "tokID": 2791, "tokenLogit": -0.0058, "isBold": false, "featAct": 0.6031, "bgColor": "#fffdfa"}, {"tok": "namespace", "tokID": 2231, "tokenLogit": -0.005, "isBold": false, "featAct": 0.6092, "bgColor": "#fffdfa"}, {"tok": " la", "tokID": 1187, "tokenLogit": -0.0128, "isBold": false, "featAct": 2.0447, "bgColor": "#fff7ed"}, {"tok": "jax", "tokID": 14518, "tokenLogit": -0.0328, "isBold": true, "featAct": 25.0227, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.7782, "bgColor": "#fff8ef"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false, "featAct": 2.5503, "bgColor": "#fff5e8"}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false, "featAct": 2.3068, "bgColor": "#fff6ea"}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 4.0238, "bgColor": "#ffefdb"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 22.1753, "bgColor": "#ffa334"}], [{"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": false, "featAct": 25.0924, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.3502, "bgColor": "#fff6ea"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.4215, "bgColor": "#fffefc"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": true, "featAct": 24.5121, "bgColor": "#ff9a1e"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": false, "featAct": 25.0271, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.943, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 2.3659, "bgColor": "#fff6ea"}, {"tok": "Source", "tokID": 3608, "tokenLogit": 0.0077, "isBold": false, "featAct": 1.4075, "bgColor": "#fffaf3"}, {"tok": "'],\\n", "tokID": 4380, "tokenLogit": 0.004, "isBold": false}], [{"tok": "jax", "tokID": 14518, "tokenLogit": -0.0328, "isBold": false, "featAct": 25.0227, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.7782, "bgColor": "#fff8ef"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false, "featAct": 2.5503, "bgColor": "#fff5e8"}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false, "featAct": 2.3068, "bgColor": "#fff6ea"}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 4.0238, "bgColor": "#ffefdb"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": true, "featAct": 22.1753, "bgColor": "#ffa334"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": false, "featAct": 17.7069, "bgColor": "#ffb65d"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false, "featAct": 0.2135, "bgColor": "#fffffe"}, {"tok": "use", "tokID": 810, "tokenLogit": 0.0382, "isBold": false}, {"tok": " Yii", "tokID": 18258, "tokenLogit": 0.0675, "isBold": false, "featAct": 2.6358, "bgColor": "#fff4e7"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false}], [{"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.0015, "bgColor": "#fff7ed"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.5969, "bgColor": "#fffdfa"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 17.6784, "bgColor": "#ffb65d"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": true, "featAct": 20.9062, "bgColor": "#ffa83f"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.8695, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 0.7928, "bgColor": "#fffcf8"}, {"tok": "',", "tokID": 516, "tokenLogit": 0.0191, "isBold": false}, {"tok": " '", "tokID": 364, "tokenLogit": 0.0358, "isBold": false, "featAct": 0.4281, "bgColor": "#fffefc"}, {"tok": "target", "tokID": 5657, "tokenLogit": 0.0297, "isBold": false}], [{"tok": " =", "tokID": 284, "tokenLogit": 0.0064, "isBold": false}, {"tok": " s", "tokID": 274, "tokenLogit": 0.0322, "isBold": false, "featAct": 0.2373, "bgColor": "#fffefd"}, {"tok": ".match", "tokID": 11072, "tokenLogit": -0.0259, "isBold": false}, {"tok": "(/", "tokID": 9921, "tokenLogit": -0.0452, "isBold": false, "featAct": 7.6328, "bgColor": "#ffdfb9"}, {"tok": "slide", "tokID": 19341, "tokenLogit": 0.0163, "isBold": false, "featAct": 8.9175, "bgColor": "#ffdaae"}, {"tok": "-(", "tokID": 8013, "tokenLogit": -0.0037, "isBold": true, "featAct": 19.4915, "bgColor": "#ffae4c"}, {"tok": ".*)", "tokID": 96494, "tokenLogit": -0.0131, "isBold": false, "featAct": 13.1699, "bgColor": "#ffc886"}, {"tok": "/", "tokID": 14, "tokenLogit": -0.0053, "isBold": false, "featAct": 0.3919, "bgColor": "#fffefc"}, {"tok": ");\\n", "tokID": 317, "tokenLogit": -0.0162, "isBold": false}, {"tok": "       ", "tokID": 286, "tokenLogit": 0.017, "isBold": false, "featAct": 0.0302, "bgColor": "#ffffff"}, {"tok": " if", "tokID": 421, "tokenLogit": 0.0209, "isBold": false}], [{"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.7782, "bgColor": "#fff8ef"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false, "featAct": 2.5503, "bgColor": "#fff5e8"}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false, "featAct": 2.3068, "bgColor": "#fff6ea"}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 4.0238, "bgColor": "#ffefdb"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 22.1753, "bgColor": "#ffa334"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": true, "featAct": 17.7069, "bgColor": "#ffb65d"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false, "featAct": 0.2135, "bgColor": "#fffffe"}, {"tok": "use", "tokID": 810, "tokenLogit": 0.0382, "isBold": false}, {"tok": " Yii", "tokID": 18258, "tokenLogit": 0.0675, "isBold": false, "featAct": 2.6358, "bgColor": "#fff4e7"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false}, {"tok": "/**\\n", "tokID": 1747, "tokenLogit": -0.0686, "isBold": false}], [{"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": false, "featAct": 25.4571, "bgColor": "#ff9515"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.0015, "bgColor": "#fff7ed"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.5969, "bgColor": "#fffdfa"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": true, "featAct": 17.6784, "bgColor": "#ffb65d"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": false, "featAct": 20.9062, "bgColor": "#ffa83f"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.8695, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 0.7928, "bgColor": "#fffcf8"}, {"tok": "',", "tokID": 516, "tokenLogit": 0.0191, "isBold": false}, {"tok": " '", "tokID": 364, "tokenLogit": 0.0358, "isBold": false, "featAct": 0.4281, "bgColor": "#fffefc"}], [{"tok": "=%", "tokID": 7846, "tokenLogit": -0.0227, "isBold": false}, {"tok": "APP", "tokID": 14707, "tokenLogit": -0.0005, "isBold": false, "featAct": 2.9043, "bgColor": "#fff3e5"}, {"tok": "_HOME", "tokID": 28466, "tokenLogit": -0.0774, "isBold": false, "featAct": 8.0872, "bgColor": "#ffdeb5"}, {"tok": "%\\", "tokID": 69616, "tokenLogit": 0.0949, "isBold": false, "featAct": 3.3033, "bgColor": "#fff1e1"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.1832, "bgColor": "#fff6eb"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": true, "featAct": 17.1982, "bgColor": "#ffb861"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.861, "bgColor": "#fff3e5"}, {"tok": "wrapper", "tokID": 21364, "tokenLogit": -0.0404, "isBold": false, "featAct": 27.8459, "bgColor": "#ff8c00"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.9645, "bgColor": "#fff7ed"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.0885, "bgColor": "#fff6ec"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": false, "featAct": 5.6494, "bgColor": "#ffe8cc"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3649, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.4411, "bgColor": "#fffdfb"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.5394, "bgColor": "#fff9f1"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.9896, "bgColor": "#fffbf6"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.4312, "bgColor": "#fff5e9"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.285, "bgColor": "#ffc47c"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 1.2537, "bgColor": "#fffaf4"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.2519, "bgColor": "#fffaf4"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 1.1138, "bgColor": "#fffaf5"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 6.0728, "bgColor": "#ffe6c8"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.1805, "bgColor": "#fffffe"}], [{"tok": "_instance", "tokID": 11904, "tokenLogit": -0.0037, "isBold": false, "featAct": 1.0449, "bgColor": "#fffbf6"}, {"tok": ":", "tokID": 25, "tokenLogit": -0.0028, "isBold": false}, {"tok": " \"<", "tokID": 4055, "tokenLogit": 0.0109, "isBold": false}, {"tok": "type", "tokID": 1313, "tokenLogit": 0.0268, "isBold": false, "featAct": 1.2144, "bgColor": "#fffaf4"}, {"tok": " \\'", "tokID": 27152, "tokenLogit": 0.035, "isBold": false, "featAct": 0.0246, "bgColor": "#ffffff"}, {"tok": "object", "tokID": 1700, "tokenLogit": 0.0312, "isBold": true, "featAct": 14.2636, "bgColor": "#ffc47c"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "'>", "tokID": 6270, "tokenLogit": 0.0424, "isBold": false, "featAct": 0.8709, "bgColor": "#fffbf7"}, {"tok": "\"\\n", "tokID": 698, "tokenLogit": 0.0452, "isBold": false}, {"tok": " ", "tokID": 220, "tokenLogit": 0.022, "isBold": false, "featAct": 0.2028, "bgColor": "#fffffe"}, {"tok": " member", "tokID": 4462, "tokenLogit": 0.0202, "isBold": false, "featAct": 0.4038, "bgColor": "#fffefc"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3373, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.4236, "bgColor": "#fffefc"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.5214, "bgColor": "#fff9f2"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.9865, "bgColor": "#fffbf6"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.4453, "bgColor": "#fff5e9"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.1961, "bgColor": "#ffc47d"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 1.1424, "bgColor": "#fffaf5"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.2585, "bgColor": "#fffaf4"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 1.1158, "bgColor": "#fffaf5"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.9857, "bgColor": "#ffe6c8"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.0711, "bgColor": "#ffffff"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3997, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.6014, "bgColor": "#fffdfa"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.4499, "bgColor": "#fff9f2"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 1.0478, "bgColor": "#fffbf6"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.5322, "bgColor": "#fff5e8"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.1658, "bgColor": "#ffc47d"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 0.6029, "bgColor": "#fffdfa"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 0.9565, "bgColor": "#fffbf7"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 1.3014, "bgColor": "#fffaf4"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.6446, "bgColor": "#ffe8cc"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.2579, "bgColor": "#fffefd"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.2697, "bgColor": "#fffaf4"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.3663, "bgColor": "#fffefc"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.6433, "bgColor": "#fff8f0"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.9164, "bgColor": "#fffbf7"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.2669, "bgColor": "#fff6eb"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.0776, "bgColor": "#ffc57e"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 1.2049, "bgColor": "#fffaf4"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.2753, "bgColor": "#fffaf4"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 0.9974, "bgColor": "#fffbf6"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.9626, "bgColor": "#ffe7c9"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.0762, "bgColor": "#ffffff"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3803, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.5453, "bgColor": "#fffdfa"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.4807, "bgColor": "#fff9f2"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.8142, "bgColor": "#fffcf8"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 1.9092, "bgColor": "#fff7ee"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 13.4023, "bgColor": "#ffc884"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 0.9789, "bgColor": "#fffbf7"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.1201, "bgColor": "#fffaf5"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 0.7948, "bgColor": "#fffcf8"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.799, "bgColor": "#ffe7ca"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false}], [{"tok": " s", "tokID": 274, "tokenLogit": 0.0322, "isBold": false, "featAct": 0.2373, "bgColor": "#fffefd"}, {"tok": ".match", "tokID": 11072, "tokenLogit": -0.0259, "isBold": false}, {"tok": "(/", "tokID": 9921, "tokenLogit": -0.0452, "isBold": false, "featAct": 7.6328, "bgColor": "#ffdfb9"}, {"tok": "slide", "tokID": 19341, "tokenLogit": 0.0163, "isBold": false, "featAct": 8.9175, "bgColor": "#ffdaae"}, {"tok": "-(", "tokID": 8013, "tokenLogit": -0.0037, "isBold": false, "featAct": 19.4915, "bgColor": "#ffae4c"}, {"tok": ".*)", "tokID": 96494, "tokenLogit": -0.0131, "isBold": true, "featAct": 13.1699, "bgColor": "#ffc886"}, {"tok": "/", "tokID": 14, "tokenLogit": -0.0053, "isBold": false, "featAct": 0.3919, "bgColor": "#fffefc"}, {"tok": ");\\n", "tokID": 317, "tokenLogit": -0.0162, "isBold": false}, {"tok": "       ", "tokID": 286, "tokenLogit": 0.017, "isBold": false, "featAct": 0.0302, "bgColor": "#ffffff"}, {"tok": " if", "tokID": 421, "tokenLogit": 0.0209, "isBold": false}, {"tok": " (", "tokID": 320, "tokenLogit": 0.0251, "isBold": false, "featAct": 0.0893, "bgColor": "#ffffff"}], [{"tok": " Language", "tokID": 11434, "tokenLogit": 0.0131, "isBold": false, "featAct": 0.6915, "bgColor": "#fffcf9"}, {"tok": "Translate", "tokID": 27473, "tokenLogit": -0.0144, "isBold": false}, {"tok": " extends", "tokID": 2239, "tokenLogit": -0.0184, "isBold": false, "featAct": 4.7773, "bgColor": "#ffecd4"}, {"tok": " \\", "tokID": 1124, "tokenLogit": -0.0341, "isBold": false, "featAct": 0.2743, "bgColor": "#fffefd"}, {"tok": "yii", "tokID": 37164, "tokenLogit": 0.0269, "isBold": false, "featAct": 8.8921, "bgColor": "#ffdaae"}, {"tok": "\\db", "tokID": 53229, "tokenLogit": -0.0467, "isBold": true, "featAct": 13.0766, "bgColor": "#ffc987"}, {"tok": "\\Active", "tokID": 43681, "tokenLogit": -0.0002, "isBold": false, "featAct": 0.0937, "bgColor": "#ffffff"}, {"tok": "Record", "tokID": 6471, "tokenLogit": 0.0314, "isBold": false}, {"tok": "\\n", "tokID": 198, "tokenLogit": 0.0101, "isBold": false}, {"tok": "{\\n", "tokID": 515, "tokenLogit": 0.0015, "isBold": false}, {"tok": "   ", "tokID": 262, "tokenLogit": 0.021, "isBold": false}]], "idSuffix": "0", "title": "TOP ACTIVATIONS<br>MAX = 27.846"}, "seq-group-2-1": {"data": [[{"tok": "Class", "tokID": 1957, "tokenLogit": -0.0087, "isBold": false}, {"tok": "'", "tokID": 6, "tokenLogit": 0.0327, "isBold": false}, {"tok": " =>", "tokID": 589, "tokenLogit": 0.0385, "isBold": false, "featAct": 2.9458, "bgColor": "#fff3e4"}, {"tok": " '\\", "tokID": 5196, "tokenLogit": 0.0405, "isBold": false, "featAct": 2.9763, "bgColor": "#fff3e4"}, {"tok": "l", "tokID": 75, "tokenLogit": 0.0307, "isBold": false, "featAct": 2.2216, "bgColor": "#fff6eb"}, {"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": true, "featAct": 25.0924, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.3502, "bgColor": "#fff6ea"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.4215, "bgColor": "#fffefc"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 24.5121, "bgColor": "#ff9a1e"}], [{"tok": "Class", "tokID": 1957, "tokenLogit": -0.0087, "isBold": false, "featAct": 0.9343, "bgColor": "#fffbf7"}, {"tok": "'", "tokID": 6, "tokenLogit": 0.0327, "isBold": false, "featAct": 0.1268, "bgColor": "#fffffe"}, {"tok": " =>", "tokID": 589, "tokenLogit": 0.0385, "isBold": false, "featAct": 6.9439, "bgColor": "#ffe3c0"}, {"tok": " '\\", "tokID": 5196, "tokenLogit": 0.0405, "isBold": false, "featAct": 3.2736, "bgColor": "#fff1e1"}, {"tok": "l", "tokID": 75, "tokenLogit": 0.0307, "isBold": false, "featAct": 1.3937, "bgColor": "#fffaf3"}, {"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": true, "featAct": 25.4571, "bgColor": "#ff9515"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.0015, "bgColor": "#fff7ed"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.5969, "bgColor": "#fffdfa"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 17.6784, "bgColor": "#ffb65d"}], [{"tok": "_HOME", "tokID": 28466, "tokenLogit": -0.0774, "isBold": false, "featAct": 8.0872, "bgColor": "#ffdeb5"}, {"tok": "%\\", "tokID": 69616, "tokenLogit": 0.0949, "isBold": false, "featAct": 3.3033, "bgColor": "#fff1e1"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.1832, "bgColor": "#fff6eb"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": false, "featAct": 17.1982, "bgColor": "#ffb861"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.861, "bgColor": "#fff3e5"}, {"tok": "wrapper", "tokID": 21364, "tokenLogit": -0.0404, "isBold": true, "featAct": 27.8459, "bgColor": "#ff8c00"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.9645, "bgColor": "#fff7ed"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.0885, "bgColor": "#fff6ec"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": false, "featAct": 5.6494, "bgColor": "#ffe8cc"}, {"tok": "-wrapper", "tokID": 17388, "tokenLogit": -0.011, "isBold": false, "featAct": 8.6936, "bgColor": "#ffdbb0"}, {"tok": ".jar", "tokID": 27628, "tokenLogit": 0.0064, "isBold": false, "featAct": 7.049, "bgColor": "#ffe2bf"}]], "idSuffix": "0", "title": "INTERVAL 25.061 - 27.846<br>CONTAINS 0.006%"}, "seq-group-2-2": {"data": [[{"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false}, {"tok": "\\n", "tokID": 198, "tokenLogit": 0.0101, "isBold": false}, {"tok": " */\\n\\n", "tokID": 2791, "tokenLogit": -0.0058, "isBold": false, "featAct": 0.6031, "bgColor": "#fffdfa"}, {"tok": "namespace", "tokID": 2231, "tokenLogit": -0.005, "isBold": false, "featAct": 0.6092, "bgColor": "#fffdfa"}, {"tok": " la", "tokID": 1187, "tokenLogit": -0.0128, "isBold": false, "featAct": 2.0447, "bgColor": "#fff7ed"}, {"tok": "jax", "tokID": 14518, "tokenLogit": -0.0328, "isBold": true, "featAct": 25.0227, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.7782, "bgColor": "#fff8ef"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false, "featAct": 2.5503, "bgColor": "#fff5e8"}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false, "featAct": 2.3068, "bgColor": "#fff6ea"}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 4.0238, "bgColor": "#ffefdb"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 22.1753, "bgColor": "#ffa334"}], [{"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": false, "featAct": 25.0924, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.3502, "bgColor": "#fff6ea"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.4215, "bgColor": "#fffefc"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": true, "featAct": 24.5121, "bgColor": "#ff9a1e"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": false, "featAct": 25.0271, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.943, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 2.3659, "bgColor": "#fff6ea"}, {"tok": "Source", "tokID": 3608, "tokenLogit": 0.0077, "isBold": false, "featAct": 1.4075, "bgColor": "#fffaf3"}, {"tok": "'],\\n", "tokID": 4380, "tokenLogit": 0.004, "isBold": false}], [{"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.3502, "bgColor": "#fff6ea"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.4215, "bgColor": "#fffefc"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 24.5121, "bgColor": "#ff9a1e"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": true, "featAct": 25.0271, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.943, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 2.3659, "bgColor": "#fff6ea"}, {"tok": "Source", "tokID": 3608, "tokenLogit": 0.0077, "isBold": false, "featAct": 1.4075, "bgColor": "#fffaf3"}, {"tok": "'],\\n", "tokID": 4380, "tokenLogit": 0.004, "isBold": false}, {"tok": "           ", "tokID": 310, "tokenLogit": -0.0126, "isBold": false}]], "idSuffix": "0", "title": "INTERVAL 22.277 - 25.061<br>CONTAINS 0.006%"}, "seq-group-2-3": {"data": [[{"tok": "jax", "tokID": 14518, "tokenLogit": -0.0328, "isBold": false, "featAct": 25.0227, "bgColor": "#ff9719"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.7782, "bgColor": "#fff8ef"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false, "featAct": 2.5503, "bgColor": "#fff5e8"}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false, "featAct": 2.3068, "bgColor": "#fff6ea"}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 4.0238, "bgColor": "#ffefdb"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": true, "featAct": 22.1753, "bgColor": "#ffa334"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": false, "featAct": 17.7069, "bgColor": "#ffb65d"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false, "featAct": 0.2135, "bgColor": "#fffffe"}, {"tok": "use", "tokID": 810, "tokenLogit": 0.0382, "isBold": false}, {"tok": " Yii", "tokID": 18258, "tokenLogit": 0.0675, "isBold": false, "featAct": 2.6358, "bgColor": "#fff4e7"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false}], [{"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.0015, "bgColor": "#fff7ed"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.5969, "bgColor": "#fffdfa"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 17.6784, "bgColor": "#ffb65d"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": true, "featAct": 20.9062, "bgColor": "#ffa83f"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.8695, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 0.7928, "bgColor": "#fffcf8"}, {"tok": "',", "tokID": 516, "tokenLogit": 0.0191, "isBold": false}, {"tok": " '", "tokID": 364, "tokenLogit": 0.0358, "isBold": false, "featAct": 0.4281, "bgColor": "#fffefc"}, {"tok": "target", "tokID": 5657, "tokenLogit": 0.0297, "isBold": false}]], "idSuffix": "0", "title": "INTERVAL 19.492 - 22.277<br>CONTAINS 0.004%"}, "seq-group-2-4": {"data": [[{"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.7782, "bgColor": "#fff8ef"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false, "featAct": 2.5503, "bgColor": "#fff5e8"}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false, "featAct": 2.3068, "bgColor": "#fff6ea"}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 4.0238, "bgColor": "#ffefdb"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": false, "featAct": 22.1753, "bgColor": "#ffa334"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": true, "featAct": 17.7069, "bgColor": "#ffb65d"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false, "featAct": 0.2135, "bgColor": "#fffffe"}, {"tok": "use", "tokID": 810, "tokenLogit": 0.0382, "isBold": false}, {"tok": " Yii", "tokID": 18258, "tokenLogit": 0.0675, "isBold": false, "featAct": 2.6358, "bgColor": "#fff4e7"}, {"tok": ";\\n\\n", "tokID": 401, "tokenLogit": -0.012, "isBold": false}, {"tok": "/**\\n", "tokID": 1747, "tokenLogit": -0.0686, "isBold": false}], [{"tok": "ajax", "tokID": 7242, "tokenLogit": 0.0064, "isBold": false, "featAct": 25.4571, "bgColor": "#ff9515"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.0015, "bgColor": "#fff7ed"}, {"tok": "trans", "tokID": 1458, "tokenLogit": -0.0393, "isBold": false}, {"tok": "lat", "tokID": 5524, "tokenLogit": 0.006, "isBold": false}, {"tok": "em", "tokID": 336, "tokenLogit": 0.0003, "isBold": false, "featAct": 0.5969, "bgColor": "#fffdfa"}, {"tok": "anager", "tokID": 8184, "tokenLogit": -0.0194, "isBold": true, "featAct": 17.6784, "bgColor": "#ffb65d"}, {"tok": "\\models", "tokID": 26106, "tokenLogit": -0.0489, "isBold": false, "featAct": 20.9062, "bgColor": "#ffa83f"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.8695, "bgColor": "#fff7ee"}, {"tok": "Language", "tokID": 13806, "tokenLogit": 0.0103, "isBold": false, "featAct": 0.7928, "bgColor": "#fffcf8"}, {"tok": "',", "tokID": 516, "tokenLogit": 0.0191, "isBold": false}, {"tok": " '", "tokID": 364, "tokenLogit": 0.0358, "isBold": false, "featAct": 0.4281, "bgColor": "#fffefc"}], [{"tok": " =", "tokID": 284, "tokenLogit": 0.0064, "isBold": false}, {"tok": " s", "tokID": 274, "tokenLogit": 0.0322, "isBold": false, "featAct": 0.2373, "bgColor": "#fffefd"}, {"tok": ".match", "tokID": 11072, "tokenLogit": -0.0259, "isBold": false}, {"tok": "(/", "tokID": 9921, "tokenLogit": -0.0452, "isBold": false, "featAct": 7.6328, "bgColor": "#ffdfb9"}, {"tok": "slide", "tokID": 19341, "tokenLogit": 0.0163, "isBold": false, "featAct": 8.9175, "bgColor": "#ffdaae"}, {"tok": "-(", "tokID": 8013, "tokenLogit": -0.0037, "isBold": true, "featAct": 19.4915, "bgColor": "#ffae4c"}, {"tok": ".*)", "tokID": 96494, "tokenLogit": -0.0131, "isBold": false, "featAct": 13.1699, "bgColor": "#ffc886"}, {"tok": "/", "tokID": 14, "tokenLogit": -0.0053, "isBold": false, "featAct": 0.3919, "bgColor": "#fffefc"}, {"tok": ");\\n", "tokID": 317, "tokenLogit": -0.0162, "isBold": false}, {"tok": "       ", "tokID": 286, "tokenLogit": 0.017, "isBold": false, "featAct": 0.0302, "bgColor": "#ffffff"}, {"tok": " if", "tokID": 421, "tokenLogit": 0.0209, "isBold": false}], [{"tok": "=%", "tokID": 7846, "tokenLogit": -0.0227, "isBold": false}, {"tok": "APP", "tokID": 14707, "tokenLogit": -0.0005, "isBold": false, "featAct": 2.9043, "bgColor": "#fff3e5"}, {"tok": "_HOME", "tokID": 28466, "tokenLogit": -0.0774, "isBold": false, "featAct": 8.0872, "bgColor": "#ffdeb5"}, {"tok": "%\\", "tokID": 69616, "tokenLogit": 0.0949, "isBold": false, "featAct": 3.3033, "bgColor": "#fff1e1"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.1832, "bgColor": "#fff6eb"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": true, "featAct": 17.1982, "bgColor": "#ffb861"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.861, "bgColor": "#fff3e5"}, {"tok": "wrapper", "tokID": 21364, "tokenLogit": -0.0404, "isBold": false, "featAct": 27.8459, "bgColor": "#ff8c00"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.9645, "bgColor": "#fff7ed"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.0885, "bgColor": "#fff6ec"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": false, "featAct": 5.6494, "bgColor": "#ffe8cc"}]], "idSuffix": "0", "title": "INTERVAL 16.708 - 19.492<br>CONTAINS 0.008%"}, "seq-group-2-5": {"data": [[{"tok": "_instance", "tokID": 11904, "tokenLogit": -0.0037, "isBold": false, "featAct": 1.0449, "bgColor": "#fffbf6"}, {"tok": ":", "tokID": 25, "tokenLogit": -0.0028, "isBold": false}, {"tok": " \"<", "tokID": 4055, "tokenLogit": 0.0109, "isBold": false}, {"tok": "type", "tokID": 1313, "tokenLogit": 0.0268, "isBold": false, "featAct": 1.2144, "bgColor": "#fffaf4"}, {"tok": " \\'", "tokID": 27152, "tokenLogit": 0.035, "isBold": false, "featAct": 0.0246, "bgColor": "#ffffff"}, {"tok": "object", "tokID": 1700, "tokenLogit": 0.0312, "isBold": true, "featAct": 14.2636, "bgColor": "#ffc47c"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "'>", "tokID": 6270, "tokenLogit": 0.0424, "isBold": false, "featAct": 0.8709, "bgColor": "#fffbf7"}, {"tok": "\"\\n", "tokID": 698, "tokenLogit": 0.0452, "isBold": false}, {"tok": " ", "tokID": 220, "tokenLogit": 0.022, "isBold": false, "featAct": 0.2028, "bgColor": "#fffffe"}, {"tok": " member", "tokID": 4462, "tokenLogit": 0.0202, "isBold": false, "featAct": 0.4038, "bgColor": "#fffefc"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.2697, "bgColor": "#fffaf4"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.3663, "bgColor": "#fffefc"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.6433, "bgColor": "#fff8f0"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.9164, "bgColor": "#fffbf7"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.2669, "bgColor": "#fff6eb"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.0776, "bgColor": "#ffc57e"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 1.2049, "bgColor": "#fffaf4"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.2753, "bgColor": "#fffaf4"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 0.9974, "bgColor": "#fffbf6"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.9626, "bgColor": "#ffe7c9"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.0762, "bgColor": "#ffffff"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3373, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.4236, "bgColor": "#fffefc"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.5214, "bgColor": "#fff9f2"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.9865, "bgColor": "#fffbf6"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.4453, "bgColor": "#fff5e9"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.1961, "bgColor": "#ffc47d"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 1.1424, "bgColor": "#fffaf5"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.2585, "bgColor": "#fffaf4"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 1.1158, "bgColor": "#fffaf5"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.9857, "bgColor": "#ffe6c8"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.0711, "bgColor": "#ffffff"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3649, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.4411, "bgColor": "#fffdfb"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.5394, "bgColor": "#fff9f1"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.9896, "bgColor": "#fffbf6"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.4312, "bgColor": "#fff5e9"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.285, "bgColor": "#ffc47c"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 1.2537, "bgColor": "#fffaf4"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.2519, "bgColor": "#fffaf4"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 1.1138, "bgColor": "#fffaf5"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 6.0728, "bgColor": "#ffe6c8"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.1805, "bgColor": "#fffffe"}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3997, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.6014, "bgColor": "#fffdfa"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.4499, "bgColor": "#fff9f2"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 1.0478, "bgColor": "#fffbf6"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.5322, "bgColor": "#fff5e8"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 14.1658, "bgColor": "#ffc47d"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 0.6029, "bgColor": "#fffdfa"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 0.9565, "bgColor": "#fffbf7"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 1.3014, "bgColor": "#fffaf4"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.6446, "bgColor": "#ffe8cc"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false, "featAct": 0.2579, "bgColor": "#fffefd"}]], "idSuffix": "0", "title": "INTERVAL 13.923 - 16.708<br>CONTAINS 0.010%"}, "seq-group-2-6": {"data": [[{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.6011, "bgColor": "#fff9f1"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.3288, "bgColor": "#fffefc"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.8019, "bgColor": "#fff8ef"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.8385, "bgColor": "#fffcf8"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 2.0801, "bgColor": "#fff6ec"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 13.0001, "bgColor": "#ffc988"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 0.8098, "bgColor": "#fffcf8"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.2254, "bgColor": "#fffaf4"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 0.8241, "bgColor": "#fffcf8"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.6169, "bgColor": "#ffe8cc"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false}], [{"tok": ">\\n", "tokID": 397, "tokenLogit": -0.0318, "isBold": false, "featAct": 1.3803, "bgColor": "#fffaf3"}, {"tok": "<", "tokID": 27, "tokenLogit": -0.0059, "isBold": false, "featAct": 0.5453, "bgColor": "#fffdfa"}, {"tok": "read", "tokID": 878, "tokenLogit": -0.007, "isBold": false, "featAct": 1.4807, "bgColor": "#fff9f2"}, {"tok": "><", "tokID": 1784, "tokenLogit": -0.0435, "isBold": false, "featAct": 0.8142, "bgColor": "#fffcf8"}, {"tok": "del", "tokID": 9588, "tokenLogit": -0.0031, "isBold": false, "featAct": 1.9092, "bgColor": "#fff7ee"}, {"tok": "im", "tokID": 318, "tokenLogit": 0.0009, "isBold": true, "featAct": 13.4023, "bgColor": "#ffc884"}, {"tok": ">\\", "tokID": 8449, "tokenLogit": 0.0886, "isBold": false, "featAct": 0.9789, "bgColor": "#fffbf7"}, {"tok": "x", "tokID": 87, "tokenLogit": 0.0335, "isBold": false, "featAct": 1.1201, "bgColor": "#fffaf5"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 0.7948, "bgColor": "#fffcf8"}, {"tok": "a", "tokID": 64, "tokenLogit": 0.0175, "isBold": false, "featAct": 5.799, "bgColor": "#ffe7ca"}, {"tok": "</", "tokID": 522, "tokenLogit": -0.0299, "isBold": false}], [{"tok": "7", "tokID": 22, "tokenLogit": 0.033, "isBold": false, "featAct": 5.4811, "bgColor": "#ffe8cd"}, {"tok": "7", "tokID": 22, "tokenLogit": 0.033, "isBold": false, "featAct": 4.0659, "bgColor": "#ffeeda"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.8334, "bgColor": "#fff3e5"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 10.8745, "bgColor": "#ffd29c"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 4.495, "bgColor": "#ffedd6"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": true, "featAct": 11.4619, "bgColor": "#ffd096"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 4.1659, "bgColor": "#ffeed9"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 10.6187, "bgColor": "#ffd39e"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.7313, "bgColor": "#fff8f0"}, {"tok": "3", "tokID": 18, "tokenLogit": 0.0362, "isBold": false, "featAct": 8.8837, "bgColor": "#ffdaae"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.958, "bgColor": "#fff7ed"}], [{"tok": " Language", "tokID": 11434, "tokenLogit": 0.0131, "isBold": false, "featAct": 0.6915, "bgColor": "#fffcf9"}, {"tok": "Translate", "tokID": 27473, "tokenLogit": -0.0144, "isBold": false}, {"tok": " extends", "tokID": 2239, "tokenLogit": -0.0184, "isBold": false, "featAct": 4.7773, "bgColor": "#ffecd4"}, {"tok": " \\", "tokID": 1124, "tokenLogit": -0.0341, "isBold": false, "featAct": 0.2743, "bgColor": "#fffefd"}, {"tok": "yii", "tokID": 37164, "tokenLogit": 0.0269, "isBold": false, "featAct": 8.8921, "bgColor": "#ffdaae"}, {"tok": "\\db", "tokID": 53229, "tokenLogit": -0.0467, "isBold": true, "featAct": 13.0766, "bgColor": "#ffc987"}, {"tok": "\\Active", "tokID": 43681, "tokenLogit": -0.0002, "isBold": false, "featAct": 0.0937, "bgColor": "#ffffff"}, {"tok": "Record", "tokID": 6471, "tokenLogit": 0.0314, "isBold": false}, {"tok": "\\n", "tokID": 198, "tokenLogit": 0.0101, "isBold": false}, {"tok": "{\\n", "tokID": 515, "tokenLogit": 0.0015, "isBold": false}, {"tok": "   ", "tokID": 262, "tokenLogit": 0.021, "isBold": false}], [{"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 1.687, "bgColor": "#fff8f0"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 2.7627, "bgColor": "#fff4e6"}, {"tok": "u", "tokID": 84, "tokenLogit": 0.0154, "isBold": false, "featAct": 10.0, "bgColor": "#ffd6a4"}, {"tok": "'\\", "tokID": 15777, "tokenLogit": 0.11, "isBold": false, "featAct": 2.338, "bgColor": "#fff6ea"}, {"tok": "(*", "tokID": 4071, "tokenLogit": -0.0137, "isBold": false, "featAct": 2.02, "bgColor": "#fff7ed"}, {"tok": "W", "tokID": 54, "tokenLogit": -0.0039, "isBold": true, "featAct": 12.367, "bgColor": "#ffcc8e"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.361, "bgColor": "#fff6ea"}, {"tok": "h", "tokID": 71, "tokenLogit": 0.0149, "isBold": false, "featAct": 1.4821, "bgColor": "#fff9f2"}, {"tok": "'-", "tokID": 24293, "tokenLogit": 0.0336, "isBold": false}, {"tok": "8", "tokID": 23, "tokenLogit": 0.0293, "isBold": false, "featAct": 1.6951, "bgColor": "#fff8f0"}, {"tok": "u", "tokID": 84, "tokenLogit": 0.0154, "isBold": false, "featAct": 4.55, "bgColor": "#ffedd6"}]], "idSuffix": "0", "title": "INTERVAL 11.138 - 13.923<br>CONTAINS 0.016%"}, "seq-group-2-7": {"data": [[{"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 2.861, "bgColor": "#fff3e5"}, {"tok": "wrapper", "tokID": 21364, "tokenLogit": -0.0404, "isBold": false, "featAct": 27.8459, "bgColor": "#ff8c00"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.9645, "bgColor": "#fff7ed"}, {"tok": "grad", "tokID": 6759, "tokenLogit": -0.0021, "isBold": false, "featAct": 2.0885, "bgColor": "#fff6ec"}, {"tok": "le", "tokID": 273, "tokenLogit": -0.0257, "isBold": false, "featAct": 5.6494, "bgColor": "#ffe8cc"}, {"tok": "-wrapper", "tokID": 17388, "tokenLogit": -0.011, "isBold": true, "featAct": 8.6936, "bgColor": "#ffdbb0"}, {"tok": ".jar", "tokID": 27628, "tokenLogit": 0.0064, "isBold": false, "featAct": 7.049, "bgColor": "#ffe2bf"}, {"tok": "\\n\\n", "tokID": 271, "tokenLogit": 0.0265, "isBold": false, "featAct": 3.2439, "bgColor": "#fff2e2"}, {"tok": "@", "tokID": 31, "tokenLogit": 0.0049, "isBold": false, "featAct": 0.6114, "bgColor": "#fffdfa"}, {"tok": "rem", "tokID": 1826, "tokenLogit": -0.0001, "isBold": false}, {"tok": " Execute", "tokID": 20848, "tokenLogit": -0.0134, "isBold": false, "featAct": 3.0096, "bgColor": "#fff3e4"}], [{"tok": "\"\\n", "tokID": 698, "tokenLogit": 0.0452, "isBold": false}, {"tok": " ", "tokID": 220, "tokenLogit": 0.022, "isBold": false}, {"tok": " \"\\", "tokID": 2917, "tokenLogit": 0.0202, "isBold": false}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 4.7863, "bgColor": "#ffebd3"}, {"tok": "5", "tokID": 20, "tokenLogit": 0.0319, "isBold": false, "featAct": 4.8731, "bgColor": "#ffebd3"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": true, "featAct": 8.4089, "bgColor": "#ffdcb2"}, {"tok": "R", "tokID": 49, "tokenLogit": 0.0066, "isBold": false, "featAct": 8.0044, "bgColor": "#ffdeb6"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.5135, "bgColor": "#fffdfb"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 7.7255, "bgColor": "#ffdfb8"}, {"tok": "*\\", "tokID": 46127, "tokenLogit": 0.0186, "isBold": false, "featAct": 1.732, "bgColor": "#fff8f0"}, {"tok": "7", "tokID": 22, "tokenLogit": 0.033, "isBold": false, "featAct": 7.3881, "bgColor": "#ffe1bc"}], [{"tok": "'\\", "tokID": 15777, "tokenLogit": 0.11, "isBold": false, "featAct": 1.1376, "bgColor": "#fffaf5"}, {"tok": "5", "tokID": 20, "tokenLogit": 0.0319, "isBold": false, "featAct": 9.4203, "bgColor": "#ffd8a9"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.7647, "bgColor": "#fffcf8"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 5.6954, "bgColor": "#ffe8cb"}, {"tok": "3", "tokID": 18, "tokenLogit": 0.0362, "isBold": false, "featAct": 8.2341, "bgColor": "#ffddb4"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": true, "featAct": 8.4101, "bgColor": "#ffdcb2"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.7911, "bgColor": "#fffcf8"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 4.6198, "bgColor": "#ffecd5"}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 5.0969, "bgColor": "#ffead1"}, {"tok": "7", "tokID": 22, "tokenLogit": 0.033, "isBold": false, "featAct": 6.127, "bgColor": "#ffe6c7"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.1593, "bgColor": "#fffffe"}], [{"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 8.872, "bgColor": "#ffdaae"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.0594, "bgColor": "#fffbf6"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 10.0616, "bgColor": "#ffd6a3"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 6.926, "bgColor": "#ffe3c0"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.4977, "bgColor": "#fff9f2"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": true, "featAct": 9.7094, "bgColor": "#ffd7a6"}, {"tok": "/\\", "tokID": 34319, "tokenLogit": 0.0142, "isBold": false, "featAct": 3.1315, "bgColor": "#fff2e3"}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 6.8014, "bgColor": "#ffe3c1"}, {"tok": "p", "tokID": 79, "tokenLogit": 0.0149, "isBold": false, "featAct": 6.2197, "bgColor": "#ffe5c6"}, {"tok": " \\", "tokID": 1124, "tokenLogit": -0.0341, "isBold": false}, {"tok": "5", "tokID": 20, "tokenLogit": 0.0319, "isBold": false, "featAct": 4.9747, "bgColor": "#ffebd2"}], [{"tok": "type", "tokID": 1313, "tokenLogit": 0.0268, "isBold": false, "featAct": 0.5725, "bgColor": "#fffdfa"}, {"tok": ":", "tokID": 25, "tokenLogit": -0.0028, "isBold": false}, {"tok": " \"<", "tokID": 4055, "tokenLogit": 0.0109, "isBold": false, "featAct": 0.5979, "bgColor": "#fffdfa"}, {"tok": "type", "tokID": 1313, "tokenLogit": 0.0268, "isBold": false, "featAct": 2.0381, "bgColor": "#fff7ed"}, {"tok": " \\'", "tokID": 27152, "tokenLogit": 0.035, "isBold": false, "featAct": 1.0448, "bgColor": "#fffbf6"}, {"tok": "property", "tokID": 3699, "tokenLogit": 0.0108, "isBold": true, "featAct": 8.7619, "bgColor": "#ffdbaf"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "'>", "tokID": 6270, "tokenLogit": 0.0424, "isBold": false, "featAct": 0.9144, "bgColor": "#fffbf7"}, {"tok": "\"\\n", "tokID": 698, "tokenLogit": 0.0452, "isBold": false}, {"tok": " ", "tokID": 220, "tokenLogit": 0.022, "isBold": false}, {"tok": " }\\n", "tokID": 456, "tokenLogit": 0.0001, "isBold": false}]], "idSuffix": "0", "title": "INTERVAL 8.354 - 11.138<br>CONTAINS 0.128%"}, "seq-group-2-8": {"data": [[{"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 7.0333, "bgColor": "#ffe2bf"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.1998, "bgColor": "#fffffe"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 8.5675, "bgColor": "#ffdcb1"}, {"tok": "&", "tokID": 5, "tokenLogit": -0.0169, "isBold": false, "featAct": 7.946, "bgColor": "#ffdeb6"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.8684, "bgColor": "#fffcf8"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": true, "featAct": 6.8961, "bgColor": "#ffe3c0"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 9.0719, "bgColor": "#ffdaac"}, {"tok": ",\\", "tokID": 26266, "tokenLogit": 0.1373, "isBold": false, "featAct": 1.2035, "bgColor": "#fffaf4"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 4.4425, "bgColor": "#ffedd7"}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 4.9605, "bgColor": "#ffebd2"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 7.2927, "bgColor": "#ffe1bc"}], [{"tok": "3", "tokID": 18, "tokenLogit": 0.0362, "isBold": false, "featAct": 4.9503, "bgColor": "#ffebd2"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 8.0521, "bgColor": "#ffdeb5"}, {"tok": "\"\\n", "tokID": 698, "tokenLogit": 0.0452, "isBold": false}, {"tok": " ", "tokID": 220, "tokenLogit": 0.022, "isBold": false}, {"tok": " \"\\", "tokID": 2917, "tokenLogit": 0.0202, "isBold": false, "featAct": 0.4041, "bgColor": "#fffefc"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": true, "featAct": 7.231, "bgColor": "#ffe1bd"}, {"tok": ".\\", "tokID": 7110, "tokenLogit": 0.1853, "isBold": false, "featAct": 0.9482, "bgColor": "#fffbf7"}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 7.9964, "bgColor": "#ffdeb6"}, {"tok": "R", "tokID": 49, "tokenLogit": 0.0066, "isBold": false, "featAct": 8.3523, "bgColor": "#ffddb3"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.2302, "bgColor": "#fffefd"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 4.5171, "bgColor": "#ffedd6"}], [{"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 7.0106, "bgColor": "#ffe2bf"}, {"tok": "S", "tokID": 50, "tokenLogit": 0.0246, "isBold": false, "featAct": 6.4509, "bgColor": "#ffe4c4"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "3", "tokID": 18, "tokenLogit": 0.0362, "isBold": false, "featAct": 4.4277, "bgColor": "#ffedd7"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 7.7346, "bgColor": "#ffdfb8"}, {"tok": "5", "tokID": 20, "tokenLogit": 0.0319, "isBold": true, "featAct": 7.0416, "bgColor": "#ffe2bf"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 6.4355, "bgColor": "#ffe4c4"}, {"tok": ")\\", "tokID": 10699, "tokenLogit": 0.1792, "isBold": false, "featAct": 1.5253, "bgColor": "#fff9f1"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 5.4627, "bgColor": "#ffe8cd"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": false, "featAct": 8.0892, "bgColor": "#ffdeb5"}], [{"tok": "s", "tokID": 82, "tokenLogit": 0.0263, "isBold": false, "featAct": 8.0397, "bgColor": "#ffdeb6"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 1.016, "bgColor": "#fffbf6"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 2.1879, "bgColor": "#fff6eb"}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 3.0771, "bgColor": "#fff2e3"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 7.5717, "bgColor": "#ffe0ba"}, {"tok": "K", "tokID": 42, "tokenLogit": -0.0135, "isBold": true, "featAct": 7.3983, "bgColor": "#ffe0bb"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.4246, "bgColor": "#fffefc"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 2.4481, "bgColor": "#fff5e9"}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 2.8193, "bgColor": "#fff4e6"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 7.0989, "bgColor": "#ffe2be"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.3806, "bgColor": "#fffefc"}], [{"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 4.3908, "bgColor": "#ffedd7"}, {"tok": "5", "tokID": 20, "tokenLogit": 0.0319, "isBold": false, "featAct": 6.3247, "bgColor": "#ffe5c5"}, {"tok": "3", "tokID": 18, "tokenLogit": 0.0362, "isBold": false, "featAct": 5.9565, "bgColor": "#ffe7c9"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 5.0378, "bgColor": "#ffead1"}, {"tok": "0", "tokID": 15, "tokenLogit": 0.0181, "isBold": true, "featAct": 6.849, "bgColor": "#ffe3c1"}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 6.8318, "bgColor": "#ffe3c1"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false, "featAct": 0.2784, "bgColor": "#fffefd"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 6.0614, "bgColor": "#ffe6c8"}, {"tok": "5", "tokID": 20, "tokenLogit": 0.0319, "isBold": false, "featAct": 3.7541, "bgColor": "#fff0dd"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 7.016, "bgColor": "#ffe2bf"}]], "idSuffix": "0", "title": "INTERVAL 5.569 - 8.354<br>CONTAINS 0.550%"}, "seq-group-2-9": {"data": [[{"tok": "5", "tokID": 20, "tokenLogit": 0.0319, "isBold": false, "featAct": 6.831, "bgColor": "#ffe3c1"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 5.22, "bgColor": "#ffead0"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 5.393, "bgColor": "#ffe9ce"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": true, "featAct": 2.8591, "bgColor": "#fff3e5"}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 3.7339, "bgColor": "#fff0dd"}, {"tok": "\\", "tokID": 59, "tokenLogit": 0.0469, "isBold": false}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 3.7989, "bgColor": "#fff0dd"}, {"tok": "4", "tokID": 19, "tokenLogit": 0.0384, "isBold": false, "featAct": 4.3819, "bgColor": "#ffedd7"}, {"tok": "\"\\n", "tokID": 698, "tokenLogit": 0.0452, "isBold": false}], [{"tok": "\"", "tokID": 1, "tokenLogit": 0.0322, "isBold": false}, {"tok": " w", "tokID": 289, "tokenLogit": 0.0181, "isBold": false, "featAct": 0.1762, "bgColor": "#fffffe"}, {"tok": "=\"", "tokID": 428, "tokenLogit": -0.0249, "isBold": false}, {"tok": "6", "tokID": 21, "tokenLogit": 0.0356, "isBold": false, "featAct": 0.4482, "bgColor": "#fffdfb"}, {"tok": "8", "tokID": 23, "tokenLogit": 0.0293, "isBold": false, "featAct": 0.0883, "bgColor": "#ffffff"}, {"tok": "\">\\n", "tokID": 881, "tokenLogit": 0.0062, "isBold": true, "featAct": 2.8181, "bgColor": "#fff4e6"}, {"tok": "   ", "tokID": 262, "tokenLogit": 0.021, "isBold": false, "featAct": 2.5105, "bgColor": "#fff5e8"}, {"tok": " <", "tokID": 366, "tokenLogit": 0.017, "isBold": false, "featAct": 2.121, "bgColor": "#fff6ec"}, {"tok": "connections", "tokID": 49986, "tokenLogit": -0.0054, "isBold": false, "featAct": 0.6266, "bgColor": "#fffdfa"}, {"tok": "/>\\n", "tokID": 10171, "tokenLogit": -0.0365, "isBold": false, "featAct": 0.9098, "bgColor": "#fffbf7"}, {"tok": "   ", "tokID": 262, "tokenLogit": 0.021, "isBold": false, "featAct": 1.6964, "bgColor": "#fff8f0"}], [{"tok": "n", "tokID": 77, "tokenLogit": 0.0273, "isBold": false, "featAct": 2.743, "bgColor": "#fff4e6"}, {"tok": "(.", "tokID": 14618, "tokenLogit": -0.0284, "isBold": false}, {"tok": "H", "tokID": 39, "tokenLogit": -0.0007, "isBold": false, "featAct": 1.3869, "bgColor": "#fffaf3"}, {"tok": "=", "tokID": 28, "tokenLogit": -0.0144, "isBold": false}, {"tok": "4", "tokID": 19, "tokenLogit": 0.0384, "isBold": false, "featAct": 0.8597, "bgColor": "#fffcf8"}, {"tok": "u", "tokID": 84, "tokenLogit": 0.0154, "isBold": true, "featAct": 2.8136, "bgColor": "#fff4e6"}, {"tok": ")&", "tokID": 14669, "tokenLogit": -0.0209, "isBold": false, "featAct": 3.3717, "bgColor": "#fff1e1"}, {"tok": "(", "tokID": 7, "tokenLogit": 0.0373, "isBold": false, "featAct": 3.608, "bgColor": "#fff0de"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 2.0613, "bgColor": "#fff7ed"}, {"tok": "m", "tokID": 76, "tokenLogit": 0.0075, "isBold": false, "featAct": 1.644, "bgColor": "#fff8f0"}, {"tok": "=", "tokID": 28, "tokenLogit": -0.0144, "isBold": false}], [{"tok": " },\\n", "tokID": 1153, "tokenLogit": -0.0044, "isBold": false}, {"tok": "       ", "tokID": 286, "tokenLogit": 0.017, "isBold": false}, {"tok": " year", "tokID": 1042, "tokenLogit": -0.0024, "isBold": false, "featAct": 1.0877, "bgColor": "#fffbf6"}, {"tok": ":", "tokID": 25, "tokenLogit": -0.0028, "isBold": false}, {"tok": " \"", "tokID": 330, "tokenLogit": 0.0284, "isBold": false, "featAct": 2.1226, "bgColor": "#fff6ec"}, {"tok": "pri", "tokID": 68608, "tokenLogit": -0.0151, "isBold": true, "featAct": 3.3476, "bgColor": "#fff1e1"}, {"tok": "je", "tokID": 3756, "tokenLogit": -0.002, "isBold": false, "featAct": 5.0751, "bgColor": "#ffead1"}, {"tok": " god", "tokID": 9886, "tokenLogit": -0.0085, "isBold": false}, {"tok": "in", "tokID": 258, "tokenLogit": 0.0061, "isBold": false, "featAct": 1.5738, "bgColor": "#fff9f1"}, {"tok": "u", "tokID": 84, "tokenLogit": 0.0154, "isBold": false, "featAct": 0.6318, "bgColor": "#fffdfa"}, {"tok": " d", "tokID": 294, "tokenLogit": 0.0324, "isBold": false, "featAct": 0.2419, "bgColor": "#fffefd"}], [{"tok": "castle", "tokID": 35108, "tokenLogit": 0.0229, "isBold": false, "featAct": 0.9434, "bgColor": "#fffbf7"}, {"tok": "App", "tokID": 2164, "tokenLogit": -0.0052, "isBold": false, "featAct": 1.3168, "bgColor": "#fffaf3"}, {"tok": " v", "tokID": 348, "tokenLogit": 0.0017, "isBold": false}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 1.5241, "bgColor": "#fff9f1"}, {"tok": "alpha", "tokID": 7141, "tokenLogit": -0.0104, "isBold": false, "featAct": 0.9716, "bgColor": "#fffbf7"}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": true, "featAct": 3.0128, "bgColor": "#fff3e4"}, {"tok": ".Fore", "tokID": 10527, "tokenLogit": -0.0048, "isBold": false}, {"tok": "castle", "tokID": 35108, "tokenLogit": 0.0229, "isBold": false, "featAct": 1.3382, "bgColor": "#fffaf3"}, {"tok": "App", "tokID": 2164, "tokenLogit": -0.0052, "isBold": false, "featAct": 1.0754, "bgColor": "#fffbf6"}, {"tok": "\\n", "tokID": 198, "tokenLogit": 0.0101, "isBold": false}, {"tok": "\\t", "tokID": 197, "tokenLogit": 0.0475, "isBold": false, "featAct": 0.1672, "bgColor": "#fffffe"}]], "idSuffix": "0", "title": "INTERVAL 2.785 - 5.569<br>CONTAINS 0.809%"}, "seq-group-2-10": {"data": [[{"tok": " files", "tokID": 3542, "tokenLogit": 0.0339, "isBold": false}, {"tok": " not", "tokID": 537, "tokenLogit": 0.0164, "isBold": false, "featAct": 0.1249, "bgColor": "#fffffe"}, {"tok": " expressly", "tokID": 52511, "tokenLogit": 0.0177, "isBold": false}, {"tok": " granted", "tokID": 11676, "tokenLogit": 0.0056, "isBold": false}, {"tok": " by", "tokID": 553, "tokenLogit": 0.0329, "isBold": false, "featAct": 0.0258, "bgColor": "#ffffff"}, {"tok": " Microsoft", "tokID": 5100, "tokenLogit": -0.0378, "isBold": true}, {"tok": ",", "tokID": 11, "tokenLogit": 0.0402, "isBold": false}, {"tok": " whether", "tokID": 3425, "tokenLogit": 0.0384, "isBold": false}, {"tok": " by", "tokID": 553, "tokenLogit": 0.0329, "isBold": false, "featAct": 2.7072, "bgColor": "#fff4e7"}, {"tok": " implication", "tokID": 60536, "tokenLogit": -0.0088, "isBold": false, "featAct": 0.4259, "bgColor": "#fffefc"}, {"tok": ",", "tokID": 11, "tokenLogit": 0.0402, "isBold": false, "featAct": 1.802, "bgColor": "#fff8ef"}], [{"tok": " \u00c3\u0123", "tokID": 42812, "tokenLogit": -0.041, "isBold": false}, {"tok": "udio", "tokID": 3230, "tokenLogit": -0.0509, "isBold": false, "featAct": 1.895, "bgColor": "#fff7ee"}, {"tok": "\";\\n", "tokID": 876, "tokenLogit": 0.0113, "isBold": false, "featAct": 1.2186, "bgColor": "#fffaf4"}, {"tok": "\"", "tokID": 1, "tokenLogit": 0.0322, "isBold": false, "featAct": 0.0792, "bgColor": "#ffffff"}, {"tok": "Save", "tokID": 8784, "tokenLogit": -0.0105, "isBold": false, "featAct": 1.2319, "bgColor": "#fffaf4"}, {"tok": " Current", "tokID": 9125, "tokenLogit": -0.0067, "isBold": true, "featAct": 1.2455, "bgColor": "#fffaf4"}, {"tok": " Image", "tokID": 4654, "tokenLogit": -0.0127, "isBold": false, "featAct": 1.476, "bgColor": "#fff9f2"}, {"tok": " (", "tokID": 320, "tokenLogit": 0.0251, "isBold": false, "featAct": 1.2158, "bgColor": "#fffaf4"}, {"tok": "Including", "tokID": 83449, "tokenLogit": -0.0077, "isBold": false, "featAct": 1.5672, "bgColor": "#fff9f1"}, {"tok": " Letter", "tokID": 26659, "tokenLogit": -0.0099, "isBold": false, "featAct": 0.8408, "bgColor": "#fffcf8"}, {"tok": " Box", "tokID": 8261, "tokenLogit": -0.017, "isBold": false, "featAct": 0.8747, "bgColor": "#fffbf7"}], [{"tok": ",", "tokID": 11, "tokenLogit": 0.0402, "isBold": false}, {"tok": "7", "tokID": 22, "tokenLogit": 0.033, "isBold": false, "featAct": 0.4845, "bgColor": "#fffdfb"}, {"tok": "};\\n", "tokID": 2440, "tokenLogit": -0.0257, "isBold": false}, {"tok": "   ", "tokID": 262, "tokenLogit": 0.021, "isBold": false, "featAct": 0.5583, "bgColor": "#fffdfa"}, {"tok": " merge", "tokID": 10880, "tokenLogit": 0.0114, "isBold": false}, {"tok": "(a", "tokID": 2877, "tokenLogit": 0.016, "isBold": true}, {"tok": "1", "tokID": 16, "tokenLogit": 0.0432, "isBold": false, "featAct": 0.6503, "bgColor": "#fffdfa"}, {"tok": ",", "tokID": 11, "tokenLogit": 0.0402, "isBold": false}, {"tok": " ", "tokID": 220, "tokenLogit": 0.022, "isBold": false}, {"tok": "2", "tokID": 17, "tokenLogit": 0.035, "isBold": false, "featAct": 0.9216, "bgColor": "#fffbf7"}, {"tok": ",", "tokID": 11, "tokenLogit": 0.0402, "isBold": false}], [{"tok": "In", "tokID": 641, "tokenLogit": 0.0155, "isBold": false}, {"tok": "Task", "tokID": 6262, "tokenLogit": 0.0058, "isBold": false}, {"tok": "bar", "tokID": 2257, "tokenLogit": -0.0226, "isBold": false, "featAct": 0.4183, "bgColor": "#fffefc"}, {"tok": " =", "tokID": 284, "tokenLogit": 0.0064, "isBold": false}, {"tok": " false", "tokID": 895, "tokenLogit": 0.0175, "isBold": false}, {"tok": ";\\n", "tokID": 280, "tokenLogit": -0.0168, "isBold": true}, {"tok": "           ", "tokID": 310, "tokenLogit": -0.0126, "isBold": false}, {"tok": " }\\n", "tokID": 456, "tokenLogit": 0.0001, "isBold": false}, {"tok": "            \\n", "tokID": 3374, "tokenLogit": -0.0044, "isBold": false}, {"tok": "           ", "tokID": 310, "tokenLogit": -0.0126, "isBold": false}, {"tok": " //", "tokID": 442, "tokenLogit": -0.0329, "isBold": false}], [{"tok": "ma", "tokID": 1728, "tokenLogit": -0.0136, "isBold": false}, {"tok": " International", "tokID": 7179, "tokenLogit": -0.027, "isBold": false}, {"tok": ".", "tokID": 13, "tokenLogit": 0.0201, "isBold": false}, {"tok": " ", "tokID": 220, "tokenLogit": 0.022, "isBold": false}, {"tok": " All", "tokID": 2009, "tokenLogit": 0.0029, "isBold": false}, {"tok": " rights", "tokID": 3188, "tokenLogit": -0.0031, "isBold": true}, {"tok": " reserved", "tokID": 4591, "tokenLogit": -0.0027, "isBold": false}, {"tok": ".\\n", "tokID": 624, "tokenLogit": -0.001, "isBold": false}, {"tok": "//", "tokID": 322, "tokenLogit": -0.0645, "isBold": false, "featAct": 0.3884, "bgColor": "#fffefc"}, {"tok": " Ec", "tokID": 36111, "tokenLogit": -0.0217, "isBold": false}, {"tok": "ma", "tokID": 1728, "tokenLogit": -0.0136, "isBold": false}]], "idSuffix": "0", "title": "INTERVAL 0.000 - 2.785<br>CONTAINS 98.463%"}}}}};
}

</script>
