<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?action=history&amp;feed=atom&amp;title=Monte_Carlo_Regression</id>
	<title>Monte Carlo Regression - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?action=history&amp;feed=atom&amp;title=Monte_Carlo_Regression"/>
	<link rel="alternate" type="text/html" href="https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;action=history"/>
	<updated>2026-04-20T21:12:08Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.43.0</generator>
	<entry>
		<id>https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;diff=1362&amp;oldid=prev</id>
		<title>Wikiroot at 14:57, 29 August 2025</title>
		<link rel="alternate" type="text/html" href="https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;diff=1362&amp;oldid=prev"/>
		<updated>2025-08-29T14:57:37Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 14:57, 29 August 2025&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot;&gt;Line 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;{{#widget:plotly}}&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;{{#widget:Monte_Carlo_Regression}}&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;{{#widget:Monte_Carlo_Regression}}&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Wikiroot</name></author>
	</entry>
	<entry>
		<id>https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;diff=1344&amp;oldid=prev</id>
		<title>Wikiroot: Replaced content with &quot;{{#widget:Monte_Carlo_Regression}}&quot;</title>
		<link rel="alternate" type="text/html" href="https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;diff=1344&amp;oldid=prev"/>
		<updated>2025-08-28T19:39:17Z</updated>

		<summary type="html">&lt;p&gt;Replaced content with &amp;quot;{{#widget:Monte_Carlo_Regression}}&amp;quot;&lt;/p&gt;
&lt;a href=&quot;https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;amp;diff=1344&amp;amp;oldid=1343&quot;&gt;Show changes&lt;/a&gt;</summary>
		<author><name>Wikiroot</name></author>
	</entry>
	<entry>
		<id>https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;diff=1343&amp;oldid=prev</id>
		<title>Wikiroot: Created page with &quot;&lt;style&gt;     body {       font-family: Arial, sans-serif;       margin: 40px;       text-align: center;     }     .input-grid {       display: grid;       grid-template-columns: repeat(3, 1fr);       gap: 15px;       max-width: 900px;       margin: 0 auto 30px;     }     .input-grid strong {       font-size: 16px;       grid-column: span 3;       text-align: left;       padding-top: 10px;     }     input[type=&quot;text&quot;] {       padding: 8px;       font-size: 14px;       widt...&quot;</title>
		<link rel="alternate" type="text/html" href="https://euler.vaniercollege.qc.ca/gwikis/pwiki/index.php?title=Monte_Carlo_Regression&amp;diff=1343&amp;oldid=prev"/>
		<updated>2025-08-28T19:38:17Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;&amp;lt;style&amp;gt;     body {       font-family: Arial, sans-serif;       margin: 40px;       text-align: center;     }     .input-grid {       display: grid;       grid-template-columns: repeat(3, 1fr);       gap: 15px;       max-width: 900px;       margin: 0 auto 30px;     }     .input-grid strong {       font-size: 16px;       grid-column: span 3;       text-align: left;       padding-top: 10px;     }     input[type=&amp;quot;text&amp;quot;] {       padding: 8px;       font-size: 14px;       widt...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;style&amp;gt;&lt;br /&gt;
    body {&lt;br /&gt;
      font-family: Arial, sans-serif;&lt;br /&gt;
      margin: 40px;&lt;br /&gt;
      text-align: center;&lt;br /&gt;
    }&lt;br /&gt;
    .input-grid {&lt;br /&gt;
      display: grid;&lt;br /&gt;
      grid-template-columns: repeat(3, 1fr);&lt;br /&gt;
      gap: 15px;&lt;br /&gt;
      max-width: 900px;&lt;br /&gt;
      margin: 0 auto 30px;&lt;br /&gt;
    }&lt;br /&gt;
    .input-grid strong {&lt;br /&gt;
      font-size: 16px;&lt;br /&gt;
      grid-column: span 3;&lt;br /&gt;
      text-align: left;&lt;br /&gt;
      padding-top: 10px;&lt;br /&gt;
    }&lt;br /&gt;
    input[type=&amp;quot;text&amp;quot;] {&lt;br /&gt;
      padding: 8px;&lt;br /&gt;
      font-size: 14px;&lt;br /&gt;
      width: 100%;&lt;br /&gt;
    }&lt;br /&gt;
    button {&lt;br /&gt;
      padding: 10px 20px;&lt;br /&gt;
      margin: 10px;&lt;br /&gt;
      font-size: 16px;&lt;br /&gt;
      background-color: #4CAF50;&lt;br /&gt;
      color: white;&lt;br /&gt;
      border: none;&lt;br /&gt;
      border-radius: 4px;&lt;br /&gt;
      cursor: pointer;&lt;br /&gt;
    }&lt;br /&gt;
    button:hover {&lt;br /&gt;
      background-color: #45a049;&lt;br /&gt;
    }&lt;br /&gt;
    #plot {&lt;br /&gt;
      width: 100%;&lt;br /&gt;
      height: 75vh;&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/style&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;my-widget-container&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;h1&amp;gt;Monte Carlo Linear Regression with Confidence Band&amp;lt;/h1&amp;gt;&lt;br /&gt;
  &amp;lt;p&amp;gt;Paste your data from Excel into the boxes below. Includes both x and y errors.&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
  &amp;lt;div class=&amp;quot;input-grid&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&amp;lt;strong&amp;gt;Axis Labels&amp;lt;/strong&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;div style=&amp;quot;grid-column: span 3;&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;p&amp;gt;You can use HTML like &amp;lt;code&amp;gt;&amp;amp;lt;sub&amp;amp;gt;&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;&amp;amp;lt;sup&amp;amp;gt;&amp;lt;/code&amp;gt; (e.g., H&amp;amp;lt;sub&amp;amp;gt;2&amp;amp;lt;/sub&amp;amp;gt;O → H&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;O).&amp;lt;/p&amp;gt;&lt;br /&gt;
    &amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;input type=&amp;quot;text&amp;quot; id=&amp;quot;xLabel&amp;quot; placeholder=&amp;quot;X Axis Label&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;input type=&amp;quot;text&amp;quot; id=&amp;quot;yLabel&amp;quot; placeholder=&amp;quot;Y Axis Label&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
    &amp;lt;div&amp;gt;&amp;lt;strong&amp;gt;X Values&amp;lt;/strong&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;input type=&amp;quot;text&amp;quot; id=&amp;quot;xValues&amp;quot; placeholder=&amp;quot;X Values (space-separated)&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;input type=&amp;quot;text&amp;quot; id=&amp;quot;xErrors&amp;quot; placeholder=&amp;quot;X Errors (optional)&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
    &amp;lt;div&amp;gt;&amp;lt;strong&amp;gt;Y Values&amp;lt;/strong&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
    &amp;lt;input type=&amp;quot;text&amp;quot; id=&amp;quot;yValues&amp;quot; placeholder=&amp;quot;Y Values&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;input type=&amp;quot;text&amp;quot; id=&amp;quot;yErrors&amp;quot; placeholder=&amp;quot;Y Errors (optional)&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;div&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
  &amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
  &amp;lt;button onclick=&amp;quot;plotData()&amp;quot;&amp;gt;Plot&amp;lt;/button&amp;gt;&lt;br /&gt;
  &amp;lt;button onclick=&amp;quot;downloadPlot()&amp;quot;&amp;gt;Download Chart&amp;lt;/button&amp;gt;&lt;br /&gt;
  &amp;lt;div id=&amp;quot;plot&amp;quot;&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;script&amp;gt;&lt;br /&gt;
    function parseValues(id) {&lt;br /&gt;
      const val = document.getElementById(id).value.trim();&lt;br /&gt;
      return val === &amp;quot;&amp;quot; ? [] : val.split(/\s+/).map(Number);&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
    function plotData() {&lt;br /&gt;
      const x = parseValues(&amp;#039;xValues&amp;#039;);&lt;br /&gt;
      const y = parseValues(&amp;#039;yValues&amp;#039;);&lt;br /&gt;
      const xErr = parseValues(&amp;#039;xErrors&amp;#039;);&lt;br /&gt;
      const yErr = parseValues(&amp;#039;yErrors&amp;#039;);&lt;br /&gt;
      const xLabel = document.getElementById(&amp;#039;xLabel&amp;#039;).value || &amp;#039;X Axis&amp;#039;;&lt;br /&gt;
      const yLabel = document.getElementById(&amp;#039;yLabel&amp;#039;).value || &amp;#039;Y Axis&amp;#039;;&lt;br /&gt;
&lt;br /&gt;
      if (x.length !== y.length) {&lt;br /&gt;
        alert(&amp;#039;X and Y values must be the same length.&amp;#039;);&lt;br /&gt;
        return;&lt;br /&gt;
      }&lt;br /&gt;
&lt;br /&gt;
      const N = 10000;&lt;br /&gt;
      const slopes = [], intercepts = [];&lt;br /&gt;
&lt;br /&gt;
      function randn_bm() {&lt;br /&gt;
        let u = 0, v = 0;&lt;br /&gt;
        while (u === 0) u = Math.random();&lt;br /&gt;
        while (v === 0) v = Math.random();&lt;br /&gt;
        return Math.sqrt(-2.0 * Math.log(u)) * Math.cos(2.0 * Math.PI * v);&lt;br /&gt;
      }&lt;br /&gt;
&lt;br /&gt;
      function linregress(xs, ys) {&lt;br /&gt;
        const n = xs.length;&lt;br /&gt;
        const xMean = xs.reduce((a, b) =&amp;gt; a + b, 0) / n;&lt;br /&gt;
        const yMean = ys.reduce((a, b) =&amp;gt; a + b, 0) / n;&lt;br /&gt;
        let num = 0, den = 0;&lt;br /&gt;
        for (let i = 0; i &amp;lt; n; i++) {&lt;br /&gt;
          num += (xs[i] - xMean) * (ys[i] - yMean);&lt;br /&gt;
          den += (xs[i] - xMean) ** 2;&lt;br /&gt;
        }&lt;br /&gt;
        const slope = num / den;&lt;br /&gt;
        const intercept = yMean - slope * xMean;&lt;br /&gt;
        return { slope, intercept };&lt;br /&gt;
      }&lt;br /&gt;
&lt;br /&gt;
      for (let i = 0; i &amp;lt; N; i++) {&lt;br /&gt;
        const xSim = x.map((xi, j) =&amp;gt; xi + randn_bm() * (xErr[j] || 0));&lt;br /&gt;
        const ySim = y.map((yi, j) =&amp;gt; yi + randn_bm() * (yErr[j] || 0));&lt;br /&gt;
        const { slope, intercept } = linregress(xSim, ySim);&lt;br /&gt;
        if (isFinite(slope) &amp;amp;&amp;amp; isFinite(intercept)) {&lt;br /&gt;
          slopes.push(slope);&lt;br /&gt;
          intercepts.push(intercept);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
&lt;br /&gt;
      const xRange = [];&lt;br /&gt;
      const xmin = Math.min(...x), xmax = Math.max(...x);&lt;br /&gt;
      const steps = 100;&lt;br /&gt;
      const step = (xmax - xmin) / steps;&lt;br /&gt;
      for (let i = 0; i &amp;lt;= steps; i++) {&lt;br /&gt;
        xRange.push(xmin + i * step);&lt;br /&gt;
      }&lt;br /&gt;
&lt;br /&gt;
      const lower = [], upper = [], meanLine = [];&lt;br /&gt;
      for (let xi of xRange) {&lt;br /&gt;
        const ySamples = slopes.map((m, i) =&amp;gt; m * xi + intercepts[i]);&lt;br /&gt;
        ySamples.sort((a, b) =&amp;gt; a - b);&lt;br /&gt;
        const lo = ySamples[Math.floor(0.025 * ySamples.length)];&lt;br /&gt;
        const hi = ySamples[Math.floor(0.975 * ySamples.length)];&lt;br /&gt;
        const avg = ySamples.reduce((a, b) =&amp;gt; a + b, 0) / ySamples.length;&lt;br /&gt;
        lower.push(lo);&lt;br /&gt;
        upper.push(hi);&lt;br /&gt;
        meanLine.push(avg);&lt;br /&gt;
      }&lt;br /&gt;
&lt;br /&gt;
      const mean = arr =&amp;gt; arr.reduce((a, b) =&amp;gt; a + b, 0) / arr.length;&lt;br /&gt;
      const std = arr =&amp;gt; {&lt;br /&gt;
        const m = mean(arr);&lt;br /&gt;
        return Math.sqrt(arr.reduce((s, v) =&amp;gt; s + (v - m) ** 2, 0) / (arr.length - 1));&lt;br /&gt;
      };&lt;br /&gt;
      const slopeStat = { mean: mean(slopes), std: std(slopes) };&lt;br /&gt;
      const interceptStat = { mean: mean(intercepts), std: std(intercepts) };&lt;br /&gt;
&lt;br /&gt;
      const annotationText = `y = (${slopeStat.mean.toExponential(3)} ± ${slopeStat.std.toExponential(3)})x + (${interceptStat.mean.toExponential(3)} ± ${interceptStat.std.toExponential(3)})`;&lt;br /&gt;
&lt;br /&gt;
      const data = [];&lt;br /&gt;
&lt;br /&gt;
      // Original data points with error bars&lt;br /&gt;
      data.push({&lt;br /&gt;
        x: x,&lt;br /&gt;
        y: y,&lt;br /&gt;
        mode: &amp;#039;markers&amp;#039;,&lt;br /&gt;
        type: &amp;#039;scatter&amp;#039;,&lt;br /&gt;
        name: &amp;#039;Data&amp;#039;,&lt;br /&gt;
        marker: { color: &amp;#039;black&amp;#039;, size: 7, symbol: &amp;#039;x-thin-open&amp;#039; },&lt;br /&gt;
        error_x: xErr.length === x.length ? {&lt;br /&gt;
          type: &amp;#039;data&amp;#039;,&lt;br /&gt;
          array: xErr,&lt;br /&gt;
          visible: true&lt;br /&gt;
        } : undefined,&lt;br /&gt;
        error_y: yErr.length === y.length ? {&lt;br /&gt;
          type: &amp;#039;data&amp;#039;,&lt;br /&gt;
          array: yErr,&lt;br /&gt;
          visible: true&lt;br /&gt;
        } : undefined&lt;br /&gt;
      });&lt;br /&gt;
&lt;br /&gt;
      // Confidence band&lt;br /&gt;
      data.push({&lt;br /&gt;
        x: [...xRange, ...xRange.slice().reverse()],&lt;br /&gt;
        y: [...upper, ...lower.slice().reverse()],&lt;br /&gt;
        fill: &amp;#039;toself&amp;#039;,&lt;br /&gt;
        fillcolor: &amp;#039;rgba(255, 0, 0, 0.2)&amp;#039;,&lt;br /&gt;
        line: { color: &amp;#039;transparent&amp;#039; },&lt;br /&gt;
        name: &amp;#039;95% Confidence Band&amp;#039;,&lt;br /&gt;
        type: &amp;#039;scatter&amp;#039;,&lt;br /&gt;
        showlegend: false&lt;br /&gt;
      });&lt;br /&gt;
&lt;br /&gt;
      // Mean regression line&lt;br /&gt;
      data.push({&lt;br /&gt;
        x: xRange,&lt;br /&gt;
        y: meanLine,&lt;br /&gt;
        mode: &amp;#039;lines&amp;#039;,&lt;br /&gt;
        type: &amp;#039;scatter&amp;#039;,&lt;br /&gt;
        name: &amp;#039;Mean Fit&amp;#039;,&lt;br /&gt;
        line: { color: &amp;#039;red&amp;#039;, width: 2 }&lt;br /&gt;
      });&lt;br /&gt;
&lt;br /&gt;
      const layout = {&lt;br /&gt;
        title: &amp;#039;&amp;#039;,&lt;br /&gt;
        xaxis: { title: xLabel },&lt;br /&gt;
        yaxis: { title: yLabel },&lt;br /&gt;
        showlegend: false,&lt;br /&gt;
        annotations: [{&lt;br /&gt;
          x: 0.05,&lt;br /&gt;
          y: 0.95,&lt;br /&gt;
          xref: &amp;#039;paper&amp;#039;,&lt;br /&gt;
          yref: &amp;#039;paper&amp;#039;,&lt;br /&gt;
          text: annotationText,&lt;br /&gt;
          showarrow: false,&lt;br /&gt;
          font: { color: &amp;#039;black&amp;#039;, size: 14 }&lt;br /&gt;
        }]&lt;br /&gt;
      };&lt;br /&gt;
&lt;br /&gt;
      Plotly.newPlot(&amp;#039;plot&amp;#039;, data, layout);&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
    function downloadPlot() {&lt;br /&gt;
      Plotly.downloadImage(&amp;#039;plot&amp;#039;, { format: &amp;#039;png&amp;#039;, filename: &amp;#039;monte_carlo_regression&amp;#039; });&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/script&amp;gt;&lt;/div&gt;</summary>
		<author><name>Wikiroot</name></author>
	</entry>
</feed>