Skip to content

Instantly share code, notes, and snippets.

@atifaziz
Last active February 9, 2024 15:58
Show Gist options
  • Star 11 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save atifaziz/8368a14c4e7b14885c92a2f76cafd72a to your computer and use it in GitHub Desktop.
Save atifaziz/8368a14c4e7b14885c92a2f76cafd72a to your computer and use it in GitHub Desktop.
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# A Practical Tour of [MoreLINQ]\n",
"\n",
"🤝 This content is distributed under the terms of [CC BY-SA 4.0].\n",
"\n",
"[MoreLINQ] is a .NET library that's been around since 2008. To date, it has added over 100 extensions to [LINQ to Objects], some of which have found their way into .NET proper! 🎉\n",
"\n",
"This notebook demonstrates a number of [MoreLINQ] extensions and how to apply them in actual practice. For illustration, we'll be implementing a [trading strategy] to see how well it performs against the historical price data for the Microsoft stock ticker symbol [MSFT]. Don't worry, you don't need to be an expert or interested in trading. Everyone knows the basic idea that to make profit, you need to sell something for a higher price than you bought it at, but to do so _systematically_ with a financial asset and perhaps even automatically, you need a _strategy_. That is, when will you buy and when will you sell? We can use a 20-day (simple) [moving average] of the stock price as a very simple indication of its trend (up or down) and buy when the price is below the moving average and sell when it goes above. They say history doesn't always repeat, but it often rhymes, so when you have a strategy in mind, it's a good idea to test how well it would have performed if you could go back in time using historical price data and play by the rules of your strategy to see if you end up in profit or loss. In trading, this is called [backtesting] and which is what we'll be doing here.\n",
"\n",
"**NOTE!** ⚠️ This is for education purposes only and the trading strategy discussed in this notebook is *extremely naïve* and for illustration purposes only.\n",
"\n",
"This notebook can be loaded and the code explored _interactively_ in [Visual Studio Code] (VS Code). See [Polyglot Notebooks in VS Code] for more. Some data structures in the display cells may be more condensely formatted and therefore easier to read in the editor than online, in Markdown.\n",
"\n",
"[MoreLINQ]: https://morelinq.github.io/\n",
"[LINQ to Objects]: https://learn.microsoft.com/en-us/dotnet/csharp/linq/query-a-collection-of-objects\n",
"[MSFT]: https://finance.yahoo.com/quote/MSFT/\n",
"[backtesting]: https://www.investopedia.com/terms/b/backtesting.asp\n",
"[trading strategy]: https://www.investopedia.com/terms/t/trading-strategy.asp\n",
"[moving average]: https://www.investopedia.com/terms/m/movingaverage.asp\n",
"[Visual Studio Code]: https://code.visualstudio.com/\n",
"[Polyglot Notebooks in VS Code]: https://code.visualstudio.com/docs/languages/polyglot\n",
"[CC BY-SA 4.0]: https://creativecommons.org/licenses/by-sa/4.0/"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's start by installing the [MoreLINQ package][nupkg] and importing the `MoreLinq` namespace along with some others we'll be needing too.\n",
"\n",
"[nupkg]: https://www.nuget.org/packages/morelinq"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><div></div><div></div><div><strong>Installed Packages</strong><ul><li><span>morelinq, 4.1.0</span></li></ul></div></div>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/plain": [
".NETCoreApp,Version=v8.0"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"#r \"nuget: morelinq, 4.1.0\"\n",
"\n",
"using System.Globalization;\n",
"using System.Net.Http;\n",
"using System.Text.RegularExpressions;\n",
"using MoreLinq;\n",
"using Microsoft.DotNet.Interactive.Formatting.TabularData;\n",
"\n",
"// For informational purposes:\n",
"AppDomain.CurrentDomain.SetupInformation.TargetFrameworkName"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We will be using and displaying [`DateOnly`] values (introduced with .NET 6) a lot, since we'll be mostly concerned with days, so let's register a compact formatting for it for this notebook (for more on this topic, see “[Replacing the default formatting for a type]” in the [.NET Interactive] documentation):\n",
"\n",
"[`DateOnly`]: https://learn.microsoft.com/en-us/dotnet/api/system.dateonly\n",
"[Replacing the default formatting for a type]: https://github.com/dotnet/interactive/blob/v1.0.4605020/docs/formatting.md#replacing-the-default-formatting-for-a-type\n",
"[.NET Interactive]: https://github.com/dotnet/interactive"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [],
"source": [
"using Microsoft.DotNet.Interactive.Formatting;\n",
"\n",
"Formatter.Register((DateOnly v) => $\"\"\"\n",
" <time datetime=\"{v:yyyy-MM-dd}\">{v:MMM dd, yyyy}</time>\n",
" \"\"\",\n",
" HtmlFormatter.MimeType);"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Later, in many of the code cells of this notebook, you'll see calls to `ToTabularDataResource()`. This is an extension method supplied by .NET Interactive and renders data in a tabular fashion. It's not strictly required, but provides a better presentation for large and inherently tabular data structures.\n",
"\n",
"We're going to be buying and selling shares, so let's begin by defining an `enum` for those actions:"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [],
"source": [
"enum Trade { Buy, Sell }"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Next, let's download the Microsoft stock price (ticker symbol [MSFT]) history for the last 5 years from [Yahoo Finance], which is what we'll be using for backtesting.\n",
"\n",
"[Yahoo Finance]: https://finance.yahoo.com/\n",
"[MSFT]: https://finance.yahoo.com/quote/MSFT?p=MSFT&.tsrc=fin-srch"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [],
"source": [
"const string ticker = \"MSFT\";\n",
"const int years = 5;\n",
"\n",
"var endDate = DateTime.SpecifyKind(new(2023, 10, 1), DateTimeKind.Utc);\n",
"var startDate = endDate.AddYears(-years);\n",
"var startTimestamp = new DateTimeOffset(startDate).ToUnixTimeSeconds();\n",
"var endTimestamp = new DateTimeOffset(endDate).ToUnixTimeSeconds();\n",
"var url = new Uri(FormattableString.Invariant(@$\"https://query1.finance.yahoo.com/v7/finance/download/{ticker}?period1={startTimestamp}&period2={endTimestamp}&interval=1d&events=history&includeAdjustedClose=true\"));\n",
"string csv;\n",
"using (var client = new HttpClient())\n",
" csv = await client.GetStringAsync(url);"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The response is CSV data, so let's parse that by first breaking it into lines delimited by either `CRLF` or `LF`:"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [],
"source": [
"var lines = Regex.Split(csv, @\"\\r?\\n\");"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's look at the headers by inspecting the first line:"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/plain": [
"Date,Open,High,Low,Close,Adj Close,Volume"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"lines.First()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"So there are 7 columns in the data:\n",
"\n",
"| Column | Description |\n",
"| :------------ | :----------------------------------------------------------------------------- |\n",
"| `Date` | The trading day |\n",
"| `Open` | Opening price at start of the trading day |\n",
"| `High` | Highest price on the trading day |\n",
"| `Low` | Lowest price on the trading day |\n",
"| `Close` | Price at the close/end of the trading day |\n",
"| [`Adj Close`] | Closing price after adjustments for applicable splits & dividend distributions |\n",
"| `Volume` | Total quantity of shared traded |\n",
"\n",
"[`Adj Close`]: https://help.yahoo.com/kb/adjusted-close-sln28256.html"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's split each row into those fields. We will skip the header line, using `Skip(1)`, and assume that the columns are always given in the above order. We will use `Split` to break-up each field by the comma (`,`) as our delimiter, but out of precation, we will only consider lines with exactly 7 fields."
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-01, 114.750000, 115.680000, 114.730003, 115.610001, 109.310699, 18883100 ]</pre></div></td></tr><tr><td>1</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-02, 115.300003, 115.839996, 114.440002, 115.150002, 108.875763, 20787200 ]</pre></div></td></tr><tr><td>2</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-03, 115.419998, 116.180000, 114.930000, 115.169998, 108.894669, 16648000 ]</pre></div></td></tr><tr><td>3</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-04, 114.610001, 114.760002, 111.629997, 112.790001, 106.644341, 34821700 ]</pre></div></td></tr><tr><td>4</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-05, 112.629997, 113.169998, 110.639999, 112.129997, 106.020332, 29068900 ]</pre></div></td></tr><tr><td>5</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-08, 111.660004, 112.029999, 109.339996, 110.849998, 104.810051, 29640600 ]</pre></div></td></tr><tr><td>6</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-09, 111.139999, 113.080002, 110.800003, 112.260002, 106.143227, 26198600 ]</pre></div></td></tr><tr><td>7</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-10, 111.239998, 111.500000, 105.790001, 106.160004, 100.375595, 61376300 ]</pre></div></td></tr><tr><td>8</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-11, 105.349998, 108.930000, 104.199997, 105.910004, 100.139244, 63904300 ]</pre></div></td></tr><tr><td>9</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-12, 109.010002, 111.239998, 107.120003, 109.570000, 103.599815, 47742100 ]</pre></div></td></tr><tr><td>10</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-15, 108.910004, 109.480003, 106.949997, 107.599998, 101.737137, 32068100 ]</pre></div></td></tr><tr><td>11</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-16, 109.540001, 111.410004, 108.949997, 111.000000, 104.951889, 31610200 ]</pre></div></td></tr><tr><td>12</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-17, 111.680000, 111.809998, 109.550003, 110.709999, 104.677689, 26548200 ]</pre></div></td></tr><tr><td>13</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-18, 110.099998, 110.529999, 107.830002, 108.500000, 102.588112, 32506200 ]</pre></div></td></tr><tr><td>14</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-19, 108.930000, 110.860001, 108.209999, 108.660004, 102.739380, 32785500 ]</pre></div></td></tr><tr><td>15</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-22, 109.320000, 110.540001, 108.239998, 109.629997, 103.656532, 26545600 ]</pre></div></td></tr><tr><td>16</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-23, 107.769997, 108.970001, 105.110001, 108.099998, 102.209915, 43770400 ]</pre></div></td></tr><tr><td>17</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-24, 108.410004, 108.489998, 101.589996, 102.320000, 96.744835, 63897800 ]</pre></div></td></tr><tr><td>18</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-25, 106.550003, 109.269997, 106.150002, 108.300003, 102.399002, 61646800 ]</pre></div></td></tr><tr><td>19</td><td><div class=\"dni-plaintext\"><pre>[ 2018-10-26, 105.690002, 108.750000, 104.760002, 106.959999, 101.132019, 55523100 ]</pre></div></td></tr><tr><td colspan=\"2\"><i>... (more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var rows =\n",
" from line in lines.Skip(1) // skip header line\n",
" select line.Split(',', 7) // split row/line into fields\n",
" into fields\n",
" where fields.Length is 7 // Filter out incomplete rows\n",
" select fields;\n",
"\n",
"rows"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Next, let's turn each row into a strong-typed object with the data we need, which will be just the date and the opening price. We will use our first extension from MoreLINQ called [`Fold`] that enables _folding_ the elements of a sequence into a single value. It's like [`Aggregate`] from LINQ except `Fold` is designed to be used for short sequences, containing up to 16 values. The arity of the lambda supplied to `Fold` determines the expected elements in the sequence (any more or less causes an exception so it has strict semantics).\n",
"\n",
"[`Fold`]: https://morelinq.github.io/4.0/ref/api/html/Overload_MoreLinq_MoreEnumerable_Fold.htm\n",
"[`Aggregate`]: https://learn.microsoft.com/en-us/dotnet/api/system.linq.enumerable.aggregate#system-linq-enumerable-aggregate-1(system-collections-generic-ienumerable((-0))-system-func((-0-0-0)))"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price\r\n",
"10/1/2018,114.750000\r\n",
"10/2/2018,115.300003\r\n",
"10/3/2018,115.419998\r\n",
"10/4/2018,114.610001\r\n",
"10/5/2018,112.629997\r\n",
"10/8/2018,111.660004\r\n",
"10/9/2018,111.139999\r\n",
"10/10/2018,111.239998\r\n",
"10/11/2018,105.349998\r\n",
"10/12/2018,109.010002\r\n",
"10/15/2018,108.910004\r\n",
"10/16/2018,109.540001\r\n",
"10/17/2018,111.680000\r\n",
"10/18/2018,110.099998\r\n",
"10/19/2018,108.930000\r\n",
"10/22/2018,109.320000\r\n",
"10/23/2018,107.769997\r\n",
"10/24/2018,108.410004\r\n",
"10/25/2018,106.550003\r\n",
"10/26/2018,105.690002\r\n",
"10/29/2018,108.110001\r\n",
"10/30/2018,103.660004\r\n",
"10/31/2018,105.440002\r\n",
"11/1/2018,107.050003\r\n",
"11/2/2018,106.480003\r\n",
"11/5/2018,106.370003\r\n",
"11/6/2018,107.379997\r\n",
"11/7/2018,109.440002\r\n",
"11/8/2018,111.800003\r\n",
"11/9/2018,110.849998\r\n",
"11/12/2018,109.419998\r\n",
"11/13/2018,107.550003\r\n",
"11/14/2018,108.099998\r\n",
"11/15/2018,104.989998\r\n",
"11/16/2018,107.080002\r\n",
"11/19/2018,108.269997\r\n",
"11/20/2018,101.800003\r\n",
"11/21/2018,103.599998\r\n",
"11/23/2018,102.169998\r\n",
"11/26/2018,104.790001\r\n",
"11/27/2018,106.269997\r\n",
"11/28/2018,107.889999\r\n",
"11/29/2018,110.330002\r\n",
"11/30/2018,110.699997\r\n",
"12/3/2018,113.000000\r\n",
"12/4/2018,111.940002\r\n",
"12/6/2018,105.820000\r\n",
"12/7/2018,108.379997\r\n",
"12/10/2018,104.800003\r\n",
"12/11/2018,109.800003\r\n",
"12/12/2018,110.889999\r\n",
"12/13/2018,109.580002\r\n",
"12/14/2018,108.250000\r\n",
"12/17/2018,105.410004\r\n",
"12/18/2018,103.750000\r\n",
"12/19/2018,103.650002\r\n",
"12/20/2018,103.050003\r\n",
"12/21/2018,101.629997\r\n",
"12/24/2018,97.680000\r\n",
"12/26/2018,95.139999\r\n",
"12/27/2018,99.300003\r\n",
"12/28/2018,102.089996\r\n",
"12/31/2018,101.290001\r\n",
"1/2/2019,99.550003\r\n",
"1/3/2019,100.099998\r\n",
"1/4/2019,99.720001\r\n",
"1/7/2019,101.639999\r\n",
"1/8/2019,103.040001\r\n",
"1/9/2019,103.860001\r\n",
"1/10/2019,103.220001\r\n",
"1/11/2019,103.190002\r\n",
"1/14/2019,101.900002\r\n",
"1/15/2019,102.510002\r\n",
"1/16/2019,105.260002\r\n",
"1/17/2019,105.000000\r\n",
"1/18/2019,107.459999\r\n",
"1/22/2019,106.750000\r\n",
"1/23/2019,106.120003\r\n",
"1/24/2019,106.860001\r\n",
"1/25/2019,107.239998\r\n",
"1/28/2019,106.260002\r\n",
"1/29/2019,104.879997\r\n",
"1/30/2019,104.620003\r\n",
"1/31/2019,103.800003\r\n",
"2/1/2019,103.779999\r\n",
"2/4/2019,102.870003\r\n",
"2/5/2019,106.059998\r\n",
"2/6/2019,107.000000\r\n",
"2/7/2019,105.190002\r\n",
"2/8/2019,104.389999\r\n",
"2/11/2019,106.199997\r\n",
"2/12/2019,106.139999\r\n",
"2/13/2019,107.500000\r\n",
"2/14/2019,106.309998\r\n",
"2/15/2019,107.910004\r\n",
"2/19/2019,107.790001\r\n",
"2/20/2019,107.860001\r\n",
"2/21/2019,106.900002\r\n",
"2/22/2019,110.050003\r\n",
"2/25/2019,111.760002\r\n",
"2/26/2019,111.260002\r\n",
"2/27/2019,111.690002\r\n",
"2/28/2019,112.040001\r\n",
"3/1/2019,112.889999\r\n",
"3/4/2019,113.019997\r\n",
"3/5/2019,112.250000\r\n",
"3/6/2019,111.870003\r\n",
"3/7/2019,111.400002\r\n",
"3/8/2019,109.160004\r\n",
"3/11/2019,110.989998\r\n",
"3/12/2019,112.820000\r\n",
"3/13/2019,114.129997\r\n",
"3/14/2019,114.540001\r\n",
"3/15/2019,115.339996\r\n",
"3/18/2019,116.169998\r\n",
"3/19/2019,118.089996\r\n",
"3/20/2019,117.389999\r\n",
"3/21/2019,117.139999\r\n",
"3/22/2019,119.500000\r\n",
"3/25/2019,116.559998\r\n",
"3/26/2019,118.620003\r\n",
"3/27/2019,117.879997\r\n",
"3/28/2019,117.440002\r\n",
"3/29/2019,118.070000\r\n",
"4/1/2019,118.949997\r\n",
"4/2/2019,119.059998\r\n",
"4/3/2019,119.860001\r\n",
"4/4/2019,120.099998\r\n",
"4/5/2019,119.389999\r\n",
"4/8/2019,119.809998\r\n",
"4/9/2019,118.629997\r\n",
"4/10/2019,119.760002\r\n",
"4/11/2019,120.540001\r\n",
"4/12/2019,120.639999\r\n",
"4/15/2019,120.940002\r\n",
"4/16/2019,121.639999\r\n",
"4/17/2019,121.239998\r\n",
"4/18/2019,122.190002\r\n",
"4/22/2019,122.620003\r\n",
"4/23/2019,124.099998\r\n",
"4/24/2019,125.790001\r\n",
"4/25/2019,130.059998\r\n",
"4/26/2019,129.699997\r\n",
"4/29/2019,129.899994\r\n",
"4/30/2019,129.809998\r\n",
"5/1/2019,130.529999\r\n",
"5/2/2019,127.980003\r\n",
"5/3/2019,127.360001\r\n",
"5/6/2019,126.389999\r\n",
"5/7/2019,126.459999\r\n",
"5/8/2019,125.440002\r\n",
"5/9/2019,124.290001\r\n",
"5/10/2019,124.910004\r\n",
"5/13/2019,124.110001\r\n",
"5/14/2019,123.870003\r\n",
"5/15/2019,124.260002\r\n",
"5/16/2019,126.750000\r\n",
"5/17/2019,128.309998\r\n",
"5/20/2019,126.519997\r\n",
"5/21/2019,127.430000\r\n",
"5/22/2019,126.620003\r\n",
"5/23/2019,126.199997\r\n",
"5/24/2019,126.910004\r\n",
"5/28/2019,126.980003\r\n",
"5/29/2019,125.379997\r\n",
"5/30/2019,125.260002\r\n",
"5/31/2019,124.230003\r\n",
"6/3/2019,123.849998\r\n",
"6/4/2019,121.279999\r\n",
"6/5/2019,124.949997\r\n",
"6/6/2019,126.440002\r\n",
"6/7/2019,129.190002\r\n",
"6/10/2019,132.399994\r\n",
"6/11/2019,133.880005\r\n",
"6/12/2019,131.399994\r\n",
"6/13/2019,131.979996\r\n",
"6/14/2019,132.259995\r\n",
"6/17/2019,132.630005\r\n",
"6/18/2019,134.190002\r\n",
"6/19/2019,135.000000\r\n",
"6/20/2019,137.449997\r\n",
"6/21/2019,136.580002\r\n",
"6/24/2019,137.000000\r\n",
"6/25/2019,137.250000\r\n",
"6/26/2019,134.350006\r\n",
"6/27/2019,134.139999\r\n",
"6/28/2019,134.570007\r\n",
"7/1/2019,136.630005\r\n",
"7/2/2019,136.119995\r\n",
"7/3/2019,136.800003\r\n",
"7/5/2019,135.940002\r\n",
"7/8/2019,136.399994\r\n",
"7/9/2019,136.000000\r\n",
"7/10/2019,137.130005\r\n",
"7/11/2019,138.199997\r\n",
"7/12/2019,138.850006\r\n",
"7/15/2019,139.440002\r\n",
"7/16/2019,138.960007\r\n",
"7/17/2019,137.699997\r\n",
"7/18/2019,135.550003\r\n",
"7/19/2019,140.220001\r\n",
"7/22/2019,137.410004\r\n",
"7/23/2019,139.759995\r\n",
"7/24/2019,138.899994\r\n",
"7/25/2019,140.429993\r\n",
"7/26/2019,140.369995\r\n",
"7/29/2019,141.500000\r\n",
"7/30/2019,140.139999\r\n",
"7/31/2019,140.330002\r\n",
"8/1/2019,137.000000\r\n",
"8/2/2019,138.089996\r\n",
"8/5/2019,133.300003\r\n",
"8/6/2019,133.800003\r\n",
"8/7/2019,133.789993\r\n",
"8/8/2019,136.600006\r\n",
"8/9/2019,138.610001\r\n",
"8/12/2019,137.070007\r\n",
"8/13/2019,136.050003\r\n",
"8/14/2019,136.360001\r\n",
"8/15/2019,134.389999\r\n",
"8/16/2019,134.880005\r\n",
"8/19/2019,137.850006\r\n",
"8/20/2019,138.210007\r\n",
"8/21/2019,138.550003\r\n",
"8/22/2019,138.660004\r\n",
"8/23/2019,137.190002\r\n",
"8/26/2019,134.990005\r\n",
"8/27/2019,136.389999\r\n",
"8/28/2019,134.880005\r\n",
"8/29/2019,137.250000\r\n",
"8/30/2019,139.149994\r\n",
"9/3/2019,136.610001\r\n",
"9/4/2019,137.300003\r\n",
"9/5/2019,139.110001\r\n",
"9/6/2019,140.029999\r\n",
"9/9/2019,139.589996\r\n",
"9/10/2019,136.800003\r\n",
"9/11/2019,135.910004\r\n",
"9/12/2019,137.850006\r\n",
"9/13/2019,137.779999\r\n",
"9/16/2019,135.830002\r\n",
"9/17/2019,136.960007\r\n",
"9/18/2019,137.360001\r\n",
"9/19/2019,140.300003\r\n",
"9/20/2019,141.009995\r\n",
"9/23/2019,139.229996\r\n",
"9/24/2019,140.360001\r\n",
"9/25/2019,137.500000\r\n",
"9/26/2019,139.440002\r\n",
"9/27/2019,140.149994\r\n",
"9/30/2019,138.050003\r\n",
"10/1/2019,139.660004\r\n",
"10/2/2019,136.250000\r\n",
"10/3/2019,134.949997\r\n",
"10/4/2019,136.750000\r\n",
"10/7/2019,137.139999\r\n",
"10/8/2019,137.080002\r\n",
"10/9/2019,137.460007\r\n",
"10/10/2019,138.490005\r\n",
"10/11/2019,140.119995\r\n",
"10/14/2019,139.690002\r\n",
"10/15/2019,140.059998\r\n",
"10/16/2019,140.789993\r\n",
"10/17/2019,140.949997\r\n",
"10/18/2019,139.759995\r\n",
"10/21/2019,138.449997\r\n",
"10/22/2019,138.970001\r\n",
"10/23/2019,136.880005\r\n",
"10/24/2019,139.389999\r\n",
"10/25/2019,139.339996\r\n",
"10/28/2019,144.399994\r\n",
"10/29/2019,144.080002\r\n",
"10/30/2019,143.520004\r\n",
"10/31/2019,144.899994\r\n",
"11/1/2019,144.259995\r\n",
"11/4/2019,144.830002\r\n",
"11/5/2019,144.970001\r\n",
"11/6/2019,144.369995\r\n",
"11/7/2019,143.839996\r\n",
"11/8/2019,143.979996\r\n",
"11/11/2019,145.339996\r\n",
"11/12/2019,146.279999\r\n",
"11/13/2019,146.740005\r\n",
"11/14/2019,147.020004\r\n",
"11/15/2019,148.929993\r\n",
"11/18/2019,150.070007\r\n",
"11/19/2019,150.880005\r\n",
"11/20/2019,150.309998\r\n",
"11/21/2019,149.399994\r\n",
"11/22/2019,150.070007\r\n",
"11/25/2019,150.000000\r\n",
"11/26/2019,151.360001\r\n",
"11/27/2019,152.330002\r\n",
"11/29/2019,152.100006\r\n",
"12/2/2019,151.809998\r\n",
"12/3/2019,147.490005\r\n",
"12/4/2019,150.139999\r\n",
"12/5/2019,150.050003\r\n",
"12/6/2019,150.990005\r\n",
"12/9/2019,151.070007\r\n",
"12/10/2019,151.289993\r\n",
"12/11/2019,151.539993\r\n",
"12/12/2019,151.649994\r\n",
"12/13/2019,153.000000\r\n",
"12/16/2019,155.110001\r\n",
"12/17/2019,155.449997\r\n",
"12/18/2019,154.300003\r\n",
"12/19/2019,154.000000\r\n",
"12/20/2019,157.350006\r\n",
"12/23/2019,158.119995\r\n",
"12/24/2019,157.479996\r\n",
"12/26/2019,157.559998\r\n",
"12/27/2019,159.449997\r\n",
"12/30/2019,158.990005\r\n",
"12/31/2019,156.770004\r\n",
"1/2/2020,158.779999\r\n",
"1/3/2020,158.320007\r\n",
"1/6/2020,157.080002\r\n",
"1/7/2020,159.320007\r\n",
"1/8/2020,158.929993\r\n",
"1/9/2020,161.839996\r\n",
"1/10/2020,162.820007\r\n",
"1/13/2020,161.759995\r\n",
"1/14/2020,163.389999\r\n",
"1/15/2020,162.619995\r\n",
"1/16/2020,164.350006\r\n",
"1/17/2020,167.419998\r\n",
"1/21/2020,166.679993\r\n",
"1/22/2020,167.399994\r\n",
"1/23/2020,166.190002\r\n",
"1/24/2020,167.509995\r\n",
"1/27/2020,161.149994\r\n",
"1/28/2020,163.779999\r\n",
"1/29/2020,167.839996\r\n",
"1/30/2020,174.050003\r\n",
"1/31/2020,172.210007\r\n",
"2/3/2020,170.429993\r\n",
"2/4/2020,177.139999\r\n",
"2/5/2020,184.029999\r\n",
"2/6/2020,180.970001\r\n",
"2/7/2020,182.850006\r\n",
"2/10/2020,183.580002\r\n",
"2/11/2020,190.649994\r\n",
"2/12/2020,185.580002\r\n",
"2/13/2020,183.080002\r\n",
"2/14/2020,183.250000\r\n",
"2/18/2020,185.610001\r\n",
"2/19/2020,188.059998\r\n",
"2/20/2020,186.949997\r\n",
"2/21/2020,183.169998\r\n",
"2/24/2020,167.770004\r\n",
"2/25/2020,174.199997\r\n",
"2/26/2020,169.710007\r\n",
"2/27/2020,163.320007\r\n",
"2/28/2020,152.410004\r\n",
"3/2/2020,165.309998\r\n",
"3/3/2020,173.800003\r\n",
"3/4/2020,168.490005\r\n",
"3/5/2020,166.050003\r\n",
"3/6/2020,162.610001\r\n",
"3/9/2020,151.000000\r\n",
"3/10/2020,158.160004\r\n",
"3/11/2020,157.130005\r\n",
"3/12/2020,145.300003\r\n",
"3/13/2020,147.500000\r\n",
"3/16/2020,140.000000\r\n",
"3/17/2020,140.000000\r\n",
"3/18/2020,138.000000\r\n",
"3/19/2020,142.770004\r\n",
"3/20/2020,146.000000\r\n",
"3/23/2020,137.009995\r\n",
"3/24/2020,143.750000\r\n",
"3/25/2020,148.910004\r\n",
"3/26/2020,148.399994\r\n",
"3/27/2020,151.750000\r\n",
"3/30/2020,152.440002\r\n",
"3/31/2020,159.399994\r\n",
"4/1/2020,153.000000\r\n",
"4/2/2020,151.860001\r\n",
"4/3/2020,155.100006\r\n",
"4/6/2020,160.320007\r\n",
"4/7/2020,169.589996\r\n",
"4/8/2020,165.669998\r\n",
"4/9/2020,166.360001\r\n",
"4/13/2020,164.350006\r\n",
"4/14/2020,169.000000\r\n",
"4/15/2020,171.199997\r\n",
"4/16/2020,174.300003\r\n",
"4/17/2020,179.500000\r\n",
"4/20/2020,176.630005\r\n",
"4/21/2020,173.500000\r\n",
"4/22/2020,171.389999\r\n",
"4/23/2020,174.110001\r\n",
"4/24/2020,172.059998\r\n",
"4/27/2020,176.589996\r\n",
"4/28/2020,175.589996\r\n",
"4/29/2020,173.220001\r\n",
"4/30/2020,180.000000\r\n",
"5/1/2020,175.800003\r\n",
"5/4/2020,174.490005\r\n",
"5/5/2020,180.619995\r\n",
"5/6/2020,182.080002\r\n",
"5/7/2020,184.169998\r\n",
"5/8/2020,184.979996\r\n",
"5/11/2020,183.149994\r\n",
"5/12/2020,186.800003\r\n",
"5/13/2020,182.550003\r\n",
"5/14/2020,177.539993\r\n",
"5/15/2020,179.059998\r\n",
"5/18/2020,185.750000\r\n",
"5/19/2020,185.029999\r\n",
"5/20/2020,184.809998\r\n",
"5/21/2020,185.399994\r\n",
"5/22/2020,183.190002\r\n",
"5/26/2020,186.339996\r\n",
"5/27/2020,180.199997\r\n",
"5/28/2020,180.740005\r\n",
"5/29/2020,182.729996\r\n",
"6/1/2020,182.539993\r\n",
"6/2/2020,184.250000\r\n",
"6/3/2020,184.820007\r\n",
"6/4/2020,184.300003\r\n",
"6/5/2020,182.619995\r\n",
"6/8/2020,185.940002\r\n",
"6/9/2020,188.000000\r\n",
"6/10/2020,191.130005\r\n",
"6/11/2020,193.130005\r\n",
"6/12/2020,190.539993\r\n",
"6/15/2020,184.580002\r\n",
"6/16/2020,192.889999\r\n",
"6/17/2020,195.029999\r\n",
"6/18/2020,194.000000\r\n",
"6/19/2020,198.589996\r\n",
"6/22/2020,195.789993\r\n",
"6/23/2020,202.089996\r\n",
"6/24/2020,201.600006\r\n",
"6/25/2020,197.800003\r\n",
"6/26/2020,199.729996\r\n",
"6/29/2020,195.779999\r\n",
"6/30/2020,197.880005\r\n",
"7/1/2020,203.139999\r\n",
"7/2/2020,205.679993\r\n",
"7/6/2020,208.830002\r\n",
"7/7/2020,210.449997\r\n",
"7/8/2020,210.070007\r\n",
"7/9/2020,216.330002\r\n",
"7/10/2020,213.619995\r\n",
"7/13/2020,214.479996\r\n",
"7/14/2020,206.130005\r\n",
"7/15/2020,209.559998\r\n",
"7/16/2020,205.399994\r\n",
"7/17/2020,204.470001\r\n",
"7/20/2020,205.000000\r\n",
"7/21/2020,213.660004\r\n",
"7/22/2020,209.199997\r\n",
"7/23/2020,207.190002\r\n",
"7/24/2020,200.419998\r\n",
"7/27/2020,201.470001\r\n",
"7/28/2020,203.610001\r\n",
"7/29/2020,202.500000\r\n",
"7/30/2020,201.000000\r\n",
"7/31/2020,204.399994\r\n",
"8/3/2020,211.520004\r\n",
"8/4/2020,214.169998\r\n",
"8/5/2020,214.899994\r\n",
"8/6/2020,212.339996\r\n",
"8/7/2020,214.850006\r\n",
"8/10/2020,211.669998\r\n",
"8/11/2020,207.160004\r\n",
"8/12/2020,205.289993\r\n",
"8/13/2020,209.440002\r\n",
"8/14/2020,208.759995\r\n",
"8/17/2020,209.600006\r\n",
"8/18/2020,210.529999\r\n",
"8/19/2020,211.490005\r\n",
"8/20/2020,209.539993\r\n",
"8/21/2020,213.860001\r\n",
"8/24/2020,214.789993\r\n",
"8/25/2020,213.100006\r\n",
"8/26/2020,217.880005\r\n",
"8/27/2020,222.889999\r\n",
"8/28/2020,228.179993\r\n",
"8/31/2020,227.000000\r\n",
"9/1/2020,225.509995\r\n",
"9/2/2020,227.970001\r\n",
"9/3/2020,229.270004\r\n",
"9/4/2020,215.100006\r\n",
"9/8/2020,206.500000\r\n",
"9/9/2020,207.600006\r\n",
"9/10/2020,213.399994\r\n",
"9/11/2020,207.199997\r\n",
"9/14/2020,204.240005\r\n",
"9/15/2020,208.419998\r\n",
"9/16/2020,210.619995\r\n",
"9/17/2020,200.050003\r\n",
"9/18/2020,202.800003\r\n",
"9/21/2020,197.190002\r\n",
"9/22/2020,205.059998\r\n",
"9/23/2020,207.899994\r\n",
"9/24/2020,199.850006\r\n",
"9/25/2020,203.550003\r\n",
"9/28/2020,210.880005\r\n",
"9/29/2020,209.350006\r\n",
"9/30/2020,207.729996\r\n",
"10/1/2020,213.490005\r\n",
"10/2/2020,208.000000\r\n",
"10/5/2020,207.220001\r\n",
"10/6/2020,208.820007\r\n",
"10/7/2020,207.059998\r\n",
"10/8/2020,210.509995\r\n",
"10/9/2020,211.229996\r\n",
"10/12/2020,218.789993\r\n",
"10/13/2020,222.720001\r\n",
"10/14/2020,223.000000\r\n",
"10/15/2020,217.100006\r\n",
"10/16/2020,220.149994\r\n",
"10/19/2020,220.419998\r\n",
"10/20/2020,215.800003\r\n",
"10/21/2020,213.119995\r\n",
"10/22/2020,213.929993\r\n",
"10/23/2020,215.029999\r\n",
"10/26/2020,213.850006\r\n",
"10/27/2020,211.589996\r\n",
"10/28/2020,207.669998\r\n",
"10/29/2020,204.070007\r\n",
"10/30/2020,203.500000\r\n",
"11/2/2020,204.289993\r\n",
"11/3/2020,203.889999\r\n",
"11/4/2020,214.020004\r\n",
"11/5/2020,222.039993\r\n",
"11/6/2020,222.259995\r\n",
"11/9/2020,224.440002\r\n",
"11/10/2020,214.500000\r\n",
"11/11/2020,212.389999\r\n",
"11/12/2020,217.210007\r\n",
"11/13/2020,216.360001\r\n",
"11/16/2020,214.869995\r\n",
"11/17/2020,216.100006\r\n",
"11/18/2020,213.649994\r\n",
"11/19/2020,211.380005\r\n",
"11/20/2020,212.199997\r\n",
"11/23/2020,210.949997\r\n",
"11/24/2020,209.589996\r\n",
"11/25/2020,215.110001\r\n",
"11/27/2020,214.850006\r\n",
"11/30/2020,214.100006\r\n",
"12/1/2020,214.509995\r\n",
"12/2/2020,214.880005\r\n",
"12/3/2020,214.610001\r\n",
"12/4/2020,214.220001\r\n",
"12/7/2020,214.369995\r\n",
"12/8/2020,213.970001\r\n",
"12/9/2020,215.160004\r\n",
"12/10/2020,211.770004\r\n",
"12/11/2020,210.050003\r\n",
"12/14/2020,213.100006\r\n",
"12/15/2020,215.169998\r\n",
"12/16/2020,214.750000\r\n",
"12/17/2020,219.869995\r\n",
"12/18/2020,218.589996\r\n",
"12/21/2020,217.550003\r\n",
"12/22/2020,222.690002\r\n",
"12/23/2020,223.110001\r\n",
"12/24/2020,221.419998\r\n",
"12/28/2020,224.449997\r\n",
"12/29/2020,226.309998\r\n",
"12/30/2020,225.229996\r\n",
"12/31/2020,221.699997\r\n",
"1/4/2021,222.529999\r\n",
"1/5/2021,217.259995\r\n",
"1/6/2021,212.169998\r\n",
"1/7/2021,214.039993\r\n",
"1/8/2021,218.679993\r\n",
"1/11/2021,218.470001\r\n",
"1/12/2021,216.500000\r\n",
"1/13/2021,214.020004\r\n",
"1/14/2021,215.910004\r\n",
"1/15/2021,213.520004\r\n",
"1/19/2021,213.750000\r\n",
"1/20/2021,217.699997\r\n",
"1/21/2021,224.699997\r\n",
"1/22/2021,227.080002\r\n",
"1/25/2021,229.119995\r\n",
"1/26/2021,231.860001\r\n",
"1/27/2021,238.000000\r\n",
"1/28/2021,235.610001\r\n",
"1/29/2021,235.990005\r\n",
"2/1/2021,235.059998\r\n",
"2/2/2021,241.300003\r\n",
"2/3/2021,239.570007\r\n",
"2/4/2021,242.660004\r\n",
"2/5/2021,242.229996\r\n",
"2/8/2021,243.149994\r\n",
"2/9/2021,241.869995\r\n",
"2/10/2021,245.000000\r\n",
"2/11/2021,244.779999\r\n",
"2/12/2021,243.929993\r\n",
"2/16/2021,245.029999\r\n",
"2/17/2021,241.320007\r\n",
"2/18/2021,241.800003\r\n",
"2/19/2021,243.750000\r\n",
"2/22/2021,237.419998\r\n",
"2/23/2021,230.330002\r\n",
"2/24/2021,230.009995\r\n",
"2/25/2021,232.080002\r\n",
"2/26/2021,231.529999\r\n",
"3/1/2021,235.899994\r\n",
"3/2/2021,237.009995\r\n",
"3/3/2021,232.160004\r\n",
"3/4/2021,226.740005\r\n",
"3/5/2021,229.520004\r\n",
"3/8/2021,231.369995\r\n",
"3/9/2021,232.880005\r\n",
"3/10/2021,237.000000\r\n",
"3/11/2021,234.960007\r\n",
"3/12/2021,234.009995\r\n",
"3/15/2021,234.960007\r\n",
"3/16/2021,236.279999\r\n",
"3/17/2021,236.149994\r\n",
"3/18/2021,232.559998\r\n",
"3/19/2021,231.020004\r\n",
"3/22/2021,230.270004\r\n",
"3/23/2021,237.490005\r\n",
"3/24/2021,237.850006\r\n",
"3/25/2021,235.300003\r\n",
"3/26/2021,231.550003\r\n",
"3/29/2021,236.589996\r\n",
"3/30/2021,233.529999\r\n",
"3/31/2021,232.910004\r\n",
"4/1/2021,238.470001\r\n",
"4/5/2021,242.759995\r\n",
"4/6/2021,247.610001\r\n",
"4/7/2021,247.809998\r\n",
"4/8/2021,252.770004\r\n",
"4/9/2021,252.869995\r\n",
"4/12/2021,254.710007\r\n",
"4/13/2021,257.260010\r\n",
"4/14/2021,257.480011\r\n",
"4/15/2021,257.929993\r\n",
"4/16/2021,259.470001\r\n",
"4/19/2021,260.190002\r\n",
"4/20/2021,257.820007\r\n",
"4/21/2021,258.940002\r\n",
"4/22/2021,260.209991\r\n",
"4/23/2021,257.880005\r\n",
"4/26/2021,261.660004\r\n",
"4/27/2021,261.579987\r\n",
"4/28/2021,256.079987\r\n",
"4/29/2021,255.460007\r\n",
"4/30/2021,249.740005\r\n",
"5/3/2021,253.399994\r\n",
"5/4/2021,250.970001\r\n",
"5/5/2021,249.059998\r\n",
"5/6/2021,246.449997\r\n",
"5/7/2021,252.149994\r\n",
"5/10/2021,250.869995\r\n",
"5/11/2021,244.550003\r\n",
"5/12/2021,242.169998\r\n",
"5/13/2021,241.800003\r\n",
"5/14/2021,245.580002\r\n",
"5/17/2021,246.550003\r\n",
"5/18/2021,246.270004\r\n",
"5/19/2021,239.309998\r\n",
"5/20/2021,243.960007\r\n",
"5/21/2021,247.570007\r\n",
"5/24/2021,247.789993\r\n",
"5/25/2021,251.770004\r\n",
"5/26/2021,251.429993\r\n",
"5/27/2021,251.169998\r\n",
"5/28/2021,251.000000\r\n",
"6/1/2021,251.229996\r\n",
"6/2/2021,248.130005\r\n",
"6/3/2021,245.220001\r\n",
"6/4/2021,247.759995\r\n",
"6/7/2021,249.979996\r\n",
"6/8/2021,255.160004\r\n",
"6/9/2021,253.809998\r\n",
"6/10/2021,254.289993\r\n",
"6/11/2021,257.989990\r\n",
"6/14/2021,257.899994\r\n",
"6/15/2021,259.769989\r\n",
"6/16/2021,259.399994\r\n",
"6/17/2021,256.070007\r\n",
"6/18/2021,259.630005\r\n",
"6/21/2021,259.820007\r\n",
"6/22/2021,262.720001\r\n",
"6/23/2021,265.989990\r\n",
"6/24/2021,266.160004\r\n",
"6/25/2021,266.230011\r\n",
"6/28/2021,266.190002\r\n",
"6/29/2021,268.869995\r\n",
"6/30/2021,270.690002\r\n",
"7/1/2021,269.609985\r\n",
"7/2/2021,272.820007\r\n",
"7/6/2021,278.029999\r\n",
"7/7/2021,279.399994\r\n",
"7/8/2021,276.899994\r\n",
"7/9/2021,275.720001\r\n",
"7/12/2021,279.160004\r\n",
"7/13/2021,277.519989\r\n",
"7/14/2021,282.350006\r\n",
"7/15/2021,282.000000\r\n",
"7/16/2021,282.070007\r\n",
"7/19/2021,278.929993\r\n",
"7/20/2021,278.029999\r\n",
"7/21/2021,278.899994\r\n",
"7/22/2021,283.839996\r\n",
"7/23/2021,287.369995\r\n",
"7/26/2021,289.000000\r\n",
"7/27/2021,289.429993\r\n",
"7/28/2021,288.989990\r\n",
"7/29/2021,286.239990\r\n",
"7/30/2021,285.170013\r\n",
"8/2/2021,286.359985\r\n",
"8/3/2021,285.420013\r\n",
"8/4/2021,286.220001\r\n",
"8/5/2021,286.880005\r\n",
"8/6/2021,288.510010\r\n",
"8/9/2021,289.750000\r\n",
"8/10/2021,288.799988\r\n",
"8/11/2021,287.209991\r\n",
"8/12/2021,286.630005\r\n",
"8/13/2021,289.480011\r\n",
"8/16/2021,293.190002\r\n",
"8/17/2021,292.390015\r\n",
"8/18/2021,292.040009\r\n",
"8/19/2021,288.690002\r\n",
"8/20/2021,299.720001\r\n",
"8/23/2021,303.250000\r\n",
"8/24/2021,305.019989\r\n",
"8/25/2021,304.299988\r\n",
"8/26/2021,300.989990\r\n",
"8/27/2021,298.989990\r\n",
"8/30/2021,301.119995\r\n",
"8/31/2021,304.420013\r\n",
"9/1/2021,302.869995\r\n",
"9/2/2021,302.200012\r\n",
"9/3/2021,300.989990\r\n",
"9/7/2021,301.010010\r\n",
"9/8/2021,299.779999\r\n",
"9/9/2021,300.820007\r\n",
"9/10/2021,298.420013\r\n",
"9/13/2021,297.549988\r\n",
"9/14/2021,299.559998\r\n",
"9/15/2021,303.260010\r\n",
"9/16/2021,303.760010\r\n",
"9/17/2021,304.170013\r\n",
"9/20/2021,296.329987\r\n",
"9/21/2021,295.690002\r\n",
"9/22/2021,296.730011\r\n",
"9/23/2021,298.850006\r\n",
"9/24/2021,298.230011\r\n",
"9/27/2021,296.140015\r\n",
"9/28/2021,289.799988\r\n",
"9/29/2021,285.100006\r\n",
"9/30/2021,285.709991\r\n",
"10/1/2021,282.119995\r\n",
"10/4/2021,287.399994\r\n",
"10/5/2021,284.049988\r\n",
"10/6/2021,285.779999\r\n",
"10/7/2021,295.179993\r\n",
"10/8/2021,296.220001\r\n",
"10/11/2021,292.920013\r\n",
"10/12/2021,295.339996\r\n",
"10/13/2021,294.910004\r\n",
"10/14/2021,299.209991\r\n",
"10/15/2021,302.339996\r\n",
"10/18/2021,303.570007\r\n",
"10/19/2021,308.350006\r\n",
"10/20/2021,309.209991\r\n",
"10/21/2021,307.170013\r\n",
"10/22/2021,310.399994\r\n",
"10/25/2021,309.359985\r\n",
"10/26/2021,311.000000\r\n",
"10/27/2021,316.000000\r\n",
"10/28/2021,324.329987\r\n",
"10/29/2021,324.130005\r\n",
"11/1/2021,331.359985\r\n",
"11/2/2021,330.309998\r\n",
"11/3/2021,333.899994\r\n",
"11/4/2021,332.890015\r\n",
"11/5/2021,338.510010\r\n",
"11/8/2021,337.299988\r\n",
"11/9/2021,337.109985\r\n",
"11/10/2021,334.570007\r\n",
"11/11/2021,331.250000\r\n",
"11/12/2021,333.920013\r\n",
"11/15/2021,337.540009\r\n",
"11/16/2021,335.679993\r\n",
"11/17/2021,338.940002\r\n",
"11/18/2021,338.179993\r\n",
"11/19/2021,342.640015\r\n",
"11/22/2021,344.619995\r\n",
"11/23/2021,337.049988\r\n",
"11/24/2021,336.279999\r\n",
"11/26/2021,334.350006\r\n",
"11/29/2021,334.940002\r\n",
"11/30/2021,335.320007\r\n",
"12/1/2021,335.130005\r\n",
"12/2/2021,330.299988\r\n",
"12/3/2021,331.989990\r\n",
"12/6/2021,323.950012\r\n",
"12/7/2021,331.640015\r\n",
"12/8/2021,335.309998\r\n",
"12/9/2021,334.410004\r\n",
"12/10/2021,334.980011\r\n",
"12/13/2021,340.679993\r\n",
"12/14/2021,333.220001\r\n",
"12/15/2021,328.609985\r\n",
"12/16/2021,335.709991\r\n",
"12/17/2021,320.880005\r\n",
"12/20/2021,320.049988\r\n",
"12/21/2021,323.290009\r\n",
"12/22/2021,328.299988\r\n",
"12/23/2021,332.750000\r\n",
"12/27/2021,335.459991\r\n",
"12/28/2021,343.149994\r\n",
"12/29/2021,341.299988\r\n",
"12/30/2021,341.910004\r\n",
"12/31/2021,338.510010\r\n",
"1/3/2022,335.350006\r\n",
"1/4/2022,334.829987\r\n",
"1/5/2022,325.859985\r\n",
"1/6/2022,313.149994\r\n",
"1/7/2022,314.149994\r\n",
"1/10/2022,309.489990\r\n",
"1/11/2022,313.380005\r\n",
"1/12/2022,319.670013\r\n",
"1/13/2022,320.470001\r\n",
"1/14/2022,304.250000\r\n",
"1/18/2022,304.070007\r\n",
"1/19/2022,306.290009\r\n",
"1/20/2022,309.070007\r\n",
"1/21/2022,302.690002\r\n",
"1/24/2022,292.200012\r\n",
"1/25/2022,291.519989\r\n",
"1/26/2022,307.989990\r\n",
"1/27/2022,302.660004\r\n",
"1/28/2022,300.230011\r\n",
"1/31/2022,308.950012\r\n",
"2/1/2022,310.410004\r\n",
"2/2/2022,309.630005\r\n",
"2/3/2022,309.489990\r\n",
"2/4/2022,300.209991\r\n",
"2/7/2022,306.170013\r\n",
"2/8/2022,301.250000\r\n",
"2/9/2022,309.869995\r\n",
"2/10/2022,304.040009\r\n",
"2/11/2022,303.190002\r\n",
"2/14/2022,293.769989\r\n",
"2/15/2022,300.010010\r\n",
"2/16/2022,298.369995\r\n",
"2/17/2022,296.359985\r\n",
"2/18/2022,293.049988\r\n",
"2/22/2022,285.000000\r\n",
"2/23/2022,290.179993\r\n",
"2/24/2022,272.510010\r\n",
"2/25/2022,295.140015\r\n",
"2/28/2022,294.309998\r\n",
"3/1/2022,296.399994\r\n",
"3/2/2022,295.359985\r\n",
"3/3/2022,302.890015\r\n",
"3/4/2022,294.290009\r\n",
"3/7/2022,288.529999\r\n",
"3/8/2022,277.799988\r\n",
"3/9/2022,283.440002\r\n",
"3/10/2022,283.019989\r\n",
"3/11/2022,287.959991\r\n",
"3/14/2022,280.339996\r\n",
"3/15/2022,280.350006\r\n",
"3/16/2022,289.109985\r\n",
"3/17/2022,293.290009\r\n",
"3/18/2022,295.369995\r\n",
"3/21/2022,298.890015\r\n",
"3/22/2022,299.799988\r\n",
"3/23/2022,300.510010\r\n",
"3/24/2022,299.140015\r\n",
"3/25/2022,305.230011\r\n",
"3/28/2022,304.329987\r\n",
"3/29/2022,313.910004\r\n",
"3/30/2022,313.760010\r\n",
"3/31/2022,313.899994\r\n",
"4/1/2022,309.369995\r\n",
"4/4/2022,310.089996\r\n",
"4/5/2022,313.269989\r\n",
"4/6/2022,305.190002\r\n",
"4/7/2022,296.660004\r\n",
"4/8/2022,300.440002\r\n",
"4/11/2022,291.790009\r\n",
"4/12/2022,289.239990\r\n",
"4/13/2022,282.730011\r\n",
"4/14/2022,288.089996\r\n",
"4/18/2022,278.910004\r\n",
"4/19/2022,279.380005\r\n",
"4/20/2022,289.399994\r\n",
"4/21/2022,288.579987\r\n",
"4/22/2022,281.679993\r\n",
"4/25/2022,273.290009\r\n",
"4/26/2022,277.500000\r\n",
"4/27/2022,282.100006\r\n",
"4/28/2022,285.190002\r\n",
"4/29/2022,288.609985\r\n",
"5/2/2022,277.709991\r\n",
"5/3/2022,283.959991\r\n",
"5/4/2022,282.589996\r\n",
"5/5/2022,285.540009\r\n",
"5/6/2022,274.809998\r\n",
"5/9/2022,270.059998\r\n",
"5/10/2022,271.690002\r\n",
"5/11/2022,265.679993\r\n",
"5/12/2022,257.690002\r\n",
"5/13/2022,257.350006\r\n",
"5/16/2022,259.959991\r\n",
"5/17/2022,266.109985\r\n",
"5/18/2022,263.000000\r\n",
"5/19/2022,253.899994\r\n",
"5/20/2022,257.239990\r\n",
"5/23/2022,255.490005\r\n",
"5/24/2022,257.890015\r\n",
"5/25/2022,258.140015\r\n",
"5/26/2022,262.269989\r\n",
"5/27/2022,268.480011\r\n",
"5/31/2022,272.529999\r\n",
"6/1/2022,275.200012\r\n",
"6/2/2022,264.450012\r\n",
"6/3/2022,270.309998\r\n",
"6/6/2022,272.059998\r\n",
"6/7/2022,266.640015\r\n",
"6/8/2022,271.709991\r\n",
"6/9/2022,267.779999\r\n",
"6/10/2022,260.579987\r\n",
"6/13/2022,245.110001\r\n",
"6/14/2022,243.860001\r\n",
"6/15/2022,248.309998\r\n",
"6/16/2022,245.979996\r\n",
"6/17/2022,244.699997\r\n",
"6/21/2022,250.259995\r\n",
"6/22/2022,251.889999\r\n",
"6/23/2022,255.570007\r\n",
"6/24/2022,261.809998\r\n",
"6/27/2022,268.209991\r\n",
"6/28/2022,263.980011\r\n",
"6/29/2022,257.589996\r\n",
"6/30/2022,257.049988\r\n",
"7/1/2022,256.390015\r\n",
"7/5/2022,256.160004\r\n",
"7/6/2022,263.750000\r\n",
"7/7/2022,265.119995\r\n",
"7/8/2022,264.790009\r\n",
"7/11/2022,265.649994\r\n",
"7/12/2022,265.880005\r\n",
"7/13/2022,250.190002\r\n",
"7/14/2022,250.570007\r\n",
"7/15/2022,255.720001\r\n",
"7/18/2022,259.750000\r\n",
"7/19/2022,257.579987\r\n",
"7/20/2022,259.899994\r\n",
"7/21/2022,259.790009\r\n",
"7/22/2022,265.239990\r\n",
"7/25/2022,261.000000\r\n",
"7/26/2022,259.859985\r\n",
"7/27/2022,261.160004\r\n",
"7/28/2022,269.750000\r\n",
"7/29/2022,277.700012\r\n",
"8/1/2022,277.820007\r\n",
"8/2/2022,276.000000\r\n",
"8/3/2022,276.760010\r\n",
"8/4/2022,281.799988\r\n",
"8/5/2022,279.149994\r\n",
"8/8/2022,284.049988\r\n",
"8/9/2022,279.640015\r\n",
"8/10/2022,288.170013\r\n",
"8/11/2022,290.850006\r\n",
"8/12/2022,288.480011\r\n",
"8/15/2022,291.000000\r\n",
"8/16/2022,291.989990\r\n",
"8/17/2022,289.739990\r\n",
"8/18/2022,290.190002\r\n",
"8/19/2022,288.899994\r\n",
"8/22/2022,282.079987\r\n",
"8/23/2022,276.440002\r\n",
"8/24/2022,275.410004\r\n",
"8/25/2022,277.329987\r\n",
"8/26/2022,279.079987\r\n",
"8/29/2022,265.850006\r\n",
"8/30/2022,266.670013\r\n",
"8/31/2022,265.390015\r\n",
"9/1/2022,258.869995\r\n",
"9/2/2022,261.700012\r\n",
"9/6/2022,256.200012\r\n",
"9/7/2022,254.699997\r\n",
"9/8/2022,257.510010\r\n",
"9/9/2022,260.500000\r\n",
"9/12/2022,265.779999\r\n",
"9/13/2022,258.839996\r\n",
"9/14/2022,253.529999\r\n",
"9/15/2022,249.770004\r\n",
"9/16/2022,244.259995\r\n",
"9/19/2022,242.470001\r\n",
"9/20/2022,242.070007\r\n",
"9/21/2022,244.270004\r\n",
"9/22/2022,237.869995\r\n",
"9/23/2022,239.539993\r\n",
"9/26/2022,237.050003\r\n",
"9/27/2022,239.979996\r\n",
"9/28/2022,236.809998\r\n",
"9/29/2022,238.889999\r\n",
"9/30/2022,238.289993\r\n",
"10/3/2022,235.410004\r\n",
"10/4/2022,245.089996\r\n",
"10/5/2022,245.990005\r\n",
"10/6/2022,247.929993\r\n",
"10/7/2022,240.899994\r\n",
"10/10/2022,233.050003\r\n",
"10/11/2022,227.619995\r\n",
"10/12/2022,225.399994\r\n",
"10/13/2022,219.850006\r\n",
"10/14/2022,235.539993\r\n",
"10/17/2022,235.820007\r\n",
"10/18/2022,243.240005\r\n",
"10/19/2022,237.039993\r\n",
"10/20/2022,235.770004\r\n",
"10/21/2022,234.740005\r\n",
"10/24/2022,243.759995\r\n",
"10/25/2022,247.259995\r\n",
"10/26/2022,231.169998\r\n",
"10/27/2022,231.039993\r\n",
"10/28/2022,226.240005\r\n",
"10/31/2022,233.759995\r\n",
"11/1/2022,234.600006\r\n",
"11/2/2022,229.460007\r\n",
"11/3/2022,220.089996\r\n",
"11/4/2022,217.550003\r\n",
"11/7/2022,221.990005\r\n",
"11/8/2022,228.699997\r\n",
"11/9/2022,227.369995\r\n",
"11/10/2022,235.429993\r\n",
"11/11/2022,242.990005\r\n",
"11/14/2022,241.990005\r\n",
"11/15/2022,245.660004\r\n",
"11/16/2022,242.789993\r\n",
"11/17/2022,237.779999\r\n",
"11/18/2022,243.509995\r\n",
"11/21/2022,241.429993\r\n",
"11/22/2022,243.589996\r\n",
"11/23/2022,245.110001\r\n",
"11/25/2022,247.309998\r\n",
"11/28/2022,246.080002\r\n",
"11/29/2022,241.399994\r\n",
"11/30/2022,240.570007\r\n",
"12/1/2022,253.869995\r\n",
"12/2/2022,249.820007\r\n",
"12/5/2022,252.009995\r\n",
"12/6/2022,250.820007\r\n",
"12/7/2022,244.830002\r\n",
"12/8/2022,244.839996\r\n",
"12/9/2022,244.699997\r\n",
"12/12/2022,247.449997\r\n",
"12/13/2022,261.690002\r\n",
"12/14/2022,257.130005\r\n",
"12/15/2022,253.720001\r\n",
"12/16/2022,248.550003\r\n",
"12/19/2022,244.860001\r\n",
"12/20/2022,239.399994\r\n",
"12/21/2022,241.690002\r\n",
"12/22/2022,241.259995\r\n",
"12/23/2022,236.110001\r\n",
"12/27/2022,238.699997\r\n",
"12/28/2022,236.889999\r\n",
"12/29/2022,235.649994\r\n",
"12/30/2022,238.210007\r\n",
"1/3/2023,243.080002\r\n",
"1/4/2023,232.279999\r\n",
"1/5/2023,227.199997\r\n",
"1/6/2023,223.000000\r\n",
"1/9/2023,226.449997\r\n",
"1/10/2023,227.759995\r\n",
"1/11/2023,231.289993\r\n",
"1/12/2023,235.259995\r\n",
"1/13/2023,237.000000\r\n",
"1/17/2023,237.970001\r\n",
"1/18/2023,241.570007\r\n",
"1/19/2023,233.779999\r\n",
"1/20/2023,234.860001\r\n",
"1/23/2023,241.100006\r\n",
"1/24/2023,242.500000\r\n",
"1/25/2023,234.479996\r\n",
"1/26/2023,243.649994\r\n",
"1/27/2023,248.990005\r\n",
"1/30/2023,244.509995\r\n",
"1/31/2023,243.449997\r\n",
"2/1/2023,248.000000\r\n",
"2/2/2023,258.820007\r\n",
"2/3/2023,259.540009\r\n",
"2/6/2023,257.440002\r\n",
"2/7/2023,260.529999\r\n",
"2/8/2023,273.200012\r\n",
"2/9/2023,273.799988\r\n",
"2/10/2023,261.529999\r\n",
"2/13/2023,267.640015\r\n",
"2/14/2023,272.670013\r\n",
"2/15/2023,268.320007\r\n",
"2/16/2023,264.019989\r\n",
"2/17/2023,259.390015\r\n",
"2/21/2023,254.479996\r\n",
"2/22/2023,254.089996\r\n",
"2/23/2023,255.559998\r\n",
"2/24/2023,249.960007\r\n",
"2/27/2023,252.460007\r\n",
"2/28/2023,249.070007\r\n",
"3/1/2023,250.759995\r\n",
"3/2/2023,246.550003\r\n",
"3/3/2023,252.190002\r\n",
"3/6/2023,256.429993\r\n",
"3/7/2023,256.299988\r\n",
"3/8/2023,254.039993\r\n",
"3/9/2023,255.820007\r\n",
"3/10/2023,251.080002\r\n",
"3/13/2023,247.399994\r\n",
"3/14/2023,256.750000\r\n",
"3/15/2023,259.980011\r\n",
"3/16/2023,265.209991\r\n",
"3/17/2023,278.260010\r\n",
"3/20/2023,276.980011\r\n",
"3/21/2023,274.880005\r\n",
"3/22/2023,273.399994\r\n",
"3/23/2023,277.940002\r\n",
"3/24/2023,277.239990\r\n",
"3/27/2023,280.500000\r\n",
"3/28/2023,275.790009\r\n",
"3/29/2023,278.959991\r\n",
"3/30/2023,284.230011\r\n",
"3/31/2023,283.730011\r\n",
"4/3/2023,286.519989\r\n",
"4/4/2023,287.230011\r\n",
"4/5/2023,285.850006\r\n",
"4/6/2023,283.209991\r\n",
"4/10/2023,289.209991\r\n",
"4/11/2023,285.750000\r\n",
"4/12/2023,284.790009\r\n",
"4/13/2023,283.589996\r\n",
"4/14/2023,287.000000\r\n",
"4/17/2023,289.929993\r\n",
"4/18/2023,291.570007\r\n",
"4/19/2023,285.989990\r\n",
"4/20/2023,285.250000\r\n",
"4/21/2023,285.010010\r\n",
"4/24/2023,282.089996\r\n",
"4/25/2023,279.510010\r\n",
"4/26/2023,296.700012\r\n",
"4/27/2023,295.970001\r\n",
"4/28/2023,304.010010\r\n",
"5/1/2023,306.970001\r\n",
"5/2/2023,307.760010\r\n",
"5/3/2023,306.619995\r\n",
"5/4/2023,306.239990\r\n",
"5/5/2023,305.720001\r\n",
"5/8/2023,310.130005\r\n",
"5/9/2023,308.000000\r\n",
"5/10/2023,308.619995\r\n",
"5/11/2023,310.100006\r\n",
"5/12/2023,310.549988\r\n",
"5/15/2023,309.100006\r\n",
"5/16/2023,309.829987\r\n",
"5/17/2023,312.290009\r\n",
"5/18/2023,314.529999\r\n",
"5/19/2023,316.739990\r\n",
"5/22/2023,318.600006\r\n",
"5/23/2023,320.029999\r\n",
"5/24/2023,314.730011\r\n",
"5/25/2023,323.239990\r\n",
"5/26/2023,324.019989\r\n",
"5/30/2023,335.230011\r\n",
"5/31/2023,332.290009\r\n",
"6/1/2023,325.929993\r\n",
"6/2/2023,334.250000\r\n",
"6/5/2023,335.220001\r\n",
"6/6/2023,335.329987\r\n",
"6/7/2023,331.649994\r\n",
"6/8/2023,323.940002\r\n",
"6/9/2023,324.989990\r\n",
"6/12/2023,328.579987\r\n",
"6/13/2023,334.470001\r\n",
"6/14/2023,334.339996\r\n",
"6/15/2023,337.480011\r\n",
"6/16/2023,351.320007\r\n",
"6/20/2023,339.309998\r\n",
"6/21/2023,336.369995\r\n",
"6/22/2023,334.119995\r\n",
"6/23/2023,334.359985\r\n",
"6/26/2023,333.720001\r\n",
"6/27/2023,331.859985\r\n",
"6/28/2023,334.660004\r\n",
"6/29/2023,334.709991\r\n",
"6/30/2023,337.750000\r\n",
"7/3/2023,339.190002\r\n",
"7/5/2023,335.089996\r\n",
"7/6/2023,337.299988\r\n",
"7/7/2023,339.320007\r\n",
"7/10/2023,334.600006\r\n",
"7/11/2023,331.059998\r\n",
"7/12/2023,336.600006\r\n",
"7/13/2023,339.559998\r\n",
"7/14/2023,347.589996\r\n",
"7/17/2023,345.679993\r\n",
"7/18/2023,345.829987\r\n",
"7/19/2023,361.750000\r\n",
"7/20/2023,353.570007\r\n",
"7/21/2023,349.149994\r\n",
"7/24/2023,345.850006\r\n",
"7/25/2023,347.109985\r\n",
"7/26/2023,341.440002\r\n",
"7/27/2023,340.480011\r\n",
"7/28/2023,333.670013\r\n",
"7/31/2023,336.920013\r\n",
"8/1/2023,335.190002\r\n",
"8/2/2023,333.630005\r\n",
"8/3/2023,326.000000\r\n",
"8/4/2023,331.880005\r\n",
"8/7/2023,328.369995\r\n",
"8/8/2023,326.959991\r\n",
"8/9/2023,326.470001\r\n",
"8/10/2023,326.019989\r\n",
"8/11/2023,320.260010\r\n",
"8/14/2023,321.390015\r\n",
"8/15/2023,323.000000\r\n",
"8/16/2023,320.799988\r\n",
"8/17/2023,320.540009\r\n",
"8/18/2023,314.489990\r\n",
"8/21/2023,317.929993\r\n",
"8/22/2023,325.500000\r\n",
"8/23/2023,323.820007\r\n",
"8/24/2023,332.850006\r\n",
"8/25/2023,321.470001\r\n",
"8/28/2023,325.660004\r\n",
"8/29/2023,321.880005\r\n",
"8/30/2023,328.670013\r\n",
"8/31/2023,329.200012\r\n",
"9/1/2023,331.309998\r\n",
"9/5/2023,329.000000\r\n",
"9/6/2023,333.380005\r\n",
"9/7/2023,331.290009\r\n",
"9/8/2023,330.089996\r\n",
"9/11/2023,337.239990\r\n",
"9/12/2023,335.820007\r\n",
"9/13/2023,331.309998\r\n",
"9/14/2023,339.149994\r\n",
"9/15/2023,336.920013\r\n",
"9/18/2023,327.799988\r\n",
"9/19/2023,326.170013\r\n",
"9/20/2023,329.510010\r\n",
"9/21/2023,319.260010\r\n",
"9/22/2023,321.320007\r\n",
"9/25/2023,316.589996\r\n",
"9/26/2023,315.130005\r\n",
"9/27/2023,312.299988\r\n",
"9/28/2023,310.989990\r\n",
"9/29/2023,317.750000\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-10-01\">Oct 01, 2018</time></td><td><div class=\"dni-plaintext\"><pre>114.750000</pre></div></td></tr><tr><td><time datetime=\"2018-10-02\">Oct 02, 2018</time></td><td><div class=\"dni-plaintext\"><pre>115.300003</pre></div></td></tr><tr><td><time datetime=\"2018-10-03\">Oct 03, 2018</time></td><td><div class=\"dni-plaintext\"><pre>115.419998</pre></div></td></tr><tr><td><time datetime=\"2018-10-04\">Oct 04, 2018</time></td><td><div class=\"dni-plaintext\"><pre>114.610001</pre></div></td></tr><tr><td><time datetime=\"2018-10-05\">Oct 05, 2018</time></td><td><div class=\"dni-plaintext\"><pre>112.629997</pre></div></td></tr><tr><td><time datetime=\"2018-10-08\">Oct 08, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.660004</pre></div></td></tr><tr><td><time datetime=\"2018-10-09\">Oct 09, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.139999</pre></div></td></tr><tr><td><time datetime=\"2018-10-10\">Oct 10, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.239998</pre></div></td></tr><tr><td><time datetime=\"2018-10-11\">Oct 11, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.349998</pre></div></td></tr><tr><td><time datetime=\"2018-10-12\">Oct 12, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.010002</pre></div></td></tr><tr><td><time datetime=\"2018-10-15\">Oct 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.910004</pre></div></td></tr><tr><td><time datetime=\"2018-10-16\">Oct 16, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.540001</pre></div></td></tr><tr><td><time datetime=\"2018-10-17\">Oct 17, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.680000</pre></div></td></tr><tr><td><time datetime=\"2018-10-18\">Oct 18, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.099998</pre></div></td></tr><tr><td><time datetime=\"2018-10-19\">Oct 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.930000</pre></div></td></tr><tr><td><time datetime=\"2018-10-22\">Oct 22, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.320000</pre></div></td></tr><tr><td><time datetime=\"2018-10-23\">Oct 23, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.769997</pre></div></td></tr><tr><td><time datetime=\"2018-10-24\">Oct 24, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.410004</pre></div></td></tr><tr><td><time datetime=\"2018-10-25\">Oct 25, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.550003</pre></div></td></tr><tr><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td></tr><tr><td colspan=\"2\"><i>(1238 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var data =\n",
" from fields in rows\n",
" //\n",
" // Note that while we don't use all the fields, the arity of the lambda\n",
" // must match the number of elements expected in the `fields` sequence,\n",
" // otherwise `Fold` will (by-design) throw an exception.\n",
" //\n",
" select fields.Fold((date, open, hi, lo, close, adjClose, vol) => new\n",
" {\n",
" Date = DateOnly.Parse(date, CultureInfo.InvariantCulture),\n",
" Price = decimal.Parse(open, CultureInfo.InvariantCulture),\n",
" });\n",
"\n",
"data.ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Nice, let's get the 20-day moving average of the opening price using [`Window`]. Remember, the 20-day moving average is our price trend indicator.\n",
"\n",
"[`Window`]: https://morelinq.github.io/4.0/ref/api/html/M_MoreLinq_MoreEnumerable_Window__1.htm"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Avg\r\n",
"10/26/2018,105.690002,110.40050045\r\n",
"10/29/2018,108.110001,110.0685005\r\n",
"10/30/2018,103.660004,109.48650055\r\n",
"10/31/2018,105.440002,108.98750075\r\n",
"11/1/2018,107.050003,108.60950085\r\n",
"11/2/2018,106.480003,108.30200115\r\n",
"11/5/2018,106.370003,108.0375011\r\n",
"11/6/2018,107.379997,107.849501\r\n",
"11/7/2018,109.440002,107.7595012\r\n",
"11/8/2018,111.800003,108.08200145\r\n",
"11/9/2018,110.849998,108.17400125\r\n",
"11/12/2018,109.419998,108.19950095\r\n",
"11/13/2018,107.550003,108.10000105\r\n",
"11/14/2018,108.099998,107.92100095\r\n",
"11/15/2018,104.989998,107.66550095\r\n",
"11/16/2018,107.080002,107.57300105\r\n",
"11/19/2018,108.269997,107.5205009\r\n",
"11/20/2018,101.800003,107.2220012\r\n",
"11/21/2018,103.599998,106.9815009\r\n",
"11/23/2018,102.169998,106.76250065\r\n",
"11/26/2018,104.790001,106.7175006\r\n",
"11/27/2018,106.269997,106.6255004\r\n",
"11/28/2018,107.889999,106.83700015\r\n",
"11/29/2018,110.330002,107.08150015\r\n",
"11/30/2018,110.699997,107.26399985\r\n",
"12/3/2018,113.000000,107.5899997\r\n",
"12/4/2018,111.940002,107.86849965\r\n",
"12/6/2018,105.820000,107.7904998\r\n",
"12/7/2018,108.379997,107.73749955\r\n",
"12/10/2018,104.800003,107.38749955\r\n",
"12/11/2018,109.800003,107.3349998\r\n",
"12/12/2018,110.889999,107.40849985\r\n",
"12/13/2018,109.580002,107.5099998\r\n",
"12/14/2018,108.250000,107.5174999\r\n",
"12/17/2018,105.410004,107.5385002\r\n",
"12/18/2018,103.750000,107.3720001\r\n",
"12/19/2018,103.650002,107.14100035\r\n",
"12/20/2018,103.050003,107.20350035\r\n",
"12/21/2018,101.629997,107.1050003\r\n",
"12/24/2018,97.680000,106.8805004\r\n",
"12/26/2018,95.139999,106.3980003\r\n",
"12/27/2018,99.300003,106.0495006\r\n",
"12/28/2018,102.089996,105.75950045\r\n",
"12/31/2018,101.290001,105.3075004\r\n",
"1/2/2019,99.550003,104.7500007\r\n",
"1/3/2019,100.099998,104.1050006\r\n",
"1/4/2019,99.720001,103.49400055\r\n",
"1/7/2019,101.639999,103.2850005\r\n",
"1/8/2019,103.040001,103.0180007\r\n",
"1/9/2019,103.860001,102.9710006\r\n",
"1/10/2019,103.220001,102.6420005\r\n",
"1/11/2019,103.190002,102.25700065\r\n",
"1/14/2019,101.900002,101.87300065\r\n",
"1/15/2019,102.510002,101.58600075\r\n",
"1/16/2019,105.260002,101.57850065\r\n",
"1/17/2019,105.000000,101.64100065\r\n",
"1/18/2019,107.459999,101.8315005\r\n",
"1/22/2019,106.750000,102.01650035\r\n",
"1/23/2019,106.120003,102.24100065\r\n",
"1/24/2019,106.860001,102.7000007\r\n",
"1/25/2019,107.239998,103.30500065\r\n",
"1/28/2019,106.260002,103.6530006\r\n",
"1/29/2019,104.879997,103.79250065\r\n",
"1/30/2019,104.620003,103.95900075\r\n",
"1/31/2019,103.800003,104.17150075\r\n",
"2/1/2019,103.779999,104.3555008\r\n",
"2/4/2019,102.870003,104.5130009\r\n",
"2/5/2019,106.059998,104.73400085\r\n",
"2/6/2019,107.000000,104.9320008\r\n",
"2/7/2019,105.190002,104.99850085\r\n",
"2/8/2019,104.389999,105.05700075\r\n",
"2/11/2019,106.199997,105.2075005\r\n",
"2/12/2019,106.139999,105.41950035\r\n",
"2/13/2019,107.500000,105.66900025\r\n",
"2/14/2019,106.309998,105.72150005\r\n",
"2/15/2019,107.910004,105.86700025\r\n",
"2/19/2019,107.790001,105.88350035\r\n",
"2/20/2019,107.860001,105.9390004\r\n",
"2/21/2019,106.900002,105.97800035\r\n",
"2/22/2019,110.050003,106.13750045\r\n",
"2/25/2019,111.760002,106.36350065\r\n",
"2/26/2019,111.260002,106.61350065\r\n",
"2/27/2019,111.690002,106.9540009\r\n",
"2/28/2019,112.040001,107.3250008\r\n",
"3/1/2019,112.889999,107.7795006\r\n",
"3/4/2019,113.019997,108.2415005\r\n",
"3/5/2019,112.250000,108.71050035\r\n",
"3/6/2019,111.870003,109.0010006\r\n",
"3/7/2019,111.400002,109.2210007\r\n",
"3/8/2019,109.160004,109.4195008\r\n",
"3/11/2019,110.989998,109.74950075\r\n",
"3/12/2019,112.820000,110.0805009\r\n",
"3/13/2019,114.129997,110.4800008\r\n",
"3/14/2019,114.540001,110.83200085\r\n",
"3/15/2019,115.339996,111.28350075\r\n",
"3/18/2019,116.169998,111.69650045\r\n",
"3/19/2019,118.089996,112.2115002\r\n",
"3/20/2019,117.389999,112.6880001\r\n",
"3/21/2019,117.139999,113.19999995\r\n",
"3/22/2019,119.500000,113.6724998\r\n",
"3/25/2019,116.559998,113.9124996\r\n",
"3/26/2019,118.620003,114.28049965\r\n",
"3/27/2019,117.879997,114.5899994\r\n",
"3/28/2019,117.440002,114.85999945\r\n",
"3/29/2019,118.070000,115.1189995\r\n",
"4/1/2019,118.949997,115.4154995\r\n",
"4/2/2019,119.059998,115.7559994\r\n",
"4/3/2019,119.860001,116.1554993\r\n",
"4/4/2019,120.099998,116.5904991\r\n",
"4/5/2019,119.389999,117.10199885\r\n",
"4/8/2019,119.809998,117.54299885\r\n",
"4/9/2019,118.629997,117.8334987\r\n",
"4/10/2019,119.760002,118.11499895\r\n",
"4/11/2019,120.540001,118.41499895\r\n",
"4/12/2019,120.639999,118.6799991\r\n",
"4/15/2019,120.940002,118.9184993\r\n",
"4/16/2019,121.639999,119.09599945\r\n",
"4/17/2019,121.239998,119.2884994\r\n",
"4/18/2019,122.190002,119.54099955\r\n",
"4/22/2019,122.620003,119.6969997\r\n",
"4/23/2019,124.099998,120.0739997\r\n",
"4/24/2019,125.790001,120.4324996\r\n",
"4/25/2019,130.059998,121.04149965\r\n",
"4/26/2019,129.699997,121.6544994\r\n",
"4/29/2019,129.899994,122.2459991\r\n",
"4/30/2019,129.809998,122.78899915\r\n",
"5/1/2019,130.529999,123.3624992\r\n",
"5/2/2019,127.980003,123.7684993\r\n",
"5/3/2019,127.360001,124.13149945\r\n",
"5/6/2019,126.389999,124.48149945\r\n",
"5/7/2019,126.459999,124.8139995\r\n",
"5/8/2019,125.440002,125.15449975\r\n",
"5/9/2019,124.290001,125.3809997\r\n",
"5/10/2019,124.910004,125.59949985\r\n",
"5/13/2019,124.110001,125.77299995\r\n",
"5/14/2019,123.870003,125.919500\r\n",
"5/15/2019,124.260002,126.05050015\r\n",
"5/16/2019,126.750000,126.32600025\r\n",
"5/17/2019,128.309998,126.63200005\r\n",
"5/20/2019,126.519997,126.82699975\r\n",
"5/21/2019,127.430000,126.99349985\r\n",
"5/22/2019,126.620003,127.03499995\r\n",
"5/23/2019,126.199997,126.8419999\r\n",
"5/24/2019,126.910004,126.70250025\r\n",
"5/28/2019,126.980003,126.5565007\r\n",
"5/29/2019,125.379997,126.33500065\r\n",
"5/30/2019,125.260002,126.0715008\r\n",
"5/31/2019,124.230003,125.8840008\r\n",
"6/3/2019,123.849998,125.70850065\r\n",
"6/4/2019,121.279999,125.45300065\r\n",
"6/5/2019,124.949997,125.37750055\r\n",
"6/6/2019,126.440002,125.42750055\r\n",
"6/7/2019,129.190002,125.6725006\r\n",
"6/10/2019,132.399994,126.0470001\r\n",
"6/11/2019,133.880005,126.5355003\r\n",
"6/12/2019,131.399994,126.91199985\r\n",
"6/13/2019,131.979996,127.29799955\r\n",
"6/14/2019,132.259995,127.5734993\r\n",
"6/17/2019,132.630005,127.78949965\r\n",
"6/18/2019,134.190002,128.1729999\r\n",
"6/19/2019,135.000000,128.5514999\r\n",
"6/20/2019,137.449997,129.0929996\r\n",
"6/21/2019,136.580002,129.61199985\r\n",
"6/24/2019,137.000000,130.11649965\r\n",
"6/25/2019,137.250000,130.6299995\r\n",
"6/26/2019,134.350006,131.07849995\r\n",
"6/27/2019,134.139999,131.5224998\r\n",
"6/28/2019,134.570007,132.039500\r\n",
"7/1/2019,136.630005,132.67850035\r\n",
"7/2/2019,136.119995,133.42050015\r\n",
"7/3/2019,136.800003,134.01300045\r\n",
"7/5/2019,135.940002,134.48800045\r\n",
"7/8/2019,136.399994,134.84850005\r\n",
"7/9/2019,136.000000,135.02850035\r\n",
"7/10/2019,137.130005,135.19100035\r\n",
"7/11/2019,138.199997,135.5310005\r\n",
"7/12/2019,138.850006,135.874501\r\n",
"7/15/2019,139.440002,136.23350135\r\n",
"7/16/2019,138.960007,136.55000145\r\n",
"7/17/2019,137.699997,136.7255012\r\n",
"7/18/2019,135.550003,136.75300135\r\n",
"7/19/2019,140.220001,136.89150155\r\n",
"7/22/2019,137.410004,136.93300165\r\n",
"7/23/2019,139.759995,137.0710014\r\n",
"7/24/2019,138.899994,137.1535011\r\n",
"7/25/2019,140.429993,137.45750045\r\n",
"7/26/2019,140.369995,137.76900025\r\n",
"7/29/2019,141.500000,138.1154999\r\n",
"7/30/2019,140.139999,138.2909996\r\n",
"7/31/2019,140.330002,138.50149995\r\n",
"8/1/2019,137.000000,138.5114998\r\n",
"8/2/2019,138.089996,138.6189995\r\n",
"8/5/2019,133.300003,138.46399995\r\n",
"8/6/2019,133.800003,138.3540001\r\n",
"8/7/2019,133.789993,138.1869995\r\n",
"8/8/2019,136.600006,138.10699995\r\n",
"8/9/2019,138.610001,138.0949997\r\n",
"8/12/2019,137.070007,137.97649995\r\n",
"8/13/2019,136.050003,137.83099975\r\n",
"8/14/2019,136.360001,137.76399995\r\n",
"8/15/2019,134.389999,137.70599975\r\n",
"8/16/2019,134.880005,137.43899995\r\n",
"8/19/2019,137.850006,137.46100005\r\n",
"8/20/2019,138.210007,137.38350065\r\n",
"8/21/2019,138.550003,137.3660011\r\n",
"8/22/2019,138.660004,137.27750165\r\n",
"8/23/2019,137.190002,137.118502\r\n",
"8/26/2019,134.990005,136.79300225\r\n",
"8/27/2019,136.389999,136.60550225\r\n",
"8/28/2019,134.880005,136.3330024\r\n",
"8/29/2019,137.250000,136.3455024\r\n",
"8/30/2019,139.149994,136.3985023\r\n",
"9/3/2019,136.610001,136.5640022\r\n",
"9/4/2019,137.300003,136.7390022\r\n",
"9/5/2019,139.110001,137.0050026\r\n",
"9/6/2019,140.029999,137.17650225\r\n",
"9/9/2019,139.589996,137.225502\r\n",
"9/10/2019,136.800003,137.2120018\r\n",
"9/11/2019,135.910004,137.20500185\r\n",
"9/12/2019,137.850006,137.2795021\r\n",
"9/13/2019,137.779999,137.4490021\r\n",
"9/16/2019,135.830002,137.49650195\r\n",
"9/17/2019,136.960007,137.452002\r\n",
"9/18/2019,137.360001,137.4095017\r\n",
"9/19/2019,140.300003,137.4970017\r\n",
"9/20/2019,141.009995,137.61450125\r\n",
"9/23/2019,139.229996,137.71650095\r\n",
"9/24/2019,140.360001,137.98500075\r\n",
"9/25/2019,137.500000,138.0405008\r\n",
"9/26/2019,139.440002,138.26850065\r\n",
"9/27/2019,140.149994,138.41350035\r\n",
"9/30/2019,138.050003,138.3585008\r\n",
"10/1/2019,139.660004,138.51100095\r\n",
"10/2/2019,136.250000,138.4585008\r\n",
"10/3/2019,134.949997,138.2505006\r\n",
"10/4/2019,136.750000,138.08650065\r\n",
"10/7/2019,137.139999,137.9640008\r\n",
"10/8/2019,137.080002,137.97800075\r\n",
"10/9/2019,137.460007,138.0555009\r\n",
"10/10/2019,138.490005,138.08750085\r\n",
"10/11/2019,140.119995,138.20450065\r\n",
"10/14/2019,139.690002,138.39750065\r\n",
"10/15/2019,140.059998,138.5525002\r\n",
"10/16/2019,140.789993,138.7239998\r\n",
"10/17/2019,140.949997,138.7564995\r\n",
"10/18/2019,139.759995,138.6939995\r\n",
"10/21/2019,138.449997,138.65499955\r\n",
"10/22/2019,138.970001,138.58549955\r\n",
"10/23/2019,136.880005,138.5544998\r\n",
"10/24/2019,139.389999,138.55199965\r\n",
"10/25/2019,139.339996,138.51149975\r\n",
"10/28/2019,144.399994,138.8289993\r\n",
"10/29/2019,144.080002,139.0499992\r\n",
"10/30/2019,143.520004,139.4134994\r\n",
"10/31/2019,144.899994,139.91099925\r\n",
"11/1/2019,144.259995,140.286499\r\n",
"11/4/2019,144.830002,140.67099915\r\n",
"11/5/2019,144.970001,141.0654991\r\n",
"11/6/2019,144.369995,141.4109985\r\n",
"11/7/2019,143.839996,141.67849805\r\n",
"11/8/2019,143.979996,141.8714981\r\n",
"11/11/2019,145.339996,142.1539978\r\n",
"11/12/2019,146.279999,142.46499785\r\n",
"11/13/2019,146.740005,142.76249845\r\n",
"11/14/2019,147.020004,143.0659988\r\n",
"11/15/2019,148.929993,143.5244987\r\n",
"11/18/2019,150.070007,144.1054992\r\n",
"11/19/2019,150.880005,144.7009994\r\n",
"11/20/2019,150.309998,145.37249905\r\n",
"11/21/2019,149.399994,145.8729988\r\n",
"11/22/2019,150.070007,146.40949935\r\n",
"11/25/2019,150.000000,146.68949965\r\n",
"11/26/2019,151.360001,147.0534996\r\n",
"11/27/2019,152.330002,147.4939995\r\n",
"11/29/2019,152.100006,147.8540001\r\n",
"12/2/2019,151.809998,148.23150025\r\n",
"12/3/2019,147.490005,148.3645004\r\n",
"12/4/2019,150.139999,148.6230003\r\n",
"12/5/2019,150.050003,148.9070007\r\n",
"12/6/2019,150.990005,149.26450115\r\n",
"12/9/2019,151.070007,149.6190017\r\n",
"12/10/2019,151.289993,149.91650155\r\n",
"12/11/2019,151.539993,150.17950125\r\n",
"12/12/2019,151.649994,150.4250007\r\n",
"12/13/2019,153.000000,150.7240005\r\n",
"12/16/2019,155.110001,151.0330009\r\n",
"12/17/2019,155.449997,151.3020004\r\n",
"12/18/2019,154.300003,151.4730003\r\n",
"12/19/2019,154.000000,151.6575004\r\n",
"12/20/2019,157.350006,152.055001\r\n",
"12/23/2019,158.119995,152.4575004\r\n",
"12/24/2019,157.479996,152.8315002\r\n",
"12/26/2019,157.559998,153.14150005\r\n",
"12/27/2019,159.449997,153.4974998\r\n",
"12/30/2019,158.990005,153.84199975\r\n",
"12/31/2019,156.770004,154.09000005\r\n",
"1/2/2020,158.779999,154.65449975\r\n",
"1/3/2020,158.320007,155.06350015\r\n",
"1/6/2020,157.080002,155.4150001\r\n",
"1/7/2020,159.320007,155.8315002\r\n",
"1/8/2020,158.929993,156.2244995\r\n",
"1/9/2020,161.839996,156.75199965\r\n",
"1/10/2020,162.820007,157.31600035\r\n",
"1/13/2020,161.759995,157.8215004\r\n",
"1/14/2020,163.389999,158.34100035\r\n",
"1/15/2020,162.619995,158.71650005\r\n",
"1/16/2020,164.350006,159.1615005\r\n",
"1/17/2020,167.419998,159.81750025\r\n",
"1/21/2020,166.679993,160.4514999\r\n",
"1/22/2020,167.399994,160.9539993\r\n",
"1/23/2020,166.190002,161.35749965\r\n",
"1/24/2020,167.509995,161.8589996\r\n",
"1/27/2020,161.149994,162.0384994\r\n",
"1/28/2020,163.779999,162.2549995\r\n",
"1/29/2020,167.839996,162.69749905\r\n",
"1/30/2020,174.050003,163.561499\r\n",
"1/31/2020,172.210007,164.2329994\r\n",
"2/3/2020,170.429993,164.8384987\r\n",
"2/4/2020,177.139999,165.84149855\r\n",
"2/5/2020,184.029999,167.07699815\r\n",
"2/6/2020,180.970001,168.17899855\r\n",
"2/7/2020,182.850006,169.22949905\r\n",
"2/10/2020,183.580002,170.2674988\r\n",
"2/11/2020,190.649994,171.71199875\r\n",
"2/12/2020,185.580002,172.8214989\r\n",
"2/13/2020,183.080002,173.84449925\r\n",
"2/14/2020,183.250000,174.78949895\r\n",
"2/18/2020,185.610001,175.6989991\r\n",
"2/19/2020,188.059998,176.76799935\r\n",
"2/20/2020,186.949997,177.7454995\r\n",
"2/21/2020,183.169998,178.5944993\r\n",
"2/24/2020,167.770004,178.60749975\r\n",
"2/25/2020,174.199997,179.2599999\r\n",
"2/26/2020,169.710007,179.5565003\r\n",
"2/27/2020,163.320007,179.33050085\r\n",
"2/28/2020,152.410004,178.2485009\r\n",
"3/2/2020,165.309998,177.90350045\r\n",
"3/3/2020,173.800003,178.07200095\r\n",
"3/4/2020,168.490005,177.63950125\r\n",
"3/5/2020,166.050003,176.74050145\r\n",
"3/6/2020,162.610001,175.82250145\r\n",
"3/9/2020,151.000000,174.23000115\r\n",
"3/10/2020,158.160004,172.95900125\r\n",
"3/11/2020,157.130005,171.2830018\r\n",
"3/12/2020,145.300003,169.26900185\r\n",
"3/13/2020,147.500000,167.49000175\r\n",
"3/16/2020,140.000000,165.32750175\r\n",
"3/17/2020,140.000000,163.0470017\r\n",
"3/18/2020,138.000000,160.5440018\r\n",
"3/19/2020,142.770004,158.33500215\r\n",
"3/20/2020,146.000000,156.47650225\r\n",
"3/23/2020,137.009995,154.9385018\r\n",
"3/24/2020,143.750000,153.41600195\r\n",
"3/25/2020,148.910004,152.3760018\r\n",
"3/26/2020,148.399994,151.63000115\r\n",
"3/27/2020,151.750000,151.59700095\r\n",
"3/30/2020,152.440002,150.95350115\r\n",
"3/31/2020,159.399994,150.2335007\r\n",
"4/1/2020,153.000000,149.45900045\r\n",
"4/2/2020,151.860001,148.74950035\r\n",
"4/3/2020,155.100006,148.3740006\r\n",
"4/6/2020,160.320007,148.84000095\r\n",
"4/7/2020,169.589996,149.41150055\r\n",
"4/8/2020,165.669998,149.8385002\r\n",
"4/9/2020,166.360001,150.8915001\r\n",
"4/13/2020,164.350006,151.7340004\r\n",
"4/14/2020,169.000000,153.1840004\r\n",
"4/15/2020,171.199997,154.74400025\r\n",
"4/16/2020,174.300003,156.5590004\r\n",
"4/17/2020,179.500000,158.3955002\r\n",
"4/20/2020,176.630005,159.92700045\r\n",
"4/21/2020,173.500000,161.7515007\r\n",
"4/22/2020,171.389999,163.13350065\r\n",
"4/23/2020,174.110001,164.3935005\r\n",
"4/24/2020,172.059998,165.5765007\r\n",
"4/27/2020,176.589996,166.8185005\r\n",
"4/28/2020,175.589996,167.9760002\r\n",
"4/29/2020,173.220001,168.66700055\r\n",
"4/30/2020,180.000000,170.01700055\r\n",
"5/1/2020,175.800003,171.21400065\r\n",
"5/4/2020,174.490005,172.1835006\r\n",
"5/5/2020,180.619995,173.198500\r\n",
"5/6/2020,182.080002,173.8230003\r\n",
"5/7/2020,184.169998,174.7480003\r\n",
"5/8/2020,184.979996,175.67900005\r\n",
"5/11/2020,183.149994,176.61899945\r\n",
"5/12/2020,186.800003,177.5089996\r\n",
"5/13/2020,182.550003,178.0764999\r\n",
"5/14/2020,177.539993,178.2384994\r\n",
"5/15/2020,179.059998,178.2164993\r\n",
"5/18/2020,185.750000,178.67249905\r\n",
"5/19/2020,185.029999,179.248999\r\n",
"5/20/2020,184.809998,179.91999895\r\n",
"5/21/2020,185.399994,180.4844986\r\n",
"5/22/2020,183.190002,181.0409988\r\n",
"5/26/2020,186.339996,181.5284988\r\n",
"5/27/2020,180.199997,181.75899885\r\n",
"5/28/2020,180.740005,182.13499905\r\n",
"5/29/2020,182.729996,182.27149885\r\n",
"6/1/2020,182.539993,182.60849835\r\n",
"6/2/2020,184.250000,183.0964981\r\n",
"6/3/2020,184.820007,183.3064987\r\n",
"6/4/2020,184.300003,183.41749875\r\n",
"6/5/2020,182.619995,183.3399986\r\n",
"6/8/2020,185.940002,183.3879989\r\n",
"6/9/2020,188.000000,183.6304992\r\n",
"6/10/2020,191.130005,183.8469993\r\n",
"6/11/2020,193.130005,184.3759994\r\n",
"6/12/2020,190.539993,185.0259994\r\n",
"6/15/2020,184.580002,185.3019996\r\n",
"6/16/2020,192.889999,185.65899955\r\n",
"6/17/2020,195.029999,186.15899955\r\n",
"6/18/2020,194.000000,186.61849965\r\n",
"6/19/2020,198.589996,187.27799975\r\n",
"6/22/2020,195.789993,187.9079993\r\n",
"6/23/2020,202.089996,188.6954993\r\n",
"6/24/2020,201.600006,189.76549975\r\n",
"6/25/2020,197.800003,190.61849965\r\n",
"6/26/2020,199.729996,191.46849965\r\n",
"6/29/2020,195.779999,192.13049995\r\n",
"6/30/2020,197.880005,192.8120002\r\n",
"7/1/2020,203.139999,193.7279998\r\n",
"7/2/2020,205.679993,194.7969993\r\n",
"7/6/2020,208.830002,196.10749965\r\n",
"7/7/2020,210.449997,197.3329994\r\n",
"7/8/2020,210.070007,198.43649975\r\n",
"7/9/2020,216.330002,199.6964996\r\n",
"7/10/2020,213.619995,200.7209991\r\n",
"7/13/2020,214.479996,201.91799925\r\n",
"7/14/2020,206.130005,202.9954994\r\n",
"7/15/2020,209.559998,203.82899935\r\n",
"7/16/2020,205.399994,204.3474991\r\n",
"7/17/2020,204.470001,204.87099915\r\n",
"7/20/2020,205.000000,205.19149935\r\n",
"7/21/2020,213.660004,206.0849999\r\n",
"7/22/2020,209.199997,206.44049995\r\n",
"7/23/2020,207.190002,206.71999975\r\n",
"7/24/2020,200.419998,206.8509995\r\n",
"7/27/2020,201.470001,206.93799975\r\n",
"7/28/2020,203.610001,207.32949985\r\n",
"7/29/2020,202.500000,207.5604996\r\n",
"7/30/2020,201.000000,207.45349965\r\n",
"7/31/2020,204.399994,207.3894997\r\n",
"8/3/2020,211.520004,207.5239998\r\n",
"8/4/2020,214.169998,207.70999985\r\n",
"8/5/2020,214.899994,207.9514992\r\n",
"8/6/2020,212.339996,207.7519989\r\n",
"8/7/2020,214.850006,207.81349945\r\n",
"8/10/2020,211.669998,207.67299955\r\n",
"8/11/2020,207.160004,207.7244995\r\n",
"8/12/2020,205.289993,207.51099925\r\n",
"8/13/2020,209.440002,207.71299965\r\n",
"8/14/2020,208.759995,207.92749935\r\n",
"8/17/2020,209.600006,208.15749965\r\n",
"8/18/2020,210.529999,208.0009994\r\n",
"8/19/2020,211.490005,208.1154998\r\n",
"8/20/2020,209.539993,208.23299935\r\n",
"8/21/2020,213.860001,208.9049995\r\n",
"8/24/2020,214.789993,209.5709991\r\n",
"8/25/2020,213.100006,210.04549935\r\n",
"8/26/2020,217.880005,210.8144996\r\n",
"8/27/2020,222.889999,211.90899955\r\n",
"8/28/2020,228.179993,213.0979995\r\n",
"8/31/2020,227.000000,213.8719993\r\n",
"9/1/2020,225.509995,214.43899915\r\n",
"9/2/2020,227.970001,215.0924995\r\n",
"9/3/2020,229.270004,215.9389999\r\n",
"9/4/2020,215.100006,215.9514999\r\n",
"9/8/2020,206.500000,215.693000\r\n",
"9/9/2020,207.600006,215.7150001\r\n",
"9/10/2020,213.399994,216.12050015\r\n",
"9/11/2020,207.199997,216.0084999\r\n",
"9/14/2020,204.240005,215.7825004\r\n",
"9/15/2020,208.419998,215.723500\r\n",
"9/16/2020,210.619995,215.7279998\r\n",
"9/17/2020,200.050003,215.1559997\r\n",
"9/18/2020,202.800003,214.8190002\r\n",
"9/21/2020,197.190002,213.98550025\r\n",
"9/22/2020,205.059998,213.4990005\r\n",
"9/23/2020,207.899994,213.2389999\r\n",
"9/24/2020,199.850006,212.33749995\r\n",
"9/25/2020,203.550003,211.37050015\r\n",
"9/28/2020,210.880005,210.50550075\r\n",
"9/29/2020,209.350006,209.62300105\r\n",
"9/30/2020,207.729996,208.7340011\r\n",
"10/1/2020,213.490005,208.0100013\r\n",
"10/2/2020,208.000000,206.9465011\r\n",
"10/5/2020,207.220001,206.55250085\r\n",
"10/6/2020,208.820007,206.6685012\r\n",
"10/7/2020,207.059998,206.6415008\r\n",
"10/8/2020,210.509995,206.49700085\r\n",
"10/9/2020,211.229996,206.6985008\r\n",
"10/12/2020,218.789993,207.4260002\r\n",
"10/13/2020,222.720001,208.14100035\r\n",
"10/14/2020,223.000000,208.7600006\r\n",
"10/15/2020,217.100006,209.61250075\r\n",
"10/16/2020,220.149994,210.4800003\r\n",
"10/19/2020,220.419998,211.6415001\r\n",
"10/20/2020,215.800003,212.17850035\r\n",
"10/21/2020,213.119995,212.4395004\r\n",
"10/22/2020,213.929993,213.14349975\r\n",
"10/23/2020,215.029999,213.71749955\r\n",
"10/26/2020,213.850006,213.8659996\r\n",
"10/27/2020,211.589996,213.9779991\r\n",
"10/28/2020,207.669998,213.9749992\r\n",
"10/29/2020,204.070007,213.5039993\r\n",
"10/30/2020,203.500000,213.2789993\r\n",
"11/2/2020,204.289993,213.1324989\r\n",
"11/3/2020,203.889999,212.8859985\r\n",
"11/4/2020,214.020004,213.2339988\r\n",
"11/5/2020,222.039993,213.8104987\r\n",
"11/6/2020,222.259995,214.36199865\r\n",
"11/9/2020,224.440002,214.6444991\r\n",
"11/10/2020,214.500000,214.23349905\r\n",
"11/11/2020,212.389999,213.702999\r\n",
"11/12/2020,217.210007,213.70849905\r\n",
"11/13/2020,216.360001,213.5189994\r\n",
"11/16/2020,214.869995,213.24149925\r\n",
"11/17/2020,216.100006,213.2564994\r\n",
"11/18/2020,213.649994,213.28299935\r\n",
"11/19/2020,211.380005,213.15549995\r\n",
"11/20/2020,212.199997,213.01399985\r\n",
"11/23/2020,210.949997,212.8689994\r\n",
"11/24/2020,209.589996,212.7689994\r\n",
"11/25/2020,215.110001,213.14099955\r\n",
"11/27/2020,214.850006,213.6799995\r\n",
"11/30/2020,214.100006,214.2099998\r\n",
"12/1/2020,214.509995,214.7209999\r\n",
"12/2/2020,214.880005,215.2705002\r\n",
"12/3/2020,214.610001,215.30000005\r\n",
"12/4/2020,214.220001,214.90900045\r\n",
"12/7/2020,214.369995,214.51450045\r\n",
"12/8/2020,213.970001,213.9910004\r\n",
"12/9/2020,215.160004,214.0240006\r\n",
"12/10/2020,211.770004,213.99300085\r\n",
"12/11/2020,210.050003,213.63500065\r\n",
"12/14/2020,213.100006,213.4720009\r\n",
"12/15/2020,215.169998,213.48700105\r\n",
"12/16/2020,214.750000,213.41950075\r\n",
"12/17/2020,219.869995,213.7305008\r\n",
"12/18/2020,218.589996,214.09100035\r\n",
"12/21/2020,217.550003,214.35850065\r\n",
"12/22/2020,222.690002,214.9455009\r\n",
"12/23/2020,223.110001,215.62150115\r\n",
"12/24/2020,221.419998,215.937001\r\n",
"12/28/2020,224.449997,216.41700055\r\n",
"12/29/2020,226.309998,217.02750015\r\n",
"12/30/2020,225.229996,217.5635002\r\n",
"12/31/2020,221.699997,217.9044998\r\n",
"1/4/2021,222.529999,218.3004997\r\n",
"1/5/2021,217.259995,218.4524994\r\n",
"1/6/2021,212.169998,218.34249955\r\n",
"1/7/2021,214.039993,218.34599915\r\n",
"1/8/2021,218.679993,218.5219986\r\n",
"1/11/2021,218.470001,218.85699845\r\n",
"1/12/2021,216.500000,219.1794983\r\n",
"1/13/2021,214.020004,219.2254982\r\n",
"1/14/2021,215.910004,219.2624985\r\n",
"1/15/2021,213.520004,219.2009987\r\n",
"1/19/2021,213.750000,218.89499895\r\n",
"1/20/2021,217.699997,218.850499\r\n",
"1/21/2021,224.699997,219.2079987\r\n",
"1/22/2021,227.080002,219.4274987\r\n",
"1/25/2021,229.119995,219.7279984\r\n",
"1/26/2021,231.860001,220.24999855\r\n",
"1/27/2021,238.000000,220.9274987\r\n",
"1/28/2021,235.610001,221.39249885\r\n",
"1/29/2021,235.990005,221.9304993\r\n",
"2/1/2021,235.059998,222.59849935\r\n",
"2/2/2021,241.300003,223.53699955\r\n",
"2/3/2021,239.570007,224.65250015\r\n",
"2/4/2021,242.660004,226.17700045\r\n",
"2/5/2021,242.229996,227.5865006\r\n",
"2/8/2021,243.149994,228.81000065\r\n",
"2/9/2021,241.869995,229.98000035\r\n",
"2/10/2021,245.000000,231.40500035\r\n",
"2/11/2021,244.779999,232.9430001\r\n",
"2/12/2021,243.929993,234.34399955\r\n",
"2/16/2021,245.029999,235.9194993\r\n",
"2/17/2021,241.320007,237.29799965\r\n",
"2/18/2021,241.800003,238.50299995\r\n",
"2/19/2021,243.750000,239.4555001\r\n",
"2/22/2021,237.419998,239.9724999\r\n",
"2/23/2021,230.330002,240.03300025\r\n",
"2/24/2021,230.009995,239.94049995\r\n",
"2/25/2021,232.080002,239.64450005\r\n",
"2/26/2021,231.529999,239.44049995\r\n",
"3/1/2021,235.899994,239.4359994\r\n",
"3/2/2021,237.009995,239.53349925\r\n",
"3/3/2021,232.160004,239.0764993\r\n",
"3/4/2021,226.740005,238.4349992\r\n",
"3/5/2021,229.520004,237.7779992\r\n",
"3/8/2021,231.369995,237.23499915\r\n",
"3/9/2021,232.880005,236.7214997\r\n",
"3/10/2021,237.000000,236.47799995\r\n",
"3/11/2021,234.960007,235.9760003\r\n",
"3/12/2021,234.009995,235.4375001\r\n",
"3/15/2021,234.960007,234.9890008\r\n",
"3/16/2021,236.279999,234.5515008\r\n",
"3/17/2021,236.149994,234.29300015\r\n",
"3/18/2021,232.559998,233.8309999\r\n",
"3/19/2021,231.020004,233.1945001\r\n",
"3/22/2021,230.270004,232.8370004\r\n",
"3/23/2021,237.490005,233.19500055\r\n",
"3/24/2021,237.850006,233.5870011\r\n",
"3/25/2021,235.300003,233.74800115\r\n",
"3/26/2021,231.550003,233.74900135\r\n",
"3/29/2021,236.589996,233.78350145\r\n",
"3/30/2021,233.529999,233.60950165\r\n",
"3/31/2021,232.910004,233.64700165\r\n",
"4/1/2021,238.470001,234.23350145\r\n",
"4/5/2021,242.759995,234.895501\r\n",
"4/6/2021,247.610001,235.7075013\r\n",
"4/7/2021,247.809998,236.45400095\r\n",
"4/8/2021,252.770004,237.24250115\r\n",
"4/9/2021,252.869995,238.13800055\r\n",
"4/12/2021,254.710007,239.17300115\r\n",
"4/13/2021,257.260010,240.2880013\r\n",
"4/14/2021,257.480011,241.3480019\r\n",
"4/15/2021,257.929993,242.43700185\r\n",
"4/16/2021,259.470001,243.782502\r\n",
"4/19/2021,260.190002,245.2410019\r\n",
"4/20/2021,257.820007,246.61850205\r\n",
"4/21/2021,258.940002,247.6910019\r\n",
"4/22/2021,260.209991,248.80900115\r\n",
"4/23/2021,257.880005,249.93800125\r\n",
"4/26/2021,261.660004,251.4435013\r\n",
"4/27/2021,261.579987,252.69300085\r\n",
"4/28/2021,256.079987,253.82050025\r\n",
"4/29/2021,255.460007,254.9480004\r\n",
"4/30/2021,249.740005,255.5115006\r\n",
"5/3/2021,253.399994,256.04350055\r\n",
"5/4/2021,250.970001,256.21150055\r\n",
"5/5/2021,249.059998,256.27400055\r\n",
"5/6/2021,246.449997,255.9580002\r\n",
"5/7/2021,252.149994,255.92200015\r\n",
"5/10/2021,250.869995,255.72999955\r\n",
"5/11/2021,244.550003,255.0944992\r\n",
"5/12/2021,242.169998,254.32899855\r\n",
"5/13/2021,241.800003,253.52249905\r\n",
"5/14/2021,245.580002,252.8279991\r\n",
"5/17/2021,246.550003,252.14599915\r\n",
"5/18/2021,246.270004,251.568499\r\n",
"5/19/2021,239.309998,250.5869988\r\n",
"5/20/2021,243.960007,249.7744996\r\n",
"5/21/2021,247.570007,249.2589997\r\n",
"5/24/2021,247.789993,248.56549915\r\n",
"5/25/2021,251.770004,248.075000\r\n",
"5/26/2021,251.429993,247.8425003\r\n",
"5/27/2021,251.169998,247.62799985\r\n",
"5/28/2021,251.000000,247.6909996\r\n",
"6/1/2021,251.229996,247.5824997\r\n",
"6/2/2021,248.130005,247.4404999\r\n",
"6/3/2021,245.220001,247.24850005\r\n",
"6/4/2021,247.759995,247.31399995\r\n",
"6/7/2021,249.979996,247.20550005\r\n",
"6/8/2021,255.160004,247.4200005\r\n",
"6/9/2021,253.809998,247.88300025\r\n",
"6/10/2021,254.289993,248.489000\r\n",
"6/11/2021,257.989990,249.29849935\r\n",
"6/14/2021,257.899994,249.91449895\r\n",
"6/15/2021,259.769989,250.57549825\r\n",
"6/16/2021,259.399994,251.23199775\r\n",
"6/17/2021,256.070007,252.0699982\r\n",
"6/18/2021,259.630005,252.8534981\r\n",
"6/21/2021,259.820007,253.4659981\r\n",
"6/22/2021,262.720001,254.2124985\r\n",
"6/23/2021,265.989990,254.9234978\r\n",
"6/24/2021,266.160004,255.65999835\r\n",
"6/25/2021,266.230011,256.412999\r\n",
"6/28/2021,266.190002,257.1724991\r\n",
"6/29/2021,268.869995,258.05449905\r\n",
"6/30/2021,270.690002,259.1824989\r\n",
"7/1/2021,269.609985,260.4019981\r\n",
"7/2/2021,272.820007,261.6549987\r\n",
"7/6/2021,278.029999,263.05749885\r\n",
"7/7/2021,279.399994,264.26949835\r\n",
"7/8/2021,276.899994,265.42399815\r\n",
"7/9/2021,275.720001,266.49549855\r\n",
"7/12/2021,279.160004,267.55399925\r\n",
"7/13/2021,277.519989,268.534999\r\n",
"7/14/2021,282.350006,269.66399985\r\n",
"7/15/2021,282.000000,270.79400015\r\n",
"7/16/2021,282.070007,272.09400015\r\n",
"7/19/2021,278.929993,273.05899955\r\n",
"7/20/2021,278.029999,273.96949915\r\n",
"7/21/2021,278.899994,274.7784988\r\n",
"7/22/2021,283.839996,275.6709991\r\n",
"7/23/2021,287.369995,276.73149865\r\n",
"7/26/2021,289.000000,277.8699981\r\n",
"7/27/2021,289.429993,279.03199765\r\n",
"7/28/2021,288.989990,280.0379974\r\n",
"7/29/2021,286.239990,280.8154968\r\n",
"7/30/2021,285.170013,281.5934982\r\n",
"8/2/2021,286.359985,282.2704971\r\n",
"8/3/2021,285.420013,282.6399978\r\n",
"8/4/2021,286.220001,282.98099815\r\n",
"8/5/2021,286.880005,283.4799987\r\n",
"8/6/2021,288.510010,284.11949915\r\n",
"8/9/2021,289.750000,284.64899895\r\n",
"8/10/2021,288.799988,285.2129989\r\n",
"8/11/2021,287.209991,285.45599815\r\n",
"8/12/2021,286.630005,285.6874984\r\n",
"8/13/2021,289.480011,286.0579986\r\n",
"8/16/2021,293.190002,286.77099905\r\n",
"8/17/2021,292.390015,287.48899985\r\n",
"8/18/2021,292.040009,288.1460006\r\n",
"8/19/2021,288.690002,288.3885009\r\n",
"8/20/2021,299.720001,289.0060012\r\n",
"8/23/2021,303.250000,289.7185012\r\n",
"8/24/2021,305.019989,290.498001\r\n",
"8/25/2021,304.299988,291.2635009\r\n",
"8/26/2021,300.989990,292.0010009\r\n",
"8/27/2021,298.989990,292.69199975\r\n",
"8/30/2021,301.119995,293.43000025\r\n",
"8/31/2021,304.420013,294.38000025\r\n",
"9/1/2021,302.869995,295.21249995\r\n",
"9/2/2021,302.200012,295.9785003\r\n",
"9/3/2021,300.989990,296.6024993\r\n",
"9/7/2021,301.010010,297.1654998\r\n",
"9/8/2021,299.779999,297.71450035\r\n",
"9/9/2021,300.820007,298.39500115\r\n",
"9/10/2021,298.420013,298.98450155\r\n",
"9/13/2021,297.549988,299.3880004\r\n",
"9/14/2021,299.559998,299.7065002\r\n",
"9/15/2021,303.260010,300.24999995\r\n",
"9/16/2021,303.760010,300.836000\r\n",
"9/17/2021,304.170013,301.61000055\r\n",
"9/20/2021,296.329987,301.44049985\r\n",
"9/21/2021,295.690002,301.06249995\r\n",
"9/22/2021,296.730011,300.64800105\r\n",
"9/23/2021,298.850006,300.37550195\r\n",
"9/24/2021,298.230011,300.237503\r\n",
"9/27/2021,296.140015,300.09500425\r\n",
"9/28/2021,289.799988,299.5290039\r\n",
"9/29/2021,285.100006,298.56300355\r\n",
"9/30/2021,285.709991,297.70500335\r\n",
"10/1/2021,282.119995,296.7010025\r\n",
"10/4/2021,287.399994,296.0215027\r\n",
"10/5/2021,284.049988,295.1735016\r\n",
"10/6/2021,285.779999,294.4735016\r\n",
"10/7/2021,295.179993,294.1915009\r\n",
"10/8/2021,296.220001,294.0815003\r\n",
"10/11/2021,292.920013,293.85000155\r\n",
"10/12/2021,295.339996,293.63900145\r\n",
"10/13/2021,294.910004,293.22150115\r\n",
"10/14/2021,299.209991,292.9940002\r\n",
"10/15/2021,302.339996,292.90249935\r\n",
"10/18/2021,303.570007,293.26450035\r\n",
"10/19/2021,308.350006,293.89750055\r\n",
"10/20/2021,309.209991,294.52149955\r\n",
"10/21/2021,307.170013,294.9374999\r\n",
"10/22/2021,310.399994,295.54599905\r\n",
"10/25/2021,309.359985,296.20699755\r\n",
"10/26/2021,311.000000,297.26699815\r\n",
"10/27/2021,316.000000,298.81199785\r\n",
"10/28/2021,324.329987,300.74299765\r\n",
"10/29/2021,324.130005,302.84349815\r\n",
"11/1/2021,331.359985,305.0414977\r\n",
"11/2/2021,330.309998,307.3544982\r\n",
"11/3/2021,333.899994,309.76049795\r\n",
"11/4/2021,332.890015,311.64599905\r\n",
"11/5/2021,338.510010,313.7604995\r\n",
"11/8/2021,337.299988,315.97949825\r\n",
"11/9/2021,337.109985,318.0679977\r\n",
"11/10/2021,334.570007,320.05099785\r\n",
"11/11/2021,331.250000,321.6529983\r\n",
"11/12/2021,333.920013,323.23199915\r\n",
"11/15/2021,337.540009,324.93049925\r\n",
"11/16/2021,335.679993,326.2969986\r\n",
"11/17/2021,338.940002,327.78349915\r\n",
"11/18/2021,338.179993,329.33399815\r\n",
"11/19/2021,342.640015,330.9459992\r\n",
"11/22/2021,344.619995,332.7089997\r\n",
"11/23/2021,337.049988,334.0114991\r\n",
"11/24/2021,336.279999,335.02549905\r\n",
"11/26/2021,334.350006,335.526500\r\n",
"11/29/2021,334.940002,336.06699985\r\n",
"11/30/2021,335.320007,336.26500095\r\n",
"12/1/2021,335.130005,336.5060013\r\n",
"12/2/2021,330.299988,336.326001\r\n",
"12/3/2021,331.989990,336.28099975\r\n",
"12/6/2021,323.950012,335.55299985\r\n",
"12/7/2021,331.640015,335.2700012\r\n",
"12/8/2021,335.309998,335.18000185\r\n",
"12/9/2021,334.410004,335.1720017\r\n",
"12/10/2021,334.980011,335.35850225\r\n",
"12/13/2021,340.679993,335.69650125\r\n",
"12/14/2021,333.220001,335.48050085\r\n",
"12/15/2021,328.609985,335.12700045\r\n",
"12/16/2021,335.709991,334.9654999\r\n",
"12/17/2021,320.880005,334.1005005\r\n",
"12/20/2021,320.049988,332.97099915\r\n",
"12/21/2021,323.290009,331.90449985\r\n",
"12/22/2021,328.299988,331.46699985\r\n",
"12/23/2021,332.750000,331.2904999\r\n",
"12/27/2021,335.459991,331.34599915\r\n",
"12/28/2021,343.149994,331.75649875\r\n",
"12/29/2021,341.299988,332.0554978\r\n",
"12/30/2021,341.910004,332.39449775\r\n",
"12/31/2021,338.510010,332.80499885\r\n",
"1/3/2022,335.350006,332.97299965\r\n",
"1/4/2022,334.829987,333.5169984\r\n",
"1/5/2022,325.859985,333.2279969\r\n",
"1/6/2022,313.149994,332.1199967\r\n",
"1/7/2022,314.149994,331.1069962\r\n",
"1/10/2022,309.489990,329.83249515\r\n",
"1/11/2022,313.380005,328.46749575\r\n",
"1/12/2022,319.670013,327.78999635\r\n",
"1/13/2022,320.470001,327.38299715\r\n",
"1/14/2022,304.250000,325.8099976\r\n",
"1/18/2022,304.070007,324.9694977\r\n",
"1/19/2022,306.290009,324.28149875\r\n",
"1/20/2022,309.070007,323.57049865\r\n",
"1/21/2022,302.690002,322.28999935\r\n",
"1/24/2022,292.200012,320.26249995\r\n",
"1/25/2022,291.519989,318.06549985\r\n",
"1/26/2022,307.989990,316.30749965\r\n",
"1/27/2022,302.660004,314.37550045\r\n",
"1/28/2022,300.230011,312.2915008\r\n",
"1/31/2022,308.950012,310.8135009\r\n",
"2/1/2022,310.410004,309.5665008\r\n",
"2/2/2022,309.630005,308.3065017\r\n",
"2/3/2022,309.489990,307.48800195\r\n",
"2/4/2022,300.209991,306.8410018\r\n",
"2/7/2022,306.170013,306.44200275\r\n",
"2/8/2022,301.250000,306.03000325\r\n",
"2/9/2022,309.869995,305.85450275\r\n",
"2/10/2022,304.040009,305.07300255\r\n",
"2/11/2022,303.190002,304.2090026\r\n",
"2/14/2022,293.769989,303.68500205\r\n",
"2/15/2022,300.010010,303.4820022\r\n",
"2/16/2022,298.369995,303.0860015\r\n",
"2/17/2022,296.359985,302.4505004\r\n",
"2/18/2022,293.049988,301.9684997\r\n",
"2/22/2022,285.000000,301.6084991\r\n",
"2/23/2022,290.179993,301.5414993\r\n",
"2/24/2022,272.510010,299.7675003\r\n",
"2/25/2022,295.140015,299.39150085\r\n",
"2/28/2022,294.309998,299.0955002\r\n",
"3/1/2022,296.399994,298.4679993\r\n",
"3/2/2022,295.359985,297.71549835\r\n",
"3/3/2022,302.890015,297.37849885\r\n",
"3/4/2022,294.290009,296.6184998\r\n",
"3/7/2022,288.529999,296.0345002\r\n",
"3/8/2022,277.799988,294.61599895\r\n",
"3/9/2022,283.440002,293.72549905\r\n",
"3/10/2022,283.019989,292.38299875\r\n",
"3/11/2022,287.959991,291.57899785\r\n",
"3/14/2022,280.339996,290.43649755\r\n",
"3/15/2022,280.350006,289.7654984\r\n",
"3/16/2022,289.109985,289.22049715\r\n",
"3/17/2022,293.290009,288.96649785\r\n",
"3/18/2022,295.369995,288.91699835\r\n",
"3/21/2022,298.890015,289.2089997\r\n",
"3/22/2022,299.799988,289.9489991\r\n",
"3/23/2022,300.510010,290.46549995\r\n",
"3/24/2022,299.140015,291.7970002\r\n",
"3/25/2022,305.230011,292.301500\r\n",
"3/28/2022,304.329987,292.80249945\r\n",
"3/29/2022,313.910004,293.67799995\r\n",
"3/30/2022,313.760010,294.5980012\r\n",
"3/31/2022,313.899994,295.14850015\r\n",
"4/1/2022,309.369995,295.90249945\r\n",
"4/4/2022,310.089996,296.9804993\r\n",
"4/5/2022,313.269989,298.75399935\r\n",
"4/6/2022,305.190002,299.84149935\r\n",
"4/7/2022,296.660004,300.5235001\r\n",
"4/8/2022,300.440002,301.14750065\r\n",
"4/11/2022,291.790009,301.7200013\r\n",
"4/12/2022,289.239990,302.1645005\r\n",
"4/13/2022,282.730011,301.8455018\r\n",
"4/14/2022,288.089996,301.58550115\r\n",
"4/18/2022,278.910004,300.7625016\r\n",
"4/19/2022,279.380005,299.7870011\r\n",
"4/20/2022,289.399994,299.2670014\r\n",
"4/21/2022,288.579987,298.67050025\r\n",
"4/22/2022,281.679993,297.79749915\r\n",
"4/25/2022,273.290009,296.20049905\r\n",
"4/26/2022,277.500000,294.8589997\r\n",
"4/27/2022,282.100006,293.2684998\r\n",
"4/28/2022,285.190002,291.8399994\r\n",
"4/29/2022,288.609985,290.57549895\r\n",
"5/2/2022,277.709991,288.99249875\r\n",
"5/3/2022,283.959991,287.6859985\r\n",
"5/4/2022,282.589996,286.15199885\r\n",
"5/5/2022,285.540009,285.1694992\r\n",
"5/6/2022,274.809998,284.0769989\r\n",
"5/9/2022,270.059998,282.5579987\r\n",
"5/10/2022,271.690002,281.55299835\r\n",
"5/11/2022,265.679993,280.3749985\r\n",
"5/12/2022,257.690002,279.12299805\r\n",
"5/13/2022,257.350006,277.58599855\r\n",
"5/16/2022,259.959991,276.6384979\r\n",
"5/17/2022,266.109985,275.9749969\r\n",
"5/18/2022,263.000000,274.6549972\r\n",
"5/19/2022,253.899994,272.92099755\r\n",
"5/20/2022,257.239990,271.6989974\r\n",
"5/23/2022,255.490005,270.8089972\r\n",
"5/24/2022,257.890015,269.82849795\r\n",
"5/25/2022,258.140015,268.6304984\r\n",
"5/26/2022,262.269989,267.48449775\r\n",
"5/27/2022,268.480011,266.47799905\r\n",
"5/31/2022,272.529999,266.21899945\r\n",
"6/1/2022,275.200012,265.7810005\r\n",
"6/2/2022,264.450012,264.8740013\r\n",
"6/3/2022,270.309998,264.11250075\r\n",
"6/6/2022,272.059998,263.97500075\r\n",
"6/7/2022,266.640015,263.8040016\r\n",
"6/8/2022,271.709991,263.80500105\r\n",
"6/9/2022,267.779999,263.91000135\r\n",
"6/10/2022,260.579987,264.0545006\r\n",
"6/13/2022,245.110001,263.44250035\r\n",
"6/14/2022,243.860001,262.63750085\r\n",
"6/15/2022,248.309998,261.7475015\r\n",
"6/16/2022,245.979996,260.8965013\r\n",
"6/17/2022,244.699997,260.43650145\r\n",
"6/21/2022,250.259995,260.0875017\r\n",
"6/22/2022,251.889999,259.9075014\r\n",
"6/23/2022,255.570007,259.791501\r\n",
"6/24/2022,261.809998,259.97500015\r\n",
"6/27/2022,268.209991,260.27200025\r\n",
"6/28/2022,263.980011,260.04700025\r\n",
"6/29/2022,257.589996,259.3000001\r\n",
"6/30/2022,257.049988,258.3924989\r\n",
"7/1/2022,256.390015,257.98949905\r\n",
"7/5/2022,256.160004,257.28199935\r\n",
"7/6/2022,263.750000,256.86649945\r\n",
"7/7/2022,265.119995,256.79049845\r\n",
"7/8/2022,264.790009,256.44449935\r\n",
"7/11/2022,265.649994,256.3379991\r\n",
"7/12/2022,265.880005,256.603000\r\n",
"7/13/2022,250.190002,256.85700005\r\n",
"7/14/2022,250.570007,257.19250035\r\n",
"7/15/2022,255.720001,257.5630005\r\n",
"7/18/2022,259.750000,258.2515007\r\n",
"7/19/2022,257.579987,258.8955002\r\n",
"7/20/2022,259.899994,259.37750015\r\n",
"7/21/2022,259.790009,259.77250065\r\n",
"7/22/2022,265.239990,260.2559998\r\n",
"7/25/2022,261.000000,260.2154999\r\n",
"7/26/2022,259.859985,259.7979996\r\n",
"7/27/2022,261.160004,259.65699925\r\n",
"7/28/2022,269.750000,260.26499945\r\n",
"7/29/2022,277.700012,261.29750065\r\n",
"8/1/2022,277.820007,262.36900025\r\n",
"8/2/2022,276.000000,263.36100005\r\n",
"8/3/2022,276.760010,264.01150055\r\n",
"8/4/2022,281.799988,264.8455002\r\n",
"8/5/2022,279.149994,265.56349945\r\n",
"8/8/2022,284.049988,266.48349915\r\n",
"8/9/2022,279.640015,267.17149965\r\n",
"8/10/2022,288.170013,269.0705002\r\n",
"8/11/2022,290.850006,271.08450015\r\n",
"8/12/2022,288.480011,272.72250065\r\n",
"8/15/2022,291.000000,274.28500065\r\n",
"8/16/2022,291.989990,276.0055008\r\n",
"8/17/2022,289.739990,277.4975006\r\n",
"8/18/2022,290.190002,279.01750025\r\n",
"8/19/2022,288.899994,280.20050045\r\n",
"8/22/2022,282.079987,281.2544998\r\n",
"8/23/2022,276.440002,282.08350065\r\n",
"8/24/2022,275.410004,282.79600065\r\n",
"8/25/2022,277.329987,283.175000\r\n",
"8/26/2022,279.079987,283.24399875\r\n",
"8/29/2022,265.850006,282.6454987\r\n",
"8/30/2022,266.670013,282.17899935\r\n",
"8/31/2022,265.390015,281.6104996\r\n",
"9/1/2022,258.869995,280.46399995\r\n",
"9/2/2022,261.700012,279.59150085\r\n",
"9/6/2022,256.200012,278.19900205\r\n",
"9/7/2022,254.699997,276.95200115\r\n",
"9/8/2022,257.510010,275.419001\r\n",
"9/9/2022,260.500000,273.9015007\r\n",
"9/12/2022,265.779999,272.7665001\r\n",
"9/13/2022,258.839996,271.1584999\r\n",
"9/14/2022,253.529999,269.23550035\r\n",
"9/15/2022,249.770004,267.23700105\r\n",
"9/16/2022,244.259995,264.9405007\r\n",
"9/19/2022,242.470001,262.61900105\r\n",
"9/20/2022,242.070007,260.61850205\r\n",
"9/21/2022,244.270004,259.01000215\r\n",
"9/22/2022,237.869995,257.1330017\r\n",
"9/23/2022,239.539993,255.243502\r\n",
"9/26/2022,237.050003,253.1420028\r\n",
"9/27/2022,239.979996,251.8485023\r\n",
"9/28/2022,236.809998,250.35550155\r\n",
"9/29/2022,238.889999,249.03050075\r\n",
"9/30/2022,238.289993,248.00150065\r\n",
"10/3/2022,235.410004,246.68700025\r\n",
"10/4/2022,245.089996,246.13149945\r\n",
"10/5/2022,245.990005,245.69599985\r\n",
"10/6/2022,247.929993,245.216999\r\n",
"10/7/2022,240.899994,244.2369987\r\n",
"10/10/2022,233.050003,242.6004989\r\n",
"10/11/2022,227.619995,241.03949885\r\n",
"10/12/2022,225.399994,239.6329986\r\n",
"10/13/2022,219.850006,238.1369987\r\n",
"10/14/2022,235.539993,237.7009986\r\n",
"10/17/2022,235.820007,237.3684989\r\n",
"10/18/2022,243.240005,237.4269988\r\n",
"10/19/2022,237.039993,237.06549825\r\n",
"10/20/2022,235.770004,236.9604987\r\n",
"10/21/2022,234.740005,236.7204993\r\n",
"10/24/2022,243.759995,237.0559989\r\n",
"10/25/2022,247.259995,237.41999885\r\n",
"10/26/2022,231.169998,237.13799885\r\n",
"10/27/2022,231.039993,236.74549855\r\n",
"10/28/2022,226.240005,236.14299915\r\n",
"10/31/2022,233.759995,236.0604987\r\n",
"11/1/2022,234.600006,235.5359992\r\n",
"11/2/2022,229.460007,234.7094993\r\n",
"11/3/2022,220.089996,233.31749945\r\n",
"11/4/2022,217.550003,232.1499999\r\n",
"11/7/2022,221.990005,231.597000\r\n",
"11/8/2022,228.699997,231.6510001\r\n",
"11/9/2022,227.369995,231.74950015\r\n",
"11/10/2022,235.429993,232.5284995\r\n",
"11/11/2022,242.990005,232.9010001\r\n",
"11/14/2022,241.990005,233.209500\r\n",
"11/15/2022,245.660004,233.33049995\r\n",
"11/16/2022,242.789993,233.61799995\r\n",
"11/17/2022,237.779999,233.7184997\r\n",
"11/18/2022,243.509995,234.1569992\r\n",
"11/21/2022,241.429993,234.0404991\r\n",
"11/22/2022,243.589996,233.85699915\r\n",
"11/23/2022,245.110001,234.5539993\r\n",
"11/25/2022,247.309998,235.36749955\r\n",
"11/28/2022,246.080002,236.3594994\r\n",
"11/29/2022,241.399994,236.74149935\r\n",
"11/30/2022,240.570007,237.0399994\r\n",
"12/1/2022,253.869995,238.2604988\r\n",
"12/2/2022,249.820007,239.74699935\r\n",
"12/5/2022,252.009995,241.46999895\r\n",
"12/6/2022,250.820007,242.91149905\r\n",
"12/7/2022,244.830002,243.7179993\r\n",
"12/8/2022,244.839996,244.59149935\r\n",
"12/9/2022,244.699997,245.05499955\r\n",
"12/12/2022,247.449997,245.27799915\r\n",
"12/13/2022,261.690002,246.262999\r\n",
"12/14/2022,257.130005,246.83649905\r\n",
"12/15/2022,253.720001,247.38299945\r\n",
"12/16/2022,248.550003,247.92149965\r\n",
"12/19/2022,244.860001,247.98899995\r\n",
"12/20/2022,239.399994,247.887500\r\n",
"12/21/2022,241.690002,247.7925003\r\n",
"12/22/2022,241.259995,247.600000\r\n",
"12/23/2022,236.110001,247.04000015\r\n",
"12/27/2022,238.699997,246.6709999\r\n",
"12/28/2022,236.889999,246.44550015\r\n",
"12/29/2022,235.649994,246.1994995\r\n",
"12/30/2022,238.210007,245.4165001\r\n",
"1/3/2023,243.080002,245.07949985\r\n",
"1/4/2023,232.279999,244.09300005\r\n",
"1/5/2023,227.199997,242.91199955\r\n",
"1/6/2023,223.000000,241.82049945\r\n",
"1/9/2023,226.449997,240.9009995\r\n",
"1/10/2023,227.759995,240.0539994\r\n",
"1/11/2023,231.289993,239.2459992\r\n",
"1/12/2023,235.259995,237.92449885\r\n",
"1/13/2023,237.000000,236.9179986\r\n",
"1/17/2023,237.970001,236.1304986\r\n",
"1/18/2023,241.570007,235.7814988\r\n",
"1/19/2023,233.779999,235.2274987\r\n",
"1/20/2023,234.860001,235.00049905\r\n",
"1/23/2023,241.100006,234.97099925\r\n",
"1/24/2023,242.500000,235.0329995\r\n",
"1/25/2023,234.479996,234.95149925\r\n",
"1/26/2023,243.649994,235.1989991\r\n",
"1/27/2023,248.990005,235.8039994\r\n",
"1/30/2023,244.509995,236.24699945\r\n",
"1/31/2023,243.449997,236.50899895\r\n",
"2/1/2023,248.000000,236.75499885\r\n",
"2/2/2023,258.820007,238.08199925\r\n",
"2/3/2023,259.540009,239.69899985\r\n",
"2/6/2023,257.440002,241.42099995\r\n",
"2/7/2023,260.529999,243.12500005\r\n",
"2/8/2023,273.200012,245.3970009\r\n",
"2/9/2023,273.799988,247.52250065\r\n",
"2/10/2023,261.529999,248.83600085\r\n",
"2/13/2023,267.640015,250.3680016\r\n",
"2/14/2023,272.670013,252.1030022\r\n",
"2/15/2023,268.320007,253.4405022\r\n",
"2/16/2023,264.019989,254.9525017\r\n",
"2/17/2023,259.390015,256.1790024\r\n",
"2/21/2023,254.479996,256.8480019\r\n",
"2/22/2023,254.089996,257.4275017\r\n",
"2/23/2023,255.559998,258.4815018\r\n",
"2/24/2023,249.960007,258.79700245\r\n",
"2/27/2023,252.460007,258.97050255\r\n",
"2/28/2023,249.070007,259.19850315\r\n",
"3/1/2023,250.759995,259.56400305\r\n",
"3/2/2023,246.550003,259.4915032\r\n",
"3/3/2023,252.190002,259.16000295\r\n",
"3/6/2023,256.429993,259.00450215\r\n",
"3/7/2023,256.299988,258.94750145\r\n",
"3/8/2023,254.039993,258.62300115\r\n",
"3/9/2023,255.820007,257.7540009\r\n",
"3/10/2023,251.080002,256.6180016\r\n",
"3/13/2023,247.399994,255.91150135\r\n",
"3/14/2023,256.750000,255.3670006\r\n",
"3/15/2023,259.980011,254.7325005\r\n",
"3/16/2023,265.209991,254.5769997\r\n",
"3/17/2023,278.260010,255.28900075\r\n",
"3/20/2023,276.980011,256.16850055\r\n",
"3/21/2023,274.880005,257.188501\r\n",
"3/22/2023,273.399994,258.1540009\r\n",
"3/23/2023,277.940002,259.2730011\r\n",
"3/24/2023,277.239990,260.63700025\r\n",
"3/27/2023,280.500000,262.0389999\r\n",
"3/28/2023,275.790009,263.375000\r\n",
"3/29/2023,278.959991,264.7849998\r\n",
"3/30/2023,284.230011,266.6690002\r\n",
"3/31/2023,283.730011,268.24600065\r\n",
"4/3/2023,286.519989,269.75050045\r\n",
"4/4/2023,287.230011,271.2970016\r\n",
"4/5/2023,285.850006,272.88750225\r\n",
"4/6/2023,283.209991,274.25700145\r\n",
"4/10/2023,289.209991,276.1635009\r\n",
"4/11/2023,285.750000,278.0810012\r\n",
"4/12/2023,284.790009,279.48300165\r\n",
"4/13/2023,283.589996,280.6635009\r\n",
"4/14/2023,287.000000,281.75300135\r\n",
"4/17/2023,289.929993,282.3365005\r\n",
"4/18/2023,291.570007,283.0660003\r\n",
"4/19/2023,285.989990,283.62149955\r\n",
"4/20/2023,285.250000,284.21399985\r\n",
"4/21/2023,285.010010,284.56750025\r\n",
"4/24/2023,282.089996,284.81000055\r\n",
"4/25/2023,279.510010,284.76050105\r\n",
"4/26/2023,296.700012,285.8060012\r\n",
"4/27/2023,295.970001,286.6565017\r\n",
"4/28/2023,304.010010,287.64550165\r\n",
"5/1/2023,306.970001,288.80750115\r\n",
"5/2/2023,307.760010,289.8695022\r\n",
"5/3/2023,306.619995,290.8390014\r\n",
"5/4/2023,306.239990,291.8585006\r\n",
"5/5/2023,305.720001,292.9840011\r\n",
"5/8/2023,310.130005,294.0300018\r\n",
"5/9/2023,308.000000,295.1425018\r\n",
"5/10/2023,308.619995,296.3340011\r\n",
"5/11/2023,310.100006,297.6595016\r\n",
"5/12/2023,310.549988,298.837001\r\n",
"5/15/2023,309.100006,299.79550165\r\n",
"5/16/2023,309.829987,300.70850065\r\n",
"5/17/2023,312.290009,302.0235016\r\n",
"5/18/2023,314.529999,303.48750155\r\n",
"5/19/2023,316.739990,305.07400055\r\n",
"5/22/2023,318.600006,306.89950105\r\n",
"5/23/2023,320.029999,308.9255005\r\n",
"5/24/2023,314.730011,309.82700045\r\n",
"5/25/2023,323.239990,311.1904999\r\n",
"5/26/2023,324.019989,312.19099885\r\n",
"5/30/2023,335.230011,313.60399935\r\n",
"5/31/2023,332.290009,314.8304993\r\n",
"6/1/2023,325.929993,315.7959992\r\n",
"6/2/2023,334.250000,317.1964997\r\n",
"6/5/2023,335.220001,318.6714997\r\n",
"6/6/2023,335.329987,319.9314988\r\n",
"6/7/2023,331.649994,321.1139985\r\n",
"6/8/2023,323.940002,321.87999885\r\n",
"6/9/2023,324.989990,322.62449805\r\n",
"6/12/2023,328.579987,323.525998\r\n",
"6/13/2023,334.470001,324.79449775\r\n",
"6/14/2023,334.339996,326.0199982\r\n",
"6/15/2023,337.480011,327.2794983\r\n",
"6/16/2023,351.320007,329.1189987\r\n",
"6/20/2023,339.309998,330.2474991\r\n",
"6/21/2023,336.369995,331.13599855\r\n",
"6/22/2023,334.119995,331.84049835\r\n",
"6/23/2023,334.359985,332.82199705\r\n",
"6/26/2023,333.720001,333.3459976\r\n",
"6/27/2023,331.859985,333.7379974\r\n",
"6/28/2023,334.660004,333.70949705\r\n",
"6/29/2023,334.709991,333.83049615\r\n",
"6/30/2023,337.750000,334.4214965\r\n",
"7/3/2023,339.190002,334.6684966\r\n",
"7/5/2023,335.089996,334.66199635\r\n",
"7/6/2023,337.299988,334.7604964\r\n",
"7/7/2023,339.320007,335.14399705\r\n",
"7/10/2023,334.600006,335.67699725\r\n",
"7/11/2023,331.059998,335.98049765\r\n",
"7/12/2023,336.600006,336.3814986\r\n",
"7/13/2023,339.559998,336.63599845\r\n",
"7/14/2023,347.589996,337.29849845\r\n",
"7/17/2023,345.679993,337.70849755\r\n",
"7/18/2023,345.829987,337.43399655\r\n",
"7/19/2023,361.750000,338.55599665\r\n",
"7/20/2023,353.570007,339.41599725\r\n",
"7/21/2023,349.149994,340.1674972\r\n",
"7/24/2023,345.850006,340.74199825\r\n",
"7/25/2023,347.109985,341.41149745\r\n",
"7/26/2023,341.440002,341.8904983\r\n",
"7/27/2023,340.480011,342.18149865\r\n",
"7/28/2023,333.670013,342.12949975\r\n",
"7/31/2023,336.920013,342.0880004\r\n",
"8/1/2023,335.190002,341.8880004\r\n",
"8/2/2023,333.630005,341.81500085\r\n",
"8/3/2023,326.000000,341.25000145\r\n",
"8/4/2023,331.880005,340.87800135\r\n",
"8/7/2023,328.369995,340.5665008\r\n",
"8/8/2023,326.959991,340.36150045\r\n",
"8/9/2023,326.470001,339.8550002\r\n",
"8/10/2023,326.019989,339.17799975\r\n",
"8/11/2023,320.260010,337.81150045\r\n",
"8/14/2023,321.390015,336.59700155\r\n",
"8/15/2023,323.000000,335.4555022\r\n",
"8/16/2023,320.799988,333.4080016\r\n",
"8/17/2023,320.540009,331.7565017\r\n",
"8/18/2023,314.489990,330.0235015\r\n",
"8/21/2023,317.929993,328.62750085\r\n",
"8/22/2023,325.500000,327.5470016\r\n",
"8/23/2023,323.820007,326.66600185\r\n",
"8/24/2023,332.850006,326.2845016\r\n",
"8/25/2023,321.470001,325.674501\r\n",
"8/28/2023,325.660004,325.11150055\r\n",
"8/29/2023,321.880005,324.4460007\r\n",
"8/30/2023,328.670013,324.1980011\r\n",
"8/31/2023,329.200012,324.3580017\r\n",
"9/1/2023,331.309998,324.32950135\r\n",
"9/5/2023,329.000000,324.3610016\r\n",
"9/6/2023,333.380005,324.6820023\r\n",
"9/7/2023,331.290009,324.9230027\r\n",
"9/8/2023,330.089996,325.12650305\r\n",
"9/11/2023,337.239990,325.97550205\r\n",
"9/12/2023,335.820007,326.69700165\r\n",
"9/13/2023,331.309998,327.11250155\r\n",
"9/14/2023,339.149994,328.03000185\r\n",
"9/15/2023,336.920013,328.84900205\r\n",
"9/18/2023,327.799988,329.51450195\r\n",
"9/19/2023,326.170013,329.92650295\r\n",
"9/20/2023,329.510010,330.12700345\r\n",
"9/21/2023,319.260010,329.8990036\r\n",
"9/22/2023,321.320007,329.32250365\r\n",
"9/25/2023,316.589996,329.0785034\r\n",
"9/26/2023,315.130005,328.55200345\r\n",
"9/27/2023,312.299988,328.0730026\r\n",
"9/28/2023,310.989990,327.18900145\r\n",
"9/29/2023,317.750000,326.61650085\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Avg</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td><td><div class=\"dni-plaintext\"><pre>110.40050045</pre></div></td></tr><tr><td><time datetime=\"2018-10-29\">Oct 29, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.110001</pre></div></td><td><div class=\"dni-plaintext\"><pre>110.0685005</pre></div></td></tr><tr><td><time datetime=\"2018-10-30\">Oct 30, 2018</time></td><td><div class=\"dni-plaintext\"><pre>103.660004</pre></div></td><td><div class=\"dni-plaintext\"><pre>109.48650055</pre></div></td></tr><tr><td><time datetime=\"2018-10-31\">Oct 31, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.98750075</pre></div></td></tr><tr><td><time datetime=\"2018-11-01\">Nov 01, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.050003</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.60950085</pre></div></td></tr><tr><td><time datetime=\"2018-11-02\">Nov 02, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.480003</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.30200115</pre></div></td></tr><tr><td><time datetime=\"2018-11-05\">Nov 05, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.370003</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.0375011</pre></div></td></tr><tr><td><time datetime=\"2018-11-06\">Nov 06, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.379997</pre></div></td><td><div class=\"dni-plaintext\"><pre>107.849501</pre></div></td></tr><tr><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>107.7595012</pre></div></td></tr><tr><td><time datetime=\"2018-11-08\">Nov 08, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.08200145</pre></div></td></tr><tr><td><time datetime=\"2018-11-09\">Nov 09, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.849998</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.17400125</pre></div></td></tr><tr><td><time datetime=\"2018-11-12\">Nov 12, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.419998</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.19950095</pre></div></td></tr><tr><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td><td><div class=\"dni-plaintext\"><pre>108.10000105</pre></div></td></tr><tr><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><div class=\"dni-plaintext\"><pre>107.92100095</pre></div></td></tr><tr><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td><td><div class=\"dni-plaintext\"><pre>107.66550095</pre></div></td></tr><tr><td><time datetime=\"2018-11-16\">Nov 16, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.080002</pre></div></td><td><div class=\"dni-plaintext\"><pre>107.57300105</pre></div></td></tr><tr><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>107.5205009</pre></div></td></tr><tr><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>107.2220012</pre></div></td></tr><tr><td><time datetime=\"2018-11-21\">Nov 21, 2018</time></td><td><div class=\"dni-plaintext\"><pre>103.599998</pre></div></td><td><div class=\"dni-plaintext\"><pre>106.9815009</pre></div></td></tr><tr><td><time datetime=\"2018-11-23\">Nov 23, 2018</time></td><td><div class=\"dni-plaintext\"><pre>102.169998</pre></div></td><td><div class=\"dni-plaintext\"><pre>106.76250065</pre></div></td></tr><tr><td colspan=\"3\"><i>(1219 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var mavg =\n",
" from w in data.Window(20)\n",
" select new\n",
" {\n",
" w[^1].Date, // last date in window\n",
" w[^1].Price, // last price in window\n",
" Avg = w.Average(e => e.Price),\n",
" };\n",
"\n",
"mavg.ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The `Window` extension essentially gives us a _scrolling window_ of a specific size over the sequence such that if you have a sequence of integers like `[1, 2, 3, 4, 5]` and you call `Window(3)` on it, then you'll get back the sequence `[[1, 2, 3], [2, 3, 4], [3, 4, 5]]`. If the source sequence is smaller than the window size, then `Window` will return an empty sequence, which is generally what you want when dealing with averages. If you want partial windows for other use cases, MoreLINQ offers [`WindowLeft`] and [`WindowRight`].\n",
"\n",
"[`WindowLeft`]: https://morelinq.github.io/4.0/ref/api/html/M_MoreLinq_MoreEnumerable_WindowLeft__1.htm\n",
"[`WindowRight`]: https://morelinq.github.io/4.0/ref/api/html/M_MoreLinq_MoreEnumerable_WindowRight__1.htm\n",
"\n",
"Let's buy when the price is below the 20-day moving average and sell otherwise:"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Action\r\n",
"10/26/2018,105.690002,Buy\r\n",
"10/29/2018,108.110001,Buy\r\n",
"10/30/2018,103.660004,Buy\r\n",
"10/31/2018,105.440002,Buy\r\n",
"11/1/2018,107.050003,Buy\r\n",
"11/2/2018,106.480003,Buy\r\n",
"11/5/2018,106.370003,Buy\r\n",
"11/6/2018,107.379997,Buy\r\n",
"11/7/2018,109.440002,Sell\r\n",
"11/8/2018,111.800003,Sell\r\n",
"11/9/2018,110.849998,Sell\r\n",
"11/12/2018,109.419998,Sell\r\n",
"11/13/2018,107.550003,Buy\r\n",
"11/14/2018,108.099998,Sell\r\n",
"11/15/2018,104.989998,Buy\r\n",
"11/16/2018,107.080002,Buy\r\n",
"11/19/2018,108.269997,Sell\r\n",
"11/20/2018,101.800003,Buy\r\n",
"11/21/2018,103.599998,Buy\r\n",
"11/23/2018,102.169998,Buy\r\n",
"11/26/2018,104.790001,Buy\r\n",
"11/27/2018,106.269997,Buy\r\n",
"11/28/2018,107.889999,Sell\r\n",
"11/29/2018,110.330002,Sell\r\n",
"11/30/2018,110.699997,Sell\r\n",
"12/3/2018,113.000000,Sell\r\n",
"12/4/2018,111.940002,Sell\r\n",
"12/6/2018,105.820000,Buy\r\n",
"12/7/2018,108.379997,Sell\r\n",
"12/10/2018,104.800003,Buy\r\n",
"12/11/2018,109.800003,Sell\r\n",
"12/12/2018,110.889999,Sell\r\n",
"12/13/2018,109.580002,Sell\r\n",
"12/14/2018,108.250000,Sell\r\n",
"12/17/2018,105.410004,Buy\r\n",
"12/18/2018,103.750000,Buy\r\n",
"12/19/2018,103.650002,Buy\r\n",
"12/20/2018,103.050003,Buy\r\n",
"12/21/2018,101.629997,Buy\r\n",
"12/24/2018,97.680000,Buy\r\n",
"12/26/2018,95.139999,Buy\r\n",
"12/27/2018,99.300003,Buy\r\n",
"12/28/2018,102.089996,Buy\r\n",
"12/31/2018,101.290001,Buy\r\n",
"1/2/2019,99.550003,Buy\r\n",
"1/3/2019,100.099998,Buy\r\n",
"1/4/2019,99.720001,Buy\r\n",
"1/7/2019,101.639999,Buy\r\n",
"1/8/2019,103.040001,Sell\r\n",
"1/9/2019,103.860001,Sell\r\n",
"1/10/2019,103.220001,Sell\r\n",
"1/11/2019,103.190002,Sell\r\n",
"1/14/2019,101.900002,Sell\r\n",
"1/15/2019,102.510002,Sell\r\n",
"1/16/2019,105.260002,Sell\r\n",
"1/17/2019,105.000000,Sell\r\n",
"1/18/2019,107.459999,Sell\r\n",
"1/22/2019,106.750000,Sell\r\n",
"1/23/2019,106.120003,Sell\r\n",
"1/24/2019,106.860001,Sell\r\n",
"1/25/2019,107.239998,Sell\r\n",
"1/28/2019,106.260002,Sell\r\n",
"1/29/2019,104.879997,Sell\r\n",
"1/30/2019,104.620003,Sell\r\n",
"1/31/2019,103.800003,Buy\r\n",
"2/1/2019,103.779999,Buy\r\n",
"2/4/2019,102.870003,Buy\r\n",
"2/5/2019,106.059998,Sell\r\n",
"2/6/2019,107.000000,Sell\r\n",
"2/7/2019,105.190002,Sell\r\n",
"2/8/2019,104.389999,Buy\r\n",
"2/11/2019,106.199997,Sell\r\n",
"2/12/2019,106.139999,Sell\r\n",
"2/13/2019,107.500000,Sell\r\n",
"2/14/2019,106.309998,Sell\r\n",
"2/15/2019,107.910004,Sell\r\n",
"2/19/2019,107.790001,Sell\r\n",
"2/20/2019,107.860001,Sell\r\n",
"2/21/2019,106.900002,Sell\r\n",
"2/22/2019,110.050003,Sell\r\n",
"2/25/2019,111.760002,Sell\r\n",
"2/26/2019,111.260002,Sell\r\n",
"2/27/2019,111.690002,Sell\r\n",
"2/28/2019,112.040001,Sell\r\n",
"3/1/2019,112.889999,Sell\r\n",
"3/4/2019,113.019997,Sell\r\n",
"3/5/2019,112.250000,Sell\r\n",
"3/6/2019,111.870003,Sell\r\n",
"3/7/2019,111.400002,Sell\r\n",
"3/8/2019,109.160004,Buy\r\n",
"3/11/2019,110.989998,Sell\r\n",
"3/12/2019,112.820000,Sell\r\n",
"3/13/2019,114.129997,Sell\r\n",
"3/14/2019,114.540001,Sell\r\n",
"3/15/2019,115.339996,Sell\r\n",
"3/18/2019,116.169998,Sell\r\n",
"3/19/2019,118.089996,Sell\r\n",
"3/20/2019,117.389999,Sell\r\n",
"3/21/2019,117.139999,Sell\r\n",
"3/22/2019,119.500000,Sell\r\n",
"3/25/2019,116.559998,Sell\r\n",
"3/26/2019,118.620003,Sell\r\n",
"3/27/2019,117.879997,Sell\r\n",
"3/28/2019,117.440002,Sell\r\n",
"3/29/2019,118.070000,Sell\r\n",
"4/1/2019,118.949997,Sell\r\n",
"4/2/2019,119.059998,Sell\r\n",
"4/3/2019,119.860001,Sell\r\n",
"4/4/2019,120.099998,Sell\r\n",
"4/5/2019,119.389999,Sell\r\n",
"4/8/2019,119.809998,Sell\r\n",
"4/9/2019,118.629997,Sell\r\n",
"4/10/2019,119.760002,Sell\r\n",
"4/11/2019,120.540001,Sell\r\n",
"4/12/2019,120.639999,Sell\r\n",
"4/15/2019,120.940002,Sell\r\n",
"4/16/2019,121.639999,Sell\r\n",
"4/17/2019,121.239998,Sell\r\n",
"4/18/2019,122.190002,Sell\r\n",
"4/22/2019,122.620003,Sell\r\n",
"4/23/2019,124.099998,Sell\r\n",
"4/24/2019,125.790001,Sell\r\n",
"4/25/2019,130.059998,Sell\r\n",
"4/26/2019,129.699997,Sell\r\n",
"4/29/2019,129.899994,Sell\r\n",
"4/30/2019,129.809998,Sell\r\n",
"5/1/2019,130.529999,Sell\r\n",
"5/2/2019,127.980003,Sell\r\n",
"5/3/2019,127.360001,Sell\r\n",
"5/6/2019,126.389999,Sell\r\n",
"5/7/2019,126.459999,Sell\r\n",
"5/8/2019,125.440002,Sell\r\n",
"5/9/2019,124.290001,Buy\r\n",
"5/10/2019,124.910004,Buy\r\n",
"5/13/2019,124.110001,Buy\r\n",
"5/14/2019,123.870003,Buy\r\n",
"5/15/2019,124.260002,Buy\r\n",
"5/16/2019,126.750000,Sell\r\n",
"5/17/2019,128.309998,Sell\r\n",
"5/20/2019,126.519997,Buy\r\n",
"5/21/2019,127.430000,Sell\r\n",
"5/22/2019,126.620003,Buy\r\n",
"5/23/2019,126.199997,Buy\r\n",
"5/24/2019,126.910004,Sell\r\n",
"5/28/2019,126.980003,Sell\r\n",
"5/29/2019,125.379997,Buy\r\n",
"5/30/2019,125.260002,Buy\r\n",
"5/31/2019,124.230003,Buy\r\n",
"6/3/2019,123.849998,Buy\r\n",
"6/4/2019,121.279999,Buy\r\n",
"6/5/2019,124.949997,Buy\r\n",
"6/6/2019,126.440002,Sell\r\n",
"6/7/2019,129.190002,Sell\r\n",
"6/10/2019,132.399994,Sell\r\n",
"6/11/2019,133.880005,Sell\r\n",
"6/12/2019,131.399994,Sell\r\n",
"6/13/2019,131.979996,Sell\r\n",
"6/14/2019,132.259995,Sell\r\n",
"6/17/2019,132.630005,Sell\r\n",
"6/18/2019,134.190002,Sell\r\n",
"6/19/2019,135.000000,Sell\r\n",
"6/20/2019,137.449997,Sell\r\n",
"6/21/2019,136.580002,Sell\r\n",
"6/24/2019,137.000000,Sell\r\n",
"6/25/2019,137.250000,Sell\r\n",
"6/26/2019,134.350006,Sell\r\n",
"6/27/2019,134.139999,Sell\r\n",
"6/28/2019,134.570007,Sell\r\n",
"7/1/2019,136.630005,Sell\r\n",
"7/2/2019,136.119995,Sell\r\n",
"7/3/2019,136.800003,Sell\r\n",
"7/5/2019,135.940002,Sell\r\n",
"7/8/2019,136.399994,Sell\r\n",
"7/9/2019,136.000000,Sell\r\n",
"7/10/2019,137.130005,Sell\r\n",
"7/11/2019,138.199997,Sell\r\n",
"7/12/2019,138.850006,Sell\r\n",
"7/15/2019,139.440002,Sell\r\n",
"7/16/2019,138.960007,Sell\r\n",
"7/17/2019,137.699997,Sell\r\n",
"7/18/2019,135.550003,Buy\r\n",
"7/19/2019,140.220001,Sell\r\n",
"7/22/2019,137.410004,Sell\r\n",
"7/23/2019,139.759995,Sell\r\n",
"7/24/2019,138.899994,Sell\r\n",
"7/25/2019,140.429993,Sell\r\n",
"7/26/2019,140.369995,Sell\r\n",
"7/29/2019,141.500000,Sell\r\n",
"7/30/2019,140.139999,Sell\r\n",
"7/31/2019,140.330002,Sell\r\n",
"8/1/2019,137.000000,Buy\r\n",
"8/2/2019,138.089996,Buy\r\n",
"8/5/2019,133.300003,Buy\r\n",
"8/6/2019,133.800003,Buy\r\n",
"8/7/2019,133.789993,Buy\r\n",
"8/8/2019,136.600006,Buy\r\n",
"8/9/2019,138.610001,Sell\r\n",
"8/12/2019,137.070007,Buy\r\n",
"8/13/2019,136.050003,Buy\r\n",
"8/14/2019,136.360001,Buy\r\n",
"8/15/2019,134.389999,Buy\r\n",
"8/16/2019,134.880005,Buy\r\n",
"8/19/2019,137.850006,Sell\r\n",
"8/20/2019,138.210007,Sell\r\n",
"8/21/2019,138.550003,Sell\r\n",
"8/22/2019,138.660004,Sell\r\n",
"8/23/2019,137.190002,Sell\r\n",
"8/26/2019,134.990005,Buy\r\n",
"8/27/2019,136.389999,Buy\r\n",
"8/28/2019,134.880005,Buy\r\n",
"8/29/2019,137.250000,Sell\r\n",
"8/30/2019,139.149994,Sell\r\n",
"9/3/2019,136.610001,Sell\r\n",
"9/4/2019,137.300003,Sell\r\n",
"9/5/2019,139.110001,Sell\r\n",
"9/6/2019,140.029999,Sell\r\n",
"9/9/2019,139.589996,Sell\r\n",
"9/10/2019,136.800003,Buy\r\n",
"9/11/2019,135.910004,Buy\r\n",
"9/12/2019,137.850006,Sell\r\n",
"9/13/2019,137.779999,Sell\r\n",
"9/16/2019,135.830002,Buy\r\n",
"9/17/2019,136.960007,Buy\r\n",
"9/18/2019,137.360001,Buy\r\n",
"9/19/2019,140.300003,Sell\r\n",
"9/20/2019,141.009995,Sell\r\n",
"9/23/2019,139.229996,Sell\r\n",
"9/24/2019,140.360001,Sell\r\n",
"9/25/2019,137.500000,Buy\r\n",
"9/26/2019,139.440002,Sell\r\n",
"9/27/2019,140.149994,Sell\r\n",
"9/30/2019,138.050003,Buy\r\n",
"10/1/2019,139.660004,Sell\r\n",
"10/2/2019,136.250000,Buy\r\n",
"10/3/2019,134.949997,Buy\r\n",
"10/4/2019,136.750000,Buy\r\n",
"10/7/2019,137.139999,Buy\r\n",
"10/8/2019,137.080002,Buy\r\n",
"10/9/2019,137.460007,Buy\r\n",
"10/10/2019,138.490005,Sell\r\n",
"10/11/2019,140.119995,Sell\r\n",
"10/14/2019,139.690002,Sell\r\n",
"10/15/2019,140.059998,Sell\r\n",
"10/16/2019,140.789993,Sell\r\n",
"10/17/2019,140.949997,Sell\r\n",
"10/18/2019,139.759995,Sell\r\n",
"10/21/2019,138.449997,Buy\r\n",
"10/22/2019,138.970001,Sell\r\n",
"10/23/2019,136.880005,Buy\r\n",
"10/24/2019,139.389999,Sell\r\n",
"10/25/2019,139.339996,Sell\r\n",
"10/28/2019,144.399994,Sell\r\n",
"10/29/2019,144.080002,Sell\r\n",
"10/30/2019,143.520004,Sell\r\n",
"10/31/2019,144.899994,Sell\r\n",
"11/1/2019,144.259995,Sell\r\n",
"11/4/2019,144.830002,Sell\r\n",
"11/5/2019,144.970001,Sell\r\n",
"11/6/2019,144.369995,Sell\r\n",
"11/7/2019,143.839996,Sell\r\n",
"11/8/2019,143.979996,Sell\r\n",
"11/11/2019,145.339996,Sell\r\n",
"11/12/2019,146.279999,Sell\r\n",
"11/13/2019,146.740005,Sell\r\n",
"11/14/2019,147.020004,Sell\r\n",
"11/15/2019,148.929993,Sell\r\n",
"11/18/2019,150.070007,Sell\r\n",
"11/19/2019,150.880005,Sell\r\n",
"11/20/2019,150.309998,Sell\r\n",
"11/21/2019,149.399994,Sell\r\n",
"11/22/2019,150.070007,Sell\r\n",
"11/25/2019,150.000000,Sell\r\n",
"11/26/2019,151.360001,Sell\r\n",
"11/27/2019,152.330002,Sell\r\n",
"11/29/2019,152.100006,Sell\r\n",
"12/2/2019,151.809998,Sell\r\n",
"12/3/2019,147.490005,Buy\r\n",
"12/4/2019,150.139999,Sell\r\n",
"12/5/2019,150.050003,Sell\r\n",
"12/6/2019,150.990005,Sell\r\n",
"12/9/2019,151.070007,Sell\r\n",
"12/10/2019,151.289993,Sell\r\n",
"12/11/2019,151.539993,Sell\r\n",
"12/12/2019,151.649994,Sell\r\n",
"12/13/2019,153.000000,Sell\r\n",
"12/16/2019,155.110001,Sell\r\n",
"12/17/2019,155.449997,Sell\r\n",
"12/18/2019,154.300003,Sell\r\n",
"12/19/2019,154.000000,Sell\r\n",
"12/20/2019,157.350006,Sell\r\n",
"12/23/2019,158.119995,Sell\r\n",
"12/24/2019,157.479996,Sell\r\n",
"12/26/2019,157.559998,Sell\r\n",
"12/27/2019,159.449997,Sell\r\n",
"12/30/2019,158.990005,Sell\r\n",
"12/31/2019,156.770004,Sell\r\n",
"1/2/2020,158.779999,Sell\r\n",
"1/3/2020,158.320007,Sell\r\n",
"1/6/2020,157.080002,Sell\r\n",
"1/7/2020,159.320007,Sell\r\n",
"1/8/2020,158.929993,Sell\r\n",
"1/9/2020,161.839996,Sell\r\n",
"1/10/2020,162.820007,Sell\r\n",
"1/13/2020,161.759995,Sell\r\n",
"1/14/2020,163.389999,Sell\r\n",
"1/15/2020,162.619995,Sell\r\n",
"1/16/2020,164.350006,Sell\r\n",
"1/17/2020,167.419998,Sell\r\n",
"1/21/2020,166.679993,Sell\r\n",
"1/22/2020,167.399994,Sell\r\n",
"1/23/2020,166.190002,Sell\r\n",
"1/24/2020,167.509995,Sell\r\n",
"1/27/2020,161.149994,Buy\r\n",
"1/28/2020,163.779999,Sell\r\n",
"1/29/2020,167.839996,Sell\r\n",
"1/30/2020,174.050003,Sell\r\n",
"1/31/2020,172.210007,Sell\r\n",
"2/3/2020,170.429993,Sell\r\n",
"2/4/2020,177.139999,Sell\r\n",
"2/5/2020,184.029999,Sell\r\n",
"2/6/2020,180.970001,Sell\r\n",
"2/7/2020,182.850006,Sell\r\n",
"2/10/2020,183.580002,Sell\r\n",
"2/11/2020,190.649994,Sell\r\n",
"2/12/2020,185.580002,Sell\r\n",
"2/13/2020,183.080002,Sell\r\n",
"2/14/2020,183.250000,Sell\r\n",
"2/18/2020,185.610001,Sell\r\n",
"2/19/2020,188.059998,Sell\r\n",
"2/20/2020,186.949997,Sell\r\n",
"2/21/2020,183.169998,Sell\r\n",
"2/24/2020,167.770004,Buy\r\n",
"2/25/2020,174.199997,Buy\r\n",
"2/26/2020,169.710007,Buy\r\n",
"2/27/2020,163.320007,Buy\r\n",
"2/28/2020,152.410004,Buy\r\n",
"3/2/2020,165.309998,Buy\r\n",
"3/3/2020,173.800003,Buy\r\n",
"3/4/2020,168.490005,Buy\r\n",
"3/5/2020,166.050003,Buy\r\n",
"3/6/2020,162.610001,Buy\r\n",
"3/9/2020,151.000000,Buy\r\n",
"3/10/2020,158.160004,Buy\r\n",
"3/11/2020,157.130005,Buy\r\n",
"3/12/2020,145.300003,Buy\r\n",
"3/13/2020,147.500000,Buy\r\n",
"3/16/2020,140.000000,Buy\r\n",
"3/17/2020,140.000000,Buy\r\n",
"3/18/2020,138.000000,Buy\r\n",
"3/19/2020,142.770004,Buy\r\n",
"3/20/2020,146.000000,Buy\r\n",
"3/23/2020,137.009995,Buy\r\n",
"3/24/2020,143.750000,Buy\r\n",
"3/25/2020,148.910004,Buy\r\n",
"3/26/2020,148.399994,Buy\r\n",
"3/27/2020,151.750000,Sell\r\n",
"3/30/2020,152.440002,Sell\r\n",
"3/31/2020,159.399994,Sell\r\n",
"4/1/2020,153.000000,Sell\r\n",
"4/2/2020,151.860001,Sell\r\n",
"4/3/2020,155.100006,Sell\r\n",
"4/6/2020,160.320007,Sell\r\n",
"4/7/2020,169.589996,Sell\r\n",
"4/8/2020,165.669998,Sell\r\n",
"4/9/2020,166.360001,Sell\r\n",
"4/13/2020,164.350006,Sell\r\n",
"4/14/2020,169.000000,Sell\r\n",
"4/15/2020,171.199997,Sell\r\n",
"4/16/2020,174.300003,Sell\r\n",
"4/17/2020,179.500000,Sell\r\n",
"4/20/2020,176.630005,Sell\r\n",
"4/21/2020,173.500000,Sell\r\n",
"4/22/2020,171.389999,Sell\r\n",
"4/23/2020,174.110001,Sell\r\n",
"4/24/2020,172.059998,Sell\r\n",
"4/27/2020,176.589996,Sell\r\n",
"4/28/2020,175.589996,Sell\r\n",
"4/29/2020,173.220001,Sell\r\n",
"4/30/2020,180.000000,Sell\r\n",
"5/1/2020,175.800003,Sell\r\n",
"5/4/2020,174.490005,Sell\r\n",
"5/5/2020,180.619995,Sell\r\n",
"5/6/2020,182.080002,Sell\r\n",
"5/7/2020,184.169998,Sell\r\n",
"5/8/2020,184.979996,Sell\r\n",
"5/11/2020,183.149994,Sell\r\n",
"5/12/2020,186.800003,Sell\r\n",
"5/13/2020,182.550003,Sell\r\n",
"5/14/2020,177.539993,Buy\r\n",
"5/15/2020,179.059998,Sell\r\n",
"5/18/2020,185.750000,Sell\r\n",
"5/19/2020,185.029999,Sell\r\n",
"5/20/2020,184.809998,Sell\r\n",
"5/21/2020,185.399994,Sell\r\n",
"5/22/2020,183.190002,Sell\r\n",
"5/26/2020,186.339996,Sell\r\n",
"5/27/2020,180.199997,Buy\r\n",
"5/28/2020,180.740005,Buy\r\n",
"5/29/2020,182.729996,Sell\r\n",
"6/1/2020,182.539993,Buy\r\n",
"6/2/2020,184.250000,Sell\r\n",
"6/3/2020,184.820007,Sell\r\n",
"6/4/2020,184.300003,Sell\r\n",
"6/5/2020,182.619995,Buy\r\n",
"6/8/2020,185.940002,Sell\r\n",
"6/9/2020,188.000000,Sell\r\n",
"6/10/2020,191.130005,Sell\r\n",
"6/11/2020,193.130005,Sell\r\n",
"6/12/2020,190.539993,Sell\r\n",
"6/15/2020,184.580002,Buy\r\n",
"6/16/2020,192.889999,Sell\r\n",
"6/17/2020,195.029999,Sell\r\n",
"6/18/2020,194.000000,Sell\r\n",
"6/19/2020,198.589996,Sell\r\n",
"6/22/2020,195.789993,Sell\r\n",
"6/23/2020,202.089996,Sell\r\n",
"6/24/2020,201.600006,Sell\r\n",
"6/25/2020,197.800003,Sell\r\n",
"6/26/2020,199.729996,Sell\r\n",
"6/29/2020,195.779999,Sell\r\n",
"6/30/2020,197.880005,Sell\r\n",
"7/1/2020,203.139999,Sell\r\n",
"7/2/2020,205.679993,Sell\r\n",
"7/6/2020,208.830002,Sell\r\n",
"7/7/2020,210.449997,Sell\r\n",
"7/8/2020,210.070007,Sell\r\n",
"7/9/2020,216.330002,Sell\r\n",
"7/10/2020,213.619995,Sell\r\n",
"7/13/2020,214.479996,Sell\r\n",
"7/14/2020,206.130005,Sell\r\n",
"7/15/2020,209.559998,Sell\r\n",
"7/16/2020,205.399994,Sell\r\n",
"7/17/2020,204.470001,Buy\r\n",
"7/20/2020,205.000000,Buy\r\n",
"7/21/2020,213.660004,Sell\r\n",
"7/22/2020,209.199997,Sell\r\n",
"7/23/2020,207.190002,Sell\r\n",
"7/24/2020,200.419998,Buy\r\n",
"7/27/2020,201.470001,Buy\r\n",
"7/28/2020,203.610001,Buy\r\n",
"7/29/2020,202.500000,Buy\r\n",
"7/30/2020,201.000000,Buy\r\n",
"7/31/2020,204.399994,Buy\r\n",
"8/3/2020,211.520004,Sell\r\n",
"8/4/2020,214.169998,Sell\r\n",
"8/5/2020,214.899994,Sell\r\n",
"8/6/2020,212.339996,Sell\r\n",
"8/7/2020,214.850006,Sell\r\n",
"8/10/2020,211.669998,Sell\r\n",
"8/11/2020,207.160004,Buy\r\n",
"8/12/2020,205.289993,Buy\r\n",
"8/13/2020,209.440002,Sell\r\n",
"8/14/2020,208.759995,Sell\r\n",
"8/17/2020,209.600006,Sell\r\n",
"8/18/2020,210.529999,Sell\r\n",
"8/19/2020,211.490005,Sell\r\n",
"8/20/2020,209.539993,Sell\r\n",
"8/21/2020,213.860001,Sell\r\n",
"8/24/2020,214.789993,Sell\r\n",
"8/25/2020,213.100006,Sell\r\n",
"8/26/2020,217.880005,Sell\r\n",
"8/27/2020,222.889999,Sell\r\n",
"8/28/2020,228.179993,Sell\r\n",
"8/31/2020,227.000000,Sell\r\n",
"9/1/2020,225.509995,Sell\r\n",
"9/2/2020,227.970001,Sell\r\n",
"9/3/2020,229.270004,Sell\r\n",
"9/4/2020,215.100006,Buy\r\n",
"9/8/2020,206.500000,Buy\r\n",
"9/9/2020,207.600006,Buy\r\n",
"9/10/2020,213.399994,Buy\r\n",
"9/11/2020,207.199997,Buy\r\n",
"9/14/2020,204.240005,Buy\r\n",
"9/15/2020,208.419998,Buy\r\n",
"9/16/2020,210.619995,Buy\r\n",
"9/17/2020,200.050003,Buy\r\n",
"9/18/2020,202.800003,Buy\r\n",
"9/21/2020,197.190002,Buy\r\n",
"9/22/2020,205.059998,Buy\r\n",
"9/23/2020,207.899994,Buy\r\n",
"9/24/2020,199.850006,Buy\r\n",
"9/25/2020,203.550003,Buy\r\n",
"9/28/2020,210.880005,Sell\r\n",
"9/29/2020,209.350006,Buy\r\n",
"9/30/2020,207.729996,Buy\r\n",
"10/1/2020,213.490005,Sell\r\n",
"10/2/2020,208.000000,Sell\r\n",
"10/5/2020,207.220001,Sell\r\n",
"10/6/2020,208.820007,Sell\r\n",
"10/7/2020,207.059998,Sell\r\n",
"10/8/2020,210.509995,Sell\r\n",
"10/9/2020,211.229996,Sell\r\n",
"10/12/2020,218.789993,Sell\r\n",
"10/13/2020,222.720001,Sell\r\n",
"10/14/2020,223.000000,Sell\r\n",
"10/15/2020,217.100006,Sell\r\n",
"10/16/2020,220.149994,Sell\r\n",
"10/19/2020,220.419998,Sell\r\n",
"10/20/2020,215.800003,Sell\r\n",
"10/21/2020,213.119995,Sell\r\n",
"10/22/2020,213.929993,Sell\r\n",
"10/23/2020,215.029999,Sell\r\n",
"10/26/2020,213.850006,Buy\r\n",
"10/27/2020,211.589996,Buy\r\n",
"10/28/2020,207.669998,Buy\r\n",
"10/29/2020,204.070007,Buy\r\n",
"10/30/2020,203.500000,Buy\r\n",
"11/2/2020,204.289993,Buy\r\n",
"11/3/2020,203.889999,Buy\r\n",
"11/4/2020,214.020004,Sell\r\n",
"11/5/2020,222.039993,Sell\r\n",
"11/6/2020,222.259995,Sell\r\n",
"11/9/2020,224.440002,Sell\r\n",
"11/10/2020,214.500000,Sell\r\n",
"11/11/2020,212.389999,Buy\r\n",
"11/12/2020,217.210007,Sell\r\n",
"11/13/2020,216.360001,Sell\r\n",
"11/16/2020,214.869995,Sell\r\n",
"11/17/2020,216.100006,Sell\r\n",
"11/18/2020,213.649994,Sell\r\n",
"11/19/2020,211.380005,Buy\r\n",
"11/20/2020,212.199997,Buy\r\n",
"11/23/2020,210.949997,Buy\r\n",
"11/24/2020,209.589996,Buy\r\n",
"11/25/2020,215.110001,Sell\r\n",
"11/27/2020,214.850006,Sell\r\n",
"11/30/2020,214.100006,Buy\r\n",
"12/1/2020,214.509995,Buy\r\n",
"12/2/2020,214.880005,Buy\r\n",
"12/3/2020,214.610001,Buy\r\n",
"12/4/2020,214.220001,Buy\r\n",
"12/7/2020,214.369995,Buy\r\n",
"12/8/2020,213.970001,Buy\r\n",
"12/9/2020,215.160004,Sell\r\n",
"12/10/2020,211.770004,Buy\r\n",
"12/11/2020,210.050003,Buy\r\n",
"12/14/2020,213.100006,Buy\r\n",
"12/15/2020,215.169998,Sell\r\n",
"12/16/2020,214.750000,Sell\r\n",
"12/17/2020,219.869995,Sell\r\n",
"12/18/2020,218.589996,Sell\r\n",
"12/21/2020,217.550003,Sell\r\n",
"12/22/2020,222.690002,Sell\r\n",
"12/23/2020,223.110001,Sell\r\n",
"12/24/2020,221.419998,Sell\r\n",
"12/28/2020,224.449997,Sell\r\n",
"12/29/2020,226.309998,Sell\r\n",
"12/30/2020,225.229996,Sell\r\n",
"12/31/2020,221.699997,Sell\r\n",
"1/4/2021,222.529999,Sell\r\n",
"1/5/2021,217.259995,Buy\r\n",
"1/6/2021,212.169998,Buy\r\n",
"1/7/2021,214.039993,Buy\r\n",
"1/8/2021,218.679993,Sell\r\n",
"1/11/2021,218.470001,Buy\r\n",
"1/12/2021,216.500000,Buy\r\n",
"1/13/2021,214.020004,Buy\r\n",
"1/14/2021,215.910004,Buy\r\n",
"1/15/2021,213.520004,Buy\r\n",
"1/19/2021,213.750000,Buy\r\n",
"1/20/2021,217.699997,Buy\r\n",
"1/21/2021,224.699997,Sell\r\n",
"1/22/2021,227.080002,Sell\r\n",
"1/25/2021,229.119995,Sell\r\n",
"1/26/2021,231.860001,Sell\r\n",
"1/27/2021,238.000000,Sell\r\n",
"1/28/2021,235.610001,Sell\r\n",
"1/29/2021,235.990005,Sell\r\n",
"2/1/2021,235.059998,Sell\r\n",
"2/2/2021,241.300003,Sell\r\n",
"2/3/2021,239.570007,Sell\r\n",
"2/4/2021,242.660004,Sell\r\n",
"2/5/2021,242.229996,Sell\r\n",
"2/8/2021,243.149994,Sell\r\n",
"2/9/2021,241.869995,Sell\r\n",
"2/10/2021,245.000000,Sell\r\n",
"2/11/2021,244.779999,Sell\r\n",
"2/12/2021,243.929993,Sell\r\n",
"2/16/2021,245.029999,Sell\r\n",
"2/17/2021,241.320007,Sell\r\n",
"2/18/2021,241.800003,Sell\r\n",
"2/19/2021,243.750000,Sell\r\n",
"2/22/2021,237.419998,Buy\r\n",
"2/23/2021,230.330002,Buy\r\n",
"2/24/2021,230.009995,Buy\r\n",
"2/25/2021,232.080002,Buy\r\n",
"2/26/2021,231.529999,Buy\r\n",
"3/1/2021,235.899994,Buy\r\n",
"3/2/2021,237.009995,Buy\r\n",
"3/3/2021,232.160004,Buy\r\n",
"3/4/2021,226.740005,Buy\r\n",
"3/5/2021,229.520004,Buy\r\n",
"3/8/2021,231.369995,Buy\r\n",
"3/9/2021,232.880005,Buy\r\n",
"3/10/2021,237.000000,Sell\r\n",
"3/11/2021,234.960007,Buy\r\n",
"3/12/2021,234.009995,Buy\r\n",
"3/15/2021,234.960007,Buy\r\n",
"3/16/2021,236.279999,Sell\r\n",
"3/17/2021,236.149994,Sell\r\n",
"3/18/2021,232.559998,Buy\r\n",
"3/19/2021,231.020004,Buy\r\n",
"3/22/2021,230.270004,Buy\r\n",
"3/23/2021,237.490005,Sell\r\n",
"3/24/2021,237.850006,Sell\r\n",
"3/25/2021,235.300003,Sell\r\n",
"3/26/2021,231.550003,Buy\r\n",
"3/29/2021,236.589996,Sell\r\n",
"3/30/2021,233.529999,Buy\r\n",
"3/31/2021,232.910004,Buy\r\n",
"4/1/2021,238.470001,Sell\r\n",
"4/5/2021,242.759995,Sell\r\n",
"4/6/2021,247.610001,Sell\r\n",
"4/7/2021,247.809998,Sell\r\n",
"4/8/2021,252.770004,Sell\r\n",
"4/9/2021,252.869995,Sell\r\n",
"4/12/2021,254.710007,Sell\r\n",
"4/13/2021,257.260010,Sell\r\n",
"4/14/2021,257.480011,Sell\r\n",
"4/15/2021,257.929993,Sell\r\n",
"4/16/2021,259.470001,Sell\r\n",
"4/19/2021,260.190002,Sell\r\n",
"4/20/2021,257.820007,Sell\r\n",
"4/21/2021,258.940002,Sell\r\n",
"4/22/2021,260.209991,Sell\r\n",
"4/23/2021,257.880005,Sell\r\n",
"4/26/2021,261.660004,Sell\r\n",
"4/27/2021,261.579987,Sell\r\n",
"4/28/2021,256.079987,Sell\r\n",
"4/29/2021,255.460007,Sell\r\n",
"4/30/2021,249.740005,Buy\r\n",
"5/3/2021,253.399994,Buy\r\n",
"5/4/2021,250.970001,Buy\r\n",
"5/5/2021,249.059998,Buy\r\n",
"5/6/2021,246.449997,Buy\r\n",
"5/7/2021,252.149994,Buy\r\n",
"5/10/2021,250.869995,Buy\r\n",
"5/11/2021,244.550003,Buy\r\n",
"5/12/2021,242.169998,Buy\r\n",
"5/13/2021,241.800003,Buy\r\n",
"5/14/2021,245.580002,Buy\r\n",
"5/17/2021,246.550003,Buy\r\n",
"5/18/2021,246.270004,Buy\r\n",
"5/19/2021,239.309998,Buy\r\n",
"5/20/2021,243.960007,Buy\r\n",
"5/21/2021,247.570007,Buy\r\n",
"5/24/2021,247.789993,Buy\r\n",
"5/25/2021,251.770004,Sell\r\n",
"5/26/2021,251.429993,Sell\r\n",
"5/27/2021,251.169998,Sell\r\n",
"5/28/2021,251.000000,Sell\r\n",
"6/1/2021,251.229996,Sell\r\n",
"6/2/2021,248.130005,Sell\r\n",
"6/3/2021,245.220001,Buy\r\n",
"6/4/2021,247.759995,Sell\r\n",
"6/7/2021,249.979996,Sell\r\n",
"6/8/2021,255.160004,Sell\r\n",
"6/9/2021,253.809998,Sell\r\n",
"6/10/2021,254.289993,Sell\r\n",
"6/11/2021,257.989990,Sell\r\n",
"6/14/2021,257.899994,Sell\r\n",
"6/15/2021,259.769989,Sell\r\n",
"6/16/2021,259.399994,Sell\r\n",
"6/17/2021,256.070007,Sell\r\n",
"6/18/2021,259.630005,Sell\r\n",
"6/21/2021,259.820007,Sell\r\n",
"6/22/2021,262.720001,Sell\r\n",
"6/23/2021,265.989990,Sell\r\n",
"6/24/2021,266.160004,Sell\r\n",
"6/25/2021,266.230011,Sell\r\n",
"6/28/2021,266.190002,Sell\r\n",
"6/29/2021,268.869995,Sell\r\n",
"6/30/2021,270.690002,Sell\r\n",
"7/1/2021,269.609985,Sell\r\n",
"7/2/2021,272.820007,Sell\r\n",
"7/6/2021,278.029999,Sell\r\n",
"7/7/2021,279.399994,Sell\r\n",
"7/8/2021,276.899994,Sell\r\n",
"7/9/2021,275.720001,Sell\r\n",
"7/12/2021,279.160004,Sell\r\n",
"7/13/2021,277.519989,Sell\r\n",
"7/14/2021,282.350006,Sell\r\n",
"7/15/2021,282.000000,Sell\r\n",
"7/16/2021,282.070007,Sell\r\n",
"7/19/2021,278.929993,Sell\r\n",
"7/20/2021,278.029999,Sell\r\n",
"7/21/2021,278.899994,Sell\r\n",
"7/22/2021,283.839996,Sell\r\n",
"7/23/2021,287.369995,Sell\r\n",
"7/26/2021,289.000000,Sell\r\n",
"7/27/2021,289.429993,Sell\r\n",
"7/28/2021,288.989990,Sell\r\n",
"7/29/2021,286.239990,Sell\r\n",
"7/30/2021,285.170013,Sell\r\n",
"8/2/2021,286.359985,Sell\r\n",
"8/3/2021,285.420013,Sell\r\n",
"8/4/2021,286.220001,Sell\r\n",
"8/5/2021,286.880005,Sell\r\n",
"8/6/2021,288.510010,Sell\r\n",
"8/9/2021,289.750000,Sell\r\n",
"8/10/2021,288.799988,Sell\r\n",
"8/11/2021,287.209991,Sell\r\n",
"8/12/2021,286.630005,Sell\r\n",
"8/13/2021,289.480011,Sell\r\n",
"8/16/2021,293.190002,Sell\r\n",
"8/17/2021,292.390015,Sell\r\n",
"8/18/2021,292.040009,Sell\r\n",
"8/19/2021,288.690002,Sell\r\n",
"8/20/2021,299.720001,Sell\r\n",
"8/23/2021,303.250000,Sell\r\n",
"8/24/2021,305.019989,Sell\r\n",
"8/25/2021,304.299988,Sell\r\n",
"8/26/2021,300.989990,Sell\r\n",
"8/27/2021,298.989990,Sell\r\n",
"8/30/2021,301.119995,Sell\r\n",
"8/31/2021,304.420013,Sell\r\n",
"9/1/2021,302.869995,Sell\r\n",
"9/2/2021,302.200012,Sell\r\n",
"9/3/2021,300.989990,Sell\r\n",
"9/7/2021,301.010010,Sell\r\n",
"9/8/2021,299.779999,Sell\r\n",
"9/9/2021,300.820007,Sell\r\n",
"9/10/2021,298.420013,Buy\r\n",
"9/13/2021,297.549988,Buy\r\n",
"9/14/2021,299.559998,Buy\r\n",
"9/15/2021,303.260010,Sell\r\n",
"9/16/2021,303.760010,Sell\r\n",
"9/17/2021,304.170013,Sell\r\n",
"9/20/2021,296.329987,Buy\r\n",
"9/21/2021,295.690002,Buy\r\n",
"9/22/2021,296.730011,Buy\r\n",
"9/23/2021,298.850006,Buy\r\n",
"9/24/2021,298.230011,Buy\r\n",
"9/27/2021,296.140015,Buy\r\n",
"9/28/2021,289.799988,Buy\r\n",
"9/29/2021,285.100006,Buy\r\n",
"9/30/2021,285.709991,Buy\r\n",
"10/1/2021,282.119995,Buy\r\n",
"10/4/2021,287.399994,Buy\r\n",
"10/5/2021,284.049988,Buy\r\n",
"10/6/2021,285.779999,Buy\r\n",
"10/7/2021,295.179993,Sell\r\n",
"10/8/2021,296.220001,Sell\r\n",
"10/11/2021,292.920013,Buy\r\n",
"10/12/2021,295.339996,Sell\r\n",
"10/13/2021,294.910004,Sell\r\n",
"10/14/2021,299.209991,Sell\r\n",
"10/15/2021,302.339996,Sell\r\n",
"10/18/2021,303.570007,Sell\r\n",
"10/19/2021,308.350006,Sell\r\n",
"10/20/2021,309.209991,Sell\r\n",
"10/21/2021,307.170013,Sell\r\n",
"10/22/2021,310.399994,Sell\r\n",
"10/25/2021,309.359985,Sell\r\n",
"10/26/2021,311.000000,Sell\r\n",
"10/27/2021,316.000000,Sell\r\n",
"10/28/2021,324.329987,Sell\r\n",
"10/29/2021,324.130005,Sell\r\n",
"11/1/2021,331.359985,Sell\r\n",
"11/2/2021,330.309998,Sell\r\n",
"11/3/2021,333.899994,Sell\r\n",
"11/4/2021,332.890015,Sell\r\n",
"11/5/2021,338.510010,Sell\r\n",
"11/8/2021,337.299988,Sell\r\n",
"11/9/2021,337.109985,Sell\r\n",
"11/10/2021,334.570007,Sell\r\n",
"11/11/2021,331.250000,Sell\r\n",
"11/12/2021,333.920013,Sell\r\n",
"11/15/2021,337.540009,Sell\r\n",
"11/16/2021,335.679993,Sell\r\n",
"11/17/2021,338.940002,Sell\r\n",
"11/18/2021,338.179993,Sell\r\n",
"11/19/2021,342.640015,Sell\r\n",
"11/22/2021,344.619995,Sell\r\n",
"11/23/2021,337.049988,Sell\r\n",
"11/24/2021,336.279999,Sell\r\n",
"11/26/2021,334.350006,Buy\r\n",
"11/29/2021,334.940002,Buy\r\n",
"11/30/2021,335.320007,Buy\r\n",
"12/1/2021,335.130005,Buy\r\n",
"12/2/2021,330.299988,Buy\r\n",
"12/3/2021,331.989990,Buy\r\n",
"12/6/2021,323.950012,Buy\r\n",
"12/7/2021,331.640015,Buy\r\n",
"12/8/2021,335.309998,Sell\r\n",
"12/9/2021,334.410004,Buy\r\n",
"12/10/2021,334.980011,Buy\r\n",
"12/13/2021,340.679993,Sell\r\n",
"12/14/2021,333.220001,Buy\r\n",
"12/15/2021,328.609985,Buy\r\n",
"12/16/2021,335.709991,Sell\r\n",
"12/17/2021,320.880005,Buy\r\n",
"12/20/2021,320.049988,Buy\r\n",
"12/21/2021,323.290009,Buy\r\n",
"12/22/2021,328.299988,Buy\r\n",
"12/23/2021,332.750000,Sell\r\n",
"12/27/2021,335.459991,Sell\r\n",
"12/28/2021,343.149994,Sell\r\n",
"12/29/2021,341.299988,Sell\r\n",
"12/30/2021,341.910004,Sell\r\n",
"12/31/2021,338.510010,Sell\r\n",
"1/3/2022,335.350006,Sell\r\n",
"1/4/2022,334.829987,Sell\r\n",
"1/5/2022,325.859985,Buy\r\n",
"1/6/2022,313.149994,Buy\r\n",
"1/7/2022,314.149994,Buy\r\n",
"1/10/2022,309.489990,Buy\r\n",
"1/11/2022,313.380005,Buy\r\n",
"1/12/2022,319.670013,Buy\r\n",
"1/13/2022,320.470001,Buy\r\n",
"1/14/2022,304.250000,Buy\r\n",
"1/18/2022,304.070007,Buy\r\n",
"1/19/2022,306.290009,Buy\r\n",
"1/20/2022,309.070007,Buy\r\n",
"1/21/2022,302.690002,Buy\r\n",
"1/24/2022,292.200012,Buy\r\n",
"1/25/2022,291.519989,Buy\r\n",
"1/26/2022,307.989990,Buy\r\n",
"1/27/2022,302.660004,Buy\r\n",
"1/28/2022,300.230011,Buy\r\n",
"1/31/2022,308.950012,Buy\r\n",
"2/1/2022,310.410004,Sell\r\n",
"2/2/2022,309.630005,Sell\r\n",
"2/3/2022,309.489990,Sell\r\n",
"2/4/2022,300.209991,Buy\r\n",
"2/7/2022,306.170013,Buy\r\n",
"2/8/2022,301.250000,Buy\r\n",
"2/9/2022,309.869995,Sell\r\n",
"2/10/2022,304.040009,Buy\r\n",
"2/11/2022,303.190002,Buy\r\n",
"2/14/2022,293.769989,Buy\r\n",
"2/15/2022,300.010010,Buy\r\n",
"2/16/2022,298.369995,Buy\r\n",
"2/17/2022,296.359985,Buy\r\n",
"2/18/2022,293.049988,Buy\r\n",
"2/22/2022,285.000000,Buy\r\n",
"2/23/2022,290.179993,Buy\r\n",
"2/24/2022,272.510010,Buy\r\n",
"2/25/2022,295.140015,Buy\r\n",
"2/28/2022,294.309998,Buy\r\n",
"3/1/2022,296.399994,Buy\r\n",
"3/2/2022,295.359985,Buy\r\n",
"3/3/2022,302.890015,Sell\r\n",
"3/4/2022,294.290009,Buy\r\n",
"3/7/2022,288.529999,Buy\r\n",
"3/8/2022,277.799988,Buy\r\n",
"3/9/2022,283.440002,Buy\r\n",
"3/10/2022,283.019989,Buy\r\n",
"3/11/2022,287.959991,Buy\r\n",
"3/14/2022,280.339996,Buy\r\n",
"3/15/2022,280.350006,Buy\r\n",
"3/16/2022,289.109985,Buy\r\n",
"3/17/2022,293.290009,Sell\r\n",
"3/18/2022,295.369995,Sell\r\n",
"3/21/2022,298.890015,Sell\r\n",
"3/22/2022,299.799988,Sell\r\n",
"3/23/2022,300.510010,Sell\r\n",
"3/24/2022,299.140015,Sell\r\n",
"3/25/2022,305.230011,Sell\r\n",
"3/28/2022,304.329987,Sell\r\n",
"3/29/2022,313.910004,Sell\r\n",
"3/30/2022,313.760010,Sell\r\n",
"3/31/2022,313.899994,Sell\r\n",
"4/1/2022,309.369995,Sell\r\n",
"4/4/2022,310.089996,Sell\r\n",
"4/5/2022,313.269989,Sell\r\n",
"4/6/2022,305.190002,Sell\r\n",
"4/7/2022,296.660004,Buy\r\n",
"4/8/2022,300.440002,Buy\r\n",
"4/11/2022,291.790009,Buy\r\n",
"4/12/2022,289.239990,Buy\r\n",
"4/13/2022,282.730011,Buy\r\n",
"4/14/2022,288.089996,Buy\r\n",
"4/18/2022,278.910004,Buy\r\n",
"4/19/2022,279.380005,Buy\r\n",
"4/20/2022,289.399994,Buy\r\n",
"4/21/2022,288.579987,Buy\r\n",
"4/22/2022,281.679993,Buy\r\n",
"4/25/2022,273.290009,Buy\r\n",
"4/26/2022,277.500000,Buy\r\n",
"4/27/2022,282.100006,Buy\r\n",
"4/28/2022,285.190002,Buy\r\n",
"4/29/2022,288.609985,Buy\r\n",
"5/2/2022,277.709991,Buy\r\n",
"5/3/2022,283.959991,Buy\r\n",
"5/4/2022,282.589996,Buy\r\n",
"5/5/2022,285.540009,Sell\r\n",
"5/6/2022,274.809998,Buy\r\n",
"5/9/2022,270.059998,Buy\r\n",
"5/10/2022,271.690002,Buy\r\n",
"5/11/2022,265.679993,Buy\r\n",
"5/12/2022,257.690002,Buy\r\n",
"5/13/2022,257.350006,Buy\r\n",
"5/16/2022,259.959991,Buy\r\n",
"5/17/2022,266.109985,Buy\r\n",
"5/18/2022,263.000000,Buy\r\n",
"5/19/2022,253.899994,Buy\r\n",
"5/20/2022,257.239990,Buy\r\n",
"5/23/2022,255.490005,Buy\r\n",
"5/24/2022,257.890015,Buy\r\n",
"5/25/2022,258.140015,Buy\r\n",
"5/26/2022,262.269989,Buy\r\n",
"5/27/2022,268.480011,Sell\r\n",
"5/31/2022,272.529999,Sell\r\n",
"6/1/2022,275.200012,Sell\r\n",
"6/2/2022,264.450012,Buy\r\n",
"6/3/2022,270.309998,Sell\r\n",
"6/6/2022,272.059998,Sell\r\n",
"6/7/2022,266.640015,Sell\r\n",
"6/8/2022,271.709991,Sell\r\n",
"6/9/2022,267.779999,Sell\r\n",
"6/10/2022,260.579987,Buy\r\n",
"6/13/2022,245.110001,Buy\r\n",
"6/14/2022,243.860001,Buy\r\n",
"6/15/2022,248.309998,Buy\r\n",
"6/16/2022,245.979996,Buy\r\n",
"6/17/2022,244.699997,Buy\r\n",
"6/21/2022,250.259995,Buy\r\n",
"6/22/2022,251.889999,Buy\r\n",
"6/23/2022,255.570007,Buy\r\n",
"6/24/2022,261.809998,Sell\r\n",
"6/27/2022,268.209991,Sell\r\n",
"6/28/2022,263.980011,Sell\r\n",
"6/29/2022,257.589996,Buy\r\n",
"6/30/2022,257.049988,Buy\r\n",
"7/1/2022,256.390015,Buy\r\n",
"7/5/2022,256.160004,Buy\r\n",
"7/6/2022,263.750000,Sell\r\n",
"7/7/2022,265.119995,Sell\r\n",
"7/8/2022,264.790009,Sell\r\n",
"7/11/2022,265.649994,Sell\r\n",
"7/12/2022,265.880005,Sell\r\n",
"7/13/2022,250.190002,Buy\r\n",
"7/14/2022,250.570007,Buy\r\n",
"7/15/2022,255.720001,Buy\r\n",
"7/18/2022,259.750000,Sell\r\n",
"7/19/2022,257.579987,Buy\r\n",
"7/20/2022,259.899994,Sell\r\n",
"7/21/2022,259.790009,Sell\r\n",
"7/22/2022,265.239990,Sell\r\n",
"7/25/2022,261.000000,Sell\r\n",
"7/26/2022,259.859985,Sell\r\n",
"7/27/2022,261.160004,Sell\r\n",
"7/28/2022,269.750000,Sell\r\n",
"7/29/2022,277.700012,Sell\r\n",
"8/1/2022,277.820007,Sell\r\n",
"8/2/2022,276.000000,Sell\r\n",
"8/3/2022,276.760010,Sell\r\n",
"8/4/2022,281.799988,Sell\r\n",
"8/5/2022,279.149994,Sell\r\n",
"8/8/2022,284.049988,Sell\r\n",
"8/9/2022,279.640015,Sell\r\n",
"8/10/2022,288.170013,Sell\r\n",
"8/11/2022,290.850006,Sell\r\n",
"8/12/2022,288.480011,Sell\r\n",
"8/15/2022,291.000000,Sell\r\n",
"8/16/2022,291.989990,Sell\r\n",
"8/17/2022,289.739990,Sell\r\n",
"8/18/2022,290.190002,Sell\r\n",
"8/19/2022,288.899994,Sell\r\n",
"8/22/2022,282.079987,Sell\r\n",
"8/23/2022,276.440002,Buy\r\n",
"8/24/2022,275.410004,Buy\r\n",
"8/25/2022,277.329987,Buy\r\n",
"8/26/2022,279.079987,Buy\r\n",
"8/29/2022,265.850006,Buy\r\n",
"8/30/2022,266.670013,Buy\r\n",
"8/31/2022,265.390015,Buy\r\n",
"9/1/2022,258.869995,Buy\r\n",
"9/2/2022,261.700012,Buy\r\n",
"9/6/2022,256.200012,Buy\r\n",
"9/7/2022,254.699997,Buy\r\n",
"9/8/2022,257.510010,Buy\r\n",
"9/9/2022,260.500000,Buy\r\n",
"9/12/2022,265.779999,Buy\r\n",
"9/13/2022,258.839996,Buy\r\n",
"9/14/2022,253.529999,Buy\r\n",
"9/15/2022,249.770004,Buy\r\n",
"9/16/2022,244.259995,Buy\r\n",
"9/19/2022,242.470001,Buy\r\n",
"9/20/2022,242.070007,Buy\r\n",
"9/21/2022,244.270004,Buy\r\n",
"9/22/2022,237.869995,Buy\r\n",
"9/23/2022,239.539993,Buy\r\n",
"9/26/2022,237.050003,Buy\r\n",
"9/27/2022,239.979996,Buy\r\n",
"9/28/2022,236.809998,Buy\r\n",
"9/29/2022,238.889999,Buy\r\n",
"9/30/2022,238.289993,Buy\r\n",
"10/3/2022,235.410004,Buy\r\n",
"10/4/2022,245.089996,Buy\r\n",
"10/5/2022,245.990005,Sell\r\n",
"10/6/2022,247.929993,Sell\r\n",
"10/7/2022,240.899994,Buy\r\n",
"10/10/2022,233.050003,Buy\r\n",
"10/11/2022,227.619995,Buy\r\n",
"10/12/2022,225.399994,Buy\r\n",
"10/13/2022,219.850006,Buy\r\n",
"10/14/2022,235.539993,Buy\r\n",
"10/17/2022,235.820007,Buy\r\n",
"10/18/2022,243.240005,Sell\r\n",
"10/19/2022,237.039993,Buy\r\n",
"10/20/2022,235.770004,Buy\r\n",
"10/21/2022,234.740005,Buy\r\n",
"10/24/2022,243.759995,Sell\r\n",
"10/25/2022,247.259995,Sell\r\n",
"10/26/2022,231.169998,Buy\r\n",
"10/27/2022,231.039993,Buy\r\n",
"10/28/2022,226.240005,Buy\r\n",
"10/31/2022,233.759995,Buy\r\n",
"11/1/2022,234.600006,Buy\r\n",
"11/2/2022,229.460007,Buy\r\n",
"11/3/2022,220.089996,Buy\r\n",
"11/4/2022,217.550003,Buy\r\n",
"11/7/2022,221.990005,Buy\r\n",
"11/8/2022,228.699997,Buy\r\n",
"11/9/2022,227.369995,Buy\r\n",
"11/10/2022,235.429993,Sell\r\n",
"11/11/2022,242.990005,Sell\r\n",
"11/14/2022,241.990005,Sell\r\n",
"11/15/2022,245.660004,Sell\r\n",
"11/16/2022,242.789993,Sell\r\n",
"11/17/2022,237.779999,Sell\r\n",
"11/18/2022,243.509995,Sell\r\n",
"11/21/2022,241.429993,Sell\r\n",
"11/22/2022,243.589996,Sell\r\n",
"11/23/2022,245.110001,Sell\r\n",
"11/25/2022,247.309998,Sell\r\n",
"11/28/2022,246.080002,Sell\r\n",
"11/29/2022,241.399994,Sell\r\n",
"11/30/2022,240.570007,Sell\r\n",
"12/1/2022,253.869995,Sell\r\n",
"12/2/2022,249.820007,Sell\r\n",
"12/5/2022,252.009995,Sell\r\n",
"12/6/2022,250.820007,Sell\r\n",
"12/7/2022,244.830002,Sell\r\n",
"12/8/2022,244.839996,Sell\r\n",
"12/9/2022,244.699997,Buy\r\n",
"12/12/2022,247.449997,Sell\r\n",
"12/13/2022,261.690002,Sell\r\n",
"12/14/2022,257.130005,Sell\r\n",
"12/15/2022,253.720001,Sell\r\n",
"12/16/2022,248.550003,Sell\r\n",
"12/19/2022,244.860001,Buy\r\n",
"12/20/2022,239.399994,Buy\r\n",
"12/21/2022,241.690002,Buy\r\n",
"12/22/2022,241.259995,Buy\r\n",
"12/23/2022,236.110001,Buy\r\n",
"12/27/2022,238.699997,Buy\r\n",
"12/28/2022,236.889999,Buy\r\n",
"12/29/2022,235.649994,Buy\r\n",
"12/30/2022,238.210007,Buy\r\n",
"1/3/2023,243.080002,Buy\r\n",
"1/4/2023,232.279999,Buy\r\n",
"1/5/2023,227.199997,Buy\r\n",
"1/6/2023,223.000000,Buy\r\n",
"1/9/2023,226.449997,Buy\r\n",
"1/10/2023,227.759995,Buy\r\n",
"1/11/2023,231.289993,Buy\r\n",
"1/12/2023,235.259995,Buy\r\n",
"1/13/2023,237.000000,Sell\r\n",
"1/17/2023,237.970001,Sell\r\n",
"1/18/2023,241.570007,Sell\r\n",
"1/19/2023,233.779999,Buy\r\n",
"1/20/2023,234.860001,Buy\r\n",
"1/23/2023,241.100006,Sell\r\n",
"1/24/2023,242.500000,Sell\r\n",
"1/25/2023,234.479996,Buy\r\n",
"1/26/2023,243.649994,Sell\r\n",
"1/27/2023,248.990005,Sell\r\n",
"1/30/2023,244.509995,Sell\r\n",
"1/31/2023,243.449997,Sell\r\n",
"2/1/2023,248.000000,Sell\r\n",
"2/2/2023,258.820007,Sell\r\n",
"2/3/2023,259.540009,Sell\r\n",
"2/6/2023,257.440002,Sell\r\n",
"2/7/2023,260.529999,Sell\r\n",
"2/8/2023,273.200012,Sell\r\n",
"2/9/2023,273.799988,Sell\r\n",
"2/10/2023,261.529999,Sell\r\n",
"2/13/2023,267.640015,Sell\r\n",
"2/14/2023,272.670013,Sell\r\n",
"2/15/2023,268.320007,Sell\r\n",
"2/16/2023,264.019989,Sell\r\n",
"2/17/2023,259.390015,Sell\r\n",
"2/21/2023,254.479996,Buy\r\n",
"2/22/2023,254.089996,Buy\r\n",
"2/23/2023,255.559998,Buy\r\n",
"2/24/2023,249.960007,Buy\r\n",
"2/27/2023,252.460007,Buy\r\n",
"2/28/2023,249.070007,Buy\r\n",
"3/1/2023,250.759995,Buy\r\n",
"3/2/2023,246.550003,Buy\r\n",
"3/3/2023,252.190002,Buy\r\n",
"3/6/2023,256.429993,Buy\r\n",
"3/7/2023,256.299988,Buy\r\n",
"3/8/2023,254.039993,Buy\r\n",
"3/9/2023,255.820007,Buy\r\n",
"3/10/2023,251.080002,Buy\r\n",
"3/13/2023,247.399994,Buy\r\n",
"3/14/2023,256.750000,Sell\r\n",
"3/15/2023,259.980011,Sell\r\n",
"3/16/2023,265.209991,Sell\r\n",
"3/17/2023,278.260010,Sell\r\n",
"3/20/2023,276.980011,Sell\r\n",
"3/21/2023,274.880005,Sell\r\n",
"3/22/2023,273.399994,Sell\r\n",
"3/23/2023,277.940002,Sell\r\n",
"3/24/2023,277.239990,Sell\r\n",
"3/27/2023,280.500000,Sell\r\n",
"3/28/2023,275.790009,Sell\r\n",
"3/29/2023,278.959991,Sell\r\n",
"3/30/2023,284.230011,Sell\r\n",
"3/31/2023,283.730011,Sell\r\n",
"4/3/2023,286.519989,Sell\r\n",
"4/4/2023,287.230011,Sell\r\n",
"4/5/2023,285.850006,Sell\r\n",
"4/6/2023,283.209991,Sell\r\n",
"4/10/2023,289.209991,Sell\r\n",
"4/11/2023,285.750000,Sell\r\n",
"4/12/2023,284.790009,Sell\r\n",
"4/13/2023,283.589996,Sell\r\n",
"4/14/2023,287.000000,Sell\r\n",
"4/17/2023,289.929993,Sell\r\n",
"4/18/2023,291.570007,Sell\r\n",
"4/19/2023,285.989990,Sell\r\n",
"4/20/2023,285.250000,Sell\r\n",
"4/21/2023,285.010010,Sell\r\n",
"4/24/2023,282.089996,Buy\r\n",
"4/25/2023,279.510010,Buy\r\n",
"4/26/2023,296.700012,Sell\r\n",
"4/27/2023,295.970001,Sell\r\n",
"4/28/2023,304.010010,Sell\r\n",
"5/1/2023,306.970001,Sell\r\n",
"5/2/2023,307.760010,Sell\r\n",
"5/3/2023,306.619995,Sell\r\n",
"5/4/2023,306.239990,Sell\r\n",
"5/5/2023,305.720001,Sell\r\n",
"5/8/2023,310.130005,Sell\r\n",
"5/9/2023,308.000000,Sell\r\n",
"5/10/2023,308.619995,Sell\r\n",
"5/11/2023,310.100006,Sell\r\n",
"5/12/2023,310.549988,Sell\r\n",
"5/15/2023,309.100006,Sell\r\n",
"5/16/2023,309.829987,Sell\r\n",
"5/17/2023,312.290009,Sell\r\n",
"5/18/2023,314.529999,Sell\r\n",
"5/19/2023,316.739990,Sell\r\n",
"5/22/2023,318.600006,Sell\r\n",
"5/23/2023,320.029999,Sell\r\n",
"5/24/2023,314.730011,Sell\r\n",
"5/25/2023,323.239990,Sell\r\n",
"5/26/2023,324.019989,Sell\r\n",
"5/30/2023,335.230011,Sell\r\n",
"5/31/2023,332.290009,Sell\r\n",
"6/1/2023,325.929993,Sell\r\n",
"6/2/2023,334.250000,Sell\r\n",
"6/5/2023,335.220001,Sell\r\n",
"6/6/2023,335.329987,Sell\r\n",
"6/7/2023,331.649994,Sell\r\n",
"6/8/2023,323.940002,Sell\r\n",
"6/9/2023,324.989990,Sell\r\n",
"6/12/2023,328.579987,Sell\r\n",
"6/13/2023,334.470001,Sell\r\n",
"6/14/2023,334.339996,Sell\r\n",
"6/15/2023,337.480011,Sell\r\n",
"6/16/2023,351.320007,Sell\r\n",
"6/20/2023,339.309998,Sell\r\n",
"6/21/2023,336.369995,Sell\r\n",
"6/22/2023,334.119995,Sell\r\n",
"6/23/2023,334.359985,Sell\r\n",
"6/26/2023,333.720001,Sell\r\n",
"6/27/2023,331.859985,Buy\r\n",
"6/28/2023,334.660004,Sell\r\n",
"6/29/2023,334.709991,Sell\r\n",
"6/30/2023,337.750000,Sell\r\n",
"7/3/2023,339.190002,Sell\r\n",
"7/5/2023,335.089996,Sell\r\n",
"7/6/2023,337.299988,Sell\r\n",
"7/7/2023,339.320007,Sell\r\n",
"7/10/2023,334.600006,Buy\r\n",
"7/11/2023,331.059998,Buy\r\n",
"7/12/2023,336.600006,Sell\r\n",
"7/13/2023,339.559998,Sell\r\n",
"7/14/2023,347.589996,Sell\r\n",
"7/17/2023,345.679993,Sell\r\n",
"7/18/2023,345.829987,Sell\r\n",
"7/19/2023,361.750000,Sell\r\n",
"7/20/2023,353.570007,Sell\r\n",
"7/21/2023,349.149994,Sell\r\n",
"7/24/2023,345.850006,Sell\r\n",
"7/25/2023,347.109985,Sell\r\n",
"7/26/2023,341.440002,Buy\r\n",
"7/27/2023,340.480011,Buy\r\n",
"7/28/2023,333.670013,Buy\r\n",
"7/31/2023,336.920013,Buy\r\n",
"8/1/2023,335.190002,Buy\r\n",
"8/2/2023,333.630005,Buy\r\n",
"8/3/2023,326.000000,Buy\r\n",
"8/4/2023,331.880005,Buy\r\n",
"8/7/2023,328.369995,Buy\r\n",
"8/8/2023,326.959991,Buy\r\n",
"8/9/2023,326.470001,Buy\r\n",
"8/10/2023,326.019989,Buy\r\n",
"8/11/2023,320.260010,Buy\r\n",
"8/14/2023,321.390015,Buy\r\n",
"8/15/2023,323.000000,Buy\r\n",
"8/16/2023,320.799988,Buy\r\n",
"8/17/2023,320.540009,Buy\r\n",
"8/18/2023,314.489990,Buy\r\n",
"8/21/2023,317.929993,Buy\r\n",
"8/22/2023,325.500000,Buy\r\n",
"8/23/2023,323.820007,Buy\r\n",
"8/24/2023,332.850006,Sell\r\n",
"8/25/2023,321.470001,Buy\r\n",
"8/28/2023,325.660004,Sell\r\n",
"8/29/2023,321.880005,Buy\r\n",
"8/30/2023,328.670013,Sell\r\n",
"8/31/2023,329.200012,Sell\r\n",
"9/1/2023,331.309998,Sell\r\n",
"9/5/2023,329.000000,Sell\r\n",
"9/6/2023,333.380005,Sell\r\n",
"9/7/2023,331.290009,Sell\r\n",
"9/8/2023,330.089996,Sell\r\n",
"9/11/2023,337.239990,Sell\r\n",
"9/12/2023,335.820007,Sell\r\n",
"9/13/2023,331.309998,Sell\r\n",
"9/14/2023,339.149994,Sell\r\n",
"9/15/2023,336.920013,Sell\r\n",
"9/18/2023,327.799988,Buy\r\n",
"9/19/2023,326.170013,Buy\r\n",
"9/20/2023,329.510010,Buy\r\n",
"9/21/2023,319.260010,Buy\r\n",
"9/22/2023,321.320007,Buy\r\n",
"9/25/2023,316.589996,Buy\r\n",
"9/26/2023,315.130005,Buy\r\n",
"9/27/2023,312.299988,Buy\r\n",
"9/28/2023,310.989990,Buy\r\n",
"9/29/2023,317.750000,Buy\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Action</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-10-29\">Oct 29, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.110001</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-10-30\">Oct 30, 2018</time></td><td><div class=\"dni-plaintext\"><pre>103.660004</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-10-31\">Oct 31, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.440002</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-01\">Nov 01, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.050003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-02\">Nov 02, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.480003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-05\">Nov 05, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.370003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-06\">Nov 06, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.379997</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-08\">Nov 08, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.800003</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-09\">Nov 09, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.849998</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-12\">Nov 12, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.419998</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-16\">Nov 16, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.080002</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-21\">Nov 21, 2018</time></td><td><div class=\"dni-plaintext\"><pre>103.599998</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-23\">Nov 23, 2018</time></td><td><div class=\"dni-plaintext\"><pre>102.169998</pre></div></td><td><span>Buy</span></td></tr><tr><td colspan=\"3\"><i>(1219 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var actions =\n",
" from e in mavg\n",
" select new\n",
" {\n",
" e.Date,\n",
" e.Price,\n",
" Action = e.Price < e.Avg ? Trade.Buy : Trade.Sell,\n",
" };\n",
"\n",
"actions.ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"That was easy, but wait! There's a problem! We can't buy or sell _every day_ the stock price is below or above the moving average. Think about it, once we've sold all the stock we're holding, we can't sell more so what we want instead, is to buy the _first time_ it dips below the moving average and sell the _first time_ it goes above. We will use [`GroupAdjacent`] from MoreLINQ to help here, by grouping all _adjacent trade actions_ together:\n",
"\n",
"[`GroupAdjacent`]: https://morelinq.github.io/4.0/ref/api/html/Overload_MoreLinq_MoreEnumerable_GroupAdjacent.htm"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/26/2018, Price = 105.690002, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/29/2018, Price = 108.110001, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-29\">Oct 29, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.110001</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/30/2018, Price = 103.660004, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-30\">Oct 30, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.660004</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>3</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/31/2018, Price = 105.440002, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-31\">Oct 31, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.440002</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>4</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/1/2018, Price = 107.050003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-01\">Nov 01, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.050003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>5</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/2/2018, Price = 106.480003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-02\">Nov 02, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.480003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>6</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/5/2018, Price = 106.370003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-05\">Nov 05, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.370003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>7</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/6/2018, Price = 107.379997, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-06\">Nov 06, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.379997</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>1</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/7/2018, Price = 109.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/8/2018, Price = 111.800003, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-08\">Nov 08, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>111.800003</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/9/2018, Price = 110.849998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-09\">Nov 09, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>110.849998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>3</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/12/2018, Price = 109.419998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-12\">Nov 12, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.419998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>2</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/13/2018, Price = 107.550003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>3</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/14/2018, Price = 108.099998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var byAction = actions.GroupAdjacent(e => e.Action);\n",
"\n",
"byAction.Take(4) // just show the first 4 groups for brevity"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"`GroupAdjacent` is like [`GroupBy`] in LINQ except it yields a group whenever the key changes. Put another way, it keeps grouping the elements of a sequence _as long as_ they share the same key and yields that one group when a different key is encountered. If the key of a previously yielded group appears again later in the sequence then it's considered a separate group of adjacent elements.\n",
"\n",
"Since we won't have any position in the market to start with, meaning we won't be holding any stock initially, we also want to make sure that the first action is to buy (when we enter or take a position in the market), not sell:\n",
"\n",
"[`GroupBy`]: https://learn.microsoft.com/en-us/dotnet/api/system.linq.enumerable.groupby"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [],
"source": [
"byAction = byAction.SkipWhile(e => e.Key is Trade.Sell);"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"From each group of trade actions, we just want to keep the _first_ buy or sell:"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Action\r\n",
"10/26/2018,105.690002,Buy\r\n",
"11/7/2018,109.440002,Sell\r\n",
"11/13/2018,107.550003,Buy\r\n",
"11/14/2018,108.099998,Sell\r\n",
"11/15/2018,104.989998,Buy\r\n",
"11/19/2018,108.269997,Sell\r\n",
"11/20/2018,101.800003,Buy\r\n",
"11/28/2018,107.889999,Sell\r\n",
"12/6/2018,105.820000,Buy\r\n",
"12/7/2018,108.379997,Sell\r\n",
"12/10/2018,104.800003,Buy\r\n",
"12/11/2018,109.800003,Sell\r\n",
"12/17/2018,105.410004,Buy\r\n",
"1/8/2019,103.040001,Sell\r\n",
"1/31/2019,103.800003,Buy\r\n",
"2/5/2019,106.059998,Sell\r\n",
"2/8/2019,104.389999,Buy\r\n",
"2/11/2019,106.199997,Sell\r\n",
"3/8/2019,109.160004,Buy\r\n",
"3/11/2019,110.989998,Sell\r\n",
"5/9/2019,124.290001,Buy\r\n",
"5/16/2019,126.750000,Sell\r\n",
"5/20/2019,126.519997,Buy\r\n",
"5/21/2019,127.430000,Sell\r\n",
"5/22/2019,126.620003,Buy\r\n",
"5/24/2019,126.910004,Sell\r\n",
"5/29/2019,125.379997,Buy\r\n",
"6/6/2019,126.440002,Sell\r\n",
"7/18/2019,135.550003,Buy\r\n",
"7/19/2019,140.220001,Sell\r\n",
"8/1/2019,137.000000,Buy\r\n",
"8/9/2019,138.610001,Sell\r\n",
"8/12/2019,137.070007,Buy\r\n",
"8/19/2019,137.850006,Sell\r\n",
"8/26/2019,134.990005,Buy\r\n",
"8/29/2019,137.250000,Sell\r\n",
"9/10/2019,136.800003,Buy\r\n",
"9/12/2019,137.850006,Sell\r\n",
"9/16/2019,135.830002,Buy\r\n",
"9/19/2019,140.300003,Sell\r\n",
"9/25/2019,137.500000,Buy\r\n",
"9/26/2019,139.440002,Sell\r\n",
"9/30/2019,138.050003,Buy\r\n",
"10/1/2019,139.660004,Sell\r\n",
"10/2/2019,136.250000,Buy\r\n",
"10/10/2019,138.490005,Sell\r\n",
"10/21/2019,138.449997,Buy\r\n",
"10/22/2019,138.970001,Sell\r\n",
"10/23/2019,136.880005,Buy\r\n",
"10/24/2019,139.389999,Sell\r\n",
"12/3/2019,147.490005,Buy\r\n",
"12/4/2019,150.139999,Sell\r\n",
"1/27/2020,161.149994,Buy\r\n",
"1/28/2020,163.779999,Sell\r\n",
"2/24/2020,167.770004,Buy\r\n",
"3/27/2020,151.750000,Sell\r\n",
"5/14/2020,177.539993,Buy\r\n",
"5/15/2020,179.059998,Sell\r\n",
"5/27/2020,180.199997,Buy\r\n",
"5/29/2020,182.729996,Sell\r\n",
"6/1/2020,182.539993,Buy\r\n",
"6/2/2020,184.250000,Sell\r\n",
"6/5/2020,182.619995,Buy\r\n",
"6/8/2020,185.940002,Sell\r\n",
"6/15/2020,184.580002,Buy\r\n",
"6/16/2020,192.889999,Sell\r\n",
"7/17/2020,204.470001,Buy\r\n",
"7/21/2020,213.660004,Sell\r\n",
"7/24/2020,200.419998,Buy\r\n",
"8/3/2020,211.520004,Sell\r\n",
"8/11/2020,207.160004,Buy\r\n",
"8/13/2020,209.440002,Sell\r\n",
"9/4/2020,215.100006,Buy\r\n",
"9/28/2020,210.880005,Sell\r\n",
"9/29/2020,209.350006,Buy\r\n",
"10/1/2020,213.490005,Sell\r\n",
"10/26/2020,213.850006,Buy\r\n",
"11/4/2020,214.020004,Sell\r\n",
"11/11/2020,212.389999,Buy\r\n",
"11/12/2020,217.210007,Sell\r\n",
"11/19/2020,211.380005,Buy\r\n",
"11/25/2020,215.110001,Sell\r\n",
"11/30/2020,214.100006,Buy\r\n",
"12/9/2020,215.160004,Sell\r\n",
"12/10/2020,211.770004,Buy\r\n",
"12/15/2020,215.169998,Sell\r\n",
"1/5/2021,217.259995,Buy\r\n",
"1/8/2021,218.679993,Sell\r\n",
"1/11/2021,218.470001,Buy\r\n",
"1/21/2021,224.699997,Sell\r\n",
"2/22/2021,237.419998,Buy\r\n",
"3/10/2021,237.000000,Sell\r\n",
"3/11/2021,234.960007,Buy\r\n",
"3/16/2021,236.279999,Sell\r\n",
"3/18/2021,232.559998,Buy\r\n",
"3/23/2021,237.490005,Sell\r\n",
"3/26/2021,231.550003,Buy\r\n",
"3/29/2021,236.589996,Sell\r\n",
"3/30/2021,233.529999,Buy\r\n",
"4/1/2021,238.470001,Sell\r\n",
"4/30/2021,249.740005,Buy\r\n",
"5/25/2021,251.770004,Sell\r\n",
"6/3/2021,245.220001,Buy\r\n",
"6/4/2021,247.759995,Sell\r\n",
"9/10/2021,298.420013,Buy\r\n",
"9/15/2021,303.260010,Sell\r\n",
"9/20/2021,296.329987,Buy\r\n",
"10/7/2021,295.179993,Sell\r\n",
"10/11/2021,292.920013,Buy\r\n",
"10/12/2021,295.339996,Sell\r\n",
"11/26/2021,334.350006,Buy\r\n",
"12/8/2021,335.309998,Sell\r\n",
"12/9/2021,334.410004,Buy\r\n",
"12/13/2021,340.679993,Sell\r\n",
"12/14/2021,333.220001,Buy\r\n",
"12/16/2021,335.709991,Sell\r\n",
"12/17/2021,320.880005,Buy\r\n",
"12/23/2021,332.750000,Sell\r\n",
"1/5/2022,325.859985,Buy\r\n",
"2/1/2022,310.410004,Sell\r\n",
"2/4/2022,300.209991,Buy\r\n",
"2/9/2022,309.869995,Sell\r\n",
"2/10/2022,304.040009,Buy\r\n",
"3/3/2022,302.890015,Sell\r\n",
"3/4/2022,294.290009,Buy\r\n",
"3/17/2022,293.290009,Sell\r\n",
"4/7/2022,296.660004,Buy\r\n",
"5/5/2022,285.540009,Sell\r\n",
"5/6/2022,274.809998,Buy\r\n",
"5/27/2022,268.480011,Sell\r\n",
"6/2/2022,264.450012,Buy\r\n",
"6/3/2022,270.309998,Sell\r\n",
"6/10/2022,260.579987,Buy\r\n",
"6/24/2022,261.809998,Sell\r\n",
"6/29/2022,257.589996,Buy\r\n",
"7/6/2022,263.750000,Sell\r\n",
"7/13/2022,250.190002,Buy\r\n",
"7/18/2022,259.750000,Sell\r\n",
"7/19/2022,257.579987,Buy\r\n",
"7/20/2022,259.899994,Sell\r\n",
"8/23/2022,276.440002,Buy\r\n",
"10/5/2022,245.990005,Sell\r\n",
"10/7/2022,240.899994,Buy\r\n",
"10/18/2022,243.240005,Sell\r\n",
"10/19/2022,237.039993,Buy\r\n",
"10/24/2022,243.759995,Sell\r\n",
"10/26/2022,231.169998,Buy\r\n",
"11/10/2022,235.429993,Sell\r\n",
"12/9/2022,244.699997,Buy\r\n",
"12/12/2022,247.449997,Sell\r\n",
"12/19/2022,244.860001,Buy\r\n",
"1/13/2023,237.000000,Sell\r\n",
"1/19/2023,233.779999,Buy\r\n",
"1/23/2023,241.100006,Sell\r\n",
"1/25/2023,234.479996,Buy\r\n",
"1/26/2023,243.649994,Sell\r\n",
"2/21/2023,254.479996,Buy\r\n",
"3/14/2023,256.750000,Sell\r\n",
"4/24/2023,282.089996,Buy\r\n",
"4/26/2023,296.700012,Sell\r\n",
"6/27/2023,331.859985,Buy\r\n",
"6/28/2023,334.660004,Sell\r\n",
"7/10/2023,334.600006,Buy\r\n",
"7/12/2023,336.600006,Sell\r\n",
"7/26/2023,341.440002,Buy\r\n",
"8/24/2023,332.850006,Sell\r\n",
"8/25/2023,321.470001,Buy\r\n",
"8/28/2023,325.660004,Sell\r\n",
"8/29/2023,321.880005,Buy\r\n",
"8/30/2023,328.670013,Sell\r\n",
"9/18/2023,327.799988,Buy\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Action</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-12-06\">Dec 06, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.820000</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-12-07\">Dec 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.379997</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-12-10\">Dec 10, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.800003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2018-12-17\">Dec 17, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.410004</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2019-01-08\">Jan 08, 2019</time></td><td><div class=\"dni-plaintext\"><pre>103.040001</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2019-01-31\">Jan 31, 2019</time></td><td><div class=\"dni-plaintext\"><pre>103.800003</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2019-02-08\">Feb 08, 2019</time></td><td><div class=\"dni-plaintext\"><pre>104.389999</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2019-02-11\">Feb 11, 2019</time></td><td><div class=\"dni-plaintext\"><pre>106.199997</pre></div></td><td><span>Sell</span></td></tr><tr><td><time datetime=\"2019-03-08\">Mar 08, 2019</time></td><td><div class=\"dni-plaintext\"><pre>109.160004</pre></div></td><td><span>Buy</span></td></tr><tr><td><time datetime=\"2019-03-11\">Mar 11, 2019</time></td><td><div class=\"dni-plaintext\"><pre>110.989998</pre></div></td><td><span>Sell</span></td></tr><tr><td colspan=\"3\"><i>(151 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"actions = from g in byAction\n",
" select g.First();\n",
"\n",
"actions.ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Now, a buy is always followed by a sell, which in turn is followed by a buy, and so on. Let's connect each buy with its sell and use [`Batch`] from MoreLINQ to create batches of two actions (.NET 6 added [`Chunk`] that does the same, but `Batch` has been around in MoreLINQ since 2009 and therefore available for use in earlier versions of .NET and .NET Framework):\n",
"\n",
"[`Batch`]: https://morelinq.github.io/4.0/ref/api/html/M_MoreLinq_MoreEnumerable_Batch__1.\n",
"[`Chunk`]: https://learn.microsoft.com/en-us/dotnet/api/system.linq.enumerable.chunk"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/26/2018, Price = 105.690002, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/7/2018, Price = 109.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>1</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/13/2018, Price = 107.550003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/14/2018, Price = 108.099998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>2</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/15/2018, Price = 104.989998, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/19/2018, Price = 108.269997, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>3</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/20/2018, Price = 101.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/28/2018, Price = 107.889999, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>4</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/6/2018, Price = 105.820000, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-06\">Dec 06, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.820000</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/7/2018, Price = 108.379997, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-07\">Dec 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.379997</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>5</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/10/2018, Price = 104.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-10\">Dec 10, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/11/2018, Price = 109.800003, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>6</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/17/2018, Price = 105.410004, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-17\">Dec 17, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.410004</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/8/2019, Price = 103.040001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-08\">Jan 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.040001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>7</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/31/2019, Price = 103.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-31\">Jan 31, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/5/2019, Price = 106.059998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>8</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/8/2019, Price = 104.389999, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-08\">Feb 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.389999</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/11/2019, Price = 106.199997, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-11\">Feb 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.199997</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>9</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/8/2019, Price = 109.160004, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-08\">Mar 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.160004</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/11/2019, Price = 110.989998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-11\">Mar 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>110.989998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>10</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/9/2019, Price = 124.290001, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-09\">May 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>124.290001</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/16/2019, Price = 126.750000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-16\">May 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.750000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>11</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/20/2019, Price = 126.519997, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-20\">May 20, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.519997</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/21/2019, Price = 127.430000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-21\">May 21, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>127.430000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>12</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/22/2019, Price = 126.620003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-22\">May 22, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.620003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/24/2019, Price = 126.910004, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-24\">May 24, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.910004</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>13</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/29/2019, Price = 125.379997, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-29\">May 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>125.379997</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 6/6/2019, Price = 126.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-06-06\">Jun 06, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>14</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/18/2019, Price = 135.550003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-18\">Jul 18, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.550003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/19/2019, Price = 140.220001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-19\">Jul 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.220001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>15</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/1/2019, Price = 137.000000, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-01\">Aug 01, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.000000</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/9/2019, Price = 138.610001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-09\">Aug 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>138.610001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>16</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/12/2019, Price = 137.070007, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-12\">Aug 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.070007</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/19/2019, Price = 137.850006, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-19\">Aug 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>17</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/26/2019, Price = 134.990005, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-26\">Aug 26, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>134.990005</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/29/2019, Price = 137.250000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-29\">Aug 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.250000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>18</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/10/2019, Price = 136.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-10\">Sep 10, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>136.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/12/2019, Price = 137.850006, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-12\">Sep 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>19</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/16/2019, Price = 135.830002, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-16\">Sep 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.830002</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/19/2019, Price = 140.300003, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-19\">Sep 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.300003</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td colspan=\"2\"><i>... (more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var batches = actions.Batch(2);\n",
"\n",
"batches"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's make sure we always have a batch of 2 because if the last trade action was a buy then we will have a batch of a single element and that's no good."
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/26/2018, Price = 105.690002, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/7/2018, Price = 109.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>1</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/13/2018, Price = 107.550003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/14/2018, Price = 108.099998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>2</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/15/2018, Price = 104.989998, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/19/2018, Price = 108.269997, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>3</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/20/2018, Price = 101.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/28/2018, Price = 107.889999, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>4</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/6/2018, Price = 105.820000, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-06\">Dec 06, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.820000</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/7/2018, Price = 108.379997, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-07\">Dec 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.379997</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>5</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/10/2018, Price = 104.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-10\">Dec 10, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/11/2018, Price = 109.800003, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>6</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/17/2018, Price = 105.410004, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-17\">Dec 17, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.410004</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/8/2019, Price = 103.040001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-08\">Jan 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.040001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>7</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/31/2019, Price = 103.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-31\">Jan 31, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/5/2019, Price = 106.059998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>8</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/8/2019, Price = 104.389999, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-08\">Feb 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.389999</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/11/2019, Price = 106.199997, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-11\">Feb 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.199997</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>9</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/8/2019, Price = 109.160004, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-08\">Mar 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.160004</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/11/2019, Price = 110.989998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-11\">Mar 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>110.989998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>10</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/9/2019, Price = 124.290001, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-09\">May 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>124.290001</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/16/2019, Price = 126.750000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-16\">May 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.750000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>11</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/20/2019, Price = 126.519997, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-20\">May 20, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.519997</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/21/2019, Price = 127.430000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-21\">May 21, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>127.430000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>12</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/22/2019, Price = 126.620003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-22\">May 22, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.620003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/24/2019, Price = 126.910004, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-24\">May 24, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.910004</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>13</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/29/2019, Price = 125.379997, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-29\">May 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>125.379997</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 6/6/2019, Price = 126.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-06-06\">Jun 06, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>14</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/18/2019, Price = 135.550003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-18\">Jul 18, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.550003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/19/2019, Price = 140.220001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-19\">Jul 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.220001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>15</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/1/2019, Price = 137.000000, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-01\">Aug 01, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.000000</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/9/2019, Price = 138.610001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-09\">Aug 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>138.610001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>16</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/12/2019, Price = 137.070007, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-12\">Aug 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.070007</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/19/2019, Price = 137.850006, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-19\">Aug 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>17</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/26/2019, Price = 134.990005, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-26\">Aug 26, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>134.990005</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/29/2019, Price = 137.250000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-29\">Aug 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.250000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>18</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/10/2019, Price = 136.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-10\">Sep 10, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>136.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/12/2019, Price = 137.850006, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-12\">Sep 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td>19</td><td><table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/16/2019, Price = 135.830002, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-16\">Sep 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.830002</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/19/2019, Price = 140.300003, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-19\">Sep 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.300003</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></td></tr><tr><td colspan=\"2\"><i>... (more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"batches =\n",
" from b in batches\n",
" where b.Length is 2\n",
" select b;\n",
"\n",
"batches"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"So just the way we used [`Fold`] earlier, when parsing the CSV data, to turn a sequence of fields into a single row object, we can use it to _fold each batch_ of buy-sell information into a single object that will represent our pair of buy-sell trades:\n",
"\n",
"[`Fold`]: https://morelinq.github.io/4.0/ref/api/html/Overload_MoreLinq_MoreEnumerable_Fold.htm"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 10/26/2018, Price = 105.690002 }, Sell = { Date = 11/7/2018, Price = 109.440002 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/26/2018, Price = 105.690002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/7/2018, Price = 109.440002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 11/13/2018, Price = 107.550003 }, Sell = { Date = 11/14/2018, Price = 108.099998 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/13/2018, Price = 107.550003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/14/2018, Price = 108.099998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 11/15/2018, Price = 104.989998 }, Sell = { Date = 11/19/2018, Price = 108.269997 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/15/2018, Price = 104.989998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/19/2018, Price = 108.269997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>3</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 11/20/2018, Price = 101.800003 }, Sell = { Date = 11/28/2018, Price = 107.889999 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/20/2018, Price = 101.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/28/2018, Price = 107.889999 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>4</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 12/6/2018, Price = 105.820000 }, Sell = { Date = 12/7/2018, Price = 108.379997 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/6/2018, Price = 105.820000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-06\">Dec 06, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.820000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/7/2018, Price = 108.379997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-07\">Dec 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.379997</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>5</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 12/10/2018, Price = 104.800003 }, Sell = { Date = 12/11/2018, Price = 109.800003 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/10/2018, Price = 104.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-10\">Dec 10, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/11/2018, Price = 109.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>6</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 12/17/2018, Price = 105.410004 }, Sell = { Date = 1/8/2019, Price = 103.040001 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/17/2018, Price = 105.410004 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-17\">Dec 17, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.410004</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/8/2019, Price = 103.040001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-08\">Jan 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.040001</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>7</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 1/31/2019, Price = 103.800003 }, Sell = { Date = 2/5/2019, Price = 106.059998 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/31/2019, Price = 103.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-31\">Jan 31, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/5/2019, Price = 106.059998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>8</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 2/8/2019, Price = 104.389999 }, Sell = { Date = 2/11/2019, Price = 106.199997 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/8/2019, Price = 104.389999 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-08\">Feb 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.389999</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/11/2019, Price = 106.199997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-11\">Feb 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.199997</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>9</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 3/8/2019, Price = 109.160004 }, Sell = { Date = 3/11/2019, Price = 110.989998 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/8/2019, Price = 109.160004 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-08\">Mar 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.160004</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/11/2019, Price = 110.989998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-11\">Mar 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>110.989998</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>10</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/9/2019, Price = 124.290001 }, Sell = { Date = 5/16/2019, Price = 126.750000 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/9/2019, Price = 124.290001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-09\">May 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>124.290001</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/16/2019, Price = 126.750000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-16\">May 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.750000</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>11</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/20/2019, Price = 126.519997 }, Sell = { Date = 5/21/2019, Price = 127.430000 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/20/2019, Price = 126.519997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-20\">May 20, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.519997</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/21/2019, Price = 127.430000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-21\">May 21, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>127.430000</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>12</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/22/2019, Price = 126.620003 }, Sell = { Date = 5/24/2019, Price = 126.910004 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/22/2019, Price = 126.620003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-22\">May 22, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.620003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/24/2019, Price = 126.910004 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-24\">May 24, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.910004</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>13</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/29/2019, Price = 125.379997 }, Sell = { Date = 6/6/2019, Price = 126.440002 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/29/2019, Price = 125.379997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-29\">May 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>125.379997</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 6/6/2019, Price = 126.440002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-06-06\">Jun 06, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.440002</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>14</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 7/18/2019, Price = 135.550003 }, Sell = { Date = 7/19/2019, Price = 140.220001 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/18/2019, Price = 135.550003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-18\">Jul 18, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.550003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/19/2019, Price = 140.220001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-19\">Jul 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.220001</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>15</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 8/1/2019, Price = 137.000000 }, Sell = { Date = 8/9/2019, Price = 138.610001 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/1/2019, Price = 137.000000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-01\">Aug 01, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.000000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/9/2019, Price = 138.610001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-09\">Aug 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>138.610001</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>16</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 8/12/2019, Price = 137.070007 }, Sell = { Date = 8/19/2019, Price = 137.850006 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/12/2019, Price = 137.070007 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-12\">Aug 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.070007</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/19/2019, Price = 137.850006 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-19\">Aug 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>17</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 8/26/2019, Price = 134.990005 }, Sell = { Date = 8/29/2019, Price = 137.250000 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/26/2019, Price = 134.990005 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-26\">Aug 26, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>134.990005</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/29/2019, Price = 137.250000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-29\">Aug 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.250000</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>18</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 9/10/2019, Price = 136.800003 }, Sell = { Date = 9/12/2019, Price = 137.850006 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/10/2019, Price = 136.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-10\">Sep 10, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>136.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/12/2019, Price = 137.850006 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-12\">Sep 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>19</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 9/16/2019, Price = 135.830002 }, Sell = { Date = 9/19/2019, Price = 140.300003 } }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/16/2019, Price = 135.830002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-16\">Sep 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.830002</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/19/2019, Price = 140.300003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-19\">Sep 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.300003</pre></div></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td colspan=\"2\"><i>... (more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var trades =\n",
" from b in batches\n",
" select b.Fold((buy, sell) => new\n",
" {\n",
" Buy = new { buy.Date, buy.Price },\n",
" Sell = new { sell.Date, sell.Price },\n",
" });\n",
"\n",
"trades"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Often times, there's more than one way to achieve the same result using various operators in LINQ and MoreLINQ. Instead of using `Batch` and `Fold`, we could have also used [`Pairwise`] with [`TakeEvery`]. `Pairwise` is just like `Window(2)`, but you get the two elements of a window as a couple (2-tuple) instead of a fixed-size array and then `TakeEvery(2)` has the effect of skipping every other pair such that the result is non-overlapping: \n",
"\n",
"[`Pairwise`]: https://morelinq.github.io/4.0/ref/api/html/M_MoreLinq_MoreEnumerable_Pairwise__2.htm\n",
"[`TakeEvery`]: https://morelinq.github.io/4.0/ref/api/html/M_MoreLinq_MoreEnumerable_TakeEvery__1.htm"
]
},
{
"cell_type": "code",
"execution_count": 123,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 10/26/2018, Price = 105.690002, Action = Buy }, { Date = 11/7/2018, Price = 109.440002, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/26/2018, Price = 105.690002, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/7/2018, Price = 109.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 11/19/2018, Price = 108.269997, Action = Sell }, { Date = 11/20/2018, Price = 101.800003, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/19/2018, Price = 108.269997, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/20/2018, Price = 101.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 12/10/2018, Price = 104.800003, Action = Buy }, { Date = 12/11/2018, Price = 109.800003, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/10/2018, Price = 104.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-10\">Dec 10, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/11/2018, Price = 109.800003, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>3</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 2/5/2019, Price = 106.059998, Action = Sell }, { Date = 2/8/2019, Price = 104.389999, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/5/2019, Price = 106.059998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/8/2019, Price = 104.389999, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-08\">Feb 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.389999</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>4</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 5/9/2019, Price = 124.290001, Action = Buy }, { Date = 5/16/2019, Price = 126.750000, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/9/2019, Price = 124.290001, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-09\">May 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>124.290001</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/16/2019, Price = 126.750000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-16\">May 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.750000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>5</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 5/24/2019, Price = 126.910004, Action = Sell }, { Date = 5/29/2019, Price = 125.379997, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/24/2019, Price = 126.910004, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-24\">May 24, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.910004</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/29/2019, Price = 125.379997, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-29\">May 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>125.379997</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>6</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 8/1/2019, Price = 137.000000, Action = Buy }, { Date = 8/9/2019, Price = 138.610001, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/1/2019, Price = 137.000000, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-01\">Aug 01, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.000000</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/9/2019, Price = 138.610001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-09\">Aug 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>138.610001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>7</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 8/29/2019, Price = 137.250000, Action = Sell }, { Date = 9/10/2019, Price = 136.800003, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/29/2019, Price = 137.250000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-29\">Aug 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.250000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/10/2019, Price = 136.800003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-10\">Sep 10, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>136.800003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>8</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 9/25/2019, Price = 137.500000, Action = Buy }, { Date = 9/26/2019, Price = 139.440002, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/25/2019, Price = 137.500000, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-25\">Sep 25, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.500000</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/26/2019, Price = 139.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-26\">Sep 26, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>139.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>9</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 10/10/2019, Price = 138.490005, Action = Sell }, { Date = 10/21/2019, Price = 138.449997, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/10/2019, Price = 138.490005, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-10-10\">Oct 10, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>138.490005</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/21/2019, Price = 138.449997, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-10-21\">Oct 21, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>138.449997</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>10</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 12/3/2019, Price = 147.490005, Action = Buy }, { Date = 12/4/2019, Price = 150.139999, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/3/2019, Price = 147.490005, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-12-03\">Dec 03, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>147.490005</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/4/2019, Price = 150.139999, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-12-04\">Dec 04, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>150.139999</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>11</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 3/27/2020, Price = 151.750000, Action = Sell }, { Date = 5/14/2020, Price = 177.539993, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/27/2020, Price = 151.750000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-03-27\">Mar 27, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>151.750000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/14/2020, Price = 177.539993, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-05-14\">May 14, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>177.539993</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>12</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 6/1/2020, Price = 182.539993, Action = Buy }, { Date = 6/2/2020, Price = 184.250000, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 6/1/2020, Price = 182.539993, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-06-01\">Jun 01, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>182.539993</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 6/2/2020, Price = 184.250000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-06-02\">Jun 02, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>184.250000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>13</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 6/16/2020, Price = 192.889999, Action = Sell }, { Date = 7/17/2020, Price = 204.470001, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 6/16/2020, Price = 192.889999, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-06-16\">Jun 16, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>192.889999</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/17/2020, Price = 204.470001, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-07-17\">Jul 17, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>204.470001</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>14</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 8/11/2020, Price = 207.160004, Action = Buy }, { Date = 8/13/2020, Price = 209.440002, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/11/2020, Price = 207.160004, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-08-11\">Aug 11, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>207.160004</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/13/2020, Price = 209.440002, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-08-13\">Aug 13, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>209.440002</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>15</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 10/1/2020, Price = 213.490005, Action = Sell }, { Date = 10/26/2020, Price = 213.850006, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/1/2020, Price = 213.490005, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-10-01\">Oct 01, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>213.490005</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/26/2020, Price = 213.850006, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-10-26\">Oct 26, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>213.850006</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>16</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 11/19/2020, Price = 211.380005, Action = Buy }, { Date = 11/25/2020, Price = 215.110001, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/19/2020, Price = 211.380005, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-11-19\">Nov 19, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>211.380005</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/25/2020, Price = 215.110001, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-11-25\">Nov 25, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>215.110001</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>17</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 12/15/2020, Price = 215.169998, Action = Sell }, { Date = 1/5/2021, Price = 217.259995, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/15/2020, Price = 215.169998, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2020-12-15\">Dec 15, 2020</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>215.169998</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/5/2021, Price = 217.259995, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2021-01-05\">Jan 05, 2021</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>217.259995</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>18</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 2/22/2021, Price = 237.419998, Action = Buy }, { Date = 3/10/2021, Price = 237.000000, Action = Sell })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/22/2021, Price = 237.419998, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2021-02-22\">Feb 22, 2021</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>237.419998</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/10/2021, Price = 237.000000, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2021-03-10\">Mar 10, 2021</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>237.000000</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td>19</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>({ Date = 3/23/2021, Price = 237.490005, Action = Sell }, { Date = 3/26/2021, Price = 231.550003, Action = Buy })</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Item1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/23/2021, Price = 237.490005, Action = Sell }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2021-03-23\">Mar 23, 2021</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>237.490005</pre></div></td></tr><tr><td>Action</td><td><span>Sell</span></td></tr></tbody></table></div></details></td></tr><tr><td>Item2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/26/2021, Price = 231.550003, Action = Buy }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2021-03-26\">Mar 26, 2021</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>231.550003</pre></div></td></tr><tr><td>Action</td><td><span>Buy</span></td></tr></tbody></table></div></details></td></tr></tbody></table></div></details></td></tr><tr><td colspan=\"2\"><i>... (more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"actions.Pairwise(ValueTuple.Create).TakeEvery(5)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We have all the trade actions lined up, knowing when we bought and sold so the next step is to calculate the performance of our trading strategy over time. Let's begin with an initial balance of $1,000:"
]
},
{
"cell_type": "code",
"execution_count": 124,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [],
"source": [
"const decimal initialBalance = 1_000;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"and see what we get at the end, but now comes the difficult part. As we go over `trades`, we'll be interested in keeping track of various pieces of information:\n",
"\n",
"- The buy/sell trade\n",
"- How many shares were bought on the buy date, with what was in the account?\n",
"- What was the remaining balance after buying whole shares?\n",
"- How many shares were sold on the sell date?\n",
"- How many days we were in the trade, between when we bought and sold the shares?\n",
"- What was the new balance based on the profit or loss?\n",
"\n",
"To do this, we will use [`Scan`] from MoreLINQ. `Scan` is like `Aggregate`, but while `Aggregate` gives you the final accumulated result, `Scan` produces a sequence of the accumulation as the source sequence is iterated, which is exactly what we need here. Like `Aggregate`, `Scan` needs a seed, an initial state, and a function that _folds_ an item in the source sequence into that state.\n",
"\n",
"Let's look at this in action:\n",
"\n",
"[`Scan`]: https://morelinq.github.io/4.0/ref/api/html/M_MoreLinq_MoreEnumerable_Scan__2.htm"
]
},
{
"cell_type": "code",
"execution_count": 125,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<table><thead><tr><th><i>index</i></th><th>value</th></tr></thead><tbody><tr><td>0</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 10/26/2018, Price = 105.690002 }, Sell = { Date = 11/7/2018, Price = 109.440002 }, Account = 1000, Shares = 9, Bought = 951.210018, Remaining = 48.789982, Sold = 984.960018, Days = 13, Balance = 1033.750000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 10/26/2018, Price = 105.690002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/7/2018, Price = 109.440002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1000</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>951.210018</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>48.789982</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>984.960018</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>13</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>1</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 11/13/2018, Price = 107.550003 }, Sell = { Date = 11/14/2018, Price = 108.099998 }, Account = 1033.750000, Shares = 9, Bought = 967.950027, Remaining = 65.799973, Sold = 972.899982, Days = 2, Balance = 1038.699955 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/13/2018, Price = 107.550003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/14/2018, Price = 108.099998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>967.950027</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>65.799973</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>972.899982</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>2</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 11/15/2018, Price = 104.989998 }, Sell = { Date = 11/19/2018, Price = 108.269997 }, Account = 1038.699955, Shares = 9, Bought = 944.909982, Remaining = 93.789973, Sold = 974.429973, Days = 5, Balance = 1068.219946 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/15/2018, Price = 104.989998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/19/2018, Price = 108.269997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>944.909982</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>93.789973</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>974.429973</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>5</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>3</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 11/20/2018, Price = 101.800003 }, Sell = { Date = 11/28/2018, Price = 107.889999 }, Account = 1068.219946, Shares = 10, Bought = 1018.000030, Remaining = 50.219916, Sold = 1078.899990, Days = 9, Balance = 1129.119906 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/20/2018, Price = 101.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 11/28/2018, Price = 107.889999 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1018.000030</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>50.219916</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1078.899990</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>4</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 12/6/2018, Price = 105.820000 }, Sell = { Date = 12/7/2018, Price = 108.379997 }, Account = 1129.119906, Shares = 10, Bought = 1058.200000, Remaining = 70.919906, Sold = 1083.799970, Days = 2, Balance = 1154.719876 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/6/2018, Price = 105.820000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-06\">Dec 06, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.820000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/7/2018, Price = 108.379997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-07\">Dec 07, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>108.379997</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1058.200000</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>70.919906</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1083.799970</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1154.719876</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>5</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 12/10/2018, Price = 104.800003 }, Sell = { Date = 12/11/2018, Price = 109.800003 }, Account = 1154.719876, Shares = 11, Bought = 1152.800033, Remaining = 1.919843, Sold = 1207.800033, Days = 2, Balance = 1209.719876 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/10/2018, Price = 104.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-10\">Dec 10, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/11/2018, Price = 109.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1154.719876</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1152.800033</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>1.919843</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1207.800033</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1209.719876</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>6</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 12/17/2018, Price = 105.410004 }, Sell = { Date = 1/8/2019, Price = 103.040001 }, Account = 1209.719876, Shares = 11, Bought = 1159.510044, Remaining = 50.209832, Sold = 1133.440011, Days = 23, Balance = 1183.649843 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 12/17/2018, Price = 105.410004 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2018-12-17\">Dec 17, 2018</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>105.410004</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/8/2019, Price = 103.040001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-08\">Jan 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.040001</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1209.719876</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1159.510044</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>50.209832</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1133.440011</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>23</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1183.649843</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>7</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 1/31/2019, Price = 103.800003 }, Sell = { Date = 2/5/2019, Price = 106.059998 }, Account = 1183.649843, Shares = 11, Bought = 1141.800033, Remaining = 41.849810, Sold = 1166.659978, Days = 6, Balance = 1208.509788 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 1/31/2019, Price = 103.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-01-31\">Jan 31, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>103.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/5/2019, Price = 106.059998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1183.649843</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1141.800033</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>41.849810</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1166.659978</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>6</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1208.509788</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>8</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 2/8/2019, Price = 104.389999 }, Sell = { Date = 2/11/2019, Price = 106.199997 }, Account = 1208.509788, Shares = 11, Bought = 1148.289989, Remaining = 60.219799, Sold = 1168.199967, Days = 4, Balance = 1228.419766 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/8/2019, Price = 104.389999 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-08\">Feb 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>104.389999</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 2/11/2019, Price = 106.199997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-02-11\">Feb 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>106.199997</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1208.509788</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1148.289989</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>60.219799</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1168.199967</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1228.419766</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>9</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 3/8/2019, Price = 109.160004 }, Sell = { Date = 3/11/2019, Price = 110.989998 }, Account = 1228.419766, Shares = 11, Bought = 1200.760044, Remaining = 27.659722, Sold = 1220.889978, Days = 4, Balance = 1248.549700 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/8/2019, Price = 109.160004 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-08\">Mar 08, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>109.160004</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 3/11/2019, Price = 110.989998 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-03-11\">Mar 11, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>110.989998</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1228.419766</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1200.760044</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>27.659722</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1220.889978</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1248.549700</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>10</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/9/2019, Price = 124.290001 }, Sell = { Date = 5/16/2019, Price = 126.750000 }, Account = 1248.549700, Shares = 10, Bought = 1242.900010, Remaining = 5.649690, Sold = 1267.500000, Days = 8, Balance = 1273.149690 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/9/2019, Price = 124.290001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-09\">May 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>124.290001</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/16/2019, Price = 126.750000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-16\">May 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.750000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1248.549700</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1242.900010</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>5.649690</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1267.500000</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>8</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1273.149690</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>11</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/20/2019, Price = 126.519997 }, Sell = { Date = 5/21/2019, Price = 127.430000 }, Account = 1273.149690, Shares = 10, Bought = 1265.199970, Remaining = 7.949720, Sold = 1274.300000, Days = 2, Balance = 1282.249720 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/20/2019, Price = 126.519997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-20\">May 20, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.519997</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/21/2019, Price = 127.430000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-21\">May 21, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>127.430000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1273.149690</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1265.199970</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>7.949720</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1274.300000</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1282.249720</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>12</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/22/2019, Price = 126.620003 }, Sell = { Date = 5/24/2019, Price = 126.910004 }, Account = 1282.249720, Shares = 10, Bought = 1266.200030, Remaining = 16.049690, Sold = 1269.100040, Days = 3, Balance = 1285.149730 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/22/2019, Price = 126.620003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-22\">May 22, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.620003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/24/2019, Price = 126.910004 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-24\">May 24, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.910004</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1282.249720</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1266.200030</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>16.049690</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1269.100040</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>3</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1285.149730</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>13</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 5/29/2019, Price = 125.379997 }, Sell = { Date = 6/6/2019, Price = 126.440002 }, Account = 1285.149730, Shares = 10, Bought = 1253.799970, Remaining = 31.349760, Sold = 1264.400020, Days = 9, Balance = 1295.749780 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 5/29/2019, Price = 125.379997 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-05-29\">May 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>125.379997</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 6/6/2019, Price = 126.440002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-06-06\">Jun 06, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>126.440002</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1285.149730</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1253.799970</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>31.349760</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1264.400020</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1295.749780</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>14</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 7/18/2019, Price = 135.550003 }, Sell = { Date = 7/19/2019, Price = 140.220001 }, Account = 1295.749780, Shares = 9, Bought = 1219.950027, Remaining = 75.799753, Sold = 1261.980009, Days = 2, Balance = 1337.779762 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/18/2019, Price = 135.550003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-18\">Jul 18, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.550003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 7/19/2019, Price = 140.220001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-07-19\">Jul 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.220001</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1295.749780</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1219.950027</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>75.799753</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1261.980009</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1337.779762</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>15</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 8/1/2019, Price = 137.000000 }, Sell = { Date = 8/9/2019, Price = 138.610001 }, Account = 1337.779762, Shares = 9, Bought = 1233.000000, Remaining = 104.779762, Sold = 1247.490009, Days = 9, Balance = 1352.269771 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/1/2019, Price = 137.000000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-01\">Aug 01, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.000000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/9/2019, Price = 138.610001 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-09\">Aug 09, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>138.610001</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1337.779762</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1233.000000</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>104.779762</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1247.490009</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1352.269771</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>16</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 8/12/2019, Price = 137.070007 }, Sell = { Date = 8/19/2019, Price = 137.850006 }, Account = 1352.269771, Shares = 9, Bought = 1233.630063, Remaining = 118.639708, Sold = 1240.650054, Days = 8, Balance = 1359.289762 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/12/2019, Price = 137.070007 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-12\">Aug 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.070007</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/19/2019, Price = 137.850006 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-19\">Aug 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1352.269771</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1233.630063</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>118.639708</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1240.650054</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>8</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1359.289762</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>17</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 8/26/2019, Price = 134.990005 }, Sell = { Date = 8/29/2019, Price = 137.250000 }, Account = 1359.289762, Shares = 10, Bought = 1349.900050, Remaining = 9.389712, Sold = 1372.500000, Days = 4, Balance = 1381.889712 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/26/2019, Price = 134.990005 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-26\">Aug 26, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>134.990005</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 8/29/2019, Price = 137.250000 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-08-29\">Aug 29, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.250000</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1359.289762</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1349.900050</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>9.389712</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1372.500000</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1381.889712</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>18</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 9/10/2019, Price = 136.800003 }, Sell = { Date = 9/12/2019, Price = 137.850006 }, Account = 1381.889712, Shares = 10, Bought = 1368.000030, Remaining = 13.889682, Sold = 1378.500060, Days = 3, Balance = 1392.389742 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/10/2019, Price = 136.800003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-10\">Sep 10, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>136.800003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/12/2019, Price = 137.850006 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-12\">Sep 12, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1381.889712</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1368.000030</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>13.889682</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1378.500060</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>3</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1392.389742</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>19</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Buy = { Date = 9/16/2019, Price = 135.830002 }, Sell = { Date = 9/19/2019, Price = 140.300003 }, Account = 1392.389742, Shares = 10, Bought = 1358.300020, Remaining = 34.089722, Sold = 1403.000030, Days = 4, Balance = 1437.089752 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Buy</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/16/2019, Price = 135.830002 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-16\">Sep 16, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>135.830002</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Sell</td><td><details class=\"dni-treeview\"><summary><span class=\"dni-code-hint\"><code>{ Date = 9/19/2019, Price = 140.300003 }</code></span></summary><div><table><thead><tr></tr></thead><tbody><tr><td>Date</td><td><time datetime=\"2019-09-19\">Sep 19, 2019</time></td></tr><tr><td>Price</td><td><div class=\"dni-plaintext\"><pre>140.300003</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td>Account</td><td><div class=\"dni-plaintext\"><pre>1392.389742</pre></div></td></tr><tr><td>Shares</td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td></tr><tr><td>Bought</td><td><div class=\"dni-plaintext\"><pre>1358.300020</pre></div></td></tr><tr><td>Remaining</td><td><div class=\"dni-plaintext\"><pre>34.089722</pre></div></td></tr><tr><td>Sold</td><td><div class=\"dni-plaintext\"><pre>1403.000030</pre></div></td></tr><tr><td>Days</td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td></tr><tr><td>Balance</td><td><div class=\"dni-plaintext\"><pre>1437.089752</pre></div></td></tr></tbody></table></div></details></td></tr><tr><td colspan=\"2\"><i>... (more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var run =\n",
" trades.Scan(seed: new\n",
" { \n",
" Buy = new { Date = DateOnly.MinValue, Price = 0m },\n",
" Sell = new { Date = DateOnly.MinValue, Price = 0m },\n",
" Account = initialBalance,\n",
" Shares = 0,\n",
" Bought = 0m,\n",
" Remaining = 0m,\n",
" Sold = 0m,\n",
" Days = 0,\n",
" Balance = initialBalance\n",
" },\n",
" (s, t) =>\n",
" { \n",
" var shares = (int)(s.Balance / t.Buy.Price);\n",
" return new\n",
" {\n",
" t.Buy,\n",
" t.Sell,\n",
" Account = s.Balance,\n",
" Shares = shares,\n",
" Bought = shares * t.Buy.Price,\n",
" Remaining = s.Balance % t.Buy.Price,\n",
" Sold = shares * t.Sell.Price,\n",
" Days = 1 + t.Sell.Date.DayNumber - t.Buy.Date.DayNumber,\n",
" Balance = shares * t.Sell.Price + (s.Balance % t.Buy.Price)\n",
" };\n",
" })\n",
" .Skip(1); // the seed\n",
"\n",
"run\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The above may be a little hard to inspect so let's flatten the structure for a more tabular output via `ToTabularDataResource`:"
]
},
{
"cell_type": "code",
"execution_count": 126,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"BuyDate,BuyPrice,SellDate,SellPrice,Account,Shares,Bought,Remaining,Sold,Days,Profit,Balance\r\n",
"10/26/2018,105.690002,11/7/2018,109.440002,1000,9,951.210018,48.789982,984.960018,13,33.750000,1033.750000\r\n",
"11/13/2018,107.550003,11/14/2018,108.099998,1033.750000,9,967.950027,65.799973,972.899982,2,4.949955,1038.699955\r\n",
"11/15/2018,104.989998,11/19/2018,108.269997,1038.699955,9,944.909982,93.789973,974.429973,5,29.519991,1068.219946\r\n",
"11/20/2018,101.800003,11/28/2018,107.889999,1068.219946,10,1018.000030,50.219916,1078.899990,9,60.899960,1129.119906\r\n",
"12/6/2018,105.820000,12/7/2018,108.379997,1129.119906,10,1058.200000,70.919906,1083.799970,2,25.599970,1154.719876\r\n",
"12/10/2018,104.800003,12/11/2018,109.800003,1154.719876,11,1152.800033,1.919843,1207.800033,2,55.000000,1209.719876\r\n",
"12/17/2018,105.410004,1/8/2019,103.040001,1209.719876,11,1159.510044,50.209832,1133.440011,23,-26.070033,1183.649843\r\n",
"1/31/2019,103.800003,2/5/2019,106.059998,1183.649843,11,1141.800033,41.849810,1166.659978,6,24.859945,1208.509788\r\n",
"2/8/2019,104.389999,2/11/2019,106.199997,1208.509788,11,1148.289989,60.219799,1168.199967,4,19.909978,1228.419766\r\n",
"3/8/2019,109.160004,3/11/2019,110.989998,1228.419766,11,1200.760044,27.659722,1220.889978,4,20.129934,1248.549700\r\n",
"5/9/2019,124.290001,5/16/2019,126.750000,1248.549700,10,1242.900010,5.649690,1267.500000,8,24.599990,1273.149690\r\n",
"5/20/2019,126.519997,5/21/2019,127.430000,1273.149690,10,1265.199970,7.949720,1274.300000,2,9.100030,1282.249720\r\n",
"5/22/2019,126.620003,5/24/2019,126.910004,1282.249720,10,1266.200030,16.049690,1269.100040,3,2.900010,1285.149730\r\n",
"5/29/2019,125.379997,6/6/2019,126.440002,1285.149730,10,1253.799970,31.349760,1264.400020,9,10.600050,1295.749780\r\n",
"7/18/2019,135.550003,7/19/2019,140.220001,1295.749780,9,1219.950027,75.799753,1261.980009,2,42.029982,1337.779762\r\n",
"8/1/2019,137.000000,8/9/2019,138.610001,1337.779762,9,1233.000000,104.779762,1247.490009,9,14.490009,1352.269771\r\n",
"8/12/2019,137.070007,8/19/2019,137.850006,1352.269771,9,1233.630063,118.639708,1240.650054,8,7.019991,1359.289762\r\n",
"8/26/2019,134.990005,8/29/2019,137.250000,1359.289762,10,1349.900050,9.389712,1372.500000,4,22.599950,1381.889712\r\n",
"9/10/2019,136.800003,9/12/2019,137.850006,1381.889712,10,1368.000030,13.889682,1378.500060,3,10.500030,1392.389742\r\n",
"9/16/2019,135.830002,9/19/2019,140.300003,1392.389742,10,1358.300020,34.089722,1403.000030,4,44.700010,1437.089752\r\n",
"9/25/2019,137.500000,9/26/2019,139.440002,1437.089752,10,1375.000000,62.089752,1394.400020,2,19.400020,1456.489772\r\n",
"9/30/2019,138.050003,10/1/2019,139.660004,1456.489772,10,1380.500030,75.989742,1396.600040,2,16.100010,1472.589782\r\n",
"10/2/2019,136.250000,10/10/2019,138.490005,1472.589782,10,1362.500000,110.089782,1384.900050,9,22.400050,1494.989832\r\n",
"10/21/2019,138.449997,10/22/2019,138.970001,1494.989832,10,1384.499970,110.489862,1389.700010,2,5.200040,1500.189872\r\n",
"10/23/2019,136.880005,10/24/2019,139.389999,1500.189872,10,1368.800050,131.389822,1393.899990,2,25.099940,1525.289812\r\n",
"12/3/2019,147.490005,12/4/2019,150.139999,1525.289812,10,1474.900050,50.389762,1501.399990,2,26.499940,1551.789752\r\n",
"1/27/2020,161.149994,1/28/2020,163.779999,1551.789752,9,1450.349946,101.439806,1474.019991,2,23.670045,1575.459797\r\n",
"2/24/2020,167.770004,3/27/2020,151.750000,1575.459797,9,1509.930036,65.529761,1365.750000,33,-144.180036,1431.279761\r\n",
"5/14/2020,177.539993,5/15/2020,179.059998,1431.279761,8,1420.319944,10.959817,1432.479984,2,12.160040,1443.439801\r\n",
"5/27/2020,180.199997,5/29/2020,182.729996,1443.439801,8,1441.599976,1.839825,1461.839968,3,20.239992,1463.679793\r\n",
"6/1/2020,182.539993,6/2/2020,184.250000,1463.679793,8,1460.319944,3.359849,1474.000000,2,13.680056,1477.359849\r\n",
"6/5/2020,182.619995,6/8/2020,185.940002,1477.359849,8,1460.959960,16.399889,1487.520016,4,26.560056,1503.919905\r\n",
"6/15/2020,184.580002,6/16/2020,192.889999,1503.919905,8,1476.640016,27.279889,1543.119992,2,66.479976,1570.399881\r\n",
"7/17/2020,204.470001,7/21/2020,213.660004,1570.399881,7,1431.290007,139.109874,1495.620028,5,64.330021,1634.729902\r\n",
"7/24/2020,200.419998,8/3/2020,211.520004,1634.729902,8,1603.359984,31.369918,1692.160032,11,88.800048,1723.529950\r\n",
"8/11/2020,207.160004,8/13/2020,209.440002,1723.529950,8,1657.280032,66.249918,1675.520016,3,18.239984,1741.769934\r\n",
"9/4/2020,215.100006,9/28/2020,210.880005,1741.769934,8,1720.800048,20.969886,1687.040040,25,-33.760008,1708.009926\r\n",
"9/29/2020,209.350006,10/1/2020,213.490005,1708.009926,8,1674.800048,33.209878,1707.920040,3,33.119992,1741.129918\r\n",
"10/26/2020,213.850006,11/4/2020,214.020004,1741.129918,8,1710.800048,30.329870,1712.160032,10,1.359984,1742.489902\r\n",
"11/11/2020,212.389999,11/12/2020,217.210007,1742.489902,8,1699.119992,43.369910,1737.680056,2,38.560064,1781.049966\r\n",
"11/19/2020,211.380005,11/25/2020,215.110001,1781.049966,8,1691.040040,90.009926,1720.880008,7,29.839968,1810.889934\r\n",
"11/30/2020,214.100006,12/9/2020,215.160004,1810.889934,8,1712.800048,98.089886,1721.280032,10,8.479984,1819.369918\r\n",
"12/10/2020,211.770004,12/15/2020,215.169998,1819.369918,8,1694.160032,125.209886,1721.359984,6,27.199952,1846.569870\r\n",
"1/5/2021,217.259995,1/8/2021,218.679993,1846.569870,8,1738.079960,108.489910,1749.439944,4,11.359984,1857.929854\r\n",
"1/11/2021,218.470001,1/21/2021,224.699997,1857.929854,8,1747.760008,110.169846,1797.599976,11,49.839968,1907.769822\r\n",
"2/22/2021,237.419998,3/10/2021,237.000000,1907.769822,8,1899.359984,8.409838,1896.000000,17,-3.359984,1904.409838\r\n",
"3/11/2021,234.960007,3/16/2021,236.279999,1904.409838,8,1879.680056,24.729782,1890.239992,6,10.559936,1914.969774\r\n",
"3/18/2021,232.559998,3/23/2021,237.490005,1914.969774,8,1860.479984,54.489790,1899.920040,6,39.440056,1954.409830\r\n",
"3/26/2021,231.550003,3/29/2021,236.589996,1954.409830,8,1852.400024,102.009806,1892.719968,4,40.319944,1994.729774\r\n",
"3/30/2021,233.529999,4/1/2021,238.470001,1994.729774,8,1868.239992,126.489782,1907.760008,3,39.520016,2034.249790\r\n",
"4/30/2021,249.740005,5/25/2021,251.770004,2034.249790,8,1997.920040,36.329750,2014.160032,26,16.239992,2050.489782\r\n",
"6/3/2021,245.220001,6/4/2021,247.759995,2050.489782,8,1961.760008,88.729774,1982.079960,2,20.319952,2070.809734\r\n",
"9/10/2021,298.420013,9/15/2021,303.260010,2070.809734,6,1790.520078,280.289656,1819.560060,6,29.039982,2099.849716\r\n",
"9/20/2021,296.329987,10/7/2021,295.179993,2099.849716,7,2074.309909,25.539807,2066.259951,18,-8.049958,2091.799758\r\n",
"10/11/2021,292.920013,10/12/2021,295.339996,2091.799758,7,2050.440091,41.359667,2067.379972,2,16.939881,2108.739639\r\n",
"11/26/2021,334.350006,12/8/2021,335.309998,2108.739639,6,2006.100036,102.639603,2011.859988,13,5.759952,2114.499591\r\n",
"12/9/2021,334.410004,12/13/2021,340.679993,2114.499591,6,2006.460024,108.039567,2044.079958,5,37.619934,2152.119525\r\n",
"12/14/2021,333.220001,12/16/2021,335.709991,2152.119525,6,1999.320006,152.799519,2014.259946,3,14.939940,2167.059465\r\n",
"12/17/2021,320.880005,12/23/2021,332.750000,2167.059465,6,1925.280030,241.779435,1996.500000,7,71.219970,2238.279435\r\n",
"1/5/2022,325.859985,2/1/2022,310.410004,2238.279435,6,1955.159910,283.119525,1862.460024,28,-92.699886,2145.579549\r\n",
"2/4/2022,300.209991,2/9/2022,309.869995,2145.579549,7,2101.469937,44.109612,2169.089965,6,67.620028,2213.199577\r\n",
"2/10/2022,304.040009,3/3/2022,302.890015,2213.199577,7,2128.280063,84.919514,2120.230105,22,-8.049958,2205.149619\r\n",
"3/4/2022,294.290009,3/17/2022,293.290009,2205.149619,7,2060.030063,145.119556,2053.030063,14,-7.000000,2198.149619\r\n",
"4/7/2022,296.660004,5/5/2022,285.540009,2198.149619,7,2076.620028,121.529591,1998.780063,29,-77.839965,2120.309654\r\n",
"5/6/2022,274.809998,5/27/2022,268.480011,2120.309654,7,1923.669986,196.639668,1879.360077,22,-44.309909,2075.999745\r\n",
"6/2/2022,264.450012,6/3/2022,270.309998,2075.999745,7,1851.150084,224.849661,1892.169986,2,41.019902,2117.019647\r\n",
"6/10/2022,260.579987,6/24/2022,261.809998,2117.019647,8,2084.639896,32.379751,2094.479984,15,9.840088,2126.859735\r\n",
"6/29/2022,257.589996,7/6/2022,263.750000,2126.859735,8,2060.719968,66.139767,2110.000000,8,49.280032,2176.139767\r\n",
"7/13/2022,250.190002,7/18/2022,259.750000,2176.139767,8,2001.520016,174.619751,2078.000000,6,76.479984,2252.619751\r\n",
"7/19/2022,257.579987,7/20/2022,259.899994,2252.619751,8,2060.639896,191.979855,2079.199952,2,18.560056,2271.179807\r\n",
"8/23/2022,276.440002,10/5/2022,245.990005,2271.179807,8,2211.520016,59.659791,1967.920040,44,-243.599976,2027.579831\r\n",
"10/7/2022,240.899994,10/18/2022,243.240005,2027.579831,8,1927.199952,100.379879,1945.920040,12,18.720088,2046.299919\r\n",
"10/19/2022,237.039993,10/24/2022,243.759995,2046.299919,8,1896.319944,149.979975,1950.079960,6,53.760016,2100.059935\r\n",
"10/26/2022,231.169998,11/10/2022,235.429993,2100.059935,9,2080.529982,19.529953,2118.869937,16,38.339955,2138.399890\r\n",
"12/9/2022,244.699997,12/12/2022,247.449997,2138.399890,8,1957.599976,180.799914,1979.599976,4,22.000000,2160.399890\r\n",
"12/19/2022,244.860001,1/13/2023,237.000000,2160.399890,8,1958.880008,201.519882,1896.000000,26,-62.880008,2097.519882\r\n",
"1/19/2023,233.779999,1/23/2023,241.100006,2097.519882,8,1870.239992,227.279890,1928.800048,5,58.560056,2156.079938\r\n",
"1/25/2023,234.479996,1/26/2023,243.649994,2156.079938,9,2110.319964,45.759974,2192.849946,2,82.529982,2238.609920\r\n",
"2/21/2023,254.479996,3/14/2023,256.750000,2238.609920,8,2035.839968,202.769952,2054.000000,22,18.160032,2256.769952\r\n",
"4/24/2023,282.089996,4/26/2023,296.700012,2256.769952,8,2256.719968,0.049984,2373.600096,3,116.880128,2373.650080\r\n",
"6/27/2023,331.859985,6/28/2023,334.660004,2373.650080,7,2323.019895,50.630185,2342.620028,2,19.600133,2393.250213\r\n",
"7/10/2023,334.600006,7/12/2023,336.600006,2393.250213,7,2342.200042,51.050171,2356.200042,3,14.000000,2407.250213\r\n",
"7/26/2023,341.440002,8/24/2023,332.850006,2407.250213,7,2390.080014,17.170199,2329.950042,30,-60.129972,2347.120241\r\n",
"8/25/2023,321.470001,8/28/2023,325.660004,2347.120241,7,2250.290007,96.830234,2279.620028,4,29.330021,2376.450262\r\n",
"8/29/2023,321.880005,8/30/2023,328.670013,2376.450262,7,2253.160035,123.290227,2300.690091,2,47.530056,2423.980318\r\n"
],
"text/html": [
"<table><thead><tr><td><span>BuyDate</span></td><td><span>BuyPrice</span></td><td><span>SellDate</span></td><td><span>SellPrice</span></td><td><span>Account</span></td><td><span>Shares</span></td><td><span>Bought</span></td><td><span>Remaining</span></td><td><span>Sold</span></td><td><span>Days</span></td><td><span>Profit</span></td><td><span>Balance</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1000</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>951.210018</pre></div></td><td><div class=\"dni-plaintext\"><pre>48.789982</pre></div></td><td><div class=\"dni-plaintext\"><pre>984.960018</pre></div></td><td><div class=\"dni-plaintext\"><pre>13</pre></div></td><td><div class=\"dni-plaintext\"><pre>33.750000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>967.950027</pre></div></td><td><div class=\"dni-plaintext\"><pre>65.799973</pre></div></td><td><div class=\"dni-plaintext\"><pre>972.899982</pre></div></td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td><td><div class=\"dni-plaintext\"><pre>4.949955</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>944.909982</pre></div></td><td><div class=\"dni-plaintext\"><pre>93.789973</pre></div></td><td><div class=\"dni-plaintext\"><pre>974.429973</pre></div></td><td><div class=\"dni-plaintext\"><pre>5</pre></div></td><td><div class=\"dni-plaintext\"><pre>29.519991</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1018.000030</pre></div></td><td><div class=\"dni-plaintext\"><pre>50.219916</pre></div></td><td><div class=\"dni-plaintext\"><pre>1078.899990</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>60.899960</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-12-06\">Dec 06, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.820000</pre></div></td><td><time datetime=\"2018-12-07\">Dec 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.379997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1058.200000</pre></div></td><td><div class=\"dni-plaintext\"><pre>70.919906</pre></div></td><td><div class=\"dni-plaintext\"><pre>1083.799970</pre></div></td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td><td><div class=\"dni-plaintext\"><pre>25.599970</pre></div></td><td><div class=\"dni-plaintext\"><pre>1154.719876</pre></div></td></tr><tr><td><time datetime=\"2018-12-10\">Dec 10, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.800003</pre></div></td><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1154.719876</pre></div></td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td><td><div class=\"dni-plaintext\"><pre>1152.800033</pre></div></td><td><div class=\"dni-plaintext\"><pre>1.919843</pre></div></td><td><div class=\"dni-plaintext\"><pre>1207.800033</pre></div></td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td><td><div class=\"dni-plaintext\"><pre>55.000000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1209.719876</pre></div></td></tr><tr><td><time datetime=\"2018-12-17\">Dec 17, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.410004</pre></div></td><td><time datetime=\"2019-01-08\">Jan 08, 2019</time></td><td><div class=\"dni-plaintext\"><pre>103.040001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1209.719876</pre></div></td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td><td><div class=\"dni-plaintext\"><pre>1159.510044</pre></div></td><td><div class=\"dni-plaintext\"><pre>50.209832</pre></div></td><td><div class=\"dni-plaintext\"><pre>1133.440011</pre></div></td><td><div class=\"dni-plaintext\"><pre>23</pre></div></td><td><div class=\"dni-plaintext\"><pre>-26.070033</pre></div></td><td><div class=\"dni-plaintext\"><pre>1183.649843</pre></div></td></tr><tr><td><time datetime=\"2019-01-31\">Jan 31, 2019</time></td><td><div class=\"dni-plaintext\"><pre>103.800003</pre></div></td><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1183.649843</pre></div></td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td><td><div class=\"dni-plaintext\"><pre>1141.800033</pre></div></td><td><div class=\"dni-plaintext\"><pre>41.849810</pre></div></td><td><div class=\"dni-plaintext\"><pre>1166.659978</pre></div></td><td><div class=\"dni-plaintext\"><pre>6</pre></div></td><td><div class=\"dni-plaintext\"><pre>24.859945</pre></div></td><td><div class=\"dni-plaintext\"><pre>1208.509788</pre></div></td></tr><tr><td><time datetime=\"2019-02-08\">Feb 08, 2019</time></td><td><div class=\"dni-plaintext\"><pre>104.389999</pre></div></td><td><time datetime=\"2019-02-11\">Feb 11, 2019</time></td><td><div class=\"dni-plaintext\"><pre>106.199997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1208.509788</pre></div></td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td><td><div class=\"dni-plaintext\"><pre>1148.289989</pre></div></td><td><div class=\"dni-plaintext\"><pre>60.219799</pre></div></td><td><div class=\"dni-plaintext\"><pre>1168.199967</pre></div></td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td><td><div class=\"dni-plaintext\"><pre>19.909978</pre></div></td><td><div class=\"dni-plaintext\"><pre>1228.419766</pre></div></td></tr><tr><td><time datetime=\"2019-03-08\">Mar 08, 2019</time></td><td><div class=\"dni-plaintext\"><pre>109.160004</pre></div></td><td><time datetime=\"2019-03-11\">Mar 11, 2019</time></td><td><div class=\"dni-plaintext\"><pre>110.989998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1228.419766</pre></div></td><td><div class=\"dni-plaintext\"><pre>11</pre></div></td><td><div class=\"dni-plaintext\"><pre>1200.760044</pre></div></td><td><div class=\"dni-plaintext\"><pre>27.659722</pre></div></td><td><div class=\"dni-plaintext\"><pre>1220.889978</pre></div></td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td><td><div class=\"dni-plaintext\"><pre>20.129934</pre></div></td><td><div class=\"dni-plaintext\"><pre>1248.549700</pre></div></td></tr><tr><td><time datetime=\"2019-05-09\">May 09, 2019</time></td><td><div class=\"dni-plaintext\"><pre>124.290001</pre></div></td><td><time datetime=\"2019-05-16\">May 16, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.750000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1248.549700</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1242.900010</pre></div></td><td><div class=\"dni-plaintext\"><pre>5.649690</pre></div></td><td><div class=\"dni-plaintext\"><pre>1267.500000</pre></div></td><td><div class=\"dni-plaintext\"><pre>8</pre></div></td><td><div class=\"dni-plaintext\"><pre>24.599990</pre></div></td><td><div class=\"dni-plaintext\"><pre>1273.149690</pre></div></td></tr><tr><td><time datetime=\"2019-05-20\">May 20, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.519997</pre></div></td><td><time datetime=\"2019-05-21\">May 21, 2019</time></td><td><div class=\"dni-plaintext\"><pre>127.430000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1273.149690</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1265.199970</pre></div></td><td><div class=\"dni-plaintext\"><pre>7.949720</pre></div></td><td><div class=\"dni-plaintext\"><pre>1274.300000</pre></div></td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td><td><div class=\"dni-plaintext\"><pre>9.100030</pre></div></td><td><div class=\"dni-plaintext\"><pre>1282.249720</pre></div></td></tr><tr><td><time datetime=\"2019-05-22\">May 22, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.620003</pre></div></td><td><time datetime=\"2019-05-24\">May 24, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.910004</pre></div></td><td><div class=\"dni-plaintext\"><pre>1282.249720</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1266.200030</pre></div></td><td><div class=\"dni-plaintext\"><pre>16.049690</pre></div></td><td><div class=\"dni-plaintext\"><pre>1269.100040</pre></div></td><td><div class=\"dni-plaintext\"><pre>3</pre></div></td><td><div class=\"dni-plaintext\"><pre>2.900010</pre></div></td><td><div class=\"dni-plaintext\"><pre>1285.149730</pre></div></td></tr><tr><td><time datetime=\"2019-05-29\">May 29, 2019</time></td><td><div class=\"dni-plaintext\"><pre>125.379997</pre></div></td><td><time datetime=\"2019-06-06\">Jun 06, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1285.149730</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1253.799970</pre></div></td><td><div class=\"dni-plaintext\"><pre>31.349760</pre></div></td><td><div class=\"dni-plaintext\"><pre>1264.400020</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>10.600050</pre></div></td><td><div class=\"dni-plaintext\"><pre>1295.749780</pre></div></td></tr><tr><td><time datetime=\"2019-07-18\">Jul 18, 2019</time></td><td><div class=\"dni-plaintext\"><pre>135.550003</pre></div></td><td><time datetime=\"2019-07-19\">Jul 19, 2019</time></td><td><div class=\"dni-plaintext\"><pre>140.220001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1295.749780</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>1219.950027</pre></div></td><td><div class=\"dni-plaintext\"><pre>75.799753</pre></div></td><td><div class=\"dni-plaintext\"><pre>1261.980009</pre></div></td><td><div class=\"dni-plaintext\"><pre>2</pre></div></td><td><div class=\"dni-plaintext\"><pre>42.029982</pre></div></td><td><div class=\"dni-plaintext\"><pre>1337.779762</pre></div></td></tr><tr><td><time datetime=\"2019-08-01\">Aug 01, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.000000</pre></div></td><td><time datetime=\"2019-08-09\">Aug 09, 2019</time></td><td><div class=\"dni-plaintext\"><pre>138.610001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1337.779762</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>1233.000000</pre></div></td><td><div class=\"dni-plaintext\"><pre>104.779762</pre></div></td><td><div class=\"dni-plaintext\"><pre>1247.490009</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>14.490009</pre></div></td><td><div class=\"dni-plaintext\"><pre>1352.269771</pre></div></td></tr><tr><td><time datetime=\"2019-08-12\">Aug 12, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.070007</pre></div></td><td><time datetime=\"2019-08-19\">Aug 19, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td><td><div class=\"dni-plaintext\"><pre>1352.269771</pre></div></td><td><div class=\"dni-plaintext\"><pre>9</pre></div></td><td><div class=\"dni-plaintext\"><pre>1233.630063</pre></div></td><td><div class=\"dni-plaintext\"><pre>118.639708</pre></div></td><td><div class=\"dni-plaintext\"><pre>1240.650054</pre></div></td><td><div class=\"dni-plaintext\"><pre>8</pre></div></td><td><div class=\"dni-plaintext\"><pre>7.019991</pre></div></td><td><div class=\"dni-plaintext\"><pre>1359.289762</pre></div></td></tr><tr><td><time datetime=\"2019-08-26\">Aug 26, 2019</time></td><td><div class=\"dni-plaintext\"><pre>134.990005</pre></div></td><td><time datetime=\"2019-08-29\">Aug 29, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.250000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1359.289762</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1349.900050</pre></div></td><td><div class=\"dni-plaintext\"><pre>9.389712</pre></div></td><td><div class=\"dni-plaintext\"><pre>1372.500000</pre></div></td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td><td><div class=\"dni-plaintext\"><pre>22.599950</pre></div></td><td><div class=\"dni-plaintext\"><pre>1381.889712</pre></div></td></tr><tr><td><time datetime=\"2019-09-10\">Sep 10, 2019</time></td><td><div class=\"dni-plaintext\"><pre>136.800003</pre></div></td><td><time datetime=\"2019-09-12\">Sep 12, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td><td><div class=\"dni-plaintext\"><pre>1381.889712</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1368.000030</pre></div></td><td><div class=\"dni-plaintext\"><pre>13.889682</pre></div></td><td><div class=\"dni-plaintext\"><pre>1378.500060</pre></div></td><td><div class=\"dni-plaintext\"><pre>3</pre></div></td><td><div class=\"dni-plaintext\"><pre>10.500030</pre></div></td><td><div class=\"dni-plaintext\"><pre>1392.389742</pre></div></td></tr><tr><td><time datetime=\"2019-09-16\">Sep 16, 2019</time></td><td><div class=\"dni-plaintext\"><pre>135.830002</pre></div></td><td><time datetime=\"2019-09-19\">Sep 19, 2019</time></td><td><div class=\"dni-plaintext\"><pre>140.300003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1392.389742</pre></div></td><td><div class=\"dni-plaintext\"><pre>10</pre></div></td><td><div class=\"dni-plaintext\"><pre>1358.300020</pre></div></td><td><div class=\"dni-plaintext\"><pre>34.089722</pre></div></td><td><div class=\"dni-plaintext\"><pre>1403.000030</pre></div></td><td><div class=\"dni-plaintext\"><pre>4</pre></div></td><td><div class=\"dni-plaintext\"><pre>44.700010</pre></div></td><td><div class=\"dni-plaintext\"><pre>1437.089752</pre></div></td></tr><tr><td colspan=\"12\"><i>(65 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var table =\n",
" from e in run\n",
" select new\n",
" {\n",
" BuyDate = e.Buy.Date,\n",
" BuyPrice = e.Buy.Price,\n",
" SellDate = e.Sell.Date,\n",
" SellPrice = e.Sell.Price,\n",
" e.Account,\n",
" e.Shares,\n",
" e.Bought,\n",
" e.Remaining,\n",
" e.Sold,\n",
" e.Days,\n",
" Profit = e.Balance - e.Account,\n",
" e.Balance, \n",
" };\n",
"\n",
"table.ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"That's better!\n",
"\n",
"The classical way to write to more or less get the same outcome without `Scan` would have been to restore to a classical `for` loop:"
]
},
{
"cell_type": "code",
"execution_count": 127,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Buy Date / Price | Sell Date / Price | Account | Shares | Bought | Remaining | Sold | Days | Balance\n",
"------------------------|-------------------------|----------|--------|------------|------------|------------|------|-----------\n",
"Oct 26, 2018 / 105.69 | Nov 07, 2018 / 109.44 | 1,033.75 | 9 | 951.21 | 82.54 | 984.96 | 13 | 1,033.75\n",
"Nov 13, 2018 / 107.55 | Nov 14, 2018 / 108.10 | 1,038.70 | 9 | 967.95 | 70.75 | 972.90 | 2 | 1,038.70\n",
"Nov 15, 2018 / 104.99 | Nov 19, 2018 / 108.27 | 1,068.22 | 9 | 944.91 | 18.32 | 974.43 | 5 | 1,068.22\n",
"Nov 20, 2018 / 101.80 | Nov 28, 2018 / 107.89 | 1,129.12 | 10 | 1,018.00 | 9.32 | 1,078.90 | 9 | 1,129.12\n",
"Dec 06, 2018 / 105.82 | Dec 07, 2018 / 108.38 | 1,154.72 | 10 | 1,058.20 | 96.52 | 1,083.80 | 2 | 1,154.72\n",
"Dec 10, 2018 / 104.80 | Dec 11, 2018 / 109.80 | 1,209.72 | 11 | 1,152.80 | 56.92 | 1,207.80 | 2 | 1,209.72\n",
"Dec 17, 2018 / 105.41 | Jan 08, 2019 / 103.04 | 1,183.65 | 11 | 1,159.51 | 24.14 | 1,133.44 | 23 | 1,183.65\n",
"Jan 31, 2019 / 103.80 | Feb 05, 2019 / 106.06 | 1,208.51 | 11 | 1,141.80 | 66.71 | 1,166.66 | 6 | 1,208.51\n",
"Feb 08, 2019 / 104.39 | Feb 11, 2019 / 106.20 | 1,228.42 | 11 | 1,148.29 | 80.13 | 1,168.20 | 4 | 1,228.42\n",
"Mar 08, 2019 / 109.16 | Mar 11, 2019 / 110.99 | 1,248.55 | 11 | 1,200.76 | 47.79 | 1,220.89 | 4 | 1,248.55\n",
"May 09, 2019 / 124.29 | May 16, 2019 / 126.75 | 1,273.15 | 10 | 1,242.90 | 30.25 | 1,267.50 | 8 | 1,273.15\n",
"May 20, 2019 / 126.52 | May 21, 2019 / 127.43 | 1,282.25 | 10 | 1,265.20 | 17.05 | 1,274.30 | 2 | 1,282.25\n",
"May 22, 2019 / 126.62 | May 24, 2019 / 126.91 | 1,285.15 | 10 | 1,266.20 | 18.95 | 1,269.10 | 3 | 1,285.15\n",
"May 29, 2019 / 125.38 | Jun 06, 2019 / 126.44 | 1,295.75 | 10 | 1,253.80 | 41.95 | 1,264.40 | 9 | 1,295.75\n",
"Jul 18, 2019 / 135.55 | Jul 19, 2019 / 140.22 | 1,337.78 | 9 | 1,219.95 | 117.83 | 1,261.98 | 2 | 1,337.78\n",
"Aug 01, 2019 / 137.00 | Aug 09, 2019 / 138.61 | 1,352.27 | 9 | 1,233.00 | 119.27 | 1,247.49 | 9 | 1,352.27\n",
"Aug 12, 2019 / 137.07 | Aug 19, 2019 / 137.85 | 1,359.29 | 9 | 1,233.63 | 125.66 | 1,240.65 | 8 | 1,359.29\n",
"Aug 26, 2019 / 134.99 | Aug 29, 2019 / 137.25 | 1,381.89 | 10 | 1,349.90 | 31.99 | 1,372.50 | 4 | 1,381.89\n",
"Sep 10, 2019 / 136.80 | Sep 12, 2019 / 137.85 | 1,392.39 | 10 | 1,368.00 | 24.39 | 1,378.50 | 3 | 1,392.39\n",
"Sep 16, 2019 / 135.83 | Sep 19, 2019 / 140.30 | 1,437.09 | 10 | 1,358.30 | 78.79 | 1,403.00 | 4 | 1,437.09\n"
]
}
],
"source": [
"var balance = initialBalance;\n",
"\n",
"Console.WriteLine(\"Buy Date / Price | Sell Date / Price | Account | Shares | Bought | Remaining | Sold | Days | Balance\");\n",
"Console.WriteLine(\"------------------------|-------------------------|----------|--------|------------|------------|------------|------|-----------\");\n",
"\n",
"foreach (var t in trades.Take(20))\n",
"{\n",
" var shares = (int)(balance / t.Buy.Price);\n",
" var newBalance = balance = shares * t.Sell.Price + (balance % t.Buy.Price);\n",
" Console.WriteLine(@$\"{t.Buy.Date:MMM dd, yyyy} / {t.Buy.Price,8:N2} | \" +\n",
" @$\"{t.Sell.Date:MMM dd, yyyy} / {t.Sell.Price,8:N2} | \" +\n",
" @$\"{balance:N2} | {shares,6} | {shares * t.Buy.Price,10:N2} | {balance % t.Buy.Price,10:N2} | \" +\n",
" @$\"{shares * t.Sell.Price,10:N2} | {1 + t.Sell.Date.DayNumber - t.Buy.Date.DayNumber,4} | {newBalance,10:N2}\");\n",
" balance = newBalance;\n",
"}"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"However, `Scan` is more powerful, especially when you want to continue to build on top of its result by composing additional operators from LINQ or MoreLINQ. With a `for` loop, you end up breaking the flow, having to build a list to continue any further processing you might still need.\n",
"\n",
"Enough with the tables and streams of data dumps so just for kicks and something more visual, let's use [ScottPlot] to plot the stock price along with the moving average and then add bars to show when we sold and what the portfolio balance was on the day:\n",
"\n",
"[ScottPlot]: https://scottplot.net/"
]
},
{
"cell_type": "code",
"execution_count": 128,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<div><div></div><div></div><div><strong>Installed Packages</strong><ul><li><span>ScottPlot, 4.1.69</span></li></ul></div></div>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\"></img>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"#r \"nuget:ScottPlot, 4.1.69\"\n",
"\n",
"using System.Drawing;\n",
"using System.Runtime.InteropServices;\n",
"using ScottPlot;\n",
"\n",
"// Convenience extension method to convert `DateOnly` to `OADate`:\n",
"public static double ToOADate(this DateOnly date) => date.ToDateTime(default, DateTimeKind.Utc).ToOADate();\n",
"\n",
"var isWindows = RuntimeInformation.IsOSPlatform(OSPlatform.Windows);\n",
"if (isWindows)\n",
"{\n",
" Formatter.Register(typeof(Plot), (p, w) => \n",
" w.Write(((Plot)p).GetImageHtml()), HtmlFormatter.MimeType);\n",
"\n",
" var plot = new Plot(1000, 400);\n",
" plot.XAxis.DateTimeFormat(true);\n",
" plot.YAxis.Label(\"Price\");\n",
" plot.YAxis2.Label(\"Balance\");\n",
" plot.YAxis2.Ticks(true);\n",
"\n",
" plot.AddScatter(data.Select(e => e.Date.ToOADate()).ToArray(),\n",
" data.Select(e => (double)e.Price).ToArray(),\n",
" markerShape: MarkerShape.none);\n",
"\n",
" plot.AddScatter(mavg.Select(e => e.Date.ToOADate()).ToArray(),\n",
" mavg.Select(e => (double)e.Avg).ToArray(),\n",
" markerShape: MarkerShape.none);\n",
"\n",
" plot.AddBar(run.Select(e => (double)e.Balance).ToArray(),\n",
" run.Select(e => e.Sell.Date.ToOADate()).ToArray())\n",
" .YAxisIndex = 1;\n",
"\n",
" plot.Display();\n",
"}"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's go back to the original trade data we have in `data` and connect the results from our strategy run in `run` so we can see the latter as a continiuous (as opposed to a discrete) time series. To connect the two, we will use [`OrderedMerge`] from MoreLINQ next. As the name implies, `OrderedMerge` *merges* or combines two source sequences into one and both sources are assumed to be sorted, or *ordered* by a common and unique key (otherwise there won't be any error but the result is undefined). `OrderedMerge` is like a [full outer join], but it's a lot more efficient in terms of memory because it can operate without materializing either of the sequence thanks precisely to the assumption that the sequence keys are ordered. It's quite common for time series data to be generally ordered by time and so it fits naturally with the requirements of `OrderedMerge`.\n",
"\n",
"[`OrderedMerge`]: https://morelinq.github.io/4.0/ref/api/html/Overload_MoreLinq_MoreEnumerable_OrderedMerge.htm\n",
"[full outer join]: https://en.wikipedia.org/wiki/Join_(SQL)#Full_outer_join"
]
},
{
"cell_type": "code",
"execution_count": 129,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Balance\r\n",
"10/1/2018,114.750000,\r\n",
"10/2/2018,115.300003,\r\n",
"10/3/2018,115.419998,\r\n",
"10/4/2018,114.610001,\r\n",
"10/5/2018,112.629997,\r\n",
"10/8/2018,111.660004,\r\n",
"10/9/2018,111.139999,\r\n",
"10/10/2018,111.239998,\r\n",
"10/11/2018,105.349998,\r\n",
"10/12/2018,109.010002,\r\n",
"10/15/2018,108.910004,\r\n",
"10/16/2018,109.540001,\r\n",
"10/17/2018,111.680000,\r\n",
"10/18/2018,110.099998,\r\n",
"10/19/2018,108.930000,\r\n",
"10/22/2018,109.320000,\r\n",
"10/23/2018,107.769997,\r\n",
"10/24/2018,108.410004,\r\n",
"10/25/2018,106.550003,\r\n",
"10/26/2018,105.690002,\r\n",
"10/29/2018,108.110001,\r\n",
"10/30/2018,103.660004,\r\n",
"10/31/2018,105.440002,\r\n",
"11/1/2018,107.050003,\r\n",
"11/2/2018,106.480003,\r\n",
"11/5/2018,106.370003,\r\n",
"11/6/2018,107.379997,\r\n",
"11/7/2018,109.440002,1033.750000\r\n",
"11/8/2018,111.800003,\r\n",
"11/9/2018,110.849998,\r\n",
"11/12/2018,109.419998,\r\n",
"11/13/2018,107.550003,\r\n",
"11/14/2018,108.099998,1038.699955\r\n",
"11/15/2018,104.989998,\r\n",
"11/16/2018,107.080002,\r\n",
"11/19/2018,108.269997,1068.219946\r\n",
"11/20/2018,101.800003,\r\n",
"11/21/2018,103.599998,\r\n",
"11/23/2018,102.169998,\r\n",
"11/26/2018,104.790001,\r\n",
"11/27/2018,106.269997,\r\n",
"11/28/2018,107.889999,1129.119906\r\n",
"11/29/2018,110.330002,\r\n",
"11/30/2018,110.699997,\r\n",
"12/3/2018,113.000000,\r\n",
"12/4/2018,111.940002,\r\n",
"12/6/2018,105.820000,\r\n",
"12/7/2018,108.379997,1154.719876\r\n",
"12/10/2018,104.800003,\r\n",
"12/11/2018,109.800003,1209.719876\r\n",
"12/12/2018,110.889999,\r\n",
"12/13/2018,109.580002,\r\n",
"12/14/2018,108.250000,\r\n",
"12/17/2018,105.410004,\r\n",
"12/18/2018,103.750000,\r\n",
"12/19/2018,103.650002,\r\n",
"12/20/2018,103.050003,\r\n",
"12/21/2018,101.629997,\r\n",
"12/24/2018,97.680000,\r\n",
"12/26/2018,95.139999,\r\n",
"12/27/2018,99.300003,\r\n",
"12/28/2018,102.089996,\r\n",
"12/31/2018,101.290001,\r\n",
"1/2/2019,99.550003,\r\n",
"1/3/2019,100.099998,\r\n",
"1/4/2019,99.720001,\r\n",
"1/7/2019,101.639999,\r\n",
"1/8/2019,103.040001,1183.649843\r\n",
"1/9/2019,103.860001,\r\n",
"1/10/2019,103.220001,\r\n",
"1/11/2019,103.190002,\r\n",
"1/14/2019,101.900002,\r\n",
"1/15/2019,102.510002,\r\n",
"1/16/2019,105.260002,\r\n",
"1/17/2019,105.000000,\r\n",
"1/18/2019,107.459999,\r\n",
"1/22/2019,106.750000,\r\n",
"1/23/2019,106.120003,\r\n",
"1/24/2019,106.860001,\r\n",
"1/25/2019,107.239998,\r\n",
"1/28/2019,106.260002,\r\n",
"1/29/2019,104.879997,\r\n",
"1/30/2019,104.620003,\r\n",
"1/31/2019,103.800003,\r\n",
"2/1/2019,103.779999,\r\n",
"2/4/2019,102.870003,\r\n",
"2/5/2019,106.059998,1208.509788\r\n",
"2/6/2019,107.000000,\r\n",
"2/7/2019,105.190002,\r\n",
"2/8/2019,104.389999,\r\n",
"2/11/2019,106.199997,1228.419766\r\n",
"2/12/2019,106.139999,\r\n",
"2/13/2019,107.500000,\r\n",
"2/14/2019,106.309998,\r\n",
"2/15/2019,107.910004,\r\n",
"2/19/2019,107.790001,\r\n",
"2/20/2019,107.860001,\r\n",
"2/21/2019,106.900002,\r\n",
"2/22/2019,110.050003,\r\n",
"2/25/2019,111.760002,\r\n",
"2/26/2019,111.260002,\r\n",
"2/27/2019,111.690002,\r\n",
"2/28/2019,112.040001,\r\n",
"3/1/2019,112.889999,\r\n",
"3/4/2019,113.019997,\r\n",
"3/5/2019,112.250000,\r\n",
"3/6/2019,111.870003,\r\n",
"3/7/2019,111.400002,\r\n",
"3/8/2019,109.160004,\r\n",
"3/11/2019,110.989998,1248.549700\r\n",
"3/12/2019,112.820000,\r\n",
"3/13/2019,114.129997,\r\n",
"3/14/2019,114.540001,\r\n",
"3/15/2019,115.339996,\r\n",
"3/18/2019,116.169998,\r\n",
"3/19/2019,118.089996,\r\n",
"3/20/2019,117.389999,\r\n",
"3/21/2019,117.139999,\r\n",
"3/22/2019,119.500000,\r\n",
"3/25/2019,116.559998,\r\n",
"3/26/2019,118.620003,\r\n",
"3/27/2019,117.879997,\r\n",
"3/28/2019,117.440002,\r\n",
"3/29/2019,118.070000,\r\n",
"4/1/2019,118.949997,\r\n",
"4/2/2019,119.059998,\r\n",
"4/3/2019,119.860001,\r\n",
"4/4/2019,120.099998,\r\n",
"4/5/2019,119.389999,\r\n",
"4/8/2019,119.809998,\r\n",
"4/9/2019,118.629997,\r\n",
"4/10/2019,119.760002,\r\n",
"4/11/2019,120.540001,\r\n",
"4/12/2019,120.639999,\r\n",
"4/15/2019,120.940002,\r\n",
"4/16/2019,121.639999,\r\n",
"4/17/2019,121.239998,\r\n",
"4/18/2019,122.190002,\r\n",
"4/22/2019,122.620003,\r\n",
"4/23/2019,124.099998,\r\n",
"4/24/2019,125.790001,\r\n",
"4/25/2019,130.059998,\r\n",
"4/26/2019,129.699997,\r\n",
"4/29/2019,129.899994,\r\n",
"4/30/2019,129.809998,\r\n",
"5/1/2019,130.529999,\r\n",
"5/2/2019,127.980003,\r\n",
"5/3/2019,127.360001,\r\n",
"5/6/2019,126.389999,\r\n",
"5/7/2019,126.459999,\r\n",
"5/8/2019,125.440002,\r\n",
"5/9/2019,124.290001,\r\n",
"5/10/2019,124.910004,\r\n",
"5/13/2019,124.110001,\r\n",
"5/14/2019,123.870003,\r\n",
"5/15/2019,124.260002,\r\n",
"5/16/2019,126.750000,1273.149690\r\n",
"5/17/2019,128.309998,\r\n",
"5/20/2019,126.519997,\r\n",
"5/21/2019,127.430000,1282.249720\r\n",
"5/22/2019,126.620003,\r\n",
"5/23/2019,126.199997,\r\n",
"5/24/2019,126.910004,1285.149730\r\n",
"5/28/2019,126.980003,\r\n",
"5/29/2019,125.379997,\r\n",
"5/30/2019,125.260002,\r\n",
"5/31/2019,124.230003,\r\n",
"6/3/2019,123.849998,\r\n",
"6/4/2019,121.279999,\r\n",
"6/5/2019,124.949997,\r\n",
"6/6/2019,126.440002,1295.749780\r\n",
"6/7/2019,129.190002,\r\n",
"6/10/2019,132.399994,\r\n",
"6/11/2019,133.880005,\r\n",
"6/12/2019,131.399994,\r\n",
"6/13/2019,131.979996,\r\n",
"6/14/2019,132.259995,\r\n",
"6/17/2019,132.630005,\r\n",
"6/18/2019,134.190002,\r\n",
"6/19/2019,135.000000,\r\n",
"6/20/2019,137.449997,\r\n",
"6/21/2019,136.580002,\r\n",
"6/24/2019,137.000000,\r\n",
"6/25/2019,137.250000,\r\n",
"6/26/2019,134.350006,\r\n",
"6/27/2019,134.139999,\r\n",
"6/28/2019,134.570007,\r\n",
"7/1/2019,136.630005,\r\n",
"7/2/2019,136.119995,\r\n",
"7/3/2019,136.800003,\r\n",
"7/5/2019,135.940002,\r\n",
"7/8/2019,136.399994,\r\n",
"7/9/2019,136.000000,\r\n",
"7/10/2019,137.130005,\r\n",
"7/11/2019,138.199997,\r\n",
"7/12/2019,138.850006,\r\n",
"7/15/2019,139.440002,\r\n",
"7/16/2019,138.960007,\r\n",
"7/17/2019,137.699997,\r\n",
"7/18/2019,135.550003,\r\n",
"7/19/2019,140.220001,1337.779762\r\n",
"7/22/2019,137.410004,\r\n",
"7/23/2019,139.759995,\r\n",
"7/24/2019,138.899994,\r\n",
"7/25/2019,140.429993,\r\n",
"7/26/2019,140.369995,\r\n",
"7/29/2019,141.500000,\r\n",
"7/30/2019,140.139999,\r\n",
"7/31/2019,140.330002,\r\n",
"8/1/2019,137.000000,\r\n",
"8/2/2019,138.089996,\r\n",
"8/5/2019,133.300003,\r\n",
"8/6/2019,133.800003,\r\n",
"8/7/2019,133.789993,\r\n",
"8/8/2019,136.600006,\r\n",
"8/9/2019,138.610001,1352.269771\r\n",
"8/12/2019,137.070007,\r\n",
"8/13/2019,136.050003,\r\n",
"8/14/2019,136.360001,\r\n",
"8/15/2019,134.389999,\r\n",
"8/16/2019,134.880005,\r\n",
"8/19/2019,137.850006,1359.289762\r\n",
"8/20/2019,138.210007,\r\n",
"8/21/2019,138.550003,\r\n",
"8/22/2019,138.660004,\r\n",
"8/23/2019,137.190002,\r\n",
"8/26/2019,134.990005,\r\n",
"8/27/2019,136.389999,\r\n",
"8/28/2019,134.880005,\r\n",
"8/29/2019,137.250000,1381.889712\r\n",
"8/30/2019,139.149994,\r\n",
"9/3/2019,136.610001,\r\n",
"9/4/2019,137.300003,\r\n",
"9/5/2019,139.110001,\r\n",
"9/6/2019,140.029999,\r\n",
"9/9/2019,139.589996,\r\n",
"9/10/2019,136.800003,\r\n",
"9/11/2019,135.910004,\r\n",
"9/12/2019,137.850006,1392.389742\r\n",
"9/13/2019,137.779999,\r\n",
"9/16/2019,135.830002,\r\n",
"9/17/2019,136.960007,\r\n",
"9/18/2019,137.360001,\r\n",
"9/19/2019,140.300003,1437.089752\r\n",
"9/20/2019,141.009995,\r\n",
"9/23/2019,139.229996,\r\n",
"9/24/2019,140.360001,\r\n",
"9/25/2019,137.500000,\r\n",
"9/26/2019,139.440002,1456.489772\r\n",
"9/27/2019,140.149994,\r\n",
"9/30/2019,138.050003,\r\n",
"10/1/2019,139.660004,1472.589782\r\n",
"10/2/2019,136.250000,\r\n",
"10/3/2019,134.949997,\r\n",
"10/4/2019,136.750000,\r\n",
"10/7/2019,137.139999,\r\n",
"10/8/2019,137.080002,\r\n",
"10/9/2019,137.460007,\r\n",
"10/10/2019,138.490005,1494.989832\r\n",
"10/11/2019,140.119995,\r\n",
"10/14/2019,139.690002,\r\n",
"10/15/2019,140.059998,\r\n",
"10/16/2019,140.789993,\r\n",
"10/17/2019,140.949997,\r\n",
"10/18/2019,139.759995,\r\n",
"10/21/2019,138.449997,\r\n",
"10/22/2019,138.970001,1500.189872\r\n",
"10/23/2019,136.880005,\r\n",
"10/24/2019,139.389999,1525.289812\r\n",
"10/25/2019,139.339996,\r\n",
"10/28/2019,144.399994,\r\n",
"10/29/2019,144.080002,\r\n",
"10/30/2019,143.520004,\r\n",
"10/31/2019,144.899994,\r\n",
"11/1/2019,144.259995,\r\n",
"11/4/2019,144.830002,\r\n",
"11/5/2019,144.970001,\r\n",
"11/6/2019,144.369995,\r\n",
"11/7/2019,143.839996,\r\n",
"11/8/2019,143.979996,\r\n",
"11/11/2019,145.339996,\r\n",
"11/12/2019,146.279999,\r\n",
"11/13/2019,146.740005,\r\n",
"11/14/2019,147.020004,\r\n",
"11/15/2019,148.929993,\r\n",
"11/18/2019,150.070007,\r\n",
"11/19/2019,150.880005,\r\n",
"11/20/2019,150.309998,\r\n",
"11/21/2019,149.399994,\r\n",
"11/22/2019,150.070007,\r\n",
"11/25/2019,150.000000,\r\n",
"11/26/2019,151.360001,\r\n",
"11/27/2019,152.330002,\r\n",
"11/29/2019,152.100006,\r\n",
"12/2/2019,151.809998,\r\n",
"12/3/2019,147.490005,\r\n",
"12/4/2019,150.139999,1551.789752\r\n",
"12/5/2019,150.050003,\r\n",
"12/6/2019,150.990005,\r\n",
"12/9/2019,151.070007,\r\n",
"12/10/2019,151.289993,\r\n",
"12/11/2019,151.539993,\r\n",
"12/12/2019,151.649994,\r\n",
"12/13/2019,153.000000,\r\n",
"12/16/2019,155.110001,\r\n",
"12/17/2019,155.449997,\r\n",
"12/18/2019,154.300003,\r\n",
"12/19/2019,154.000000,\r\n",
"12/20/2019,157.350006,\r\n",
"12/23/2019,158.119995,\r\n",
"12/24/2019,157.479996,\r\n",
"12/26/2019,157.559998,\r\n",
"12/27/2019,159.449997,\r\n",
"12/30/2019,158.990005,\r\n",
"12/31/2019,156.770004,\r\n",
"1/2/2020,158.779999,\r\n",
"1/3/2020,158.320007,\r\n",
"1/6/2020,157.080002,\r\n",
"1/7/2020,159.320007,\r\n",
"1/8/2020,158.929993,\r\n",
"1/9/2020,161.839996,\r\n",
"1/10/2020,162.820007,\r\n",
"1/13/2020,161.759995,\r\n",
"1/14/2020,163.389999,\r\n",
"1/15/2020,162.619995,\r\n",
"1/16/2020,164.350006,\r\n",
"1/17/2020,167.419998,\r\n",
"1/21/2020,166.679993,\r\n",
"1/22/2020,167.399994,\r\n",
"1/23/2020,166.190002,\r\n",
"1/24/2020,167.509995,\r\n",
"1/27/2020,161.149994,\r\n",
"1/28/2020,163.779999,1575.459797\r\n",
"1/29/2020,167.839996,\r\n",
"1/30/2020,174.050003,\r\n",
"1/31/2020,172.210007,\r\n",
"2/3/2020,170.429993,\r\n",
"2/4/2020,177.139999,\r\n",
"2/5/2020,184.029999,\r\n",
"2/6/2020,180.970001,\r\n",
"2/7/2020,182.850006,\r\n",
"2/10/2020,183.580002,\r\n",
"2/11/2020,190.649994,\r\n",
"2/12/2020,185.580002,\r\n",
"2/13/2020,183.080002,\r\n",
"2/14/2020,183.250000,\r\n",
"2/18/2020,185.610001,\r\n",
"2/19/2020,188.059998,\r\n",
"2/20/2020,186.949997,\r\n",
"2/21/2020,183.169998,\r\n",
"2/24/2020,167.770004,\r\n",
"2/25/2020,174.199997,\r\n",
"2/26/2020,169.710007,\r\n",
"2/27/2020,163.320007,\r\n",
"2/28/2020,152.410004,\r\n",
"3/2/2020,165.309998,\r\n",
"3/3/2020,173.800003,\r\n",
"3/4/2020,168.490005,\r\n",
"3/5/2020,166.050003,\r\n",
"3/6/2020,162.610001,\r\n",
"3/9/2020,151.000000,\r\n",
"3/10/2020,158.160004,\r\n",
"3/11/2020,157.130005,\r\n",
"3/12/2020,145.300003,\r\n",
"3/13/2020,147.500000,\r\n",
"3/16/2020,140.000000,\r\n",
"3/17/2020,140.000000,\r\n",
"3/18/2020,138.000000,\r\n",
"3/19/2020,142.770004,\r\n",
"3/20/2020,146.000000,\r\n",
"3/23/2020,137.009995,\r\n",
"3/24/2020,143.750000,\r\n",
"3/25/2020,148.910004,\r\n",
"3/26/2020,148.399994,\r\n",
"3/27/2020,151.750000,1431.279761\r\n",
"3/30/2020,152.440002,\r\n",
"3/31/2020,159.399994,\r\n",
"4/1/2020,153.000000,\r\n",
"4/2/2020,151.860001,\r\n",
"4/3/2020,155.100006,\r\n",
"4/6/2020,160.320007,\r\n",
"4/7/2020,169.589996,\r\n",
"4/8/2020,165.669998,\r\n",
"4/9/2020,166.360001,\r\n",
"4/13/2020,164.350006,\r\n",
"4/14/2020,169.000000,\r\n",
"4/15/2020,171.199997,\r\n",
"4/16/2020,174.300003,\r\n",
"4/17/2020,179.500000,\r\n",
"4/20/2020,176.630005,\r\n",
"4/21/2020,173.500000,\r\n",
"4/22/2020,171.389999,\r\n",
"4/23/2020,174.110001,\r\n",
"4/24/2020,172.059998,\r\n",
"4/27/2020,176.589996,\r\n",
"4/28/2020,175.589996,\r\n",
"4/29/2020,173.220001,\r\n",
"4/30/2020,180.000000,\r\n",
"5/1/2020,175.800003,\r\n",
"5/4/2020,174.490005,\r\n",
"5/5/2020,180.619995,\r\n",
"5/6/2020,182.080002,\r\n",
"5/7/2020,184.169998,\r\n",
"5/8/2020,184.979996,\r\n",
"5/11/2020,183.149994,\r\n",
"5/12/2020,186.800003,\r\n",
"5/13/2020,182.550003,\r\n",
"5/14/2020,177.539993,\r\n",
"5/15/2020,179.059998,1443.439801\r\n",
"5/18/2020,185.750000,\r\n",
"5/19/2020,185.029999,\r\n",
"5/20/2020,184.809998,\r\n",
"5/21/2020,185.399994,\r\n",
"5/22/2020,183.190002,\r\n",
"5/26/2020,186.339996,\r\n",
"5/27/2020,180.199997,\r\n",
"5/28/2020,180.740005,\r\n",
"5/29/2020,182.729996,1463.679793\r\n",
"6/1/2020,182.539993,\r\n",
"6/2/2020,184.250000,1477.359849\r\n",
"6/3/2020,184.820007,\r\n",
"6/4/2020,184.300003,\r\n",
"6/5/2020,182.619995,\r\n",
"6/8/2020,185.940002,1503.919905\r\n",
"6/9/2020,188.000000,\r\n",
"6/10/2020,191.130005,\r\n",
"6/11/2020,193.130005,\r\n",
"6/12/2020,190.539993,\r\n",
"6/15/2020,184.580002,\r\n",
"6/16/2020,192.889999,1570.399881\r\n",
"6/17/2020,195.029999,\r\n",
"6/18/2020,194.000000,\r\n",
"6/19/2020,198.589996,\r\n",
"6/22/2020,195.789993,\r\n",
"6/23/2020,202.089996,\r\n",
"6/24/2020,201.600006,\r\n",
"6/25/2020,197.800003,\r\n",
"6/26/2020,199.729996,\r\n",
"6/29/2020,195.779999,\r\n",
"6/30/2020,197.880005,\r\n",
"7/1/2020,203.139999,\r\n",
"7/2/2020,205.679993,\r\n",
"7/6/2020,208.830002,\r\n",
"7/7/2020,210.449997,\r\n",
"7/8/2020,210.070007,\r\n",
"7/9/2020,216.330002,\r\n",
"7/10/2020,213.619995,\r\n",
"7/13/2020,214.479996,\r\n",
"7/14/2020,206.130005,\r\n",
"7/15/2020,209.559998,\r\n",
"7/16/2020,205.399994,\r\n",
"7/17/2020,204.470001,\r\n",
"7/20/2020,205.000000,\r\n",
"7/21/2020,213.660004,1634.729902\r\n",
"7/22/2020,209.199997,\r\n",
"7/23/2020,207.190002,\r\n",
"7/24/2020,200.419998,\r\n",
"7/27/2020,201.470001,\r\n",
"7/28/2020,203.610001,\r\n",
"7/29/2020,202.500000,\r\n",
"7/30/2020,201.000000,\r\n",
"7/31/2020,204.399994,\r\n",
"8/3/2020,211.520004,1723.529950\r\n",
"8/4/2020,214.169998,\r\n",
"8/5/2020,214.899994,\r\n",
"8/6/2020,212.339996,\r\n",
"8/7/2020,214.850006,\r\n",
"8/10/2020,211.669998,\r\n",
"8/11/2020,207.160004,\r\n",
"8/12/2020,205.289993,\r\n",
"8/13/2020,209.440002,1741.769934\r\n",
"8/14/2020,208.759995,\r\n",
"8/17/2020,209.600006,\r\n",
"8/18/2020,210.529999,\r\n",
"8/19/2020,211.490005,\r\n",
"8/20/2020,209.539993,\r\n",
"8/21/2020,213.860001,\r\n",
"8/24/2020,214.789993,\r\n",
"8/25/2020,213.100006,\r\n",
"8/26/2020,217.880005,\r\n",
"8/27/2020,222.889999,\r\n",
"8/28/2020,228.179993,\r\n",
"8/31/2020,227.000000,\r\n",
"9/1/2020,225.509995,\r\n",
"9/2/2020,227.970001,\r\n",
"9/3/2020,229.270004,\r\n",
"9/4/2020,215.100006,\r\n",
"9/8/2020,206.500000,\r\n",
"9/9/2020,207.600006,\r\n",
"9/10/2020,213.399994,\r\n",
"9/11/2020,207.199997,\r\n",
"9/14/2020,204.240005,\r\n",
"9/15/2020,208.419998,\r\n",
"9/16/2020,210.619995,\r\n",
"9/17/2020,200.050003,\r\n",
"9/18/2020,202.800003,\r\n",
"9/21/2020,197.190002,\r\n",
"9/22/2020,205.059998,\r\n",
"9/23/2020,207.899994,\r\n",
"9/24/2020,199.850006,\r\n",
"9/25/2020,203.550003,\r\n",
"9/28/2020,210.880005,1708.009926\r\n",
"9/29/2020,209.350006,\r\n",
"9/30/2020,207.729996,\r\n",
"10/1/2020,213.490005,1741.129918\r\n",
"10/2/2020,208.000000,\r\n",
"10/5/2020,207.220001,\r\n",
"10/6/2020,208.820007,\r\n",
"10/7/2020,207.059998,\r\n",
"10/8/2020,210.509995,\r\n",
"10/9/2020,211.229996,\r\n",
"10/12/2020,218.789993,\r\n",
"10/13/2020,222.720001,\r\n",
"10/14/2020,223.000000,\r\n",
"10/15/2020,217.100006,\r\n",
"10/16/2020,220.149994,\r\n",
"10/19/2020,220.419998,\r\n",
"10/20/2020,215.800003,\r\n",
"10/21/2020,213.119995,\r\n",
"10/22/2020,213.929993,\r\n",
"10/23/2020,215.029999,\r\n",
"10/26/2020,213.850006,\r\n",
"10/27/2020,211.589996,\r\n",
"10/28/2020,207.669998,\r\n",
"10/29/2020,204.070007,\r\n",
"10/30/2020,203.500000,\r\n",
"11/2/2020,204.289993,\r\n",
"11/3/2020,203.889999,\r\n",
"11/4/2020,214.020004,1742.489902\r\n",
"11/5/2020,222.039993,\r\n",
"11/6/2020,222.259995,\r\n",
"11/9/2020,224.440002,\r\n",
"11/10/2020,214.500000,\r\n",
"11/11/2020,212.389999,\r\n",
"11/12/2020,217.210007,1781.049966\r\n",
"11/13/2020,216.360001,\r\n",
"11/16/2020,214.869995,\r\n",
"11/17/2020,216.100006,\r\n",
"11/18/2020,213.649994,\r\n",
"11/19/2020,211.380005,\r\n",
"11/20/2020,212.199997,\r\n",
"11/23/2020,210.949997,\r\n",
"11/24/2020,209.589996,\r\n",
"11/25/2020,215.110001,1810.889934\r\n",
"11/27/2020,214.850006,\r\n",
"11/30/2020,214.100006,\r\n",
"12/1/2020,214.509995,\r\n",
"12/2/2020,214.880005,\r\n",
"12/3/2020,214.610001,\r\n",
"12/4/2020,214.220001,\r\n",
"12/7/2020,214.369995,\r\n",
"12/8/2020,213.970001,\r\n",
"12/9/2020,215.160004,1819.369918\r\n",
"12/10/2020,211.770004,\r\n",
"12/11/2020,210.050003,\r\n",
"12/14/2020,213.100006,\r\n",
"12/15/2020,215.169998,1846.569870\r\n",
"12/16/2020,214.750000,\r\n",
"12/17/2020,219.869995,\r\n",
"12/18/2020,218.589996,\r\n",
"12/21/2020,217.550003,\r\n",
"12/22/2020,222.690002,\r\n",
"12/23/2020,223.110001,\r\n",
"12/24/2020,221.419998,\r\n",
"12/28/2020,224.449997,\r\n",
"12/29/2020,226.309998,\r\n",
"12/30/2020,225.229996,\r\n",
"12/31/2020,221.699997,\r\n",
"1/4/2021,222.529999,\r\n",
"1/5/2021,217.259995,\r\n",
"1/6/2021,212.169998,\r\n",
"1/7/2021,214.039993,\r\n",
"1/8/2021,218.679993,1857.929854\r\n",
"1/11/2021,218.470001,\r\n",
"1/12/2021,216.500000,\r\n",
"1/13/2021,214.020004,\r\n",
"1/14/2021,215.910004,\r\n",
"1/15/2021,213.520004,\r\n",
"1/19/2021,213.750000,\r\n",
"1/20/2021,217.699997,\r\n",
"1/21/2021,224.699997,1907.769822\r\n",
"1/22/2021,227.080002,\r\n",
"1/25/2021,229.119995,\r\n",
"1/26/2021,231.860001,\r\n",
"1/27/2021,238.000000,\r\n",
"1/28/2021,235.610001,\r\n",
"1/29/2021,235.990005,\r\n",
"2/1/2021,235.059998,\r\n",
"2/2/2021,241.300003,\r\n",
"2/3/2021,239.570007,\r\n",
"2/4/2021,242.660004,\r\n",
"2/5/2021,242.229996,\r\n",
"2/8/2021,243.149994,\r\n",
"2/9/2021,241.869995,\r\n",
"2/10/2021,245.000000,\r\n",
"2/11/2021,244.779999,\r\n",
"2/12/2021,243.929993,\r\n",
"2/16/2021,245.029999,\r\n",
"2/17/2021,241.320007,\r\n",
"2/18/2021,241.800003,\r\n",
"2/19/2021,243.750000,\r\n",
"2/22/2021,237.419998,\r\n",
"2/23/2021,230.330002,\r\n",
"2/24/2021,230.009995,\r\n",
"2/25/2021,232.080002,\r\n",
"2/26/2021,231.529999,\r\n",
"3/1/2021,235.899994,\r\n",
"3/2/2021,237.009995,\r\n",
"3/3/2021,232.160004,\r\n",
"3/4/2021,226.740005,\r\n",
"3/5/2021,229.520004,\r\n",
"3/8/2021,231.369995,\r\n",
"3/9/2021,232.880005,\r\n",
"3/10/2021,237.000000,1904.409838\r\n",
"3/11/2021,234.960007,\r\n",
"3/12/2021,234.009995,\r\n",
"3/15/2021,234.960007,\r\n",
"3/16/2021,236.279999,1914.969774\r\n",
"3/17/2021,236.149994,\r\n",
"3/18/2021,232.559998,\r\n",
"3/19/2021,231.020004,\r\n",
"3/22/2021,230.270004,\r\n",
"3/23/2021,237.490005,1954.409830\r\n",
"3/24/2021,237.850006,\r\n",
"3/25/2021,235.300003,\r\n",
"3/26/2021,231.550003,\r\n",
"3/29/2021,236.589996,1994.729774\r\n",
"3/30/2021,233.529999,\r\n",
"3/31/2021,232.910004,\r\n",
"4/1/2021,238.470001,2034.249790\r\n",
"4/5/2021,242.759995,\r\n",
"4/6/2021,247.610001,\r\n",
"4/7/2021,247.809998,\r\n",
"4/8/2021,252.770004,\r\n",
"4/9/2021,252.869995,\r\n",
"4/12/2021,254.710007,\r\n",
"4/13/2021,257.260010,\r\n",
"4/14/2021,257.480011,\r\n",
"4/15/2021,257.929993,\r\n",
"4/16/2021,259.470001,\r\n",
"4/19/2021,260.190002,\r\n",
"4/20/2021,257.820007,\r\n",
"4/21/2021,258.940002,\r\n",
"4/22/2021,260.209991,\r\n",
"4/23/2021,257.880005,\r\n",
"4/26/2021,261.660004,\r\n",
"4/27/2021,261.579987,\r\n",
"4/28/2021,256.079987,\r\n",
"4/29/2021,255.460007,\r\n",
"4/30/2021,249.740005,\r\n",
"5/3/2021,253.399994,\r\n",
"5/4/2021,250.970001,\r\n",
"5/5/2021,249.059998,\r\n",
"5/6/2021,246.449997,\r\n",
"5/7/2021,252.149994,\r\n",
"5/10/2021,250.869995,\r\n",
"5/11/2021,244.550003,\r\n",
"5/12/2021,242.169998,\r\n",
"5/13/2021,241.800003,\r\n",
"5/14/2021,245.580002,\r\n",
"5/17/2021,246.550003,\r\n",
"5/18/2021,246.270004,\r\n",
"5/19/2021,239.309998,\r\n",
"5/20/2021,243.960007,\r\n",
"5/21/2021,247.570007,\r\n",
"5/24/2021,247.789993,\r\n",
"5/25/2021,251.770004,2050.489782\r\n",
"5/26/2021,251.429993,\r\n",
"5/27/2021,251.169998,\r\n",
"5/28/2021,251.000000,\r\n",
"6/1/2021,251.229996,\r\n",
"6/2/2021,248.130005,\r\n",
"6/3/2021,245.220001,\r\n",
"6/4/2021,247.759995,2070.809734\r\n",
"6/7/2021,249.979996,\r\n",
"6/8/2021,255.160004,\r\n",
"6/9/2021,253.809998,\r\n",
"6/10/2021,254.289993,\r\n",
"6/11/2021,257.989990,\r\n",
"6/14/2021,257.899994,\r\n",
"6/15/2021,259.769989,\r\n",
"6/16/2021,259.399994,\r\n",
"6/17/2021,256.070007,\r\n",
"6/18/2021,259.630005,\r\n",
"6/21/2021,259.820007,\r\n",
"6/22/2021,262.720001,\r\n",
"6/23/2021,265.989990,\r\n",
"6/24/2021,266.160004,\r\n",
"6/25/2021,266.230011,\r\n",
"6/28/2021,266.190002,\r\n",
"6/29/2021,268.869995,\r\n",
"6/30/2021,270.690002,\r\n",
"7/1/2021,269.609985,\r\n",
"7/2/2021,272.820007,\r\n",
"7/6/2021,278.029999,\r\n",
"7/7/2021,279.399994,\r\n",
"7/8/2021,276.899994,\r\n",
"7/9/2021,275.720001,\r\n",
"7/12/2021,279.160004,\r\n",
"7/13/2021,277.519989,\r\n",
"7/14/2021,282.350006,\r\n",
"7/15/2021,282.000000,\r\n",
"7/16/2021,282.070007,\r\n",
"7/19/2021,278.929993,\r\n",
"7/20/2021,278.029999,\r\n",
"7/21/2021,278.899994,\r\n",
"7/22/2021,283.839996,\r\n",
"7/23/2021,287.369995,\r\n",
"7/26/2021,289.000000,\r\n",
"7/27/2021,289.429993,\r\n",
"7/28/2021,288.989990,\r\n",
"7/29/2021,286.239990,\r\n",
"7/30/2021,285.170013,\r\n",
"8/2/2021,286.359985,\r\n",
"8/3/2021,285.420013,\r\n",
"8/4/2021,286.220001,\r\n",
"8/5/2021,286.880005,\r\n",
"8/6/2021,288.510010,\r\n",
"8/9/2021,289.750000,\r\n",
"8/10/2021,288.799988,\r\n",
"8/11/2021,287.209991,\r\n",
"8/12/2021,286.630005,\r\n",
"8/13/2021,289.480011,\r\n",
"8/16/2021,293.190002,\r\n",
"8/17/2021,292.390015,\r\n",
"8/18/2021,292.040009,\r\n",
"8/19/2021,288.690002,\r\n",
"8/20/2021,299.720001,\r\n",
"8/23/2021,303.250000,\r\n",
"8/24/2021,305.019989,\r\n",
"8/25/2021,304.299988,\r\n",
"8/26/2021,300.989990,\r\n",
"8/27/2021,298.989990,\r\n",
"8/30/2021,301.119995,\r\n",
"8/31/2021,304.420013,\r\n",
"9/1/2021,302.869995,\r\n",
"9/2/2021,302.200012,\r\n",
"9/3/2021,300.989990,\r\n",
"9/7/2021,301.010010,\r\n",
"9/8/2021,299.779999,\r\n",
"9/9/2021,300.820007,\r\n",
"9/10/2021,298.420013,\r\n",
"9/13/2021,297.549988,\r\n",
"9/14/2021,299.559998,\r\n",
"9/15/2021,303.260010,2099.849716\r\n",
"9/16/2021,303.760010,\r\n",
"9/17/2021,304.170013,\r\n",
"9/20/2021,296.329987,\r\n",
"9/21/2021,295.690002,\r\n",
"9/22/2021,296.730011,\r\n",
"9/23/2021,298.850006,\r\n",
"9/24/2021,298.230011,\r\n",
"9/27/2021,296.140015,\r\n",
"9/28/2021,289.799988,\r\n",
"9/29/2021,285.100006,\r\n",
"9/30/2021,285.709991,\r\n",
"10/1/2021,282.119995,\r\n",
"10/4/2021,287.399994,\r\n",
"10/5/2021,284.049988,\r\n",
"10/6/2021,285.779999,\r\n",
"10/7/2021,295.179993,2091.799758\r\n",
"10/8/2021,296.220001,\r\n",
"10/11/2021,292.920013,\r\n",
"10/12/2021,295.339996,2108.739639\r\n",
"10/13/2021,294.910004,\r\n",
"10/14/2021,299.209991,\r\n",
"10/15/2021,302.339996,\r\n",
"10/18/2021,303.570007,\r\n",
"10/19/2021,308.350006,\r\n",
"10/20/2021,309.209991,\r\n",
"10/21/2021,307.170013,\r\n",
"10/22/2021,310.399994,\r\n",
"10/25/2021,309.359985,\r\n",
"10/26/2021,311.000000,\r\n",
"10/27/2021,316.000000,\r\n",
"10/28/2021,324.329987,\r\n",
"10/29/2021,324.130005,\r\n",
"11/1/2021,331.359985,\r\n",
"11/2/2021,330.309998,\r\n",
"11/3/2021,333.899994,\r\n",
"11/4/2021,332.890015,\r\n",
"11/5/2021,338.510010,\r\n",
"11/8/2021,337.299988,\r\n",
"11/9/2021,337.109985,\r\n",
"11/10/2021,334.570007,\r\n",
"11/11/2021,331.250000,\r\n",
"11/12/2021,333.920013,\r\n",
"11/15/2021,337.540009,\r\n",
"11/16/2021,335.679993,\r\n",
"11/17/2021,338.940002,\r\n",
"11/18/2021,338.179993,\r\n",
"11/19/2021,342.640015,\r\n",
"11/22/2021,344.619995,\r\n",
"11/23/2021,337.049988,\r\n",
"11/24/2021,336.279999,\r\n",
"11/26/2021,334.350006,\r\n",
"11/29/2021,334.940002,\r\n",
"11/30/2021,335.320007,\r\n",
"12/1/2021,335.130005,\r\n",
"12/2/2021,330.299988,\r\n",
"12/3/2021,331.989990,\r\n",
"12/6/2021,323.950012,\r\n",
"12/7/2021,331.640015,\r\n",
"12/8/2021,335.309998,2114.499591\r\n",
"12/9/2021,334.410004,\r\n",
"12/10/2021,334.980011,\r\n",
"12/13/2021,340.679993,2152.119525\r\n",
"12/14/2021,333.220001,\r\n",
"12/15/2021,328.609985,\r\n",
"12/16/2021,335.709991,2167.059465\r\n",
"12/17/2021,320.880005,\r\n",
"12/20/2021,320.049988,\r\n",
"12/21/2021,323.290009,\r\n",
"12/22/2021,328.299988,\r\n",
"12/23/2021,332.750000,2238.279435\r\n",
"12/27/2021,335.459991,\r\n",
"12/28/2021,343.149994,\r\n",
"12/29/2021,341.299988,\r\n",
"12/30/2021,341.910004,\r\n",
"12/31/2021,338.510010,\r\n",
"1/3/2022,335.350006,\r\n",
"1/4/2022,334.829987,\r\n",
"1/5/2022,325.859985,\r\n",
"1/6/2022,313.149994,\r\n",
"1/7/2022,314.149994,\r\n",
"1/10/2022,309.489990,\r\n",
"1/11/2022,313.380005,\r\n",
"1/12/2022,319.670013,\r\n",
"1/13/2022,320.470001,\r\n",
"1/14/2022,304.250000,\r\n",
"1/18/2022,304.070007,\r\n",
"1/19/2022,306.290009,\r\n",
"1/20/2022,309.070007,\r\n",
"1/21/2022,302.690002,\r\n",
"1/24/2022,292.200012,\r\n",
"1/25/2022,291.519989,\r\n",
"1/26/2022,307.989990,\r\n",
"1/27/2022,302.660004,\r\n",
"1/28/2022,300.230011,\r\n",
"1/31/2022,308.950012,\r\n",
"2/1/2022,310.410004,2145.579549\r\n",
"2/2/2022,309.630005,\r\n",
"2/3/2022,309.489990,\r\n",
"2/4/2022,300.209991,\r\n",
"2/7/2022,306.170013,\r\n",
"2/8/2022,301.250000,\r\n",
"2/9/2022,309.869995,2213.199577\r\n",
"2/10/2022,304.040009,\r\n",
"2/11/2022,303.190002,\r\n",
"2/14/2022,293.769989,\r\n",
"2/15/2022,300.010010,\r\n",
"2/16/2022,298.369995,\r\n",
"2/17/2022,296.359985,\r\n",
"2/18/2022,293.049988,\r\n",
"2/22/2022,285.000000,\r\n",
"2/23/2022,290.179993,\r\n",
"2/24/2022,272.510010,\r\n",
"2/25/2022,295.140015,\r\n",
"2/28/2022,294.309998,\r\n",
"3/1/2022,296.399994,\r\n",
"3/2/2022,295.359985,\r\n",
"3/3/2022,302.890015,2205.149619\r\n",
"3/4/2022,294.290009,\r\n",
"3/7/2022,288.529999,\r\n",
"3/8/2022,277.799988,\r\n",
"3/9/2022,283.440002,\r\n",
"3/10/2022,283.019989,\r\n",
"3/11/2022,287.959991,\r\n",
"3/14/2022,280.339996,\r\n",
"3/15/2022,280.350006,\r\n",
"3/16/2022,289.109985,\r\n",
"3/17/2022,293.290009,2198.149619\r\n",
"3/18/2022,295.369995,\r\n",
"3/21/2022,298.890015,\r\n",
"3/22/2022,299.799988,\r\n",
"3/23/2022,300.510010,\r\n",
"3/24/2022,299.140015,\r\n",
"3/25/2022,305.230011,\r\n",
"3/28/2022,304.329987,\r\n",
"3/29/2022,313.910004,\r\n",
"3/30/2022,313.760010,\r\n",
"3/31/2022,313.899994,\r\n",
"4/1/2022,309.369995,\r\n",
"4/4/2022,310.089996,\r\n",
"4/5/2022,313.269989,\r\n",
"4/6/2022,305.190002,\r\n",
"4/7/2022,296.660004,\r\n",
"4/8/2022,300.440002,\r\n",
"4/11/2022,291.790009,\r\n",
"4/12/2022,289.239990,\r\n",
"4/13/2022,282.730011,\r\n",
"4/14/2022,288.089996,\r\n",
"4/18/2022,278.910004,\r\n",
"4/19/2022,279.380005,\r\n",
"4/20/2022,289.399994,\r\n",
"4/21/2022,288.579987,\r\n",
"4/22/2022,281.679993,\r\n",
"4/25/2022,273.290009,\r\n",
"4/26/2022,277.500000,\r\n",
"4/27/2022,282.100006,\r\n",
"4/28/2022,285.190002,\r\n",
"4/29/2022,288.609985,\r\n",
"5/2/2022,277.709991,\r\n",
"5/3/2022,283.959991,\r\n",
"5/4/2022,282.589996,\r\n",
"5/5/2022,285.540009,2120.309654\r\n",
"5/6/2022,274.809998,\r\n",
"5/9/2022,270.059998,\r\n",
"5/10/2022,271.690002,\r\n",
"5/11/2022,265.679993,\r\n",
"5/12/2022,257.690002,\r\n",
"5/13/2022,257.350006,\r\n",
"5/16/2022,259.959991,\r\n",
"5/17/2022,266.109985,\r\n",
"5/18/2022,263.000000,\r\n",
"5/19/2022,253.899994,\r\n",
"5/20/2022,257.239990,\r\n",
"5/23/2022,255.490005,\r\n",
"5/24/2022,257.890015,\r\n",
"5/25/2022,258.140015,\r\n",
"5/26/2022,262.269989,\r\n",
"5/27/2022,268.480011,2075.999745\r\n",
"5/31/2022,272.529999,\r\n",
"6/1/2022,275.200012,\r\n",
"6/2/2022,264.450012,\r\n",
"6/3/2022,270.309998,2117.019647\r\n",
"6/6/2022,272.059998,\r\n",
"6/7/2022,266.640015,\r\n",
"6/8/2022,271.709991,\r\n",
"6/9/2022,267.779999,\r\n",
"6/10/2022,260.579987,\r\n",
"6/13/2022,245.110001,\r\n",
"6/14/2022,243.860001,\r\n",
"6/15/2022,248.309998,\r\n",
"6/16/2022,245.979996,\r\n",
"6/17/2022,244.699997,\r\n",
"6/21/2022,250.259995,\r\n",
"6/22/2022,251.889999,\r\n",
"6/23/2022,255.570007,\r\n",
"6/24/2022,261.809998,2126.859735\r\n",
"6/27/2022,268.209991,\r\n",
"6/28/2022,263.980011,\r\n",
"6/29/2022,257.589996,\r\n",
"6/30/2022,257.049988,\r\n",
"7/1/2022,256.390015,\r\n",
"7/5/2022,256.160004,\r\n",
"7/6/2022,263.750000,2176.139767\r\n",
"7/7/2022,265.119995,\r\n",
"7/8/2022,264.790009,\r\n",
"7/11/2022,265.649994,\r\n",
"7/12/2022,265.880005,\r\n",
"7/13/2022,250.190002,\r\n",
"7/14/2022,250.570007,\r\n",
"7/15/2022,255.720001,\r\n",
"7/18/2022,259.750000,2252.619751\r\n",
"7/19/2022,257.579987,\r\n",
"7/20/2022,259.899994,2271.179807\r\n",
"7/21/2022,259.790009,\r\n",
"7/22/2022,265.239990,\r\n",
"7/25/2022,261.000000,\r\n",
"7/26/2022,259.859985,\r\n",
"7/27/2022,261.160004,\r\n",
"7/28/2022,269.750000,\r\n",
"7/29/2022,277.700012,\r\n",
"8/1/2022,277.820007,\r\n",
"8/2/2022,276.000000,\r\n",
"8/3/2022,276.760010,\r\n",
"8/4/2022,281.799988,\r\n",
"8/5/2022,279.149994,\r\n",
"8/8/2022,284.049988,\r\n",
"8/9/2022,279.640015,\r\n",
"8/10/2022,288.170013,\r\n",
"8/11/2022,290.850006,\r\n",
"8/12/2022,288.480011,\r\n",
"8/15/2022,291.000000,\r\n",
"8/16/2022,291.989990,\r\n",
"8/17/2022,289.739990,\r\n",
"8/18/2022,290.190002,\r\n",
"8/19/2022,288.899994,\r\n",
"8/22/2022,282.079987,\r\n",
"8/23/2022,276.440002,\r\n",
"8/24/2022,275.410004,\r\n",
"8/25/2022,277.329987,\r\n",
"8/26/2022,279.079987,\r\n",
"8/29/2022,265.850006,\r\n",
"8/30/2022,266.670013,\r\n",
"8/31/2022,265.390015,\r\n",
"9/1/2022,258.869995,\r\n",
"9/2/2022,261.700012,\r\n",
"9/6/2022,256.200012,\r\n",
"9/7/2022,254.699997,\r\n",
"9/8/2022,257.510010,\r\n",
"9/9/2022,260.500000,\r\n",
"9/12/2022,265.779999,\r\n",
"9/13/2022,258.839996,\r\n",
"9/14/2022,253.529999,\r\n",
"9/15/2022,249.770004,\r\n",
"9/16/2022,244.259995,\r\n",
"9/19/2022,242.470001,\r\n",
"9/20/2022,242.070007,\r\n",
"9/21/2022,244.270004,\r\n",
"9/22/2022,237.869995,\r\n",
"9/23/2022,239.539993,\r\n",
"9/26/2022,237.050003,\r\n",
"9/27/2022,239.979996,\r\n",
"9/28/2022,236.809998,\r\n",
"9/29/2022,238.889999,\r\n",
"9/30/2022,238.289993,\r\n",
"10/3/2022,235.410004,\r\n",
"10/4/2022,245.089996,\r\n",
"10/5/2022,245.990005,2027.579831\r\n",
"10/6/2022,247.929993,\r\n",
"10/7/2022,240.899994,\r\n",
"10/10/2022,233.050003,\r\n",
"10/11/2022,227.619995,\r\n",
"10/12/2022,225.399994,\r\n",
"10/13/2022,219.850006,\r\n",
"10/14/2022,235.539993,\r\n",
"10/17/2022,235.820007,\r\n",
"10/18/2022,243.240005,2046.299919\r\n",
"10/19/2022,237.039993,\r\n",
"10/20/2022,235.770004,\r\n",
"10/21/2022,234.740005,\r\n",
"10/24/2022,243.759995,2100.059935\r\n",
"10/25/2022,247.259995,\r\n",
"10/26/2022,231.169998,\r\n",
"10/27/2022,231.039993,\r\n",
"10/28/2022,226.240005,\r\n",
"10/31/2022,233.759995,\r\n",
"11/1/2022,234.600006,\r\n",
"11/2/2022,229.460007,\r\n",
"11/3/2022,220.089996,\r\n",
"11/4/2022,217.550003,\r\n",
"11/7/2022,221.990005,\r\n",
"11/8/2022,228.699997,\r\n",
"11/9/2022,227.369995,\r\n",
"11/10/2022,235.429993,2138.399890\r\n",
"11/11/2022,242.990005,\r\n",
"11/14/2022,241.990005,\r\n",
"11/15/2022,245.660004,\r\n",
"11/16/2022,242.789993,\r\n",
"11/17/2022,237.779999,\r\n",
"11/18/2022,243.509995,\r\n",
"11/21/2022,241.429993,\r\n",
"11/22/2022,243.589996,\r\n",
"11/23/2022,245.110001,\r\n",
"11/25/2022,247.309998,\r\n",
"11/28/2022,246.080002,\r\n",
"11/29/2022,241.399994,\r\n",
"11/30/2022,240.570007,\r\n",
"12/1/2022,253.869995,\r\n",
"12/2/2022,249.820007,\r\n",
"12/5/2022,252.009995,\r\n",
"12/6/2022,250.820007,\r\n",
"12/7/2022,244.830002,\r\n",
"12/8/2022,244.839996,\r\n",
"12/9/2022,244.699997,\r\n",
"12/12/2022,247.449997,2160.399890\r\n",
"12/13/2022,261.690002,\r\n",
"12/14/2022,257.130005,\r\n",
"12/15/2022,253.720001,\r\n",
"12/16/2022,248.550003,\r\n",
"12/19/2022,244.860001,\r\n",
"12/20/2022,239.399994,\r\n",
"12/21/2022,241.690002,\r\n",
"12/22/2022,241.259995,\r\n",
"12/23/2022,236.110001,\r\n",
"12/27/2022,238.699997,\r\n",
"12/28/2022,236.889999,\r\n",
"12/29/2022,235.649994,\r\n",
"12/30/2022,238.210007,\r\n",
"1/3/2023,243.080002,\r\n",
"1/4/2023,232.279999,\r\n",
"1/5/2023,227.199997,\r\n",
"1/6/2023,223.000000,\r\n",
"1/9/2023,226.449997,\r\n",
"1/10/2023,227.759995,\r\n",
"1/11/2023,231.289993,\r\n",
"1/12/2023,235.259995,\r\n",
"1/13/2023,237.000000,2097.519882\r\n",
"1/17/2023,237.970001,\r\n",
"1/18/2023,241.570007,\r\n",
"1/19/2023,233.779999,\r\n",
"1/20/2023,234.860001,\r\n",
"1/23/2023,241.100006,2156.079938\r\n",
"1/24/2023,242.500000,\r\n",
"1/25/2023,234.479996,\r\n",
"1/26/2023,243.649994,2238.609920\r\n",
"1/27/2023,248.990005,\r\n",
"1/30/2023,244.509995,\r\n",
"1/31/2023,243.449997,\r\n",
"2/1/2023,248.000000,\r\n",
"2/2/2023,258.820007,\r\n",
"2/3/2023,259.540009,\r\n",
"2/6/2023,257.440002,\r\n",
"2/7/2023,260.529999,\r\n",
"2/8/2023,273.200012,\r\n",
"2/9/2023,273.799988,\r\n",
"2/10/2023,261.529999,\r\n",
"2/13/2023,267.640015,\r\n",
"2/14/2023,272.670013,\r\n",
"2/15/2023,268.320007,\r\n",
"2/16/2023,264.019989,\r\n",
"2/17/2023,259.390015,\r\n",
"2/21/2023,254.479996,\r\n",
"2/22/2023,254.089996,\r\n",
"2/23/2023,255.559998,\r\n",
"2/24/2023,249.960007,\r\n",
"2/27/2023,252.460007,\r\n",
"2/28/2023,249.070007,\r\n",
"3/1/2023,250.759995,\r\n",
"3/2/2023,246.550003,\r\n",
"3/3/2023,252.190002,\r\n",
"3/6/2023,256.429993,\r\n",
"3/7/2023,256.299988,\r\n",
"3/8/2023,254.039993,\r\n",
"3/9/2023,255.820007,\r\n",
"3/10/2023,251.080002,\r\n",
"3/13/2023,247.399994,\r\n",
"3/14/2023,256.750000,2256.769952\r\n",
"3/15/2023,259.980011,\r\n",
"3/16/2023,265.209991,\r\n",
"3/17/2023,278.260010,\r\n",
"3/20/2023,276.980011,\r\n",
"3/21/2023,274.880005,\r\n",
"3/22/2023,273.399994,\r\n",
"3/23/2023,277.940002,\r\n",
"3/24/2023,277.239990,\r\n",
"3/27/2023,280.500000,\r\n",
"3/28/2023,275.790009,\r\n",
"3/29/2023,278.959991,\r\n",
"3/30/2023,284.230011,\r\n",
"3/31/2023,283.730011,\r\n",
"4/3/2023,286.519989,\r\n",
"4/4/2023,287.230011,\r\n",
"4/5/2023,285.850006,\r\n",
"4/6/2023,283.209991,\r\n",
"4/10/2023,289.209991,\r\n",
"4/11/2023,285.750000,\r\n",
"4/12/2023,284.790009,\r\n",
"4/13/2023,283.589996,\r\n",
"4/14/2023,287.000000,\r\n",
"4/17/2023,289.929993,\r\n",
"4/18/2023,291.570007,\r\n",
"4/19/2023,285.989990,\r\n",
"4/20/2023,285.250000,\r\n",
"4/21/2023,285.010010,\r\n",
"4/24/2023,282.089996,\r\n",
"4/25/2023,279.510010,\r\n",
"4/26/2023,296.700012,2373.650080\r\n",
"4/27/2023,295.970001,\r\n",
"4/28/2023,304.010010,\r\n",
"5/1/2023,306.970001,\r\n",
"5/2/2023,307.760010,\r\n",
"5/3/2023,306.619995,\r\n",
"5/4/2023,306.239990,\r\n",
"5/5/2023,305.720001,\r\n",
"5/8/2023,310.130005,\r\n",
"5/9/2023,308.000000,\r\n",
"5/10/2023,308.619995,\r\n",
"5/11/2023,310.100006,\r\n",
"5/12/2023,310.549988,\r\n",
"5/15/2023,309.100006,\r\n",
"5/16/2023,309.829987,\r\n",
"5/17/2023,312.290009,\r\n",
"5/18/2023,314.529999,\r\n",
"5/19/2023,316.739990,\r\n",
"5/22/2023,318.600006,\r\n",
"5/23/2023,320.029999,\r\n",
"5/24/2023,314.730011,\r\n",
"5/25/2023,323.239990,\r\n",
"5/26/2023,324.019989,\r\n",
"5/30/2023,335.230011,\r\n",
"5/31/2023,332.290009,\r\n",
"6/1/2023,325.929993,\r\n",
"6/2/2023,334.250000,\r\n",
"6/5/2023,335.220001,\r\n",
"6/6/2023,335.329987,\r\n",
"6/7/2023,331.649994,\r\n",
"6/8/2023,323.940002,\r\n",
"6/9/2023,324.989990,\r\n",
"6/12/2023,328.579987,\r\n",
"6/13/2023,334.470001,\r\n",
"6/14/2023,334.339996,\r\n",
"6/15/2023,337.480011,\r\n",
"6/16/2023,351.320007,\r\n",
"6/20/2023,339.309998,\r\n",
"6/21/2023,336.369995,\r\n",
"6/22/2023,334.119995,\r\n",
"6/23/2023,334.359985,\r\n",
"6/26/2023,333.720001,\r\n",
"6/27/2023,331.859985,\r\n",
"6/28/2023,334.660004,2393.250213\r\n",
"6/29/2023,334.709991,\r\n",
"6/30/2023,337.750000,\r\n",
"7/3/2023,339.190002,\r\n",
"7/5/2023,335.089996,\r\n",
"7/6/2023,337.299988,\r\n",
"7/7/2023,339.320007,\r\n",
"7/10/2023,334.600006,\r\n",
"7/11/2023,331.059998,\r\n",
"7/12/2023,336.600006,2407.250213\r\n",
"7/13/2023,339.559998,\r\n",
"7/14/2023,347.589996,\r\n",
"7/17/2023,345.679993,\r\n",
"7/18/2023,345.829987,\r\n",
"7/19/2023,361.750000,\r\n",
"7/20/2023,353.570007,\r\n",
"7/21/2023,349.149994,\r\n",
"7/24/2023,345.850006,\r\n",
"7/25/2023,347.109985,\r\n",
"7/26/2023,341.440002,\r\n",
"7/27/2023,340.480011,\r\n",
"7/28/2023,333.670013,\r\n",
"7/31/2023,336.920013,\r\n",
"8/1/2023,335.190002,\r\n",
"8/2/2023,333.630005,\r\n",
"8/3/2023,326.000000,\r\n",
"8/4/2023,331.880005,\r\n",
"8/7/2023,328.369995,\r\n",
"8/8/2023,326.959991,\r\n",
"8/9/2023,326.470001,\r\n",
"8/10/2023,326.019989,\r\n",
"8/11/2023,320.260010,\r\n",
"8/14/2023,321.390015,\r\n",
"8/15/2023,323.000000,\r\n",
"8/16/2023,320.799988,\r\n",
"8/17/2023,320.540009,\r\n",
"8/18/2023,314.489990,\r\n",
"8/21/2023,317.929993,\r\n",
"8/22/2023,325.500000,\r\n",
"8/23/2023,323.820007,\r\n",
"8/24/2023,332.850006,2347.120241\r\n",
"8/25/2023,321.470001,\r\n",
"8/28/2023,325.660004,2376.450262\r\n",
"8/29/2023,321.880005,\r\n",
"8/30/2023,328.670013,2423.980318\r\n",
"8/31/2023,329.200012,\r\n",
"9/1/2023,331.309998,\r\n",
"9/5/2023,329.000000,\r\n",
"9/6/2023,333.380005,\r\n",
"9/7/2023,331.290009,\r\n",
"9/8/2023,330.089996,\r\n",
"9/11/2023,337.239990,\r\n",
"9/12/2023,335.820007,\r\n",
"9/13/2023,331.309998,\r\n",
"9/14/2023,339.149994,\r\n",
"9/15/2023,336.920013,\r\n",
"9/18/2023,327.799988,\r\n",
"9/19/2023,326.170013,\r\n",
"9/20/2023,329.510010,\r\n",
"9/21/2023,319.260010,\r\n",
"9/22/2023,321.320007,\r\n",
"9/25/2023,316.589996,\r\n",
"9/26/2023,315.130005,\r\n",
"9/27/2023,312.299988,\r\n",
"9/28/2023,310.989990,\r\n",
"9/29/2023,317.750000,\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Balance</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-10-01\">Oct 01, 2018</time></td><td><div class=\"dni-plaintext\"><pre>114.750000</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-02\">Oct 02, 2018</time></td><td><div class=\"dni-plaintext\"><pre>115.300003</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-03\">Oct 03, 2018</time></td><td><div class=\"dni-plaintext\"><pre>115.419998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-04\">Oct 04, 2018</time></td><td><div class=\"dni-plaintext\"><pre>114.610001</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-05\">Oct 05, 2018</time></td><td><div class=\"dni-plaintext\"><pre>112.629997</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-08\">Oct 08, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.660004</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-09\">Oct 09, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.139999</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-10\">Oct 10, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.239998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-11\">Oct 11, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.349998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-12\">Oct 12, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.010002</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-15\">Oct 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.910004</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-16\">Oct 16, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.540001</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-17\">Oct 17, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.680000</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-18\">Oct 18, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.099998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-19\">Oct 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.930000</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-22\">Oct 22, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.320000</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-23\">Oct 23, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.769997</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-24\">Oct 24, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.410004</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-25\">Oct 25, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.550003</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-10-26\">Oct 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>105.690002</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td colspan=\"3\"><i>(1238 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var merged =\n",
" data.OrderedMerge(run,\n",
" // left key function\n",
" d => d.Date,\n",
" // right key function\n",
" r => r.Sell.Date,\n",
" // project result for when just the left side is available\n",
" d => new { d.Date, d.Price, Balance = (decimal?)null },\n",
" // project result for when just the right side is available\n",
" r => throw new(), // this should never happen\n",
" // project result for when both sides are available\n",
" (d, r) => new { d.Date, d.Price, Balance = (decimal?)r.Balance });\n",
"\n",
"merged.ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Hang on! Why is the balance always `null`? What's going on here? Do we have a bug? Let's see if there is any value ever for balance:"
]
},
{
"cell_type": "code",
"execution_count": 130,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Balance\r\n",
"11/7/2018,109.440002,1033.750000\r\n",
"11/14/2018,108.099998,1038.699955\r\n",
"11/19/2018,108.269997,1068.219946\r\n",
"11/28/2018,107.889999,1129.119906\r\n",
"12/7/2018,108.379997,1154.719876\r\n",
"12/11/2018,109.800003,1209.719876\r\n",
"1/8/2019,103.040001,1183.649843\r\n",
"2/5/2019,106.059998,1208.509788\r\n",
"2/11/2019,106.199997,1228.419766\r\n",
"3/11/2019,110.989998,1248.549700\r\n",
"5/16/2019,126.750000,1273.149690\r\n",
"5/21/2019,127.430000,1282.249720\r\n",
"5/24/2019,126.910004,1285.149730\r\n",
"6/6/2019,126.440002,1295.749780\r\n",
"7/19/2019,140.220001,1337.779762\r\n",
"8/9/2019,138.610001,1352.269771\r\n",
"8/19/2019,137.850006,1359.289762\r\n",
"8/29/2019,137.250000,1381.889712\r\n",
"9/12/2019,137.850006,1392.389742\r\n",
"9/19/2019,140.300003,1437.089752\r\n",
"9/26/2019,139.440002,1456.489772\r\n",
"10/1/2019,139.660004,1472.589782\r\n",
"10/10/2019,138.490005,1494.989832\r\n",
"10/22/2019,138.970001,1500.189872\r\n",
"10/24/2019,139.389999,1525.289812\r\n",
"12/4/2019,150.139999,1551.789752\r\n",
"1/28/2020,163.779999,1575.459797\r\n",
"3/27/2020,151.750000,1431.279761\r\n",
"5/15/2020,179.059998,1443.439801\r\n",
"5/29/2020,182.729996,1463.679793\r\n",
"6/2/2020,184.250000,1477.359849\r\n",
"6/8/2020,185.940002,1503.919905\r\n",
"6/16/2020,192.889999,1570.399881\r\n",
"7/21/2020,213.660004,1634.729902\r\n",
"8/3/2020,211.520004,1723.529950\r\n",
"8/13/2020,209.440002,1741.769934\r\n",
"9/28/2020,210.880005,1708.009926\r\n",
"10/1/2020,213.490005,1741.129918\r\n",
"11/4/2020,214.020004,1742.489902\r\n",
"11/12/2020,217.210007,1781.049966\r\n",
"11/25/2020,215.110001,1810.889934\r\n",
"12/9/2020,215.160004,1819.369918\r\n",
"12/15/2020,215.169998,1846.569870\r\n",
"1/8/2021,218.679993,1857.929854\r\n",
"1/21/2021,224.699997,1907.769822\r\n",
"3/10/2021,237.000000,1904.409838\r\n",
"3/16/2021,236.279999,1914.969774\r\n",
"3/23/2021,237.490005,1954.409830\r\n",
"3/29/2021,236.589996,1994.729774\r\n",
"4/1/2021,238.470001,2034.249790\r\n",
"5/25/2021,251.770004,2050.489782\r\n",
"6/4/2021,247.759995,2070.809734\r\n",
"9/15/2021,303.260010,2099.849716\r\n",
"10/7/2021,295.179993,2091.799758\r\n",
"10/12/2021,295.339996,2108.739639\r\n",
"12/8/2021,335.309998,2114.499591\r\n",
"12/13/2021,340.679993,2152.119525\r\n",
"12/16/2021,335.709991,2167.059465\r\n",
"12/23/2021,332.750000,2238.279435\r\n",
"2/1/2022,310.410004,2145.579549\r\n",
"2/9/2022,309.869995,2213.199577\r\n",
"3/3/2022,302.890015,2205.149619\r\n",
"3/17/2022,293.290009,2198.149619\r\n",
"5/5/2022,285.540009,2120.309654\r\n",
"5/27/2022,268.480011,2075.999745\r\n",
"6/3/2022,270.309998,2117.019647\r\n",
"6/24/2022,261.809998,2126.859735\r\n",
"7/6/2022,263.750000,2176.139767\r\n",
"7/18/2022,259.750000,2252.619751\r\n",
"7/20/2022,259.899994,2271.179807\r\n",
"10/5/2022,245.990005,2027.579831\r\n",
"10/18/2022,243.240005,2046.299919\r\n",
"10/24/2022,243.759995,2100.059935\r\n",
"11/10/2022,235.429993,2138.399890\r\n",
"12/12/2022,247.449997,2160.399890\r\n",
"1/13/2023,237.000000,2097.519882\r\n",
"1/23/2023,241.100006,2156.079938\r\n",
"1/26/2023,243.649994,2238.609920\r\n",
"3/14/2023,256.750000,2256.769952\r\n",
"4/26/2023,296.700012,2373.650080\r\n",
"6/28/2023,334.660004,2393.250213\r\n",
"7/12/2023,336.600006,2407.250213\r\n",
"8/24/2023,332.850006,2347.120241\r\n",
"8/28/2023,325.660004,2376.450262\r\n",
"8/30/2023,328.670013,2423.980318\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Balance</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-12-07\">Dec 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.379997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1154.719876</pre></div></td></tr><tr><td><time datetime=\"2018-12-11\">Dec 11, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1209.719876</pre></div></td></tr><tr><td><time datetime=\"2019-01-08\">Jan 08, 2019</time></td><td><div class=\"dni-plaintext\"><pre>103.040001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1183.649843</pre></div></td></tr><tr><td><time datetime=\"2019-02-05\">Feb 05, 2019</time></td><td><div class=\"dni-plaintext\"><pre>106.059998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1208.509788</pre></div></td></tr><tr><td><time datetime=\"2019-02-11\">Feb 11, 2019</time></td><td><div class=\"dni-plaintext\"><pre>106.199997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1228.419766</pre></div></td></tr><tr><td><time datetime=\"2019-03-11\">Mar 11, 2019</time></td><td><div class=\"dni-plaintext\"><pre>110.989998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1248.549700</pre></div></td></tr><tr><td><time datetime=\"2019-05-16\">May 16, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.750000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1273.149690</pre></div></td></tr><tr><td><time datetime=\"2019-05-21\">May 21, 2019</time></td><td><div class=\"dni-plaintext\"><pre>127.430000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1282.249720</pre></div></td></tr><tr><td><time datetime=\"2019-05-24\">May 24, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.910004</pre></div></td><td><div class=\"dni-plaintext\"><pre>1285.149730</pre></div></td></tr><tr><td><time datetime=\"2019-06-06\">Jun 06, 2019</time></td><td><div class=\"dni-plaintext\"><pre>126.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1295.749780</pre></div></td></tr><tr><td><time datetime=\"2019-07-19\">Jul 19, 2019</time></td><td><div class=\"dni-plaintext\"><pre>140.220001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1337.779762</pre></div></td></tr><tr><td><time datetime=\"2019-08-09\">Aug 09, 2019</time></td><td><div class=\"dni-plaintext\"><pre>138.610001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1352.269771</pre></div></td></tr><tr><td><time datetime=\"2019-08-19\">Aug 19, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td><td><div class=\"dni-plaintext\"><pre>1359.289762</pre></div></td></tr><tr><td><time datetime=\"2019-08-29\">Aug 29, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.250000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1381.889712</pre></div></td></tr><tr><td><time datetime=\"2019-09-12\">Sep 12, 2019</time></td><td><div class=\"dni-plaintext\"><pre>137.850006</pre></div></td><td><div class=\"dni-plaintext\"><pre>1392.389742</pre></div></td></tr><tr><td><time datetime=\"2019-09-19\">Sep 19, 2019</time></td><td><div class=\"dni-plaintext\"><pre>140.300003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1437.089752</pre></div></td></tr><tr><td colspan=\"3\"><i>(65 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"merged.Where(e => e.Balance is not null)\n",
" .ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
" Ah there is balance data, but it starts from the beginning of November and then available on specific dates thereafter! What's going here is that there is no trade decision that can be made until there's 20 days worth of price action to build the moving average, so it would be more interesting to skip the beginning until things get interesting. What if we could skip to just before the first trade? But how do you get something _just before_? What if we could *look-ahead* into a sequence such that we can skip until we see that the balance is about to become non-null? MoreLINQ has [`Lead`] just for that. You give it an offset and it will give you the current element together with the element at the given offset from the current, thus enabling one to _peek_ into the sequence. So let's look-ahead by 2 elements and skip the beginning of the data until we start seeing the balance moving due to a trade action:\n",
"\n",
" [`Lead`]: https://morelinq.github.io/4.0/ref/api/html/Overload_MoreLinq_MoreEnumerable_Lead.htm"
]
},
{
"cell_type": "code",
"execution_count": 131,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Balance\r\n",
"11/5/2018,106.370003,\r\n",
"11/6/2018,107.379997,\r\n",
"11/7/2018,109.440002,1033.750000\r\n",
"11/8/2018,111.800003,\r\n",
"11/9/2018,110.849998,\r\n",
"11/12/2018,109.419998,\r\n",
"11/13/2018,107.550003,\r\n",
"11/14/2018,108.099998,1038.699955\r\n",
"11/15/2018,104.989998,\r\n",
"11/16/2018,107.080002,\r\n",
"11/19/2018,108.269997,1068.219946\r\n",
"11/20/2018,101.800003,\r\n",
"11/21/2018,103.599998,\r\n",
"11/23/2018,102.169998,\r\n",
"11/26/2018,104.790001,\r\n",
"11/27/2018,106.269997,\r\n",
"11/28/2018,107.889999,1129.119906\r\n",
"11/29/2018,110.330002,\r\n",
"11/30/2018,110.699997,\r\n",
"12/3/2018,113.000000,\r\n",
"12/4/2018,111.940002,\r\n",
"12/6/2018,105.820000,\r\n",
"12/7/2018,108.379997,1154.719876\r\n",
"12/10/2018,104.800003,\r\n",
"12/11/2018,109.800003,1209.719876\r\n",
"12/12/2018,110.889999,\r\n",
"12/13/2018,109.580002,\r\n",
"12/14/2018,108.250000,\r\n",
"12/17/2018,105.410004,\r\n",
"12/18/2018,103.750000,\r\n",
"12/19/2018,103.650002,\r\n",
"12/20/2018,103.050003,\r\n",
"12/21/2018,101.629997,\r\n",
"12/24/2018,97.680000,\r\n",
"12/26/2018,95.139999,\r\n",
"12/27/2018,99.300003,\r\n",
"12/28/2018,102.089996,\r\n",
"12/31/2018,101.290001,\r\n",
"1/2/2019,99.550003,\r\n",
"1/3/2019,100.099998,\r\n",
"1/4/2019,99.720001,\r\n",
"1/7/2019,101.639999,\r\n",
"1/8/2019,103.040001,1183.649843\r\n",
"1/9/2019,103.860001,\r\n",
"1/10/2019,103.220001,\r\n",
"1/11/2019,103.190002,\r\n",
"1/14/2019,101.900002,\r\n",
"1/15/2019,102.510002,\r\n",
"1/16/2019,105.260002,\r\n",
"1/17/2019,105.000000,\r\n",
"1/18/2019,107.459999,\r\n",
"1/22/2019,106.750000,\r\n",
"1/23/2019,106.120003,\r\n",
"1/24/2019,106.860001,\r\n",
"1/25/2019,107.239998,\r\n",
"1/28/2019,106.260002,\r\n",
"1/29/2019,104.879997,\r\n",
"1/30/2019,104.620003,\r\n",
"1/31/2019,103.800003,\r\n",
"2/1/2019,103.779999,\r\n",
"2/4/2019,102.870003,\r\n",
"2/5/2019,106.059998,1208.509788\r\n",
"2/6/2019,107.000000,\r\n",
"2/7/2019,105.190002,\r\n",
"2/8/2019,104.389999,\r\n",
"2/11/2019,106.199997,1228.419766\r\n",
"2/12/2019,106.139999,\r\n",
"2/13/2019,107.500000,\r\n",
"2/14/2019,106.309998,\r\n",
"2/15/2019,107.910004,\r\n",
"2/19/2019,107.790001,\r\n",
"2/20/2019,107.860001,\r\n",
"2/21/2019,106.900002,\r\n",
"2/22/2019,110.050003,\r\n",
"2/25/2019,111.760002,\r\n",
"2/26/2019,111.260002,\r\n",
"2/27/2019,111.690002,\r\n",
"2/28/2019,112.040001,\r\n",
"3/1/2019,112.889999,\r\n",
"3/4/2019,113.019997,\r\n",
"3/5/2019,112.250000,\r\n",
"3/6/2019,111.870003,\r\n",
"3/7/2019,111.400002,\r\n",
"3/8/2019,109.160004,\r\n",
"3/11/2019,110.989998,1248.549700\r\n",
"3/12/2019,112.820000,\r\n",
"3/13/2019,114.129997,\r\n",
"3/14/2019,114.540001,\r\n",
"3/15/2019,115.339996,\r\n",
"3/18/2019,116.169998,\r\n",
"3/19/2019,118.089996,\r\n",
"3/20/2019,117.389999,\r\n",
"3/21/2019,117.139999,\r\n",
"3/22/2019,119.500000,\r\n",
"3/25/2019,116.559998,\r\n",
"3/26/2019,118.620003,\r\n",
"3/27/2019,117.879997,\r\n",
"3/28/2019,117.440002,\r\n",
"3/29/2019,118.070000,\r\n",
"4/1/2019,118.949997,\r\n",
"4/2/2019,119.059998,\r\n",
"4/3/2019,119.860001,\r\n",
"4/4/2019,120.099998,\r\n",
"4/5/2019,119.389999,\r\n",
"4/8/2019,119.809998,\r\n",
"4/9/2019,118.629997,\r\n",
"4/10/2019,119.760002,\r\n",
"4/11/2019,120.540001,\r\n",
"4/12/2019,120.639999,\r\n",
"4/15/2019,120.940002,\r\n",
"4/16/2019,121.639999,\r\n",
"4/17/2019,121.239998,\r\n",
"4/18/2019,122.190002,\r\n",
"4/22/2019,122.620003,\r\n",
"4/23/2019,124.099998,\r\n",
"4/24/2019,125.790001,\r\n",
"4/25/2019,130.059998,\r\n",
"4/26/2019,129.699997,\r\n",
"4/29/2019,129.899994,\r\n",
"4/30/2019,129.809998,\r\n",
"5/1/2019,130.529999,\r\n",
"5/2/2019,127.980003,\r\n",
"5/3/2019,127.360001,\r\n",
"5/6/2019,126.389999,\r\n",
"5/7/2019,126.459999,\r\n",
"5/8/2019,125.440002,\r\n",
"5/9/2019,124.290001,\r\n",
"5/10/2019,124.910004,\r\n",
"5/13/2019,124.110001,\r\n",
"5/14/2019,123.870003,\r\n",
"5/15/2019,124.260002,\r\n",
"5/16/2019,126.750000,1273.149690\r\n",
"5/17/2019,128.309998,\r\n",
"5/20/2019,126.519997,\r\n",
"5/21/2019,127.430000,1282.249720\r\n",
"5/22/2019,126.620003,\r\n",
"5/23/2019,126.199997,\r\n",
"5/24/2019,126.910004,1285.149730\r\n",
"5/28/2019,126.980003,\r\n",
"5/29/2019,125.379997,\r\n",
"5/30/2019,125.260002,\r\n",
"5/31/2019,124.230003,\r\n",
"6/3/2019,123.849998,\r\n",
"6/4/2019,121.279999,\r\n",
"6/5/2019,124.949997,\r\n",
"6/6/2019,126.440002,1295.749780\r\n",
"6/7/2019,129.190002,\r\n",
"6/10/2019,132.399994,\r\n",
"6/11/2019,133.880005,\r\n",
"6/12/2019,131.399994,\r\n",
"6/13/2019,131.979996,\r\n",
"6/14/2019,132.259995,\r\n",
"6/17/2019,132.630005,\r\n",
"6/18/2019,134.190002,\r\n",
"6/19/2019,135.000000,\r\n",
"6/20/2019,137.449997,\r\n",
"6/21/2019,136.580002,\r\n",
"6/24/2019,137.000000,\r\n",
"6/25/2019,137.250000,\r\n",
"6/26/2019,134.350006,\r\n",
"6/27/2019,134.139999,\r\n",
"6/28/2019,134.570007,\r\n",
"7/1/2019,136.630005,\r\n",
"7/2/2019,136.119995,\r\n",
"7/3/2019,136.800003,\r\n",
"7/5/2019,135.940002,\r\n",
"7/8/2019,136.399994,\r\n",
"7/9/2019,136.000000,\r\n",
"7/10/2019,137.130005,\r\n",
"7/11/2019,138.199997,\r\n",
"7/12/2019,138.850006,\r\n",
"7/15/2019,139.440002,\r\n",
"7/16/2019,138.960007,\r\n",
"7/17/2019,137.699997,\r\n",
"7/18/2019,135.550003,\r\n",
"7/19/2019,140.220001,1337.779762\r\n",
"7/22/2019,137.410004,\r\n",
"7/23/2019,139.759995,\r\n",
"7/24/2019,138.899994,\r\n",
"7/25/2019,140.429993,\r\n",
"7/26/2019,140.369995,\r\n",
"7/29/2019,141.500000,\r\n",
"7/30/2019,140.139999,\r\n",
"7/31/2019,140.330002,\r\n",
"8/1/2019,137.000000,\r\n",
"8/2/2019,138.089996,\r\n",
"8/5/2019,133.300003,\r\n",
"8/6/2019,133.800003,\r\n",
"8/7/2019,133.789993,\r\n",
"8/8/2019,136.600006,\r\n",
"8/9/2019,138.610001,1352.269771\r\n",
"8/12/2019,137.070007,\r\n",
"8/13/2019,136.050003,\r\n",
"8/14/2019,136.360001,\r\n",
"8/15/2019,134.389999,\r\n",
"8/16/2019,134.880005,\r\n",
"8/19/2019,137.850006,1359.289762\r\n",
"8/20/2019,138.210007,\r\n",
"8/21/2019,138.550003,\r\n",
"8/22/2019,138.660004,\r\n",
"8/23/2019,137.190002,\r\n",
"8/26/2019,134.990005,\r\n",
"8/27/2019,136.389999,\r\n",
"8/28/2019,134.880005,\r\n",
"8/29/2019,137.250000,1381.889712\r\n",
"8/30/2019,139.149994,\r\n",
"9/3/2019,136.610001,\r\n",
"9/4/2019,137.300003,\r\n",
"9/5/2019,139.110001,\r\n",
"9/6/2019,140.029999,\r\n",
"9/9/2019,139.589996,\r\n",
"9/10/2019,136.800003,\r\n",
"9/11/2019,135.910004,\r\n",
"9/12/2019,137.850006,1392.389742\r\n",
"9/13/2019,137.779999,\r\n",
"9/16/2019,135.830002,\r\n",
"9/17/2019,136.960007,\r\n",
"9/18/2019,137.360001,\r\n",
"9/19/2019,140.300003,1437.089752\r\n",
"9/20/2019,141.009995,\r\n",
"9/23/2019,139.229996,\r\n",
"9/24/2019,140.360001,\r\n",
"9/25/2019,137.500000,\r\n",
"9/26/2019,139.440002,1456.489772\r\n",
"9/27/2019,140.149994,\r\n",
"9/30/2019,138.050003,\r\n",
"10/1/2019,139.660004,1472.589782\r\n",
"10/2/2019,136.250000,\r\n",
"10/3/2019,134.949997,\r\n",
"10/4/2019,136.750000,\r\n",
"10/7/2019,137.139999,\r\n",
"10/8/2019,137.080002,\r\n",
"10/9/2019,137.460007,\r\n",
"10/10/2019,138.490005,1494.989832\r\n",
"10/11/2019,140.119995,\r\n",
"10/14/2019,139.690002,\r\n",
"10/15/2019,140.059998,\r\n",
"10/16/2019,140.789993,\r\n",
"10/17/2019,140.949997,\r\n",
"10/18/2019,139.759995,\r\n",
"10/21/2019,138.449997,\r\n",
"10/22/2019,138.970001,1500.189872\r\n",
"10/23/2019,136.880005,\r\n",
"10/24/2019,139.389999,1525.289812\r\n",
"10/25/2019,139.339996,\r\n",
"10/28/2019,144.399994,\r\n",
"10/29/2019,144.080002,\r\n",
"10/30/2019,143.520004,\r\n",
"10/31/2019,144.899994,\r\n",
"11/1/2019,144.259995,\r\n",
"11/4/2019,144.830002,\r\n",
"11/5/2019,144.970001,\r\n",
"11/6/2019,144.369995,\r\n",
"11/7/2019,143.839996,\r\n",
"11/8/2019,143.979996,\r\n",
"11/11/2019,145.339996,\r\n",
"11/12/2019,146.279999,\r\n",
"11/13/2019,146.740005,\r\n",
"11/14/2019,147.020004,\r\n",
"11/15/2019,148.929993,\r\n",
"11/18/2019,150.070007,\r\n",
"11/19/2019,150.880005,\r\n",
"11/20/2019,150.309998,\r\n",
"11/21/2019,149.399994,\r\n",
"11/22/2019,150.070007,\r\n",
"11/25/2019,150.000000,\r\n",
"11/26/2019,151.360001,\r\n",
"11/27/2019,152.330002,\r\n",
"11/29/2019,152.100006,\r\n",
"12/2/2019,151.809998,\r\n",
"12/3/2019,147.490005,\r\n",
"12/4/2019,150.139999,1551.789752\r\n",
"12/5/2019,150.050003,\r\n",
"12/6/2019,150.990005,\r\n",
"12/9/2019,151.070007,\r\n",
"12/10/2019,151.289993,\r\n",
"12/11/2019,151.539993,\r\n",
"12/12/2019,151.649994,\r\n",
"12/13/2019,153.000000,\r\n",
"12/16/2019,155.110001,\r\n",
"12/17/2019,155.449997,\r\n",
"12/18/2019,154.300003,\r\n",
"12/19/2019,154.000000,\r\n",
"12/20/2019,157.350006,\r\n",
"12/23/2019,158.119995,\r\n",
"12/24/2019,157.479996,\r\n",
"12/26/2019,157.559998,\r\n",
"12/27/2019,159.449997,\r\n",
"12/30/2019,158.990005,\r\n",
"12/31/2019,156.770004,\r\n",
"1/2/2020,158.779999,\r\n",
"1/3/2020,158.320007,\r\n",
"1/6/2020,157.080002,\r\n",
"1/7/2020,159.320007,\r\n",
"1/8/2020,158.929993,\r\n",
"1/9/2020,161.839996,\r\n",
"1/10/2020,162.820007,\r\n",
"1/13/2020,161.759995,\r\n",
"1/14/2020,163.389999,\r\n",
"1/15/2020,162.619995,\r\n",
"1/16/2020,164.350006,\r\n",
"1/17/2020,167.419998,\r\n",
"1/21/2020,166.679993,\r\n",
"1/22/2020,167.399994,\r\n",
"1/23/2020,166.190002,\r\n",
"1/24/2020,167.509995,\r\n",
"1/27/2020,161.149994,\r\n",
"1/28/2020,163.779999,1575.459797\r\n",
"1/29/2020,167.839996,\r\n",
"1/30/2020,174.050003,\r\n",
"1/31/2020,172.210007,\r\n",
"2/3/2020,170.429993,\r\n",
"2/4/2020,177.139999,\r\n",
"2/5/2020,184.029999,\r\n",
"2/6/2020,180.970001,\r\n",
"2/7/2020,182.850006,\r\n",
"2/10/2020,183.580002,\r\n",
"2/11/2020,190.649994,\r\n",
"2/12/2020,185.580002,\r\n",
"2/13/2020,183.080002,\r\n",
"2/14/2020,183.250000,\r\n",
"2/18/2020,185.610001,\r\n",
"2/19/2020,188.059998,\r\n",
"2/20/2020,186.949997,\r\n",
"2/21/2020,183.169998,\r\n",
"2/24/2020,167.770004,\r\n",
"2/25/2020,174.199997,\r\n",
"2/26/2020,169.710007,\r\n",
"2/27/2020,163.320007,\r\n",
"2/28/2020,152.410004,\r\n",
"3/2/2020,165.309998,\r\n",
"3/3/2020,173.800003,\r\n",
"3/4/2020,168.490005,\r\n",
"3/5/2020,166.050003,\r\n",
"3/6/2020,162.610001,\r\n",
"3/9/2020,151.000000,\r\n",
"3/10/2020,158.160004,\r\n",
"3/11/2020,157.130005,\r\n",
"3/12/2020,145.300003,\r\n",
"3/13/2020,147.500000,\r\n",
"3/16/2020,140.000000,\r\n",
"3/17/2020,140.000000,\r\n",
"3/18/2020,138.000000,\r\n",
"3/19/2020,142.770004,\r\n",
"3/20/2020,146.000000,\r\n",
"3/23/2020,137.009995,\r\n",
"3/24/2020,143.750000,\r\n",
"3/25/2020,148.910004,\r\n",
"3/26/2020,148.399994,\r\n",
"3/27/2020,151.750000,1431.279761\r\n",
"3/30/2020,152.440002,\r\n",
"3/31/2020,159.399994,\r\n",
"4/1/2020,153.000000,\r\n",
"4/2/2020,151.860001,\r\n",
"4/3/2020,155.100006,\r\n",
"4/6/2020,160.320007,\r\n",
"4/7/2020,169.589996,\r\n",
"4/8/2020,165.669998,\r\n",
"4/9/2020,166.360001,\r\n",
"4/13/2020,164.350006,\r\n",
"4/14/2020,169.000000,\r\n",
"4/15/2020,171.199997,\r\n",
"4/16/2020,174.300003,\r\n",
"4/17/2020,179.500000,\r\n",
"4/20/2020,176.630005,\r\n",
"4/21/2020,173.500000,\r\n",
"4/22/2020,171.389999,\r\n",
"4/23/2020,174.110001,\r\n",
"4/24/2020,172.059998,\r\n",
"4/27/2020,176.589996,\r\n",
"4/28/2020,175.589996,\r\n",
"4/29/2020,173.220001,\r\n",
"4/30/2020,180.000000,\r\n",
"5/1/2020,175.800003,\r\n",
"5/4/2020,174.490005,\r\n",
"5/5/2020,180.619995,\r\n",
"5/6/2020,182.080002,\r\n",
"5/7/2020,184.169998,\r\n",
"5/8/2020,184.979996,\r\n",
"5/11/2020,183.149994,\r\n",
"5/12/2020,186.800003,\r\n",
"5/13/2020,182.550003,\r\n",
"5/14/2020,177.539993,\r\n",
"5/15/2020,179.059998,1443.439801\r\n",
"5/18/2020,185.750000,\r\n",
"5/19/2020,185.029999,\r\n",
"5/20/2020,184.809998,\r\n",
"5/21/2020,185.399994,\r\n",
"5/22/2020,183.190002,\r\n",
"5/26/2020,186.339996,\r\n",
"5/27/2020,180.199997,\r\n",
"5/28/2020,180.740005,\r\n",
"5/29/2020,182.729996,1463.679793\r\n",
"6/1/2020,182.539993,\r\n",
"6/2/2020,184.250000,1477.359849\r\n",
"6/3/2020,184.820007,\r\n",
"6/4/2020,184.300003,\r\n",
"6/5/2020,182.619995,\r\n",
"6/8/2020,185.940002,1503.919905\r\n",
"6/9/2020,188.000000,\r\n",
"6/10/2020,191.130005,\r\n",
"6/11/2020,193.130005,\r\n",
"6/12/2020,190.539993,\r\n",
"6/15/2020,184.580002,\r\n",
"6/16/2020,192.889999,1570.399881\r\n",
"6/17/2020,195.029999,\r\n",
"6/18/2020,194.000000,\r\n",
"6/19/2020,198.589996,\r\n",
"6/22/2020,195.789993,\r\n",
"6/23/2020,202.089996,\r\n",
"6/24/2020,201.600006,\r\n",
"6/25/2020,197.800003,\r\n",
"6/26/2020,199.729996,\r\n",
"6/29/2020,195.779999,\r\n",
"6/30/2020,197.880005,\r\n",
"7/1/2020,203.139999,\r\n",
"7/2/2020,205.679993,\r\n",
"7/6/2020,208.830002,\r\n",
"7/7/2020,210.449997,\r\n",
"7/8/2020,210.070007,\r\n",
"7/9/2020,216.330002,\r\n",
"7/10/2020,213.619995,\r\n",
"7/13/2020,214.479996,\r\n",
"7/14/2020,206.130005,\r\n",
"7/15/2020,209.559998,\r\n",
"7/16/2020,205.399994,\r\n",
"7/17/2020,204.470001,\r\n",
"7/20/2020,205.000000,\r\n",
"7/21/2020,213.660004,1634.729902\r\n",
"7/22/2020,209.199997,\r\n",
"7/23/2020,207.190002,\r\n",
"7/24/2020,200.419998,\r\n",
"7/27/2020,201.470001,\r\n",
"7/28/2020,203.610001,\r\n",
"7/29/2020,202.500000,\r\n",
"7/30/2020,201.000000,\r\n",
"7/31/2020,204.399994,\r\n",
"8/3/2020,211.520004,1723.529950\r\n",
"8/4/2020,214.169998,\r\n",
"8/5/2020,214.899994,\r\n",
"8/6/2020,212.339996,\r\n",
"8/7/2020,214.850006,\r\n",
"8/10/2020,211.669998,\r\n",
"8/11/2020,207.160004,\r\n",
"8/12/2020,205.289993,\r\n",
"8/13/2020,209.440002,1741.769934\r\n",
"8/14/2020,208.759995,\r\n",
"8/17/2020,209.600006,\r\n",
"8/18/2020,210.529999,\r\n",
"8/19/2020,211.490005,\r\n",
"8/20/2020,209.539993,\r\n",
"8/21/2020,213.860001,\r\n",
"8/24/2020,214.789993,\r\n",
"8/25/2020,213.100006,\r\n",
"8/26/2020,217.880005,\r\n",
"8/27/2020,222.889999,\r\n",
"8/28/2020,228.179993,\r\n",
"8/31/2020,227.000000,\r\n",
"9/1/2020,225.509995,\r\n",
"9/2/2020,227.970001,\r\n",
"9/3/2020,229.270004,\r\n",
"9/4/2020,215.100006,\r\n",
"9/8/2020,206.500000,\r\n",
"9/9/2020,207.600006,\r\n",
"9/10/2020,213.399994,\r\n",
"9/11/2020,207.199997,\r\n",
"9/14/2020,204.240005,\r\n",
"9/15/2020,208.419998,\r\n",
"9/16/2020,210.619995,\r\n",
"9/17/2020,200.050003,\r\n",
"9/18/2020,202.800003,\r\n",
"9/21/2020,197.190002,\r\n",
"9/22/2020,205.059998,\r\n",
"9/23/2020,207.899994,\r\n",
"9/24/2020,199.850006,\r\n",
"9/25/2020,203.550003,\r\n",
"9/28/2020,210.880005,1708.009926\r\n",
"9/29/2020,209.350006,\r\n",
"9/30/2020,207.729996,\r\n",
"10/1/2020,213.490005,1741.129918\r\n",
"10/2/2020,208.000000,\r\n",
"10/5/2020,207.220001,\r\n",
"10/6/2020,208.820007,\r\n",
"10/7/2020,207.059998,\r\n",
"10/8/2020,210.509995,\r\n",
"10/9/2020,211.229996,\r\n",
"10/12/2020,218.789993,\r\n",
"10/13/2020,222.720001,\r\n",
"10/14/2020,223.000000,\r\n",
"10/15/2020,217.100006,\r\n",
"10/16/2020,220.149994,\r\n",
"10/19/2020,220.419998,\r\n",
"10/20/2020,215.800003,\r\n",
"10/21/2020,213.119995,\r\n",
"10/22/2020,213.929993,\r\n",
"10/23/2020,215.029999,\r\n",
"10/26/2020,213.850006,\r\n",
"10/27/2020,211.589996,\r\n",
"10/28/2020,207.669998,\r\n",
"10/29/2020,204.070007,\r\n",
"10/30/2020,203.500000,\r\n",
"11/2/2020,204.289993,\r\n",
"11/3/2020,203.889999,\r\n",
"11/4/2020,214.020004,1742.489902\r\n",
"11/5/2020,222.039993,\r\n",
"11/6/2020,222.259995,\r\n",
"11/9/2020,224.440002,\r\n",
"11/10/2020,214.500000,\r\n",
"11/11/2020,212.389999,\r\n",
"11/12/2020,217.210007,1781.049966\r\n",
"11/13/2020,216.360001,\r\n",
"11/16/2020,214.869995,\r\n",
"11/17/2020,216.100006,\r\n",
"11/18/2020,213.649994,\r\n",
"11/19/2020,211.380005,\r\n",
"11/20/2020,212.199997,\r\n",
"11/23/2020,210.949997,\r\n",
"11/24/2020,209.589996,\r\n",
"11/25/2020,215.110001,1810.889934\r\n",
"11/27/2020,214.850006,\r\n",
"11/30/2020,214.100006,\r\n",
"12/1/2020,214.509995,\r\n",
"12/2/2020,214.880005,\r\n",
"12/3/2020,214.610001,\r\n",
"12/4/2020,214.220001,\r\n",
"12/7/2020,214.369995,\r\n",
"12/8/2020,213.970001,\r\n",
"12/9/2020,215.160004,1819.369918\r\n",
"12/10/2020,211.770004,\r\n",
"12/11/2020,210.050003,\r\n",
"12/14/2020,213.100006,\r\n",
"12/15/2020,215.169998,1846.569870\r\n",
"12/16/2020,214.750000,\r\n",
"12/17/2020,219.869995,\r\n",
"12/18/2020,218.589996,\r\n",
"12/21/2020,217.550003,\r\n",
"12/22/2020,222.690002,\r\n",
"12/23/2020,223.110001,\r\n",
"12/24/2020,221.419998,\r\n",
"12/28/2020,224.449997,\r\n",
"12/29/2020,226.309998,\r\n",
"12/30/2020,225.229996,\r\n",
"12/31/2020,221.699997,\r\n",
"1/4/2021,222.529999,\r\n",
"1/5/2021,217.259995,\r\n",
"1/6/2021,212.169998,\r\n",
"1/7/2021,214.039993,\r\n",
"1/8/2021,218.679993,1857.929854\r\n",
"1/11/2021,218.470001,\r\n",
"1/12/2021,216.500000,\r\n",
"1/13/2021,214.020004,\r\n",
"1/14/2021,215.910004,\r\n",
"1/15/2021,213.520004,\r\n",
"1/19/2021,213.750000,\r\n",
"1/20/2021,217.699997,\r\n",
"1/21/2021,224.699997,1907.769822\r\n",
"1/22/2021,227.080002,\r\n",
"1/25/2021,229.119995,\r\n",
"1/26/2021,231.860001,\r\n",
"1/27/2021,238.000000,\r\n",
"1/28/2021,235.610001,\r\n",
"1/29/2021,235.990005,\r\n",
"2/1/2021,235.059998,\r\n",
"2/2/2021,241.300003,\r\n",
"2/3/2021,239.570007,\r\n",
"2/4/2021,242.660004,\r\n",
"2/5/2021,242.229996,\r\n",
"2/8/2021,243.149994,\r\n",
"2/9/2021,241.869995,\r\n",
"2/10/2021,245.000000,\r\n",
"2/11/2021,244.779999,\r\n",
"2/12/2021,243.929993,\r\n",
"2/16/2021,245.029999,\r\n",
"2/17/2021,241.320007,\r\n",
"2/18/2021,241.800003,\r\n",
"2/19/2021,243.750000,\r\n",
"2/22/2021,237.419998,\r\n",
"2/23/2021,230.330002,\r\n",
"2/24/2021,230.009995,\r\n",
"2/25/2021,232.080002,\r\n",
"2/26/2021,231.529999,\r\n",
"3/1/2021,235.899994,\r\n",
"3/2/2021,237.009995,\r\n",
"3/3/2021,232.160004,\r\n",
"3/4/2021,226.740005,\r\n",
"3/5/2021,229.520004,\r\n",
"3/8/2021,231.369995,\r\n",
"3/9/2021,232.880005,\r\n",
"3/10/2021,237.000000,1904.409838\r\n",
"3/11/2021,234.960007,\r\n",
"3/12/2021,234.009995,\r\n",
"3/15/2021,234.960007,\r\n",
"3/16/2021,236.279999,1914.969774\r\n",
"3/17/2021,236.149994,\r\n",
"3/18/2021,232.559998,\r\n",
"3/19/2021,231.020004,\r\n",
"3/22/2021,230.270004,\r\n",
"3/23/2021,237.490005,1954.409830\r\n",
"3/24/2021,237.850006,\r\n",
"3/25/2021,235.300003,\r\n",
"3/26/2021,231.550003,\r\n",
"3/29/2021,236.589996,1994.729774\r\n",
"3/30/2021,233.529999,\r\n",
"3/31/2021,232.910004,\r\n",
"4/1/2021,238.470001,2034.249790\r\n",
"4/5/2021,242.759995,\r\n",
"4/6/2021,247.610001,\r\n",
"4/7/2021,247.809998,\r\n",
"4/8/2021,252.770004,\r\n",
"4/9/2021,252.869995,\r\n",
"4/12/2021,254.710007,\r\n",
"4/13/2021,257.260010,\r\n",
"4/14/2021,257.480011,\r\n",
"4/15/2021,257.929993,\r\n",
"4/16/2021,259.470001,\r\n",
"4/19/2021,260.190002,\r\n",
"4/20/2021,257.820007,\r\n",
"4/21/2021,258.940002,\r\n",
"4/22/2021,260.209991,\r\n",
"4/23/2021,257.880005,\r\n",
"4/26/2021,261.660004,\r\n",
"4/27/2021,261.579987,\r\n",
"4/28/2021,256.079987,\r\n",
"4/29/2021,255.460007,\r\n",
"4/30/2021,249.740005,\r\n",
"5/3/2021,253.399994,\r\n",
"5/4/2021,250.970001,\r\n",
"5/5/2021,249.059998,\r\n",
"5/6/2021,246.449997,\r\n",
"5/7/2021,252.149994,\r\n",
"5/10/2021,250.869995,\r\n",
"5/11/2021,244.550003,\r\n",
"5/12/2021,242.169998,\r\n",
"5/13/2021,241.800003,\r\n",
"5/14/2021,245.580002,\r\n",
"5/17/2021,246.550003,\r\n",
"5/18/2021,246.270004,\r\n",
"5/19/2021,239.309998,\r\n",
"5/20/2021,243.960007,\r\n",
"5/21/2021,247.570007,\r\n",
"5/24/2021,247.789993,\r\n",
"5/25/2021,251.770004,2050.489782\r\n",
"5/26/2021,251.429993,\r\n",
"5/27/2021,251.169998,\r\n",
"5/28/2021,251.000000,\r\n",
"6/1/2021,251.229996,\r\n",
"6/2/2021,248.130005,\r\n",
"6/3/2021,245.220001,\r\n",
"6/4/2021,247.759995,2070.809734\r\n",
"6/7/2021,249.979996,\r\n",
"6/8/2021,255.160004,\r\n",
"6/9/2021,253.809998,\r\n",
"6/10/2021,254.289993,\r\n",
"6/11/2021,257.989990,\r\n",
"6/14/2021,257.899994,\r\n",
"6/15/2021,259.769989,\r\n",
"6/16/2021,259.399994,\r\n",
"6/17/2021,256.070007,\r\n",
"6/18/2021,259.630005,\r\n",
"6/21/2021,259.820007,\r\n",
"6/22/2021,262.720001,\r\n",
"6/23/2021,265.989990,\r\n",
"6/24/2021,266.160004,\r\n",
"6/25/2021,266.230011,\r\n",
"6/28/2021,266.190002,\r\n",
"6/29/2021,268.869995,\r\n",
"6/30/2021,270.690002,\r\n",
"7/1/2021,269.609985,\r\n",
"7/2/2021,272.820007,\r\n",
"7/6/2021,278.029999,\r\n",
"7/7/2021,279.399994,\r\n",
"7/8/2021,276.899994,\r\n",
"7/9/2021,275.720001,\r\n",
"7/12/2021,279.160004,\r\n",
"7/13/2021,277.519989,\r\n",
"7/14/2021,282.350006,\r\n",
"7/15/2021,282.000000,\r\n",
"7/16/2021,282.070007,\r\n",
"7/19/2021,278.929993,\r\n",
"7/20/2021,278.029999,\r\n",
"7/21/2021,278.899994,\r\n",
"7/22/2021,283.839996,\r\n",
"7/23/2021,287.369995,\r\n",
"7/26/2021,289.000000,\r\n",
"7/27/2021,289.429993,\r\n",
"7/28/2021,288.989990,\r\n",
"7/29/2021,286.239990,\r\n",
"7/30/2021,285.170013,\r\n",
"8/2/2021,286.359985,\r\n",
"8/3/2021,285.420013,\r\n",
"8/4/2021,286.220001,\r\n",
"8/5/2021,286.880005,\r\n",
"8/6/2021,288.510010,\r\n",
"8/9/2021,289.750000,\r\n",
"8/10/2021,288.799988,\r\n",
"8/11/2021,287.209991,\r\n",
"8/12/2021,286.630005,\r\n",
"8/13/2021,289.480011,\r\n",
"8/16/2021,293.190002,\r\n",
"8/17/2021,292.390015,\r\n",
"8/18/2021,292.040009,\r\n",
"8/19/2021,288.690002,\r\n",
"8/20/2021,299.720001,\r\n",
"8/23/2021,303.250000,\r\n",
"8/24/2021,305.019989,\r\n",
"8/25/2021,304.299988,\r\n",
"8/26/2021,300.989990,\r\n",
"8/27/2021,298.989990,\r\n",
"8/30/2021,301.119995,\r\n",
"8/31/2021,304.420013,\r\n",
"9/1/2021,302.869995,\r\n",
"9/2/2021,302.200012,\r\n",
"9/3/2021,300.989990,\r\n",
"9/7/2021,301.010010,\r\n",
"9/8/2021,299.779999,\r\n",
"9/9/2021,300.820007,\r\n",
"9/10/2021,298.420013,\r\n",
"9/13/2021,297.549988,\r\n",
"9/14/2021,299.559998,\r\n",
"9/15/2021,303.260010,2099.849716\r\n",
"9/16/2021,303.760010,\r\n",
"9/17/2021,304.170013,\r\n",
"9/20/2021,296.329987,\r\n",
"9/21/2021,295.690002,\r\n",
"9/22/2021,296.730011,\r\n",
"9/23/2021,298.850006,\r\n",
"9/24/2021,298.230011,\r\n",
"9/27/2021,296.140015,\r\n",
"9/28/2021,289.799988,\r\n",
"9/29/2021,285.100006,\r\n",
"9/30/2021,285.709991,\r\n",
"10/1/2021,282.119995,\r\n",
"10/4/2021,287.399994,\r\n",
"10/5/2021,284.049988,\r\n",
"10/6/2021,285.779999,\r\n",
"10/7/2021,295.179993,2091.799758\r\n",
"10/8/2021,296.220001,\r\n",
"10/11/2021,292.920013,\r\n",
"10/12/2021,295.339996,2108.739639\r\n",
"10/13/2021,294.910004,\r\n",
"10/14/2021,299.209991,\r\n",
"10/15/2021,302.339996,\r\n",
"10/18/2021,303.570007,\r\n",
"10/19/2021,308.350006,\r\n",
"10/20/2021,309.209991,\r\n",
"10/21/2021,307.170013,\r\n",
"10/22/2021,310.399994,\r\n",
"10/25/2021,309.359985,\r\n",
"10/26/2021,311.000000,\r\n",
"10/27/2021,316.000000,\r\n",
"10/28/2021,324.329987,\r\n",
"10/29/2021,324.130005,\r\n",
"11/1/2021,331.359985,\r\n",
"11/2/2021,330.309998,\r\n",
"11/3/2021,333.899994,\r\n",
"11/4/2021,332.890015,\r\n",
"11/5/2021,338.510010,\r\n",
"11/8/2021,337.299988,\r\n",
"11/9/2021,337.109985,\r\n",
"11/10/2021,334.570007,\r\n",
"11/11/2021,331.250000,\r\n",
"11/12/2021,333.920013,\r\n",
"11/15/2021,337.540009,\r\n",
"11/16/2021,335.679993,\r\n",
"11/17/2021,338.940002,\r\n",
"11/18/2021,338.179993,\r\n",
"11/19/2021,342.640015,\r\n",
"11/22/2021,344.619995,\r\n",
"11/23/2021,337.049988,\r\n",
"11/24/2021,336.279999,\r\n",
"11/26/2021,334.350006,\r\n",
"11/29/2021,334.940002,\r\n",
"11/30/2021,335.320007,\r\n",
"12/1/2021,335.130005,\r\n",
"12/2/2021,330.299988,\r\n",
"12/3/2021,331.989990,\r\n",
"12/6/2021,323.950012,\r\n",
"12/7/2021,331.640015,\r\n",
"12/8/2021,335.309998,2114.499591\r\n",
"12/9/2021,334.410004,\r\n",
"12/10/2021,334.980011,\r\n",
"12/13/2021,340.679993,2152.119525\r\n",
"12/14/2021,333.220001,\r\n",
"12/15/2021,328.609985,\r\n",
"12/16/2021,335.709991,2167.059465\r\n",
"12/17/2021,320.880005,\r\n",
"12/20/2021,320.049988,\r\n",
"12/21/2021,323.290009,\r\n",
"12/22/2021,328.299988,\r\n",
"12/23/2021,332.750000,2238.279435\r\n",
"12/27/2021,335.459991,\r\n",
"12/28/2021,343.149994,\r\n",
"12/29/2021,341.299988,\r\n",
"12/30/2021,341.910004,\r\n",
"12/31/2021,338.510010,\r\n",
"1/3/2022,335.350006,\r\n",
"1/4/2022,334.829987,\r\n",
"1/5/2022,325.859985,\r\n",
"1/6/2022,313.149994,\r\n",
"1/7/2022,314.149994,\r\n",
"1/10/2022,309.489990,\r\n",
"1/11/2022,313.380005,\r\n",
"1/12/2022,319.670013,\r\n",
"1/13/2022,320.470001,\r\n",
"1/14/2022,304.250000,\r\n",
"1/18/2022,304.070007,\r\n",
"1/19/2022,306.290009,\r\n",
"1/20/2022,309.070007,\r\n",
"1/21/2022,302.690002,\r\n",
"1/24/2022,292.200012,\r\n",
"1/25/2022,291.519989,\r\n",
"1/26/2022,307.989990,\r\n",
"1/27/2022,302.660004,\r\n",
"1/28/2022,300.230011,\r\n",
"1/31/2022,308.950012,\r\n",
"2/1/2022,310.410004,2145.579549\r\n",
"2/2/2022,309.630005,\r\n",
"2/3/2022,309.489990,\r\n",
"2/4/2022,300.209991,\r\n",
"2/7/2022,306.170013,\r\n",
"2/8/2022,301.250000,\r\n",
"2/9/2022,309.869995,2213.199577\r\n",
"2/10/2022,304.040009,\r\n",
"2/11/2022,303.190002,\r\n",
"2/14/2022,293.769989,\r\n",
"2/15/2022,300.010010,\r\n",
"2/16/2022,298.369995,\r\n",
"2/17/2022,296.359985,\r\n",
"2/18/2022,293.049988,\r\n",
"2/22/2022,285.000000,\r\n",
"2/23/2022,290.179993,\r\n",
"2/24/2022,272.510010,\r\n",
"2/25/2022,295.140015,\r\n",
"2/28/2022,294.309998,\r\n",
"3/1/2022,296.399994,\r\n",
"3/2/2022,295.359985,\r\n",
"3/3/2022,302.890015,2205.149619\r\n",
"3/4/2022,294.290009,\r\n",
"3/7/2022,288.529999,\r\n",
"3/8/2022,277.799988,\r\n",
"3/9/2022,283.440002,\r\n",
"3/10/2022,283.019989,\r\n",
"3/11/2022,287.959991,\r\n",
"3/14/2022,280.339996,\r\n",
"3/15/2022,280.350006,\r\n",
"3/16/2022,289.109985,\r\n",
"3/17/2022,293.290009,2198.149619\r\n",
"3/18/2022,295.369995,\r\n",
"3/21/2022,298.890015,\r\n",
"3/22/2022,299.799988,\r\n",
"3/23/2022,300.510010,\r\n",
"3/24/2022,299.140015,\r\n",
"3/25/2022,305.230011,\r\n",
"3/28/2022,304.329987,\r\n",
"3/29/2022,313.910004,\r\n",
"3/30/2022,313.760010,\r\n",
"3/31/2022,313.899994,\r\n",
"4/1/2022,309.369995,\r\n",
"4/4/2022,310.089996,\r\n",
"4/5/2022,313.269989,\r\n",
"4/6/2022,305.190002,\r\n",
"4/7/2022,296.660004,\r\n",
"4/8/2022,300.440002,\r\n",
"4/11/2022,291.790009,\r\n",
"4/12/2022,289.239990,\r\n",
"4/13/2022,282.730011,\r\n",
"4/14/2022,288.089996,\r\n",
"4/18/2022,278.910004,\r\n",
"4/19/2022,279.380005,\r\n",
"4/20/2022,289.399994,\r\n",
"4/21/2022,288.579987,\r\n",
"4/22/2022,281.679993,\r\n",
"4/25/2022,273.290009,\r\n",
"4/26/2022,277.500000,\r\n",
"4/27/2022,282.100006,\r\n",
"4/28/2022,285.190002,\r\n",
"4/29/2022,288.609985,\r\n",
"5/2/2022,277.709991,\r\n",
"5/3/2022,283.959991,\r\n",
"5/4/2022,282.589996,\r\n",
"5/5/2022,285.540009,2120.309654\r\n",
"5/6/2022,274.809998,\r\n",
"5/9/2022,270.059998,\r\n",
"5/10/2022,271.690002,\r\n",
"5/11/2022,265.679993,\r\n",
"5/12/2022,257.690002,\r\n",
"5/13/2022,257.350006,\r\n",
"5/16/2022,259.959991,\r\n",
"5/17/2022,266.109985,\r\n",
"5/18/2022,263.000000,\r\n",
"5/19/2022,253.899994,\r\n",
"5/20/2022,257.239990,\r\n",
"5/23/2022,255.490005,\r\n",
"5/24/2022,257.890015,\r\n",
"5/25/2022,258.140015,\r\n",
"5/26/2022,262.269989,\r\n",
"5/27/2022,268.480011,2075.999745\r\n",
"5/31/2022,272.529999,\r\n",
"6/1/2022,275.200012,\r\n",
"6/2/2022,264.450012,\r\n",
"6/3/2022,270.309998,2117.019647\r\n",
"6/6/2022,272.059998,\r\n",
"6/7/2022,266.640015,\r\n",
"6/8/2022,271.709991,\r\n",
"6/9/2022,267.779999,\r\n",
"6/10/2022,260.579987,\r\n",
"6/13/2022,245.110001,\r\n",
"6/14/2022,243.860001,\r\n",
"6/15/2022,248.309998,\r\n",
"6/16/2022,245.979996,\r\n",
"6/17/2022,244.699997,\r\n",
"6/21/2022,250.259995,\r\n",
"6/22/2022,251.889999,\r\n",
"6/23/2022,255.570007,\r\n",
"6/24/2022,261.809998,2126.859735\r\n",
"6/27/2022,268.209991,\r\n",
"6/28/2022,263.980011,\r\n",
"6/29/2022,257.589996,\r\n",
"6/30/2022,257.049988,\r\n",
"7/1/2022,256.390015,\r\n",
"7/5/2022,256.160004,\r\n",
"7/6/2022,263.750000,2176.139767\r\n",
"7/7/2022,265.119995,\r\n",
"7/8/2022,264.790009,\r\n",
"7/11/2022,265.649994,\r\n",
"7/12/2022,265.880005,\r\n",
"7/13/2022,250.190002,\r\n",
"7/14/2022,250.570007,\r\n",
"7/15/2022,255.720001,\r\n",
"7/18/2022,259.750000,2252.619751\r\n",
"7/19/2022,257.579987,\r\n",
"7/20/2022,259.899994,2271.179807\r\n",
"7/21/2022,259.790009,\r\n",
"7/22/2022,265.239990,\r\n",
"7/25/2022,261.000000,\r\n",
"7/26/2022,259.859985,\r\n",
"7/27/2022,261.160004,\r\n",
"7/28/2022,269.750000,\r\n",
"7/29/2022,277.700012,\r\n",
"8/1/2022,277.820007,\r\n",
"8/2/2022,276.000000,\r\n",
"8/3/2022,276.760010,\r\n",
"8/4/2022,281.799988,\r\n",
"8/5/2022,279.149994,\r\n",
"8/8/2022,284.049988,\r\n",
"8/9/2022,279.640015,\r\n",
"8/10/2022,288.170013,\r\n",
"8/11/2022,290.850006,\r\n",
"8/12/2022,288.480011,\r\n",
"8/15/2022,291.000000,\r\n",
"8/16/2022,291.989990,\r\n",
"8/17/2022,289.739990,\r\n",
"8/18/2022,290.190002,\r\n",
"8/19/2022,288.899994,\r\n",
"8/22/2022,282.079987,\r\n",
"8/23/2022,276.440002,\r\n",
"8/24/2022,275.410004,\r\n",
"8/25/2022,277.329987,\r\n",
"8/26/2022,279.079987,\r\n",
"8/29/2022,265.850006,\r\n",
"8/30/2022,266.670013,\r\n",
"8/31/2022,265.390015,\r\n",
"9/1/2022,258.869995,\r\n",
"9/2/2022,261.700012,\r\n",
"9/6/2022,256.200012,\r\n",
"9/7/2022,254.699997,\r\n",
"9/8/2022,257.510010,\r\n",
"9/9/2022,260.500000,\r\n",
"9/12/2022,265.779999,\r\n",
"9/13/2022,258.839996,\r\n",
"9/14/2022,253.529999,\r\n",
"9/15/2022,249.770004,\r\n",
"9/16/2022,244.259995,\r\n",
"9/19/2022,242.470001,\r\n",
"9/20/2022,242.070007,\r\n",
"9/21/2022,244.270004,\r\n",
"9/22/2022,237.869995,\r\n",
"9/23/2022,239.539993,\r\n",
"9/26/2022,237.050003,\r\n",
"9/27/2022,239.979996,\r\n",
"9/28/2022,236.809998,\r\n",
"9/29/2022,238.889999,\r\n",
"9/30/2022,238.289993,\r\n",
"10/3/2022,235.410004,\r\n",
"10/4/2022,245.089996,\r\n",
"10/5/2022,245.990005,2027.579831\r\n",
"10/6/2022,247.929993,\r\n",
"10/7/2022,240.899994,\r\n",
"10/10/2022,233.050003,\r\n",
"10/11/2022,227.619995,\r\n",
"10/12/2022,225.399994,\r\n",
"10/13/2022,219.850006,\r\n",
"10/14/2022,235.539993,\r\n",
"10/17/2022,235.820007,\r\n",
"10/18/2022,243.240005,2046.299919\r\n",
"10/19/2022,237.039993,\r\n",
"10/20/2022,235.770004,\r\n",
"10/21/2022,234.740005,\r\n",
"10/24/2022,243.759995,2100.059935\r\n",
"10/25/2022,247.259995,\r\n",
"10/26/2022,231.169998,\r\n",
"10/27/2022,231.039993,\r\n",
"10/28/2022,226.240005,\r\n",
"10/31/2022,233.759995,\r\n",
"11/1/2022,234.600006,\r\n",
"11/2/2022,229.460007,\r\n",
"11/3/2022,220.089996,\r\n",
"11/4/2022,217.550003,\r\n",
"11/7/2022,221.990005,\r\n",
"11/8/2022,228.699997,\r\n",
"11/9/2022,227.369995,\r\n",
"11/10/2022,235.429993,2138.399890\r\n",
"11/11/2022,242.990005,\r\n",
"11/14/2022,241.990005,\r\n",
"11/15/2022,245.660004,\r\n",
"11/16/2022,242.789993,\r\n",
"11/17/2022,237.779999,\r\n",
"11/18/2022,243.509995,\r\n",
"11/21/2022,241.429993,\r\n",
"11/22/2022,243.589996,\r\n",
"11/23/2022,245.110001,\r\n",
"11/25/2022,247.309998,\r\n",
"11/28/2022,246.080002,\r\n",
"11/29/2022,241.399994,\r\n",
"11/30/2022,240.570007,\r\n",
"12/1/2022,253.869995,\r\n",
"12/2/2022,249.820007,\r\n",
"12/5/2022,252.009995,\r\n",
"12/6/2022,250.820007,\r\n",
"12/7/2022,244.830002,\r\n",
"12/8/2022,244.839996,\r\n",
"12/9/2022,244.699997,\r\n",
"12/12/2022,247.449997,2160.399890\r\n",
"12/13/2022,261.690002,\r\n",
"12/14/2022,257.130005,\r\n",
"12/15/2022,253.720001,\r\n",
"12/16/2022,248.550003,\r\n",
"12/19/2022,244.860001,\r\n",
"12/20/2022,239.399994,\r\n",
"12/21/2022,241.690002,\r\n",
"12/22/2022,241.259995,\r\n",
"12/23/2022,236.110001,\r\n",
"12/27/2022,238.699997,\r\n",
"12/28/2022,236.889999,\r\n",
"12/29/2022,235.649994,\r\n",
"12/30/2022,238.210007,\r\n",
"1/3/2023,243.080002,\r\n",
"1/4/2023,232.279999,\r\n",
"1/5/2023,227.199997,\r\n",
"1/6/2023,223.000000,\r\n",
"1/9/2023,226.449997,\r\n",
"1/10/2023,227.759995,\r\n",
"1/11/2023,231.289993,\r\n",
"1/12/2023,235.259995,\r\n",
"1/13/2023,237.000000,2097.519882\r\n",
"1/17/2023,237.970001,\r\n",
"1/18/2023,241.570007,\r\n",
"1/19/2023,233.779999,\r\n",
"1/20/2023,234.860001,\r\n",
"1/23/2023,241.100006,2156.079938\r\n",
"1/24/2023,242.500000,\r\n",
"1/25/2023,234.479996,\r\n",
"1/26/2023,243.649994,2238.609920\r\n",
"1/27/2023,248.990005,\r\n",
"1/30/2023,244.509995,\r\n",
"1/31/2023,243.449997,\r\n",
"2/1/2023,248.000000,\r\n",
"2/2/2023,258.820007,\r\n",
"2/3/2023,259.540009,\r\n",
"2/6/2023,257.440002,\r\n",
"2/7/2023,260.529999,\r\n",
"2/8/2023,273.200012,\r\n",
"2/9/2023,273.799988,\r\n",
"2/10/2023,261.529999,\r\n",
"2/13/2023,267.640015,\r\n",
"2/14/2023,272.670013,\r\n",
"2/15/2023,268.320007,\r\n",
"2/16/2023,264.019989,\r\n",
"2/17/2023,259.390015,\r\n",
"2/21/2023,254.479996,\r\n",
"2/22/2023,254.089996,\r\n",
"2/23/2023,255.559998,\r\n",
"2/24/2023,249.960007,\r\n",
"2/27/2023,252.460007,\r\n",
"2/28/2023,249.070007,\r\n",
"3/1/2023,250.759995,\r\n",
"3/2/2023,246.550003,\r\n",
"3/3/2023,252.190002,\r\n",
"3/6/2023,256.429993,\r\n",
"3/7/2023,256.299988,\r\n",
"3/8/2023,254.039993,\r\n",
"3/9/2023,255.820007,\r\n",
"3/10/2023,251.080002,\r\n",
"3/13/2023,247.399994,\r\n",
"3/14/2023,256.750000,2256.769952\r\n",
"3/15/2023,259.980011,\r\n",
"3/16/2023,265.209991,\r\n",
"3/17/2023,278.260010,\r\n",
"3/20/2023,276.980011,\r\n",
"3/21/2023,274.880005,\r\n",
"3/22/2023,273.399994,\r\n",
"3/23/2023,277.940002,\r\n",
"3/24/2023,277.239990,\r\n",
"3/27/2023,280.500000,\r\n",
"3/28/2023,275.790009,\r\n",
"3/29/2023,278.959991,\r\n",
"3/30/2023,284.230011,\r\n",
"3/31/2023,283.730011,\r\n",
"4/3/2023,286.519989,\r\n",
"4/4/2023,287.230011,\r\n",
"4/5/2023,285.850006,\r\n",
"4/6/2023,283.209991,\r\n",
"4/10/2023,289.209991,\r\n",
"4/11/2023,285.750000,\r\n",
"4/12/2023,284.790009,\r\n",
"4/13/2023,283.589996,\r\n",
"4/14/2023,287.000000,\r\n",
"4/17/2023,289.929993,\r\n",
"4/18/2023,291.570007,\r\n",
"4/19/2023,285.989990,\r\n",
"4/20/2023,285.250000,\r\n",
"4/21/2023,285.010010,\r\n",
"4/24/2023,282.089996,\r\n",
"4/25/2023,279.510010,\r\n",
"4/26/2023,296.700012,2373.650080\r\n",
"4/27/2023,295.970001,\r\n",
"4/28/2023,304.010010,\r\n",
"5/1/2023,306.970001,\r\n",
"5/2/2023,307.760010,\r\n",
"5/3/2023,306.619995,\r\n",
"5/4/2023,306.239990,\r\n",
"5/5/2023,305.720001,\r\n",
"5/8/2023,310.130005,\r\n",
"5/9/2023,308.000000,\r\n",
"5/10/2023,308.619995,\r\n",
"5/11/2023,310.100006,\r\n",
"5/12/2023,310.549988,\r\n",
"5/15/2023,309.100006,\r\n",
"5/16/2023,309.829987,\r\n",
"5/17/2023,312.290009,\r\n",
"5/18/2023,314.529999,\r\n",
"5/19/2023,316.739990,\r\n",
"5/22/2023,318.600006,\r\n",
"5/23/2023,320.029999,\r\n",
"5/24/2023,314.730011,\r\n",
"5/25/2023,323.239990,\r\n",
"5/26/2023,324.019989,\r\n",
"5/30/2023,335.230011,\r\n",
"5/31/2023,332.290009,\r\n",
"6/1/2023,325.929993,\r\n",
"6/2/2023,334.250000,\r\n",
"6/5/2023,335.220001,\r\n",
"6/6/2023,335.329987,\r\n",
"6/7/2023,331.649994,\r\n",
"6/8/2023,323.940002,\r\n",
"6/9/2023,324.989990,\r\n",
"6/12/2023,328.579987,\r\n",
"6/13/2023,334.470001,\r\n",
"6/14/2023,334.339996,\r\n",
"6/15/2023,337.480011,\r\n",
"6/16/2023,351.320007,\r\n",
"6/20/2023,339.309998,\r\n",
"6/21/2023,336.369995,\r\n",
"6/22/2023,334.119995,\r\n",
"6/23/2023,334.359985,\r\n",
"6/26/2023,333.720001,\r\n",
"6/27/2023,331.859985,\r\n",
"6/28/2023,334.660004,2393.250213\r\n",
"6/29/2023,334.709991,\r\n",
"6/30/2023,337.750000,\r\n",
"7/3/2023,339.190002,\r\n",
"7/5/2023,335.089996,\r\n",
"7/6/2023,337.299988,\r\n",
"7/7/2023,339.320007,\r\n",
"7/10/2023,334.600006,\r\n",
"7/11/2023,331.059998,\r\n",
"7/12/2023,336.600006,2407.250213\r\n",
"7/13/2023,339.559998,\r\n",
"7/14/2023,347.589996,\r\n",
"7/17/2023,345.679993,\r\n",
"7/18/2023,345.829987,\r\n",
"7/19/2023,361.750000,\r\n",
"7/20/2023,353.570007,\r\n",
"7/21/2023,349.149994,\r\n",
"7/24/2023,345.850006,\r\n",
"7/25/2023,347.109985,\r\n",
"7/26/2023,341.440002,\r\n",
"7/27/2023,340.480011,\r\n",
"7/28/2023,333.670013,\r\n",
"7/31/2023,336.920013,\r\n",
"8/1/2023,335.190002,\r\n",
"8/2/2023,333.630005,\r\n",
"8/3/2023,326.000000,\r\n",
"8/4/2023,331.880005,\r\n",
"8/7/2023,328.369995,\r\n",
"8/8/2023,326.959991,\r\n",
"8/9/2023,326.470001,\r\n",
"8/10/2023,326.019989,\r\n",
"8/11/2023,320.260010,\r\n",
"8/14/2023,321.390015,\r\n",
"8/15/2023,323.000000,\r\n",
"8/16/2023,320.799988,\r\n",
"8/17/2023,320.540009,\r\n",
"8/18/2023,314.489990,\r\n",
"8/21/2023,317.929993,\r\n",
"8/22/2023,325.500000,\r\n",
"8/23/2023,323.820007,\r\n",
"8/24/2023,332.850006,2347.120241\r\n",
"8/25/2023,321.470001,\r\n",
"8/28/2023,325.660004,2376.450262\r\n",
"8/29/2023,321.880005,\r\n",
"8/30/2023,328.670013,2423.980318\r\n",
"8/31/2023,329.200012,\r\n",
"9/1/2023,331.309998,\r\n",
"9/5/2023,329.000000,\r\n",
"9/6/2023,333.380005,\r\n",
"9/7/2023,331.290009,\r\n",
"9/8/2023,330.089996,\r\n",
"9/11/2023,337.239990,\r\n",
"9/12/2023,335.820007,\r\n",
"9/13/2023,331.309998,\r\n",
"9/14/2023,339.149994,\r\n",
"9/15/2023,336.920013,\r\n",
"9/18/2023,327.799988,\r\n",
"9/19/2023,326.170013,\r\n",
"9/20/2023,329.510010,\r\n",
"9/21/2023,319.260010,\r\n",
"9/22/2023,321.320007,\r\n",
"9/25/2023,316.589996,\r\n",
"9/26/2023,315.130005,\r\n",
"9/27/2023,312.299988,\r\n",
"9/28/2023,310.989990,\r\n",
"9/29/2023,317.750000,\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Balance</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-11-05\">Nov 05, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.370003</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-06\">Nov 06, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.379997</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-08\">Nov 08, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-09\">Nov 09, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.849998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-12\">Nov 12, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.419998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-16\">Nov 16, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.080002</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-21\">Nov 21, 2018</time></td><td><div class=\"dni-plaintext\"><pre>103.599998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-23\">Nov 23, 2018</time></td><td><div class=\"dni-plaintext\"><pre>102.169998</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-26\">Nov 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.790001</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-27\">Nov 27, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-11-29\">Nov 29, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.330002</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-30\">Nov 30, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.699997</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-12-03\">Dec 03, 2018</time></td><td><div class=\"dni-plaintext\"><pre>113.000000</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td colspan=\"3\"><i>(1213 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"merged.Lead(2, (curr, peek) => (Current: curr, Peek: peek))\n",
" .SkipWhile(e => e is (_, { Balance: null }))\n",
" .Select(e => e.Current)\n",
" .ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"That's better, but notice that we have `null` _gaps_ in `Balance`. To turn it into a continuous time series like the `Price`, let's carry over the _last known value_ for balance to where there is a `null`. To do this carrying over business, we can use [`FillForward`] from MoreLINQ. You tell it what constitutes a blank in the sequence and then `FillForward` does the rest of the magic of remembering the last known value and provides it to you for filling in:\n",
"\n",
"[`FillForward`]: https://morelinq.github.io/4.0/ref/api/html/Overload_MoreLinq_MoreEnumerable_FillForward.htm"
]
},
{
"cell_type": "code",
"execution_count": 132,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Balance\r\n",
"11/5/2018,106.370003,\r\n",
"11/6/2018,107.379997,\r\n",
"11/7/2018,109.440002,1033.750000\r\n",
"11/8/2018,111.800003,1033.750000\r\n",
"11/9/2018,110.849998,1033.750000\r\n",
"11/12/2018,109.419998,1033.750000\r\n",
"11/13/2018,107.550003,1033.750000\r\n",
"11/14/2018,108.099998,1038.699955\r\n",
"11/15/2018,104.989998,1038.699955\r\n",
"11/16/2018,107.080002,1038.699955\r\n",
"11/19/2018,108.269997,1068.219946\r\n",
"11/20/2018,101.800003,1068.219946\r\n",
"11/21/2018,103.599998,1068.219946\r\n",
"11/23/2018,102.169998,1068.219946\r\n",
"11/26/2018,104.790001,1068.219946\r\n",
"11/27/2018,106.269997,1068.219946\r\n",
"11/28/2018,107.889999,1129.119906\r\n",
"11/29/2018,110.330002,1129.119906\r\n",
"11/30/2018,110.699997,1129.119906\r\n",
"12/3/2018,113.000000,1129.119906\r\n",
"12/4/2018,111.940002,1129.119906\r\n",
"12/6/2018,105.820000,1129.119906\r\n",
"12/7/2018,108.379997,1154.719876\r\n",
"12/10/2018,104.800003,1154.719876\r\n",
"12/11/2018,109.800003,1209.719876\r\n",
"12/12/2018,110.889999,1209.719876\r\n",
"12/13/2018,109.580002,1209.719876\r\n",
"12/14/2018,108.250000,1209.719876\r\n",
"12/17/2018,105.410004,1209.719876\r\n",
"12/18/2018,103.750000,1209.719876\r\n",
"12/19/2018,103.650002,1209.719876\r\n",
"12/20/2018,103.050003,1209.719876\r\n",
"12/21/2018,101.629997,1209.719876\r\n",
"12/24/2018,97.680000,1209.719876\r\n",
"12/26/2018,95.139999,1209.719876\r\n",
"12/27/2018,99.300003,1209.719876\r\n",
"12/28/2018,102.089996,1209.719876\r\n",
"12/31/2018,101.290001,1209.719876\r\n",
"1/2/2019,99.550003,1209.719876\r\n",
"1/3/2019,100.099998,1209.719876\r\n",
"1/4/2019,99.720001,1209.719876\r\n",
"1/7/2019,101.639999,1209.719876\r\n",
"1/8/2019,103.040001,1183.649843\r\n",
"1/9/2019,103.860001,1183.649843\r\n",
"1/10/2019,103.220001,1183.649843\r\n",
"1/11/2019,103.190002,1183.649843\r\n",
"1/14/2019,101.900002,1183.649843\r\n",
"1/15/2019,102.510002,1183.649843\r\n",
"1/16/2019,105.260002,1183.649843\r\n",
"1/17/2019,105.000000,1183.649843\r\n",
"1/18/2019,107.459999,1183.649843\r\n",
"1/22/2019,106.750000,1183.649843\r\n",
"1/23/2019,106.120003,1183.649843\r\n",
"1/24/2019,106.860001,1183.649843\r\n",
"1/25/2019,107.239998,1183.649843\r\n",
"1/28/2019,106.260002,1183.649843\r\n",
"1/29/2019,104.879997,1183.649843\r\n",
"1/30/2019,104.620003,1183.649843\r\n",
"1/31/2019,103.800003,1183.649843\r\n",
"2/1/2019,103.779999,1183.649843\r\n",
"2/4/2019,102.870003,1183.649843\r\n",
"2/5/2019,106.059998,1208.509788\r\n",
"2/6/2019,107.000000,1208.509788\r\n",
"2/7/2019,105.190002,1208.509788\r\n",
"2/8/2019,104.389999,1208.509788\r\n",
"2/11/2019,106.199997,1228.419766\r\n",
"2/12/2019,106.139999,1228.419766\r\n",
"2/13/2019,107.500000,1228.419766\r\n",
"2/14/2019,106.309998,1228.419766\r\n",
"2/15/2019,107.910004,1228.419766\r\n",
"2/19/2019,107.790001,1228.419766\r\n",
"2/20/2019,107.860001,1228.419766\r\n",
"2/21/2019,106.900002,1228.419766\r\n",
"2/22/2019,110.050003,1228.419766\r\n",
"2/25/2019,111.760002,1228.419766\r\n",
"2/26/2019,111.260002,1228.419766\r\n",
"2/27/2019,111.690002,1228.419766\r\n",
"2/28/2019,112.040001,1228.419766\r\n",
"3/1/2019,112.889999,1228.419766\r\n",
"3/4/2019,113.019997,1228.419766\r\n",
"3/5/2019,112.250000,1228.419766\r\n",
"3/6/2019,111.870003,1228.419766\r\n",
"3/7/2019,111.400002,1228.419766\r\n",
"3/8/2019,109.160004,1228.419766\r\n",
"3/11/2019,110.989998,1248.549700\r\n",
"3/12/2019,112.820000,1248.549700\r\n",
"3/13/2019,114.129997,1248.549700\r\n",
"3/14/2019,114.540001,1248.549700\r\n",
"3/15/2019,115.339996,1248.549700\r\n",
"3/18/2019,116.169998,1248.549700\r\n",
"3/19/2019,118.089996,1248.549700\r\n",
"3/20/2019,117.389999,1248.549700\r\n",
"3/21/2019,117.139999,1248.549700\r\n",
"3/22/2019,119.500000,1248.549700\r\n",
"3/25/2019,116.559998,1248.549700\r\n",
"3/26/2019,118.620003,1248.549700\r\n",
"3/27/2019,117.879997,1248.549700\r\n",
"3/28/2019,117.440002,1248.549700\r\n",
"3/29/2019,118.070000,1248.549700\r\n",
"4/1/2019,118.949997,1248.549700\r\n",
"4/2/2019,119.059998,1248.549700\r\n",
"4/3/2019,119.860001,1248.549700\r\n",
"4/4/2019,120.099998,1248.549700\r\n",
"4/5/2019,119.389999,1248.549700\r\n",
"4/8/2019,119.809998,1248.549700\r\n",
"4/9/2019,118.629997,1248.549700\r\n",
"4/10/2019,119.760002,1248.549700\r\n",
"4/11/2019,120.540001,1248.549700\r\n",
"4/12/2019,120.639999,1248.549700\r\n",
"4/15/2019,120.940002,1248.549700\r\n",
"4/16/2019,121.639999,1248.549700\r\n",
"4/17/2019,121.239998,1248.549700\r\n",
"4/18/2019,122.190002,1248.549700\r\n",
"4/22/2019,122.620003,1248.549700\r\n",
"4/23/2019,124.099998,1248.549700\r\n",
"4/24/2019,125.790001,1248.549700\r\n",
"4/25/2019,130.059998,1248.549700\r\n",
"4/26/2019,129.699997,1248.549700\r\n",
"4/29/2019,129.899994,1248.549700\r\n",
"4/30/2019,129.809998,1248.549700\r\n",
"5/1/2019,130.529999,1248.549700\r\n",
"5/2/2019,127.980003,1248.549700\r\n",
"5/3/2019,127.360001,1248.549700\r\n",
"5/6/2019,126.389999,1248.549700\r\n",
"5/7/2019,126.459999,1248.549700\r\n",
"5/8/2019,125.440002,1248.549700\r\n",
"5/9/2019,124.290001,1248.549700\r\n",
"5/10/2019,124.910004,1248.549700\r\n",
"5/13/2019,124.110001,1248.549700\r\n",
"5/14/2019,123.870003,1248.549700\r\n",
"5/15/2019,124.260002,1248.549700\r\n",
"5/16/2019,126.750000,1273.149690\r\n",
"5/17/2019,128.309998,1273.149690\r\n",
"5/20/2019,126.519997,1273.149690\r\n",
"5/21/2019,127.430000,1282.249720\r\n",
"5/22/2019,126.620003,1282.249720\r\n",
"5/23/2019,126.199997,1282.249720\r\n",
"5/24/2019,126.910004,1285.149730\r\n",
"5/28/2019,126.980003,1285.149730\r\n",
"5/29/2019,125.379997,1285.149730\r\n",
"5/30/2019,125.260002,1285.149730\r\n",
"5/31/2019,124.230003,1285.149730\r\n",
"6/3/2019,123.849998,1285.149730\r\n",
"6/4/2019,121.279999,1285.149730\r\n",
"6/5/2019,124.949997,1285.149730\r\n",
"6/6/2019,126.440002,1295.749780\r\n",
"6/7/2019,129.190002,1295.749780\r\n",
"6/10/2019,132.399994,1295.749780\r\n",
"6/11/2019,133.880005,1295.749780\r\n",
"6/12/2019,131.399994,1295.749780\r\n",
"6/13/2019,131.979996,1295.749780\r\n",
"6/14/2019,132.259995,1295.749780\r\n",
"6/17/2019,132.630005,1295.749780\r\n",
"6/18/2019,134.190002,1295.749780\r\n",
"6/19/2019,135.000000,1295.749780\r\n",
"6/20/2019,137.449997,1295.749780\r\n",
"6/21/2019,136.580002,1295.749780\r\n",
"6/24/2019,137.000000,1295.749780\r\n",
"6/25/2019,137.250000,1295.749780\r\n",
"6/26/2019,134.350006,1295.749780\r\n",
"6/27/2019,134.139999,1295.749780\r\n",
"6/28/2019,134.570007,1295.749780\r\n",
"7/1/2019,136.630005,1295.749780\r\n",
"7/2/2019,136.119995,1295.749780\r\n",
"7/3/2019,136.800003,1295.749780\r\n",
"7/5/2019,135.940002,1295.749780\r\n",
"7/8/2019,136.399994,1295.749780\r\n",
"7/9/2019,136.000000,1295.749780\r\n",
"7/10/2019,137.130005,1295.749780\r\n",
"7/11/2019,138.199997,1295.749780\r\n",
"7/12/2019,138.850006,1295.749780\r\n",
"7/15/2019,139.440002,1295.749780\r\n",
"7/16/2019,138.960007,1295.749780\r\n",
"7/17/2019,137.699997,1295.749780\r\n",
"7/18/2019,135.550003,1295.749780\r\n",
"7/19/2019,140.220001,1337.779762\r\n",
"7/22/2019,137.410004,1337.779762\r\n",
"7/23/2019,139.759995,1337.779762\r\n",
"7/24/2019,138.899994,1337.779762\r\n",
"7/25/2019,140.429993,1337.779762\r\n",
"7/26/2019,140.369995,1337.779762\r\n",
"7/29/2019,141.500000,1337.779762\r\n",
"7/30/2019,140.139999,1337.779762\r\n",
"7/31/2019,140.330002,1337.779762\r\n",
"8/1/2019,137.000000,1337.779762\r\n",
"8/2/2019,138.089996,1337.779762\r\n",
"8/5/2019,133.300003,1337.779762\r\n",
"8/6/2019,133.800003,1337.779762\r\n",
"8/7/2019,133.789993,1337.779762\r\n",
"8/8/2019,136.600006,1337.779762\r\n",
"8/9/2019,138.610001,1352.269771\r\n",
"8/12/2019,137.070007,1352.269771\r\n",
"8/13/2019,136.050003,1352.269771\r\n",
"8/14/2019,136.360001,1352.269771\r\n",
"8/15/2019,134.389999,1352.269771\r\n",
"8/16/2019,134.880005,1352.269771\r\n",
"8/19/2019,137.850006,1359.289762\r\n",
"8/20/2019,138.210007,1359.289762\r\n",
"8/21/2019,138.550003,1359.289762\r\n",
"8/22/2019,138.660004,1359.289762\r\n",
"8/23/2019,137.190002,1359.289762\r\n",
"8/26/2019,134.990005,1359.289762\r\n",
"8/27/2019,136.389999,1359.289762\r\n",
"8/28/2019,134.880005,1359.289762\r\n",
"8/29/2019,137.250000,1381.889712\r\n",
"8/30/2019,139.149994,1381.889712\r\n",
"9/3/2019,136.610001,1381.889712\r\n",
"9/4/2019,137.300003,1381.889712\r\n",
"9/5/2019,139.110001,1381.889712\r\n",
"9/6/2019,140.029999,1381.889712\r\n",
"9/9/2019,139.589996,1381.889712\r\n",
"9/10/2019,136.800003,1381.889712\r\n",
"9/11/2019,135.910004,1381.889712\r\n",
"9/12/2019,137.850006,1392.389742\r\n",
"9/13/2019,137.779999,1392.389742\r\n",
"9/16/2019,135.830002,1392.389742\r\n",
"9/17/2019,136.960007,1392.389742\r\n",
"9/18/2019,137.360001,1392.389742\r\n",
"9/19/2019,140.300003,1437.089752\r\n",
"9/20/2019,141.009995,1437.089752\r\n",
"9/23/2019,139.229996,1437.089752\r\n",
"9/24/2019,140.360001,1437.089752\r\n",
"9/25/2019,137.500000,1437.089752\r\n",
"9/26/2019,139.440002,1456.489772\r\n",
"9/27/2019,140.149994,1456.489772\r\n",
"9/30/2019,138.050003,1456.489772\r\n",
"10/1/2019,139.660004,1472.589782\r\n",
"10/2/2019,136.250000,1472.589782\r\n",
"10/3/2019,134.949997,1472.589782\r\n",
"10/4/2019,136.750000,1472.589782\r\n",
"10/7/2019,137.139999,1472.589782\r\n",
"10/8/2019,137.080002,1472.589782\r\n",
"10/9/2019,137.460007,1472.589782\r\n",
"10/10/2019,138.490005,1494.989832\r\n",
"10/11/2019,140.119995,1494.989832\r\n",
"10/14/2019,139.690002,1494.989832\r\n",
"10/15/2019,140.059998,1494.989832\r\n",
"10/16/2019,140.789993,1494.989832\r\n",
"10/17/2019,140.949997,1494.989832\r\n",
"10/18/2019,139.759995,1494.989832\r\n",
"10/21/2019,138.449997,1494.989832\r\n",
"10/22/2019,138.970001,1500.189872\r\n",
"10/23/2019,136.880005,1500.189872\r\n",
"10/24/2019,139.389999,1525.289812\r\n",
"10/25/2019,139.339996,1525.289812\r\n",
"10/28/2019,144.399994,1525.289812\r\n",
"10/29/2019,144.080002,1525.289812\r\n",
"10/30/2019,143.520004,1525.289812\r\n",
"10/31/2019,144.899994,1525.289812\r\n",
"11/1/2019,144.259995,1525.289812\r\n",
"11/4/2019,144.830002,1525.289812\r\n",
"11/5/2019,144.970001,1525.289812\r\n",
"11/6/2019,144.369995,1525.289812\r\n",
"11/7/2019,143.839996,1525.289812\r\n",
"11/8/2019,143.979996,1525.289812\r\n",
"11/11/2019,145.339996,1525.289812\r\n",
"11/12/2019,146.279999,1525.289812\r\n",
"11/13/2019,146.740005,1525.289812\r\n",
"11/14/2019,147.020004,1525.289812\r\n",
"11/15/2019,148.929993,1525.289812\r\n",
"11/18/2019,150.070007,1525.289812\r\n",
"11/19/2019,150.880005,1525.289812\r\n",
"11/20/2019,150.309998,1525.289812\r\n",
"11/21/2019,149.399994,1525.289812\r\n",
"11/22/2019,150.070007,1525.289812\r\n",
"11/25/2019,150.000000,1525.289812\r\n",
"11/26/2019,151.360001,1525.289812\r\n",
"11/27/2019,152.330002,1525.289812\r\n",
"11/29/2019,152.100006,1525.289812\r\n",
"12/2/2019,151.809998,1525.289812\r\n",
"12/3/2019,147.490005,1525.289812\r\n",
"12/4/2019,150.139999,1551.789752\r\n",
"12/5/2019,150.050003,1551.789752\r\n",
"12/6/2019,150.990005,1551.789752\r\n",
"12/9/2019,151.070007,1551.789752\r\n",
"12/10/2019,151.289993,1551.789752\r\n",
"12/11/2019,151.539993,1551.789752\r\n",
"12/12/2019,151.649994,1551.789752\r\n",
"12/13/2019,153.000000,1551.789752\r\n",
"12/16/2019,155.110001,1551.789752\r\n",
"12/17/2019,155.449997,1551.789752\r\n",
"12/18/2019,154.300003,1551.789752\r\n",
"12/19/2019,154.000000,1551.789752\r\n",
"12/20/2019,157.350006,1551.789752\r\n",
"12/23/2019,158.119995,1551.789752\r\n",
"12/24/2019,157.479996,1551.789752\r\n",
"12/26/2019,157.559998,1551.789752\r\n",
"12/27/2019,159.449997,1551.789752\r\n",
"12/30/2019,158.990005,1551.789752\r\n",
"12/31/2019,156.770004,1551.789752\r\n",
"1/2/2020,158.779999,1551.789752\r\n",
"1/3/2020,158.320007,1551.789752\r\n",
"1/6/2020,157.080002,1551.789752\r\n",
"1/7/2020,159.320007,1551.789752\r\n",
"1/8/2020,158.929993,1551.789752\r\n",
"1/9/2020,161.839996,1551.789752\r\n",
"1/10/2020,162.820007,1551.789752\r\n",
"1/13/2020,161.759995,1551.789752\r\n",
"1/14/2020,163.389999,1551.789752\r\n",
"1/15/2020,162.619995,1551.789752\r\n",
"1/16/2020,164.350006,1551.789752\r\n",
"1/17/2020,167.419998,1551.789752\r\n",
"1/21/2020,166.679993,1551.789752\r\n",
"1/22/2020,167.399994,1551.789752\r\n",
"1/23/2020,166.190002,1551.789752\r\n",
"1/24/2020,167.509995,1551.789752\r\n",
"1/27/2020,161.149994,1551.789752\r\n",
"1/28/2020,163.779999,1575.459797\r\n",
"1/29/2020,167.839996,1575.459797\r\n",
"1/30/2020,174.050003,1575.459797\r\n",
"1/31/2020,172.210007,1575.459797\r\n",
"2/3/2020,170.429993,1575.459797\r\n",
"2/4/2020,177.139999,1575.459797\r\n",
"2/5/2020,184.029999,1575.459797\r\n",
"2/6/2020,180.970001,1575.459797\r\n",
"2/7/2020,182.850006,1575.459797\r\n",
"2/10/2020,183.580002,1575.459797\r\n",
"2/11/2020,190.649994,1575.459797\r\n",
"2/12/2020,185.580002,1575.459797\r\n",
"2/13/2020,183.080002,1575.459797\r\n",
"2/14/2020,183.250000,1575.459797\r\n",
"2/18/2020,185.610001,1575.459797\r\n",
"2/19/2020,188.059998,1575.459797\r\n",
"2/20/2020,186.949997,1575.459797\r\n",
"2/21/2020,183.169998,1575.459797\r\n",
"2/24/2020,167.770004,1575.459797\r\n",
"2/25/2020,174.199997,1575.459797\r\n",
"2/26/2020,169.710007,1575.459797\r\n",
"2/27/2020,163.320007,1575.459797\r\n",
"2/28/2020,152.410004,1575.459797\r\n",
"3/2/2020,165.309998,1575.459797\r\n",
"3/3/2020,173.800003,1575.459797\r\n",
"3/4/2020,168.490005,1575.459797\r\n",
"3/5/2020,166.050003,1575.459797\r\n",
"3/6/2020,162.610001,1575.459797\r\n",
"3/9/2020,151.000000,1575.459797\r\n",
"3/10/2020,158.160004,1575.459797\r\n",
"3/11/2020,157.130005,1575.459797\r\n",
"3/12/2020,145.300003,1575.459797\r\n",
"3/13/2020,147.500000,1575.459797\r\n",
"3/16/2020,140.000000,1575.459797\r\n",
"3/17/2020,140.000000,1575.459797\r\n",
"3/18/2020,138.000000,1575.459797\r\n",
"3/19/2020,142.770004,1575.459797\r\n",
"3/20/2020,146.000000,1575.459797\r\n",
"3/23/2020,137.009995,1575.459797\r\n",
"3/24/2020,143.750000,1575.459797\r\n",
"3/25/2020,148.910004,1575.459797\r\n",
"3/26/2020,148.399994,1575.459797\r\n",
"3/27/2020,151.750000,1431.279761\r\n",
"3/30/2020,152.440002,1431.279761\r\n",
"3/31/2020,159.399994,1431.279761\r\n",
"4/1/2020,153.000000,1431.279761\r\n",
"4/2/2020,151.860001,1431.279761\r\n",
"4/3/2020,155.100006,1431.279761\r\n",
"4/6/2020,160.320007,1431.279761\r\n",
"4/7/2020,169.589996,1431.279761\r\n",
"4/8/2020,165.669998,1431.279761\r\n",
"4/9/2020,166.360001,1431.279761\r\n",
"4/13/2020,164.350006,1431.279761\r\n",
"4/14/2020,169.000000,1431.279761\r\n",
"4/15/2020,171.199997,1431.279761\r\n",
"4/16/2020,174.300003,1431.279761\r\n",
"4/17/2020,179.500000,1431.279761\r\n",
"4/20/2020,176.630005,1431.279761\r\n",
"4/21/2020,173.500000,1431.279761\r\n",
"4/22/2020,171.389999,1431.279761\r\n",
"4/23/2020,174.110001,1431.279761\r\n",
"4/24/2020,172.059998,1431.279761\r\n",
"4/27/2020,176.589996,1431.279761\r\n",
"4/28/2020,175.589996,1431.279761\r\n",
"4/29/2020,173.220001,1431.279761\r\n",
"4/30/2020,180.000000,1431.279761\r\n",
"5/1/2020,175.800003,1431.279761\r\n",
"5/4/2020,174.490005,1431.279761\r\n",
"5/5/2020,180.619995,1431.279761\r\n",
"5/6/2020,182.080002,1431.279761\r\n",
"5/7/2020,184.169998,1431.279761\r\n",
"5/8/2020,184.979996,1431.279761\r\n",
"5/11/2020,183.149994,1431.279761\r\n",
"5/12/2020,186.800003,1431.279761\r\n",
"5/13/2020,182.550003,1431.279761\r\n",
"5/14/2020,177.539993,1431.279761\r\n",
"5/15/2020,179.059998,1443.439801\r\n",
"5/18/2020,185.750000,1443.439801\r\n",
"5/19/2020,185.029999,1443.439801\r\n",
"5/20/2020,184.809998,1443.439801\r\n",
"5/21/2020,185.399994,1443.439801\r\n",
"5/22/2020,183.190002,1443.439801\r\n",
"5/26/2020,186.339996,1443.439801\r\n",
"5/27/2020,180.199997,1443.439801\r\n",
"5/28/2020,180.740005,1443.439801\r\n",
"5/29/2020,182.729996,1463.679793\r\n",
"6/1/2020,182.539993,1463.679793\r\n",
"6/2/2020,184.250000,1477.359849\r\n",
"6/3/2020,184.820007,1477.359849\r\n",
"6/4/2020,184.300003,1477.359849\r\n",
"6/5/2020,182.619995,1477.359849\r\n",
"6/8/2020,185.940002,1503.919905\r\n",
"6/9/2020,188.000000,1503.919905\r\n",
"6/10/2020,191.130005,1503.919905\r\n",
"6/11/2020,193.130005,1503.919905\r\n",
"6/12/2020,190.539993,1503.919905\r\n",
"6/15/2020,184.580002,1503.919905\r\n",
"6/16/2020,192.889999,1570.399881\r\n",
"6/17/2020,195.029999,1570.399881\r\n",
"6/18/2020,194.000000,1570.399881\r\n",
"6/19/2020,198.589996,1570.399881\r\n",
"6/22/2020,195.789993,1570.399881\r\n",
"6/23/2020,202.089996,1570.399881\r\n",
"6/24/2020,201.600006,1570.399881\r\n",
"6/25/2020,197.800003,1570.399881\r\n",
"6/26/2020,199.729996,1570.399881\r\n",
"6/29/2020,195.779999,1570.399881\r\n",
"6/30/2020,197.880005,1570.399881\r\n",
"7/1/2020,203.139999,1570.399881\r\n",
"7/2/2020,205.679993,1570.399881\r\n",
"7/6/2020,208.830002,1570.399881\r\n",
"7/7/2020,210.449997,1570.399881\r\n",
"7/8/2020,210.070007,1570.399881\r\n",
"7/9/2020,216.330002,1570.399881\r\n",
"7/10/2020,213.619995,1570.399881\r\n",
"7/13/2020,214.479996,1570.399881\r\n",
"7/14/2020,206.130005,1570.399881\r\n",
"7/15/2020,209.559998,1570.399881\r\n",
"7/16/2020,205.399994,1570.399881\r\n",
"7/17/2020,204.470001,1570.399881\r\n",
"7/20/2020,205.000000,1570.399881\r\n",
"7/21/2020,213.660004,1634.729902\r\n",
"7/22/2020,209.199997,1634.729902\r\n",
"7/23/2020,207.190002,1634.729902\r\n",
"7/24/2020,200.419998,1634.729902\r\n",
"7/27/2020,201.470001,1634.729902\r\n",
"7/28/2020,203.610001,1634.729902\r\n",
"7/29/2020,202.500000,1634.729902\r\n",
"7/30/2020,201.000000,1634.729902\r\n",
"7/31/2020,204.399994,1634.729902\r\n",
"8/3/2020,211.520004,1723.529950\r\n",
"8/4/2020,214.169998,1723.529950\r\n",
"8/5/2020,214.899994,1723.529950\r\n",
"8/6/2020,212.339996,1723.529950\r\n",
"8/7/2020,214.850006,1723.529950\r\n",
"8/10/2020,211.669998,1723.529950\r\n",
"8/11/2020,207.160004,1723.529950\r\n",
"8/12/2020,205.289993,1723.529950\r\n",
"8/13/2020,209.440002,1741.769934\r\n",
"8/14/2020,208.759995,1741.769934\r\n",
"8/17/2020,209.600006,1741.769934\r\n",
"8/18/2020,210.529999,1741.769934\r\n",
"8/19/2020,211.490005,1741.769934\r\n",
"8/20/2020,209.539993,1741.769934\r\n",
"8/21/2020,213.860001,1741.769934\r\n",
"8/24/2020,214.789993,1741.769934\r\n",
"8/25/2020,213.100006,1741.769934\r\n",
"8/26/2020,217.880005,1741.769934\r\n",
"8/27/2020,222.889999,1741.769934\r\n",
"8/28/2020,228.179993,1741.769934\r\n",
"8/31/2020,227.000000,1741.769934\r\n",
"9/1/2020,225.509995,1741.769934\r\n",
"9/2/2020,227.970001,1741.769934\r\n",
"9/3/2020,229.270004,1741.769934\r\n",
"9/4/2020,215.100006,1741.769934\r\n",
"9/8/2020,206.500000,1741.769934\r\n",
"9/9/2020,207.600006,1741.769934\r\n",
"9/10/2020,213.399994,1741.769934\r\n",
"9/11/2020,207.199997,1741.769934\r\n",
"9/14/2020,204.240005,1741.769934\r\n",
"9/15/2020,208.419998,1741.769934\r\n",
"9/16/2020,210.619995,1741.769934\r\n",
"9/17/2020,200.050003,1741.769934\r\n",
"9/18/2020,202.800003,1741.769934\r\n",
"9/21/2020,197.190002,1741.769934\r\n",
"9/22/2020,205.059998,1741.769934\r\n",
"9/23/2020,207.899994,1741.769934\r\n",
"9/24/2020,199.850006,1741.769934\r\n",
"9/25/2020,203.550003,1741.769934\r\n",
"9/28/2020,210.880005,1708.009926\r\n",
"9/29/2020,209.350006,1708.009926\r\n",
"9/30/2020,207.729996,1708.009926\r\n",
"10/1/2020,213.490005,1741.129918\r\n",
"10/2/2020,208.000000,1741.129918\r\n",
"10/5/2020,207.220001,1741.129918\r\n",
"10/6/2020,208.820007,1741.129918\r\n",
"10/7/2020,207.059998,1741.129918\r\n",
"10/8/2020,210.509995,1741.129918\r\n",
"10/9/2020,211.229996,1741.129918\r\n",
"10/12/2020,218.789993,1741.129918\r\n",
"10/13/2020,222.720001,1741.129918\r\n",
"10/14/2020,223.000000,1741.129918\r\n",
"10/15/2020,217.100006,1741.129918\r\n",
"10/16/2020,220.149994,1741.129918\r\n",
"10/19/2020,220.419998,1741.129918\r\n",
"10/20/2020,215.800003,1741.129918\r\n",
"10/21/2020,213.119995,1741.129918\r\n",
"10/22/2020,213.929993,1741.129918\r\n",
"10/23/2020,215.029999,1741.129918\r\n",
"10/26/2020,213.850006,1741.129918\r\n",
"10/27/2020,211.589996,1741.129918\r\n",
"10/28/2020,207.669998,1741.129918\r\n",
"10/29/2020,204.070007,1741.129918\r\n",
"10/30/2020,203.500000,1741.129918\r\n",
"11/2/2020,204.289993,1741.129918\r\n",
"11/3/2020,203.889999,1741.129918\r\n",
"11/4/2020,214.020004,1742.489902\r\n",
"11/5/2020,222.039993,1742.489902\r\n",
"11/6/2020,222.259995,1742.489902\r\n",
"11/9/2020,224.440002,1742.489902\r\n",
"11/10/2020,214.500000,1742.489902\r\n",
"11/11/2020,212.389999,1742.489902\r\n",
"11/12/2020,217.210007,1781.049966\r\n",
"11/13/2020,216.360001,1781.049966\r\n",
"11/16/2020,214.869995,1781.049966\r\n",
"11/17/2020,216.100006,1781.049966\r\n",
"11/18/2020,213.649994,1781.049966\r\n",
"11/19/2020,211.380005,1781.049966\r\n",
"11/20/2020,212.199997,1781.049966\r\n",
"11/23/2020,210.949997,1781.049966\r\n",
"11/24/2020,209.589996,1781.049966\r\n",
"11/25/2020,215.110001,1810.889934\r\n",
"11/27/2020,214.850006,1810.889934\r\n",
"11/30/2020,214.100006,1810.889934\r\n",
"12/1/2020,214.509995,1810.889934\r\n",
"12/2/2020,214.880005,1810.889934\r\n",
"12/3/2020,214.610001,1810.889934\r\n",
"12/4/2020,214.220001,1810.889934\r\n",
"12/7/2020,214.369995,1810.889934\r\n",
"12/8/2020,213.970001,1810.889934\r\n",
"12/9/2020,215.160004,1819.369918\r\n",
"12/10/2020,211.770004,1819.369918\r\n",
"12/11/2020,210.050003,1819.369918\r\n",
"12/14/2020,213.100006,1819.369918\r\n",
"12/15/2020,215.169998,1846.569870\r\n",
"12/16/2020,214.750000,1846.569870\r\n",
"12/17/2020,219.869995,1846.569870\r\n",
"12/18/2020,218.589996,1846.569870\r\n",
"12/21/2020,217.550003,1846.569870\r\n",
"12/22/2020,222.690002,1846.569870\r\n",
"12/23/2020,223.110001,1846.569870\r\n",
"12/24/2020,221.419998,1846.569870\r\n",
"12/28/2020,224.449997,1846.569870\r\n",
"12/29/2020,226.309998,1846.569870\r\n",
"12/30/2020,225.229996,1846.569870\r\n",
"12/31/2020,221.699997,1846.569870\r\n",
"1/4/2021,222.529999,1846.569870\r\n",
"1/5/2021,217.259995,1846.569870\r\n",
"1/6/2021,212.169998,1846.569870\r\n",
"1/7/2021,214.039993,1846.569870\r\n",
"1/8/2021,218.679993,1857.929854\r\n",
"1/11/2021,218.470001,1857.929854\r\n",
"1/12/2021,216.500000,1857.929854\r\n",
"1/13/2021,214.020004,1857.929854\r\n",
"1/14/2021,215.910004,1857.929854\r\n",
"1/15/2021,213.520004,1857.929854\r\n",
"1/19/2021,213.750000,1857.929854\r\n",
"1/20/2021,217.699997,1857.929854\r\n",
"1/21/2021,224.699997,1907.769822\r\n",
"1/22/2021,227.080002,1907.769822\r\n",
"1/25/2021,229.119995,1907.769822\r\n",
"1/26/2021,231.860001,1907.769822\r\n",
"1/27/2021,238.000000,1907.769822\r\n",
"1/28/2021,235.610001,1907.769822\r\n",
"1/29/2021,235.990005,1907.769822\r\n",
"2/1/2021,235.059998,1907.769822\r\n",
"2/2/2021,241.300003,1907.769822\r\n",
"2/3/2021,239.570007,1907.769822\r\n",
"2/4/2021,242.660004,1907.769822\r\n",
"2/5/2021,242.229996,1907.769822\r\n",
"2/8/2021,243.149994,1907.769822\r\n",
"2/9/2021,241.869995,1907.769822\r\n",
"2/10/2021,245.000000,1907.769822\r\n",
"2/11/2021,244.779999,1907.769822\r\n",
"2/12/2021,243.929993,1907.769822\r\n",
"2/16/2021,245.029999,1907.769822\r\n",
"2/17/2021,241.320007,1907.769822\r\n",
"2/18/2021,241.800003,1907.769822\r\n",
"2/19/2021,243.750000,1907.769822\r\n",
"2/22/2021,237.419998,1907.769822\r\n",
"2/23/2021,230.330002,1907.769822\r\n",
"2/24/2021,230.009995,1907.769822\r\n",
"2/25/2021,232.080002,1907.769822\r\n",
"2/26/2021,231.529999,1907.769822\r\n",
"3/1/2021,235.899994,1907.769822\r\n",
"3/2/2021,237.009995,1907.769822\r\n",
"3/3/2021,232.160004,1907.769822\r\n",
"3/4/2021,226.740005,1907.769822\r\n",
"3/5/2021,229.520004,1907.769822\r\n",
"3/8/2021,231.369995,1907.769822\r\n",
"3/9/2021,232.880005,1907.769822\r\n",
"3/10/2021,237.000000,1904.409838\r\n",
"3/11/2021,234.960007,1904.409838\r\n",
"3/12/2021,234.009995,1904.409838\r\n",
"3/15/2021,234.960007,1904.409838\r\n",
"3/16/2021,236.279999,1914.969774\r\n",
"3/17/2021,236.149994,1914.969774\r\n",
"3/18/2021,232.559998,1914.969774\r\n",
"3/19/2021,231.020004,1914.969774\r\n",
"3/22/2021,230.270004,1914.969774\r\n",
"3/23/2021,237.490005,1954.409830\r\n",
"3/24/2021,237.850006,1954.409830\r\n",
"3/25/2021,235.300003,1954.409830\r\n",
"3/26/2021,231.550003,1954.409830\r\n",
"3/29/2021,236.589996,1994.729774\r\n",
"3/30/2021,233.529999,1994.729774\r\n",
"3/31/2021,232.910004,1994.729774\r\n",
"4/1/2021,238.470001,2034.249790\r\n",
"4/5/2021,242.759995,2034.249790\r\n",
"4/6/2021,247.610001,2034.249790\r\n",
"4/7/2021,247.809998,2034.249790\r\n",
"4/8/2021,252.770004,2034.249790\r\n",
"4/9/2021,252.869995,2034.249790\r\n",
"4/12/2021,254.710007,2034.249790\r\n",
"4/13/2021,257.260010,2034.249790\r\n",
"4/14/2021,257.480011,2034.249790\r\n",
"4/15/2021,257.929993,2034.249790\r\n",
"4/16/2021,259.470001,2034.249790\r\n",
"4/19/2021,260.190002,2034.249790\r\n",
"4/20/2021,257.820007,2034.249790\r\n",
"4/21/2021,258.940002,2034.249790\r\n",
"4/22/2021,260.209991,2034.249790\r\n",
"4/23/2021,257.880005,2034.249790\r\n",
"4/26/2021,261.660004,2034.249790\r\n",
"4/27/2021,261.579987,2034.249790\r\n",
"4/28/2021,256.079987,2034.249790\r\n",
"4/29/2021,255.460007,2034.249790\r\n",
"4/30/2021,249.740005,2034.249790\r\n",
"5/3/2021,253.399994,2034.249790\r\n",
"5/4/2021,250.970001,2034.249790\r\n",
"5/5/2021,249.059998,2034.249790\r\n",
"5/6/2021,246.449997,2034.249790\r\n",
"5/7/2021,252.149994,2034.249790\r\n",
"5/10/2021,250.869995,2034.249790\r\n",
"5/11/2021,244.550003,2034.249790\r\n",
"5/12/2021,242.169998,2034.249790\r\n",
"5/13/2021,241.800003,2034.249790\r\n",
"5/14/2021,245.580002,2034.249790\r\n",
"5/17/2021,246.550003,2034.249790\r\n",
"5/18/2021,246.270004,2034.249790\r\n",
"5/19/2021,239.309998,2034.249790\r\n",
"5/20/2021,243.960007,2034.249790\r\n",
"5/21/2021,247.570007,2034.249790\r\n",
"5/24/2021,247.789993,2034.249790\r\n",
"5/25/2021,251.770004,2050.489782\r\n",
"5/26/2021,251.429993,2050.489782\r\n",
"5/27/2021,251.169998,2050.489782\r\n",
"5/28/2021,251.000000,2050.489782\r\n",
"6/1/2021,251.229996,2050.489782\r\n",
"6/2/2021,248.130005,2050.489782\r\n",
"6/3/2021,245.220001,2050.489782\r\n",
"6/4/2021,247.759995,2070.809734\r\n",
"6/7/2021,249.979996,2070.809734\r\n",
"6/8/2021,255.160004,2070.809734\r\n",
"6/9/2021,253.809998,2070.809734\r\n",
"6/10/2021,254.289993,2070.809734\r\n",
"6/11/2021,257.989990,2070.809734\r\n",
"6/14/2021,257.899994,2070.809734\r\n",
"6/15/2021,259.769989,2070.809734\r\n",
"6/16/2021,259.399994,2070.809734\r\n",
"6/17/2021,256.070007,2070.809734\r\n",
"6/18/2021,259.630005,2070.809734\r\n",
"6/21/2021,259.820007,2070.809734\r\n",
"6/22/2021,262.720001,2070.809734\r\n",
"6/23/2021,265.989990,2070.809734\r\n",
"6/24/2021,266.160004,2070.809734\r\n",
"6/25/2021,266.230011,2070.809734\r\n",
"6/28/2021,266.190002,2070.809734\r\n",
"6/29/2021,268.869995,2070.809734\r\n",
"6/30/2021,270.690002,2070.809734\r\n",
"7/1/2021,269.609985,2070.809734\r\n",
"7/2/2021,272.820007,2070.809734\r\n",
"7/6/2021,278.029999,2070.809734\r\n",
"7/7/2021,279.399994,2070.809734\r\n",
"7/8/2021,276.899994,2070.809734\r\n",
"7/9/2021,275.720001,2070.809734\r\n",
"7/12/2021,279.160004,2070.809734\r\n",
"7/13/2021,277.519989,2070.809734\r\n",
"7/14/2021,282.350006,2070.809734\r\n",
"7/15/2021,282.000000,2070.809734\r\n",
"7/16/2021,282.070007,2070.809734\r\n",
"7/19/2021,278.929993,2070.809734\r\n",
"7/20/2021,278.029999,2070.809734\r\n",
"7/21/2021,278.899994,2070.809734\r\n",
"7/22/2021,283.839996,2070.809734\r\n",
"7/23/2021,287.369995,2070.809734\r\n",
"7/26/2021,289.000000,2070.809734\r\n",
"7/27/2021,289.429993,2070.809734\r\n",
"7/28/2021,288.989990,2070.809734\r\n",
"7/29/2021,286.239990,2070.809734\r\n",
"7/30/2021,285.170013,2070.809734\r\n",
"8/2/2021,286.359985,2070.809734\r\n",
"8/3/2021,285.420013,2070.809734\r\n",
"8/4/2021,286.220001,2070.809734\r\n",
"8/5/2021,286.880005,2070.809734\r\n",
"8/6/2021,288.510010,2070.809734\r\n",
"8/9/2021,289.750000,2070.809734\r\n",
"8/10/2021,288.799988,2070.809734\r\n",
"8/11/2021,287.209991,2070.809734\r\n",
"8/12/2021,286.630005,2070.809734\r\n",
"8/13/2021,289.480011,2070.809734\r\n",
"8/16/2021,293.190002,2070.809734\r\n",
"8/17/2021,292.390015,2070.809734\r\n",
"8/18/2021,292.040009,2070.809734\r\n",
"8/19/2021,288.690002,2070.809734\r\n",
"8/20/2021,299.720001,2070.809734\r\n",
"8/23/2021,303.250000,2070.809734\r\n",
"8/24/2021,305.019989,2070.809734\r\n",
"8/25/2021,304.299988,2070.809734\r\n",
"8/26/2021,300.989990,2070.809734\r\n",
"8/27/2021,298.989990,2070.809734\r\n",
"8/30/2021,301.119995,2070.809734\r\n",
"8/31/2021,304.420013,2070.809734\r\n",
"9/1/2021,302.869995,2070.809734\r\n",
"9/2/2021,302.200012,2070.809734\r\n",
"9/3/2021,300.989990,2070.809734\r\n",
"9/7/2021,301.010010,2070.809734\r\n",
"9/8/2021,299.779999,2070.809734\r\n",
"9/9/2021,300.820007,2070.809734\r\n",
"9/10/2021,298.420013,2070.809734\r\n",
"9/13/2021,297.549988,2070.809734\r\n",
"9/14/2021,299.559998,2070.809734\r\n",
"9/15/2021,303.260010,2099.849716\r\n",
"9/16/2021,303.760010,2099.849716\r\n",
"9/17/2021,304.170013,2099.849716\r\n",
"9/20/2021,296.329987,2099.849716\r\n",
"9/21/2021,295.690002,2099.849716\r\n",
"9/22/2021,296.730011,2099.849716\r\n",
"9/23/2021,298.850006,2099.849716\r\n",
"9/24/2021,298.230011,2099.849716\r\n",
"9/27/2021,296.140015,2099.849716\r\n",
"9/28/2021,289.799988,2099.849716\r\n",
"9/29/2021,285.100006,2099.849716\r\n",
"9/30/2021,285.709991,2099.849716\r\n",
"10/1/2021,282.119995,2099.849716\r\n",
"10/4/2021,287.399994,2099.849716\r\n",
"10/5/2021,284.049988,2099.849716\r\n",
"10/6/2021,285.779999,2099.849716\r\n",
"10/7/2021,295.179993,2091.799758\r\n",
"10/8/2021,296.220001,2091.799758\r\n",
"10/11/2021,292.920013,2091.799758\r\n",
"10/12/2021,295.339996,2108.739639\r\n",
"10/13/2021,294.910004,2108.739639\r\n",
"10/14/2021,299.209991,2108.739639\r\n",
"10/15/2021,302.339996,2108.739639\r\n",
"10/18/2021,303.570007,2108.739639\r\n",
"10/19/2021,308.350006,2108.739639\r\n",
"10/20/2021,309.209991,2108.739639\r\n",
"10/21/2021,307.170013,2108.739639\r\n",
"10/22/2021,310.399994,2108.739639\r\n",
"10/25/2021,309.359985,2108.739639\r\n",
"10/26/2021,311.000000,2108.739639\r\n",
"10/27/2021,316.000000,2108.739639\r\n",
"10/28/2021,324.329987,2108.739639\r\n",
"10/29/2021,324.130005,2108.739639\r\n",
"11/1/2021,331.359985,2108.739639\r\n",
"11/2/2021,330.309998,2108.739639\r\n",
"11/3/2021,333.899994,2108.739639\r\n",
"11/4/2021,332.890015,2108.739639\r\n",
"11/5/2021,338.510010,2108.739639\r\n",
"11/8/2021,337.299988,2108.739639\r\n",
"11/9/2021,337.109985,2108.739639\r\n",
"11/10/2021,334.570007,2108.739639\r\n",
"11/11/2021,331.250000,2108.739639\r\n",
"11/12/2021,333.920013,2108.739639\r\n",
"11/15/2021,337.540009,2108.739639\r\n",
"11/16/2021,335.679993,2108.739639\r\n",
"11/17/2021,338.940002,2108.739639\r\n",
"11/18/2021,338.179993,2108.739639\r\n",
"11/19/2021,342.640015,2108.739639\r\n",
"11/22/2021,344.619995,2108.739639\r\n",
"11/23/2021,337.049988,2108.739639\r\n",
"11/24/2021,336.279999,2108.739639\r\n",
"11/26/2021,334.350006,2108.739639\r\n",
"11/29/2021,334.940002,2108.739639\r\n",
"11/30/2021,335.320007,2108.739639\r\n",
"12/1/2021,335.130005,2108.739639\r\n",
"12/2/2021,330.299988,2108.739639\r\n",
"12/3/2021,331.989990,2108.739639\r\n",
"12/6/2021,323.950012,2108.739639\r\n",
"12/7/2021,331.640015,2108.739639\r\n",
"12/8/2021,335.309998,2114.499591\r\n",
"12/9/2021,334.410004,2114.499591\r\n",
"12/10/2021,334.980011,2114.499591\r\n",
"12/13/2021,340.679993,2152.119525\r\n",
"12/14/2021,333.220001,2152.119525\r\n",
"12/15/2021,328.609985,2152.119525\r\n",
"12/16/2021,335.709991,2167.059465\r\n",
"12/17/2021,320.880005,2167.059465\r\n",
"12/20/2021,320.049988,2167.059465\r\n",
"12/21/2021,323.290009,2167.059465\r\n",
"12/22/2021,328.299988,2167.059465\r\n",
"12/23/2021,332.750000,2238.279435\r\n",
"12/27/2021,335.459991,2238.279435\r\n",
"12/28/2021,343.149994,2238.279435\r\n",
"12/29/2021,341.299988,2238.279435\r\n",
"12/30/2021,341.910004,2238.279435\r\n",
"12/31/2021,338.510010,2238.279435\r\n",
"1/3/2022,335.350006,2238.279435\r\n",
"1/4/2022,334.829987,2238.279435\r\n",
"1/5/2022,325.859985,2238.279435\r\n",
"1/6/2022,313.149994,2238.279435\r\n",
"1/7/2022,314.149994,2238.279435\r\n",
"1/10/2022,309.489990,2238.279435\r\n",
"1/11/2022,313.380005,2238.279435\r\n",
"1/12/2022,319.670013,2238.279435\r\n",
"1/13/2022,320.470001,2238.279435\r\n",
"1/14/2022,304.250000,2238.279435\r\n",
"1/18/2022,304.070007,2238.279435\r\n",
"1/19/2022,306.290009,2238.279435\r\n",
"1/20/2022,309.070007,2238.279435\r\n",
"1/21/2022,302.690002,2238.279435\r\n",
"1/24/2022,292.200012,2238.279435\r\n",
"1/25/2022,291.519989,2238.279435\r\n",
"1/26/2022,307.989990,2238.279435\r\n",
"1/27/2022,302.660004,2238.279435\r\n",
"1/28/2022,300.230011,2238.279435\r\n",
"1/31/2022,308.950012,2238.279435\r\n",
"2/1/2022,310.410004,2145.579549\r\n",
"2/2/2022,309.630005,2145.579549\r\n",
"2/3/2022,309.489990,2145.579549\r\n",
"2/4/2022,300.209991,2145.579549\r\n",
"2/7/2022,306.170013,2145.579549\r\n",
"2/8/2022,301.250000,2145.579549\r\n",
"2/9/2022,309.869995,2213.199577\r\n",
"2/10/2022,304.040009,2213.199577\r\n",
"2/11/2022,303.190002,2213.199577\r\n",
"2/14/2022,293.769989,2213.199577\r\n",
"2/15/2022,300.010010,2213.199577\r\n",
"2/16/2022,298.369995,2213.199577\r\n",
"2/17/2022,296.359985,2213.199577\r\n",
"2/18/2022,293.049988,2213.199577\r\n",
"2/22/2022,285.000000,2213.199577\r\n",
"2/23/2022,290.179993,2213.199577\r\n",
"2/24/2022,272.510010,2213.199577\r\n",
"2/25/2022,295.140015,2213.199577\r\n",
"2/28/2022,294.309998,2213.199577\r\n",
"3/1/2022,296.399994,2213.199577\r\n",
"3/2/2022,295.359985,2213.199577\r\n",
"3/3/2022,302.890015,2205.149619\r\n",
"3/4/2022,294.290009,2205.149619\r\n",
"3/7/2022,288.529999,2205.149619\r\n",
"3/8/2022,277.799988,2205.149619\r\n",
"3/9/2022,283.440002,2205.149619\r\n",
"3/10/2022,283.019989,2205.149619\r\n",
"3/11/2022,287.959991,2205.149619\r\n",
"3/14/2022,280.339996,2205.149619\r\n",
"3/15/2022,280.350006,2205.149619\r\n",
"3/16/2022,289.109985,2205.149619\r\n",
"3/17/2022,293.290009,2198.149619\r\n",
"3/18/2022,295.369995,2198.149619\r\n",
"3/21/2022,298.890015,2198.149619\r\n",
"3/22/2022,299.799988,2198.149619\r\n",
"3/23/2022,300.510010,2198.149619\r\n",
"3/24/2022,299.140015,2198.149619\r\n",
"3/25/2022,305.230011,2198.149619\r\n",
"3/28/2022,304.329987,2198.149619\r\n",
"3/29/2022,313.910004,2198.149619\r\n",
"3/30/2022,313.760010,2198.149619\r\n",
"3/31/2022,313.899994,2198.149619\r\n",
"4/1/2022,309.369995,2198.149619\r\n",
"4/4/2022,310.089996,2198.149619\r\n",
"4/5/2022,313.269989,2198.149619\r\n",
"4/6/2022,305.190002,2198.149619\r\n",
"4/7/2022,296.660004,2198.149619\r\n",
"4/8/2022,300.440002,2198.149619\r\n",
"4/11/2022,291.790009,2198.149619\r\n",
"4/12/2022,289.239990,2198.149619\r\n",
"4/13/2022,282.730011,2198.149619\r\n",
"4/14/2022,288.089996,2198.149619\r\n",
"4/18/2022,278.910004,2198.149619\r\n",
"4/19/2022,279.380005,2198.149619\r\n",
"4/20/2022,289.399994,2198.149619\r\n",
"4/21/2022,288.579987,2198.149619\r\n",
"4/22/2022,281.679993,2198.149619\r\n",
"4/25/2022,273.290009,2198.149619\r\n",
"4/26/2022,277.500000,2198.149619\r\n",
"4/27/2022,282.100006,2198.149619\r\n",
"4/28/2022,285.190002,2198.149619\r\n",
"4/29/2022,288.609985,2198.149619\r\n",
"5/2/2022,277.709991,2198.149619\r\n",
"5/3/2022,283.959991,2198.149619\r\n",
"5/4/2022,282.589996,2198.149619\r\n",
"5/5/2022,285.540009,2120.309654\r\n",
"5/6/2022,274.809998,2120.309654\r\n",
"5/9/2022,270.059998,2120.309654\r\n",
"5/10/2022,271.690002,2120.309654\r\n",
"5/11/2022,265.679993,2120.309654\r\n",
"5/12/2022,257.690002,2120.309654\r\n",
"5/13/2022,257.350006,2120.309654\r\n",
"5/16/2022,259.959991,2120.309654\r\n",
"5/17/2022,266.109985,2120.309654\r\n",
"5/18/2022,263.000000,2120.309654\r\n",
"5/19/2022,253.899994,2120.309654\r\n",
"5/20/2022,257.239990,2120.309654\r\n",
"5/23/2022,255.490005,2120.309654\r\n",
"5/24/2022,257.890015,2120.309654\r\n",
"5/25/2022,258.140015,2120.309654\r\n",
"5/26/2022,262.269989,2120.309654\r\n",
"5/27/2022,268.480011,2075.999745\r\n",
"5/31/2022,272.529999,2075.999745\r\n",
"6/1/2022,275.200012,2075.999745\r\n",
"6/2/2022,264.450012,2075.999745\r\n",
"6/3/2022,270.309998,2117.019647\r\n",
"6/6/2022,272.059998,2117.019647\r\n",
"6/7/2022,266.640015,2117.019647\r\n",
"6/8/2022,271.709991,2117.019647\r\n",
"6/9/2022,267.779999,2117.019647\r\n",
"6/10/2022,260.579987,2117.019647\r\n",
"6/13/2022,245.110001,2117.019647\r\n",
"6/14/2022,243.860001,2117.019647\r\n",
"6/15/2022,248.309998,2117.019647\r\n",
"6/16/2022,245.979996,2117.019647\r\n",
"6/17/2022,244.699997,2117.019647\r\n",
"6/21/2022,250.259995,2117.019647\r\n",
"6/22/2022,251.889999,2117.019647\r\n",
"6/23/2022,255.570007,2117.019647\r\n",
"6/24/2022,261.809998,2126.859735\r\n",
"6/27/2022,268.209991,2126.859735\r\n",
"6/28/2022,263.980011,2126.859735\r\n",
"6/29/2022,257.589996,2126.859735\r\n",
"6/30/2022,257.049988,2126.859735\r\n",
"7/1/2022,256.390015,2126.859735\r\n",
"7/5/2022,256.160004,2126.859735\r\n",
"7/6/2022,263.750000,2176.139767\r\n",
"7/7/2022,265.119995,2176.139767\r\n",
"7/8/2022,264.790009,2176.139767\r\n",
"7/11/2022,265.649994,2176.139767\r\n",
"7/12/2022,265.880005,2176.139767\r\n",
"7/13/2022,250.190002,2176.139767\r\n",
"7/14/2022,250.570007,2176.139767\r\n",
"7/15/2022,255.720001,2176.139767\r\n",
"7/18/2022,259.750000,2252.619751\r\n",
"7/19/2022,257.579987,2252.619751\r\n",
"7/20/2022,259.899994,2271.179807\r\n",
"7/21/2022,259.790009,2271.179807\r\n",
"7/22/2022,265.239990,2271.179807\r\n",
"7/25/2022,261.000000,2271.179807\r\n",
"7/26/2022,259.859985,2271.179807\r\n",
"7/27/2022,261.160004,2271.179807\r\n",
"7/28/2022,269.750000,2271.179807\r\n",
"7/29/2022,277.700012,2271.179807\r\n",
"8/1/2022,277.820007,2271.179807\r\n",
"8/2/2022,276.000000,2271.179807\r\n",
"8/3/2022,276.760010,2271.179807\r\n",
"8/4/2022,281.799988,2271.179807\r\n",
"8/5/2022,279.149994,2271.179807\r\n",
"8/8/2022,284.049988,2271.179807\r\n",
"8/9/2022,279.640015,2271.179807\r\n",
"8/10/2022,288.170013,2271.179807\r\n",
"8/11/2022,290.850006,2271.179807\r\n",
"8/12/2022,288.480011,2271.179807\r\n",
"8/15/2022,291.000000,2271.179807\r\n",
"8/16/2022,291.989990,2271.179807\r\n",
"8/17/2022,289.739990,2271.179807\r\n",
"8/18/2022,290.190002,2271.179807\r\n",
"8/19/2022,288.899994,2271.179807\r\n",
"8/22/2022,282.079987,2271.179807\r\n",
"8/23/2022,276.440002,2271.179807\r\n",
"8/24/2022,275.410004,2271.179807\r\n",
"8/25/2022,277.329987,2271.179807\r\n",
"8/26/2022,279.079987,2271.179807\r\n",
"8/29/2022,265.850006,2271.179807\r\n",
"8/30/2022,266.670013,2271.179807\r\n",
"8/31/2022,265.390015,2271.179807\r\n",
"9/1/2022,258.869995,2271.179807\r\n",
"9/2/2022,261.700012,2271.179807\r\n",
"9/6/2022,256.200012,2271.179807\r\n",
"9/7/2022,254.699997,2271.179807\r\n",
"9/8/2022,257.510010,2271.179807\r\n",
"9/9/2022,260.500000,2271.179807\r\n",
"9/12/2022,265.779999,2271.179807\r\n",
"9/13/2022,258.839996,2271.179807\r\n",
"9/14/2022,253.529999,2271.179807\r\n",
"9/15/2022,249.770004,2271.179807\r\n",
"9/16/2022,244.259995,2271.179807\r\n",
"9/19/2022,242.470001,2271.179807\r\n",
"9/20/2022,242.070007,2271.179807\r\n",
"9/21/2022,244.270004,2271.179807\r\n",
"9/22/2022,237.869995,2271.179807\r\n",
"9/23/2022,239.539993,2271.179807\r\n",
"9/26/2022,237.050003,2271.179807\r\n",
"9/27/2022,239.979996,2271.179807\r\n",
"9/28/2022,236.809998,2271.179807\r\n",
"9/29/2022,238.889999,2271.179807\r\n",
"9/30/2022,238.289993,2271.179807\r\n",
"10/3/2022,235.410004,2271.179807\r\n",
"10/4/2022,245.089996,2271.179807\r\n",
"10/5/2022,245.990005,2027.579831\r\n",
"10/6/2022,247.929993,2027.579831\r\n",
"10/7/2022,240.899994,2027.579831\r\n",
"10/10/2022,233.050003,2027.579831\r\n",
"10/11/2022,227.619995,2027.579831\r\n",
"10/12/2022,225.399994,2027.579831\r\n",
"10/13/2022,219.850006,2027.579831\r\n",
"10/14/2022,235.539993,2027.579831\r\n",
"10/17/2022,235.820007,2027.579831\r\n",
"10/18/2022,243.240005,2046.299919\r\n",
"10/19/2022,237.039993,2046.299919\r\n",
"10/20/2022,235.770004,2046.299919\r\n",
"10/21/2022,234.740005,2046.299919\r\n",
"10/24/2022,243.759995,2100.059935\r\n",
"10/25/2022,247.259995,2100.059935\r\n",
"10/26/2022,231.169998,2100.059935\r\n",
"10/27/2022,231.039993,2100.059935\r\n",
"10/28/2022,226.240005,2100.059935\r\n",
"10/31/2022,233.759995,2100.059935\r\n",
"11/1/2022,234.600006,2100.059935\r\n",
"11/2/2022,229.460007,2100.059935\r\n",
"11/3/2022,220.089996,2100.059935\r\n",
"11/4/2022,217.550003,2100.059935\r\n",
"11/7/2022,221.990005,2100.059935\r\n",
"11/8/2022,228.699997,2100.059935\r\n",
"11/9/2022,227.369995,2100.059935\r\n",
"11/10/2022,235.429993,2138.399890\r\n",
"11/11/2022,242.990005,2138.399890\r\n",
"11/14/2022,241.990005,2138.399890\r\n",
"11/15/2022,245.660004,2138.399890\r\n",
"11/16/2022,242.789993,2138.399890\r\n",
"11/17/2022,237.779999,2138.399890\r\n",
"11/18/2022,243.509995,2138.399890\r\n",
"11/21/2022,241.429993,2138.399890\r\n",
"11/22/2022,243.589996,2138.399890\r\n",
"11/23/2022,245.110001,2138.399890\r\n",
"11/25/2022,247.309998,2138.399890\r\n",
"11/28/2022,246.080002,2138.399890\r\n",
"11/29/2022,241.399994,2138.399890\r\n",
"11/30/2022,240.570007,2138.399890\r\n",
"12/1/2022,253.869995,2138.399890\r\n",
"12/2/2022,249.820007,2138.399890\r\n",
"12/5/2022,252.009995,2138.399890\r\n",
"12/6/2022,250.820007,2138.399890\r\n",
"12/7/2022,244.830002,2138.399890\r\n",
"12/8/2022,244.839996,2138.399890\r\n",
"12/9/2022,244.699997,2138.399890\r\n",
"12/12/2022,247.449997,2160.399890\r\n",
"12/13/2022,261.690002,2160.399890\r\n",
"12/14/2022,257.130005,2160.399890\r\n",
"12/15/2022,253.720001,2160.399890\r\n",
"12/16/2022,248.550003,2160.399890\r\n",
"12/19/2022,244.860001,2160.399890\r\n",
"12/20/2022,239.399994,2160.399890\r\n",
"12/21/2022,241.690002,2160.399890\r\n",
"12/22/2022,241.259995,2160.399890\r\n",
"12/23/2022,236.110001,2160.399890\r\n",
"12/27/2022,238.699997,2160.399890\r\n",
"12/28/2022,236.889999,2160.399890\r\n",
"12/29/2022,235.649994,2160.399890\r\n",
"12/30/2022,238.210007,2160.399890\r\n",
"1/3/2023,243.080002,2160.399890\r\n",
"1/4/2023,232.279999,2160.399890\r\n",
"1/5/2023,227.199997,2160.399890\r\n",
"1/6/2023,223.000000,2160.399890\r\n",
"1/9/2023,226.449997,2160.399890\r\n",
"1/10/2023,227.759995,2160.399890\r\n",
"1/11/2023,231.289993,2160.399890\r\n",
"1/12/2023,235.259995,2160.399890\r\n",
"1/13/2023,237.000000,2097.519882\r\n",
"1/17/2023,237.970001,2097.519882\r\n",
"1/18/2023,241.570007,2097.519882\r\n",
"1/19/2023,233.779999,2097.519882\r\n",
"1/20/2023,234.860001,2097.519882\r\n",
"1/23/2023,241.100006,2156.079938\r\n",
"1/24/2023,242.500000,2156.079938\r\n",
"1/25/2023,234.479996,2156.079938\r\n",
"1/26/2023,243.649994,2238.609920\r\n",
"1/27/2023,248.990005,2238.609920\r\n",
"1/30/2023,244.509995,2238.609920\r\n",
"1/31/2023,243.449997,2238.609920\r\n",
"2/1/2023,248.000000,2238.609920\r\n",
"2/2/2023,258.820007,2238.609920\r\n",
"2/3/2023,259.540009,2238.609920\r\n",
"2/6/2023,257.440002,2238.609920\r\n",
"2/7/2023,260.529999,2238.609920\r\n",
"2/8/2023,273.200012,2238.609920\r\n",
"2/9/2023,273.799988,2238.609920\r\n",
"2/10/2023,261.529999,2238.609920\r\n",
"2/13/2023,267.640015,2238.609920\r\n",
"2/14/2023,272.670013,2238.609920\r\n",
"2/15/2023,268.320007,2238.609920\r\n",
"2/16/2023,264.019989,2238.609920\r\n",
"2/17/2023,259.390015,2238.609920\r\n",
"2/21/2023,254.479996,2238.609920\r\n",
"2/22/2023,254.089996,2238.609920\r\n",
"2/23/2023,255.559998,2238.609920\r\n",
"2/24/2023,249.960007,2238.609920\r\n",
"2/27/2023,252.460007,2238.609920\r\n",
"2/28/2023,249.070007,2238.609920\r\n",
"3/1/2023,250.759995,2238.609920\r\n",
"3/2/2023,246.550003,2238.609920\r\n",
"3/3/2023,252.190002,2238.609920\r\n",
"3/6/2023,256.429993,2238.609920\r\n",
"3/7/2023,256.299988,2238.609920\r\n",
"3/8/2023,254.039993,2238.609920\r\n",
"3/9/2023,255.820007,2238.609920\r\n",
"3/10/2023,251.080002,2238.609920\r\n",
"3/13/2023,247.399994,2238.609920\r\n",
"3/14/2023,256.750000,2256.769952\r\n",
"3/15/2023,259.980011,2256.769952\r\n",
"3/16/2023,265.209991,2256.769952\r\n",
"3/17/2023,278.260010,2256.769952\r\n",
"3/20/2023,276.980011,2256.769952\r\n",
"3/21/2023,274.880005,2256.769952\r\n",
"3/22/2023,273.399994,2256.769952\r\n",
"3/23/2023,277.940002,2256.769952\r\n",
"3/24/2023,277.239990,2256.769952\r\n",
"3/27/2023,280.500000,2256.769952\r\n",
"3/28/2023,275.790009,2256.769952\r\n",
"3/29/2023,278.959991,2256.769952\r\n",
"3/30/2023,284.230011,2256.769952\r\n",
"3/31/2023,283.730011,2256.769952\r\n",
"4/3/2023,286.519989,2256.769952\r\n",
"4/4/2023,287.230011,2256.769952\r\n",
"4/5/2023,285.850006,2256.769952\r\n",
"4/6/2023,283.209991,2256.769952\r\n",
"4/10/2023,289.209991,2256.769952\r\n",
"4/11/2023,285.750000,2256.769952\r\n",
"4/12/2023,284.790009,2256.769952\r\n",
"4/13/2023,283.589996,2256.769952\r\n",
"4/14/2023,287.000000,2256.769952\r\n",
"4/17/2023,289.929993,2256.769952\r\n",
"4/18/2023,291.570007,2256.769952\r\n",
"4/19/2023,285.989990,2256.769952\r\n",
"4/20/2023,285.250000,2256.769952\r\n",
"4/21/2023,285.010010,2256.769952\r\n",
"4/24/2023,282.089996,2256.769952\r\n",
"4/25/2023,279.510010,2256.769952\r\n",
"4/26/2023,296.700012,2373.650080\r\n",
"4/27/2023,295.970001,2373.650080\r\n",
"4/28/2023,304.010010,2373.650080\r\n",
"5/1/2023,306.970001,2373.650080\r\n",
"5/2/2023,307.760010,2373.650080\r\n",
"5/3/2023,306.619995,2373.650080\r\n",
"5/4/2023,306.239990,2373.650080\r\n",
"5/5/2023,305.720001,2373.650080\r\n",
"5/8/2023,310.130005,2373.650080\r\n",
"5/9/2023,308.000000,2373.650080\r\n",
"5/10/2023,308.619995,2373.650080\r\n",
"5/11/2023,310.100006,2373.650080\r\n",
"5/12/2023,310.549988,2373.650080\r\n",
"5/15/2023,309.100006,2373.650080\r\n",
"5/16/2023,309.829987,2373.650080\r\n",
"5/17/2023,312.290009,2373.650080\r\n",
"5/18/2023,314.529999,2373.650080\r\n",
"5/19/2023,316.739990,2373.650080\r\n",
"5/22/2023,318.600006,2373.650080\r\n",
"5/23/2023,320.029999,2373.650080\r\n",
"5/24/2023,314.730011,2373.650080\r\n",
"5/25/2023,323.239990,2373.650080\r\n",
"5/26/2023,324.019989,2373.650080\r\n",
"5/30/2023,335.230011,2373.650080\r\n",
"5/31/2023,332.290009,2373.650080\r\n",
"6/1/2023,325.929993,2373.650080\r\n",
"6/2/2023,334.250000,2373.650080\r\n",
"6/5/2023,335.220001,2373.650080\r\n",
"6/6/2023,335.329987,2373.650080\r\n",
"6/7/2023,331.649994,2373.650080\r\n",
"6/8/2023,323.940002,2373.650080\r\n",
"6/9/2023,324.989990,2373.650080\r\n",
"6/12/2023,328.579987,2373.650080\r\n",
"6/13/2023,334.470001,2373.650080\r\n",
"6/14/2023,334.339996,2373.650080\r\n",
"6/15/2023,337.480011,2373.650080\r\n",
"6/16/2023,351.320007,2373.650080\r\n",
"6/20/2023,339.309998,2373.650080\r\n",
"6/21/2023,336.369995,2373.650080\r\n",
"6/22/2023,334.119995,2373.650080\r\n",
"6/23/2023,334.359985,2373.650080\r\n",
"6/26/2023,333.720001,2373.650080\r\n",
"6/27/2023,331.859985,2373.650080\r\n",
"6/28/2023,334.660004,2393.250213\r\n",
"6/29/2023,334.709991,2393.250213\r\n",
"6/30/2023,337.750000,2393.250213\r\n",
"7/3/2023,339.190002,2393.250213\r\n",
"7/5/2023,335.089996,2393.250213\r\n",
"7/6/2023,337.299988,2393.250213\r\n",
"7/7/2023,339.320007,2393.250213\r\n",
"7/10/2023,334.600006,2393.250213\r\n",
"7/11/2023,331.059998,2393.250213\r\n",
"7/12/2023,336.600006,2407.250213\r\n",
"7/13/2023,339.559998,2407.250213\r\n",
"7/14/2023,347.589996,2407.250213\r\n",
"7/17/2023,345.679993,2407.250213\r\n",
"7/18/2023,345.829987,2407.250213\r\n",
"7/19/2023,361.750000,2407.250213\r\n",
"7/20/2023,353.570007,2407.250213\r\n",
"7/21/2023,349.149994,2407.250213\r\n",
"7/24/2023,345.850006,2407.250213\r\n",
"7/25/2023,347.109985,2407.250213\r\n",
"7/26/2023,341.440002,2407.250213\r\n",
"7/27/2023,340.480011,2407.250213\r\n",
"7/28/2023,333.670013,2407.250213\r\n",
"7/31/2023,336.920013,2407.250213\r\n",
"8/1/2023,335.190002,2407.250213\r\n",
"8/2/2023,333.630005,2407.250213\r\n",
"8/3/2023,326.000000,2407.250213\r\n",
"8/4/2023,331.880005,2407.250213\r\n",
"8/7/2023,328.369995,2407.250213\r\n",
"8/8/2023,326.959991,2407.250213\r\n",
"8/9/2023,326.470001,2407.250213\r\n",
"8/10/2023,326.019989,2407.250213\r\n",
"8/11/2023,320.260010,2407.250213\r\n",
"8/14/2023,321.390015,2407.250213\r\n",
"8/15/2023,323.000000,2407.250213\r\n",
"8/16/2023,320.799988,2407.250213\r\n",
"8/17/2023,320.540009,2407.250213\r\n",
"8/18/2023,314.489990,2407.250213\r\n",
"8/21/2023,317.929993,2407.250213\r\n",
"8/22/2023,325.500000,2407.250213\r\n",
"8/23/2023,323.820007,2407.250213\r\n",
"8/24/2023,332.850006,2347.120241\r\n",
"8/25/2023,321.470001,2347.120241\r\n",
"8/28/2023,325.660004,2376.450262\r\n",
"8/29/2023,321.880005,2376.450262\r\n",
"8/30/2023,328.670013,2423.980318\r\n",
"8/31/2023,329.200012,2423.980318\r\n",
"9/1/2023,331.309998,2423.980318\r\n",
"9/5/2023,329.000000,2423.980318\r\n",
"9/6/2023,333.380005,2423.980318\r\n",
"9/7/2023,331.290009,2423.980318\r\n",
"9/8/2023,330.089996,2423.980318\r\n",
"9/11/2023,337.239990,2423.980318\r\n",
"9/12/2023,335.820007,2423.980318\r\n",
"9/13/2023,331.309998,2423.980318\r\n",
"9/14/2023,339.149994,2423.980318\r\n",
"9/15/2023,336.920013,2423.980318\r\n",
"9/18/2023,327.799988,2423.980318\r\n",
"9/19/2023,326.170013,2423.980318\r\n",
"9/20/2023,329.510010,2423.980318\r\n",
"9/21/2023,319.260010,2423.980318\r\n",
"9/22/2023,321.320007,2423.980318\r\n",
"9/25/2023,316.589996,2423.980318\r\n",
"9/26/2023,315.130005,2423.980318\r\n",
"9/27/2023,312.299988,2423.980318\r\n",
"9/28/2023,310.989990,2423.980318\r\n",
"9/29/2023,317.750000,2423.980318\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Balance</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-11-05\">Nov 05, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.370003</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-06\">Nov 06, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.379997</pre></div></td><td><div class=\"dni-plaintext\"><pre>&lt;null&gt;</pre></div></td></tr><tr><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-08\">Nov 08, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-09\">Nov 09, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.849998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-12\">Nov 12, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.419998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-16\">Nov 16, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.080002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-21\">Nov 21, 2018</time></td><td><div class=\"dni-plaintext\"><pre>103.599998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-23\">Nov 23, 2018</time></td><td><div class=\"dni-plaintext\"><pre>102.169998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-26\">Nov 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.790001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-27\">Nov 27, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-11-29\">Nov 29, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.330002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-11-30\">Nov 30, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.699997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-12-03\">Dec 03, 2018</time></td><td><div class=\"dni-plaintext\"><pre>113.000000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td colspan=\"3\"><i>(1213 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var filled = merged.FillForward(e => e.Balance is null,\n",
" (e, f) => new { e.Date, e.Price, Balance = f.Balance ?? e.Balance });\n",
" \n",
"filled.Lead(2, (curr, peek) => (Current: curr, Peek: peek))\n",
" .SkipWhile(e => e is (_, { Balance: null }))\n",
" .Select(e => e.Current)\n",
" .ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Great, but there's one last problem. The initial balance is missing from the start of the series, which is normal. Let's fix that by seeding the `initialBalance` using [`Prepend`] from LINQ such that `FillForward` will always start with a last known value for when it sees a `null`. The seeding element is later removed or filtered by skipping it because it isn't really part of the original data.\n",
"\n",
"[`Prepend`]: https://learn.microsoft.com/en-us/dotnet/api/system.linq.enumerable.prepend"
]
},
{
"cell_type": "code",
"execution_count": 133,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/csv": [
"Date,Price,Balance\r\n",
"11/5/2018,106.370003,1000\r\n",
"11/6/2018,107.379997,1000\r\n",
"11/7/2018,109.440002,1033.750000\r\n",
"11/8/2018,111.800003,1033.750000\r\n",
"11/9/2018,110.849998,1033.750000\r\n",
"11/12/2018,109.419998,1033.750000\r\n",
"11/13/2018,107.550003,1033.750000\r\n",
"11/14/2018,108.099998,1038.699955\r\n",
"11/15/2018,104.989998,1038.699955\r\n",
"11/16/2018,107.080002,1038.699955\r\n",
"11/19/2018,108.269997,1068.219946\r\n",
"11/20/2018,101.800003,1068.219946\r\n",
"11/21/2018,103.599998,1068.219946\r\n",
"11/23/2018,102.169998,1068.219946\r\n",
"11/26/2018,104.790001,1068.219946\r\n",
"11/27/2018,106.269997,1068.219946\r\n",
"11/28/2018,107.889999,1129.119906\r\n",
"11/29/2018,110.330002,1129.119906\r\n",
"11/30/2018,110.699997,1129.119906\r\n",
"12/3/2018,113.000000,1129.119906\r\n",
"12/4/2018,111.940002,1129.119906\r\n",
"12/6/2018,105.820000,1129.119906\r\n",
"12/7/2018,108.379997,1154.719876\r\n",
"12/10/2018,104.800003,1154.719876\r\n",
"12/11/2018,109.800003,1209.719876\r\n",
"12/12/2018,110.889999,1209.719876\r\n",
"12/13/2018,109.580002,1209.719876\r\n",
"12/14/2018,108.250000,1209.719876\r\n",
"12/17/2018,105.410004,1209.719876\r\n",
"12/18/2018,103.750000,1209.719876\r\n",
"12/19/2018,103.650002,1209.719876\r\n",
"12/20/2018,103.050003,1209.719876\r\n",
"12/21/2018,101.629997,1209.719876\r\n",
"12/24/2018,97.680000,1209.719876\r\n",
"12/26/2018,95.139999,1209.719876\r\n",
"12/27/2018,99.300003,1209.719876\r\n",
"12/28/2018,102.089996,1209.719876\r\n",
"12/31/2018,101.290001,1209.719876\r\n",
"1/2/2019,99.550003,1209.719876\r\n",
"1/3/2019,100.099998,1209.719876\r\n",
"1/4/2019,99.720001,1209.719876\r\n",
"1/7/2019,101.639999,1209.719876\r\n",
"1/8/2019,103.040001,1183.649843\r\n",
"1/9/2019,103.860001,1183.649843\r\n",
"1/10/2019,103.220001,1183.649843\r\n",
"1/11/2019,103.190002,1183.649843\r\n",
"1/14/2019,101.900002,1183.649843\r\n",
"1/15/2019,102.510002,1183.649843\r\n",
"1/16/2019,105.260002,1183.649843\r\n",
"1/17/2019,105.000000,1183.649843\r\n",
"1/18/2019,107.459999,1183.649843\r\n",
"1/22/2019,106.750000,1183.649843\r\n",
"1/23/2019,106.120003,1183.649843\r\n",
"1/24/2019,106.860001,1183.649843\r\n",
"1/25/2019,107.239998,1183.649843\r\n",
"1/28/2019,106.260002,1183.649843\r\n",
"1/29/2019,104.879997,1183.649843\r\n",
"1/30/2019,104.620003,1183.649843\r\n",
"1/31/2019,103.800003,1183.649843\r\n",
"2/1/2019,103.779999,1183.649843\r\n",
"2/4/2019,102.870003,1183.649843\r\n",
"2/5/2019,106.059998,1208.509788\r\n",
"2/6/2019,107.000000,1208.509788\r\n",
"2/7/2019,105.190002,1208.509788\r\n",
"2/8/2019,104.389999,1208.509788\r\n",
"2/11/2019,106.199997,1228.419766\r\n",
"2/12/2019,106.139999,1228.419766\r\n",
"2/13/2019,107.500000,1228.419766\r\n",
"2/14/2019,106.309998,1228.419766\r\n",
"2/15/2019,107.910004,1228.419766\r\n",
"2/19/2019,107.790001,1228.419766\r\n",
"2/20/2019,107.860001,1228.419766\r\n",
"2/21/2019,106.900002,1228.419766\r\n",
"2/22/2019,110.050003,1228.419766\r\n",
"2/25/2019,111.760002,1228.419766\r\n",
"2/26/2019,111.260002,1228.419766\r\n",
"2/27/2019,111.690002,1228.419766\r\n",
"2/28/2019,112.040001,1228.419766\r\n",
"3/1/2019,112.889999,1228.419766\r\n",
"3/4/2019,113.019997,1228.419766\r\n",
"3/5/2019,112.250000,1228.419766\r\n",
"3/6/2019,111.870003,1228.419766\r\n",
"3/7/2019,111.400002,1228.419766\r\n",
"3/8/2019,109.160004,1228.419766\r\n",
"3/11/2019,110.989998,1248.549700\r\n",
"3/12/2019,112.820000,1248.549700\r\n",
"3/13/2019,114.129997,1248.549700\r\n",
"3/14/2019,114.540001,1248.549700\r\n",
"3/15/2019,115.339996,1248.549700\r\n",
"3/18/2019,116.169998,1248.549700\r\n",
"3/19/2019,118.089996,1248.549700\r\n",
"3/20/2019,117.389999,1248.549700\r\n",
"3/21/2019,117.139999,1248.549700\r\n",
"3/22/2019,119.500000,1248.549700\r\n",
"3/25/2019,116.559998,1248.549700\r\n",
"3/26/2019,118.620003,1248.549700\r\n",
"3/27/2019,117.879997,1248.549700\r\n",
"3/28/2019,117.440002,1248.549700\r\n",
"3/29/2019,118.070000,1248.549700\r\n",
"4/1/2019,118.949997,1248.549700\r\n",
"4/2/2019,119.059998,1248.549700\r\n",
"4/3/2019,119.860001,1248.549700\r\n",
"4/4/2019,120.099998,1248.549700\r\n",
"4/5/2019,119.389999,1248.549700\r\n",
"4/8/2019,119.809998,1248.549700\r\n",
"4/9/2019,118.629997,1248.549700\r\n",
"4/10/2019,119.760002,1248.549700\r\n",
"4/11/2019,120.540001,1248.549700\r\n",
"4/12/2019,120.639999,1248.549700\r\n",
"4/15/2019,120.940002,1248.549700\r\n",
"4/16/2019,121.639999,1248.549700\r\n",
"4/17/2019,121.239998,1248.549700\r\n",
"4/18/2019,122.190002,1248.549700\r\n",
"4/22/2019,122.620003,1248.549700\r\n",
"4/23/2019,124.099998,1248.549700\r\n",
"4/24/2019,125.790001,1248.549700\r\n",
"4/25/2019,130.059998,1248.549700\r\n",
"4/26/2019,129.699997,1248.549700\r\n",
"4/29/2019,129.899994,1248.549700\r\n",
"4/30/2019,129.809998,1248.549700\r\n",
"5/1/2019,130.529999,1248.549700\r\n",
"5/2/2019,127.980003,1248.549700\r\n",
"5/3/2019,127.360001,1248.549700\r\n",
"5/6/2019,126.389999,1248.549700\r\n",
"5/7/2019,126.459999,1248.549700\r\n",
"5/8/2019,125.440002,1248.549700\r\n",
"5/9/2019,124.290001,1248.549700\r\n",
"5/10/2019,124.910004,1248.549700\r\n",
"5/13/2019,124.110001,1248.549700\r\n",
"5/14/2019,123.870003,1248.549700\r\n",
"5/15/2019,124.260002,1248.549700\r\n",
"5/16/2019,126.750000,1273.149690\r\n",
"5/17/2019,128.309998,1273.149690\r\n",
"5/20/2019,126.519997,1273.149690\r\n",
"5/21/2019,127.430000,1282.249720\r\n",
"5/22/2019,126.620003,1282.249720\r\n",
"5/23/2019,126.199997,1282.249720\r\n",
"5/24/2019,126.910004,1285.149730\r\n",
"5/28/2019,126.980003,1285.149730\r\n",
"5/29/2019,125.379997,1285.149730\r\n",
"5/30/2019,125.260002,1285.149730\r\n",
"5/31/2019,124.230003,1285.149730\r\n",
"6/3/2019,123.849998,1285.149730\r\n",
"6/4/2019,121.279999,1285.149730\r\n",
"6/5/2019,124.949997,1285.149730\r\n",
"6/6/2019,126.440002,1295.749780\r\n",
"6/7/2019,129.190002,1295.749780\r\n",
"6/10/2019,132.399994,1295.749780\r\n",
"6/11/2019,133.880005,1295.749780\r\n",
"6/12/2019,131.399994,1295.749780\r\n",
"6/13/2019,131.979996,1295.749780\r\n",
"6/14/2019,132.259995,1295.749780\r\n",
"6/17/2019,132.630005,1295.749780\r\n",
"6/18/2019,134.190002,1295.749780\r\n",
"6/19/2019,135.000000,1295.749780\r\n",
"6/20/2019,137.449997,1295.749780\r\n",
"6/21/2019,136.580002,1295.749780\r\n",
"6/24/2019,137.000000,1295.749780\r\n",
"6/25/2019,137.250000,1295.749780\r\n",
"6/26/2019,134.350006,1295.749780\r\n",
"6/27/2019,134.139999,1295.749780\r\n",
"6/28/2019,134.570007,1295.749780\r\n",
"7/1/2019,136.630005,1295.749780\r\n",
"7/2/2019,136.119995,1295.749780\r\n",
"7/3/2019,136.800003,1295.749780\r\n",
"7/5/2019,135.940002,1295.749780\r\n",
"7/8/2019,136.399994,1295.749780\r\n",
"7/9/2019,136.000000,1295.749780\r\n",
"7/10/2019,137.130005,1295.749780\r\n",
"7/11/2019,138.199997,1295.749780\r\n",
"7/12/2019,138.850006,1295.749780\r\n",
"7/15/2019,139.440002,1295.749780\r\n",
"7/16/2019,138.960007,1295.749780\r\n",
"7/17/2019,137.699997,1295.749780\r\n",
"7/18/2019,135.550003,1295.749780\r\n",
"7/19/2019,140.220001,1337.779762\r\n",
"7/22/2019,137.410004,1337.779762\r\n",
"7/23/2019,139.759995,1337.779762\r\n",
"7/24/2019,138.899994,1337.779762\r\n",
"7/25/2019,140.429993,1337.779762\r\n",
"7/26/2019,140.369995,1337.779762\r\n",
"7/29/2019,141.500000,1337.779762\r\n",
"7/30/2019,140.139999,1337.779762\r\n",
"7/31/2019,140.330002,1337.779762\r\n",
"8/1/2019,137.000000,1337.779762\r\n",
"8/2/2019,138.089996,1337.779762\r\n",
"8/5/2019,133.300003,1337.779762\r\n",
"8/6/2019,133.800003,1337.779762\r\n",
"8/7/2019,133.789993,1337.779762\r\n",
"8/8/2019,136.600006,1337.779762\r\n",
"8/9/2019,138.610001,1352.269771\r\n",
"8/12/2019,137.070007,1352.269771\r\n",
"8/13/2019,136.050003,1352.269771\r\n",
"8/14/2019,136.360001,1352.269771\r\n",
"8/15/2019,134.389999,1352.269771\r\n",
"8/16/2019,134.880005,1352.269771\r\n",
"8/19/2019,137.850006,1359.289762\r\n",
"8/20/2019,138.210007,1359.289762\r\n",
"8/21/2019,138.550003,1359.289762\r\n",
"8/22/2019,138.660004,1359.289762\r\n",
"8/23/2019,137.190002,1359.289762\r\n",
"8/26/2019,134.990005,1359.289762\r\n",
"8/27/2019,136.389999,1359.289762\r\n",
"8/28/2019,134.880005,1359.289762\r\n",
"8/29/2019,137.250000,1381.889712\r\n",
"8/30/2019,139.149994,1381.889712\r\n",
"9/3/2019,136.610001,1381.889712\r\n",
"9/4/2019,137.300003,1381.889712\r\n",
"9/5/2019,139.110001,1381.889712\r\n",
"9/6/2019,140.029999,1381.889712\r\n",
"9/9/2019,139.589996,1381.889712\r\n",
"9/10/2019,136.800003,1381.889712\r\n",
"9/11/2019,135.910004,1381.889712\r\n",
"9/12/2019,137.850006,1392.389742\r\n",
"9/13/2019,137.779999,1392.389742\r\n",
"9/16/2019,135.830002,1392.389742\r\n",
"9/17/2019,136.960007,1392.389742\r\n",
"9/18/2019,137.360001,1392.389742\r\n",
"9/19/2019,140.300003,1437.089752\r\n",
"9/20/2019,141.009995,1437.089752\r\n",
"9/23/2019,139.229996,1437.089752\r\n",
"9/24/2019,140.360001,1437.089752\r\n",
"9/25/2019,137.500000,1437.089752\r\n",
"9/26/2019,139.440002,1456.489772\r\n",
"9/27/2019,140.149994,1456.489772\r\n",
"9/30/2019,138.050003,1456.489772\r\n",
"10/1/2019,139.660004,1472.589782\r\n",
"10/2/2019,136.250000,1472.589782\r\n",
"10/3/2019,134.949997,1472.589782\r\n",
"10/4/2019,136.750000,1472.589782\r\n",
"10/7/2019,137.139999,1472.589782\r\n",
"10/8/2019,137.080002,1472.589782\r\n",
"10/9/2019,137.460007,1472.589782\r\n",
"10/10/2019,138.490005,1494.989832\r\n",
"10/11/2019,140.119995,1494.989832\r\n",
"10/14/2019,139.690002,1494.989832\r\n",
"10/15/2019,140.059998,1494.989832\r\n",
"10/16/2019,140.789993,1494.989832\r\n",
"10/17/2019,140.949997,1494.989832\r\n",
"10/18/2019,139.759995,1494.989832\r\n",
"10/21/2019,138.449997,1494.989832\r\n",
"10/22/2019,138.970001,1500.189872\r\n",
"10/23/2019,136.880005,1500.189872\r\n",
"10/24/2019,139.389999,1525.289812\r\n",
"10/25/2019,139.339996,1525.289812\r\n",
"10/28/2019,144.399994,1525.289812\r\n",
"10/29/2019,144.080002,1525.289812\r\n",
"10/30/2019,143.520004,1525.289812\r\n",
"10/31/2019,144.899994,1525.289812\r\n",
"11/1/2019,144.259995,1525.289812\r\n",
"11/4/2019,144.830002,1525.289812\r\n",
"11/5/2019,144.970001,1525.289812\r\n",
"11/6/2019,144.369995,1525.289812\r\n",
"11/7/2019,143.839996,1525.289812\r\n",
"11/8/2019,143.979996,1525.289812\r\n",
"11/11/2019,145.339996,1525.289812\r\n",
"11/12/2019,146.279999,1525.289812\r\n",
"11/13/2019,146.740005,1525.289812\r\n",
"11/14/2019,147.020004,1525.289812\r\n",
"11/15/2019,148.929993,1525.289812\r\n",
"11/18/2019,150.070007,1525.289812\r\n",
"11/19/2019,150.880005,1525.289812\r\n",
"11/20/2019,150.309998,1525.289812\r\n",
"11/21/2019,149.399994,1525.289812\r\n",
"11/22/2019,150.070007,1525.289812\r\n",
"11/25/2019,150.000000,1525.289812\r\n",
"11/26/2019,151.360001,1525.289812\r\n",
"11/27/2019,152.330002,1525.289812\r\n",
"11/29/2019,152.100006,1525.289812\r\n",
"12/2/2019,151.809998,1525.289812\r\n",
"12/3/2019,147.490005,1525.289812\r\n",
"12/4/2019,150.139999,1551.789752\r\n",
"12/5/2019,150.050003,1551.789752\r\n",
"12/6/2019,150.990005,1551.789752\r\n",
"12/9/2019,151.070007,1551.789752\r\n",
"12/10/2019,151.289993,1551.789752\r\n",
"12/11/2019,151.539993,1551.789752\r\n",
"12/12/2019,151.649994,1551.789752\r\n",
"12/13/2019,153.000000,1551.789752\r\n",
"12/16/2019,155.110001,1551.789752\r\n",
"12/17/2019,155.449997,1551.789752\r\n",
"12/18/2019,154.300003,1551.789752\r\n",
"12/19/2019,154.000000,1551.789752\r\n",
"12/20/2019,157.350006,1551.789752\r\n",
"12/23/2019,158.119995,1551.789752\r\n",
"12/24/2019,157.479996,1551.789752\r\n",
"12/26/2019,157.559998,1551.789752\r\n",
"12/27/2019,159.449997,1551.789752\r\n",
"12/30/2019,158.990005,1551.789752\r\n",
"12/31/2019,156.770004,1551.789752\r\n",
"1/2/2020,158.779999,1551.789752\r\n",
"1/3/2020,158.320007,1551.789752\r\n",
"1/6/2020,157.080002,1551.789752\r\n",
"1/7/2020,159.320007,1551.789752\r\n",
"1/8/2020,158.929993,1551.789752\r\n",
"1/9/2020,161.839996,1551.789752\r\n",
"1/10/2020,162.820007,1551.789752\r\n",
"1/13/2020,161.759995,1551.789752\r\n",
"1/14/2020,163.389999,1551.789752\r\n",
"1/15/2020,162.619995,1551.789752\r\n",
"1/16/2020,164.350006,1551.789752\r\n",
"1/17/2020,167.419998,1551.789752\r\n",
"1/21/2020,166.679993,1551.789752\r\n",
"1/22/2020,167.399994,1551.789752\r\n",
"1/23/2020,166.190002,1551.789752\r\n",
"1/24/2020,167.509995,1551.789752\r\n",
"1/27/2020,161.149994,1551.789752\r\n",
"1/28/2020,163.779999,1575.459797\r\n",
"1/29/2020,167.839996,1575.459797\r\n",
"1/30/2020,174.050003,1575.459797\r\n",
"1/31/2020,172.210007,1575.459797\r\n",
"2/3/2020,170.429993,1575.459797\r\n",
"2/4/2020,177.139999,1575.459797\r\n",
"2/5/2020,184.029999,1575.459797\r\n",
"2/6/2020,180.970001,1575.459797\r\n",
"2/7/2020,182.850006,1575.459797\r\n",
"2/10/2020,183.580002,1575.459797\r\n",
"2/11/2020,190.649994,1575.459797\r\n",
"2/12/2020,185.580002,1575.459797\r\n",
"2/13/2020,183.080002,1575.459797\r\n",
"2/14/2020,183.250000,1575.459797\r\n",
"2/18/2020,185.610001,1575.459797\r\n",
"2/19/2020,188.059998,1575.459797\r\n",
"2/20/2020,186.949997,1575.459797\r\n",
"2/21/2020,183.169998,1575.459797\r\n",
"2/24/2020,167.770004,1575.459797\r\n",
"2/25/2020,174.199997,1575.459797\r\n",
"2/26/2020,169.710007,1575.459797\r\n",
"2/27/2020,163.320007,1575.459797\r\n",
"2/28/2020,152.410004,1575.459797\r\n",
"3/2/2020,165.309998,1575.459797\r\n",
"3/3/2020,173.800003,1575.459797\r\n",
"3/4/2020,168.490005,1575.459797\r\n",
"3/5/2020,166.050003,1575.459797\r\n",
"3/6/2020,162.610001,1575.459797\r\n",
"3/9/2020,151.000000,1575.459797\r\n",
"3/10/2020,158.160004,1575.459797\r\n",
"3/11/2020,157.130005,1575.459797\r\n",
"3/12/2020,145.300003,1575.459797\r\n",
"3/13/2020,147.500000,1575.459797\r\n",
"3/16/2020,140.000000,1575.459797\r\n",
"3/17/2020,140.000000,1575.459797\r\n",
"3/18/2020,138.000000,1575.459797\r\n",
"3/19/2020,142.770004,1575.459797\r\n",
"3/20/2020,146.000000,1575.459797\r\n",
"3/23/2020,137.009995,1575.459797\r\n",
"3/24/2020,143.750000,1575.459797\r\n",
"3/25/2020,148.910004,1575.459797\r\n",
"3/26/2020,148.399994,1575.459797\r\n",
"3/27/2020,151.750000,1431.279761\r\n",
"3/30/2020,152.440002,1431.279761\r\n",
"3/31/2020,159.399994,1431.279761\r\n",
"4/1/2020,153.000000,1431.279761\r\n",
"4/2/2020,151.860001,1431.279761\r\n",
"4/3/2020,155.100006,1431.279761\r\n",
"4/6/2020,160.320007,1431.279761\r\n",
"4/7/2020,169.589996,1431.279761\r\n",
"4/8/2020,165.669998,1431.279761\r\n",
"4/9/2020,166.360001,1431.279761\r\n",
"4/13/2020,164.350006,1431.279761\r\n",
"4/14/2020,169.000000,1431.279761\r\n",
"4/15/2020,171.199997,1431.279761\r\n",
"4/16/2020,174.300003,1431.279761\r\n",
"4/17/2020,179.500000,1431.279761\r\n",
"4/20/2020,176.630005,1431.279761\r\n",
"4/21/2020,173.500000,1431.279761\r\n",
"4/22/2020,171.389999,1431.279761\r\n",
"4/23/2020,174.110001,1431.279761\r\n",
"4/24/2020,172.059998,1431.279761\r\n",
"4/27/2020,176.589996,1431.279761\r\n",
"4/28/2020,175.589996,1431.279761\r\n",
"4/29/2020,173.220001,1431.279761\r\n",
"4/30/2020,180.000000,1431.279761\r\n",
"5/1/2020,175.800003,1431.279761\r\n",
"5/4/2020,174.490005,1431.279761\r\n",
"5/5/2020,180.619995,1431.279761\r\n",
"5/6/2020,182.080002,1431.279761\r\n",
"5/7/2020,184.169998,1431.279761\r\n",
"5/8/2020,184.979996,1431.279761\r\n",
"5/11/2020,183.149994,1431.279761\r\n",
"5/12/2020,186.800003,1431.279761\r\n",
"5/13/2020,182.550003,1431.279761\r\n",
"5/14/2020,177.539993,1431.279761\r\n",
"5/15/2020,179.059998,1443.439801\r\n",
"5/18/2020,185.750000,1443.439801\r\n",
"5/19/2020,185.029999,1443.439801\r\n",
"5/20/2020,184.809998,1443.439801\r\n",
"5/21/2020,185.399994,1443.439801\r\n",
"5/22/2020,183.190002,1443.439801\r\n",
"5/26/2020,186.339996,1443.439801\r\n",
"5/27/2020,180.199997,1443.439801\r\n",
"5/28/2020,180.740005,1443.439801\r\n",
"5/29/2020,182.729996,1463.679793\r\n",
"6/1/2020,182.539993,1463.679793\r\n",
"6/2/2020,184.250000,1477.359849\r\n",
"6/3/2020,184.820007,1477.359849\r\n",
"6/4/2020,184.300003,1477.359849\r\n",
"6/5/2020,182.619995,1477.359849\r\n",
"6/8/2020,185.940002,1503.919905\r\n",
"6/9/2020,188.000000,1503.919905\r\n",
"6/10/2020,191.130005,1503.919905\r\n",
"6/11/2020,193.130005,1503.919905\r\n",
"6/12/2020,190.539993,1503.919905\r\n",
"6/15/2020,184.580002,1503.919905\r\n",
"6/16/2020,192.889999,1570.399881\r\n",
"6/17/2020,195.029999,1570.399881\r\n",
"6/18/2020,194.000000,1570.399881\r\n",
"6/19/2020,198.589996,1570.399881\r\n",
"6/22/2020,195.789993,1570.399881\r\n",
"6/23/2020,202.089996,1570.399881\r\n",
"6/24/2020,201.600006,1570.399881\r\n",
"6/25/2020,197.800003,1570.399881\r\n",
"6/26/2020,199.729996,1570.399881\r\n",
"6/29/2020,195.779999,1570.399881\r\n",
"6/30/2020,197.880005,1570.399881\r\n",
"7/1/2020,203.139999,1570.399881\r\n",
"7/2/2020,205.679993,1570.399881\r\n",
"7/6/2020,208.830002,1570.399881\r\n",
"7/7/2020,210.449997,1570.399881\r\n",
"7/8/2020,210.070007,1570.399881\r\n",
"7/9/2020,216.330002,1570.399881\r\n",
"7/10/2020,213.619995,1570.399881\r\n",
"7/13/2020,214.479996,1570.399881\r\n",
"7/14/2020,206.130005,1570.399881\r\n",
"7/15/2020,209.559998,1570.399881\r\n",
"7/16/2020,205.399994,1570.399881\r\n",
"7/17/2020,204.470001,1570.399881\r\n",
"7/20/2020,205.000000,1570.399881\r\n",
"7/21/2020,213.660004,1634.729902\r\n",
"7/22/2020,209.199997,1634.729902\r\n",
"7/23/2020,207.190002,1634.729902\r\n",
"7/24/2020,200.419998,1634.729902\r\n",
"7/27/2020,201.470001,1634.729902\r\n",
"7/28/2020,203.610001,1634.729902\r\n",
"7/29/2020,202.500000,1634.729902\r\n",
"7/30/2020,201.000000,1634.729902\r\n",
"7/31/2020,204.399994,1634.729902\r\n",
"8/3/2020,211.520004,1723.529950\r\n",
"8/4/2020,214.169998,1723.529950\r\n",
"8/5/2020,214.899994,1723.529950\r\n",
"8/6/2020,212.339996,1723.529950\r\n",
"8/7/2020,214.850006,1723.529950\r\n",
"8/10/2020,211.669998,1723.529950\r\n",
"8/11/2020,207.160004,1723.529950\r\n",
"8/12/2020,205.289993,1723.529950\r\n",
"8/13/2020,209.440002,1741.769934\r\n",
"8/14/2020,208.759995,1741.769934\r\n",
"8/17/2020,209.600006,1741.769934\r\n",
"8/18/2020,210.529999,1741.769934\r\n",
"8/19/2020,211.490005,1741.769934\r\n",
"8/20/2020,209.539993,1741.769934\r\n",
"8/21/2020,213.860001,1741.769934\r\n",
"8/24/2020,214.789993,1741.769934\r\n",
"8/25/2020,213.100006,1741.769934\r\n",
"8/26/2020,217.880005,1741.769934\r\n",
"8/27/2020,222.889999,1741.769934\r\n",
"8/28/2020,228.179993,1741.769934\r\n",
"8/31/2020,227.000000,1741.769934\r\n",
"9/1/2020,225.509995,1741.769934\r\n",
"9/2/2020,227.970001,1741.769934\r\n",
"9/3/2020,229.270004,1741.769934\r\n",
"9/4/2020,215.100006,1741.769934\r\n",
"9/8/2020,206.500000,1741.769934\r\n",
"9/9/2020,207.600006,1741.769934\r\n",
"9/10/2020,213.399994,1741.769934\r\n",
"9/11/2020,207.199997,1741.769934\r\n",
"9/14/2020,204.240005,1741.769934\r\n",
"9/15/2020,208.419998,1741.769934\r\n",
"9/16/2020,210.619995,1741.769934\r\n",
"9/17/2020,200.050003,1741.769934\r\n",
"9/18/2020,202.800003,1741.769934\r\n",
"9/21/2020,197.190002,1741.769934\r\n",
"9/22/2020,205.059998,1741.769934\r\n",
"9/23/2020,207.899994,1741.769934\r\n",
"9/24/2020,199.850006,1741.769934\r\n",
"9/25/2020,203.550003,1741.769934\r\n",
"9/28/2020,210.880005,1708.009926\r\n",
"9/29/2020,209.350006,1708.009926\r\n",
"9/30/2020,207.729996,1708.009926\r\n",
"10/1/2020,213.490005,1741.129918\r\n",
"10/2/2020,208.000000,1741.129918\r\n",
"10/5/2020,207.220001,1741.129918\r\n",
"10/6/2020,208.820007,1741.129918\r\n",
"10/7/2020,207.059998,1741.129918\r\n",
"10/8/2020,210.509995,1741.129918\r\n",
"10/9/2020,211.229996,1741.129918\r\n",
"10/12/2020,218.789993,1741.129918\r\n",
"10/13/2020,222.720001,1741.129918\r\n",
"10/14/2020,223.000000,1741.129918\r\n",
"10/15/2020,217.100006,1741.129918\r\n",
"10/16/2020,220.149994,1741.129918\r\n",
"10/19/2020,220.419998,1741.129918\r\n",
"10/20/2020,215.800003,1741.129918\r\n",
"10/21/2020,213.119995,1741.129918\r\n",
"10/22/2020,213.929993,1741.129918\r\n",
"10/23/2020,215.029999,1741.129918\r\n",
"10/26/2020,213.850006,1741.129918\r\n",
"10/27/2020,211.589996,1741.129918\r\n",
"10/28/2020,207.669998,1741.129918\r\n",
"10/29/2020,204.070007,1741.129918\r\n",
"10/30/2020,203.500000,1741.129918\r\n",
"11/2/2020,204.289993,1741.129918\r\n",
"11/3/2020,203.889999,1741.129918\r\n",
"11/4/2020,214.020004,1742.489902\r\n",
"11/5/2020,222.039993,1742.489902\r\n",
"11/6/2020,222.259995,1742.489902\r\n",
"11/9/2020,224.440002,1742.489902\r\n",
"11/10/2020,214.500000,1742.489902\r\n",
"11/11/2020,212.389999,1742.489902\r\n",
"11/12/2020,217.210007,1781.049966\r\n",
"11/13/2020,216.360001,1781.049966\r\n",
"11/16/2020,214.869995,1781.049966\r\n",
"11/17/2020,216.100006,1781.049966\r\n",
"11/18/2020,213.649994,1781.049966\r\n",
"11/19/2020,211.380005,1781.049966\r\n",
"11/20/2020,212.199997,1781.049966\r\n",
"11/23/2020,210.949997,1781.049966\r\n",
"11/24/2020,209.589996,1781.049966\r\n",
"11/25/2020,215.110001,1810.889934\r\n",
"11/27/2020,214.850006,1810.889934\r\n",
"11/30/2020,214.100006,1810.889934\r\n",
"12/1/2020,214.509995,1810.889934\r\n",
"12/2/2020,214.880005,1810.889934\r\n",
"12/3/2020,214.610001,1810.889934\r\n",
"12/4/2020,214.220001,1810.889934\r\n",
"12/7/2020,214.369995,1810.889934\r\n",
"12/8/2020,213.970001,1810.889934\r\n",
"12/9/2020,215.160004,1819.369918\r\n",
"12/10/2020,211.770004,1819.369918\r\n",
"12/11/2020,210.050003,1819.369918\r\n",
"12/14/2020,213.100006,1819.369918\r\n",
"12/15/2020,215.169998,1846.569870\r\n",
"12/16/2020,214.750000,1846.569870\r\n",
"12/17/2020,219.869995,1846.569870\r\n",
"12/18/2020,218.589996,1846.569870\r\n",
"12/21/2020,217.550003,1846.569870\r\n",
"12/22/2020,222.690002,1846.569870\r\n",
"12/23/2020,223.110001,1846.569870\r\n",
"12/24/2020,221.419998,1846.569870\r\n",
"12/28/2020,224.449997,1846.569870\r\n",
"12/29/2020,226.309998,1846.569870\r\n",
"12/30/2020,225.229996,1846.569870\r\n",
"12/31/2020,221.699997,1846.569870\r\n",
"1/4/2021,222.529999,1846.569870\r\n",
"1/5/2021,217.259995,1846.569870\r\n",
"1/6/2021,212.169998,1846.569870\r\n",
"1/7/2021,214.039993,1846.569870\r\n",
"1/8/2021,218.679993,1857.929854\r\n",
"1/11/2021,218.470001,1857.929854\r\n",
"1/12/2021,216.500000,1857.929854\r\n",
"1/13/2021,214.020004,1857.929854\r\n",
"1/14/2021,215.910004,1857.929854\r\n",
"1/15/2021,213.520004,1857.929854\r\n",
"1/19/2021,213.750000,1857.929854\r\n",
"1/20/2021,217.699997,1857.929854\r\n",
"1/21/2021,224.699997,1907.769822\r\n",
"1/22/2021,227.080002,1907.769822\r\n",
"1/25/2021,229.119995,1907.769822\r\n",
"1/26/2021,231.860001,1907.769822\r\n",
"1/27/2021,238.000000,1907.769822\r\n",
"1/28/2021,235.610001,1907.769822\r\n",
"1/29/2021,235.990005,1907.769822\r\n",
"2/1/2021,235.059998,1907.769822\r\n",
"2/2/2021,241.300003,1907.769822\r\n",
"2/3/2021,239.570007,1907.769822\r\n",
"2/4/2021,242.660004,1907.769822\r\n",
"2/5/2021,242.229996,1907.769822\r\n",
"2/8/2021,243.149994,1907.769822\r\n",
"2/9/2021,241.869995,1907.769822\r\n",
"2/10/2021,245.000000,1907.769822\r\n",
"2/11/2021,244.779999,1907.769822\r\n",
"2/12/2021,243.929993,1907.769822\r\n",
"2/16/2021,245.029999,1907.769822\r\n",
"2/17/2021,241.320007,1907.769822\r\n",
"2/18/2021,241.800003,1907.769822\r\n",
"2/19/2021,243.750000,1907.769822\r\n",
"2/22/2021,237.419998,1907.769822\r\n",
"2/23/2021,230.330002,1907.769822\r\n",
"2/24/2021,230.009995,1907.769822\r\n",
"2/25/2021,232.080002,1907.769822\r\n",
"2/26/2021,231.529999,1907.769822\r\n",
"3/1/2021,235.899994,1907.769822\r\n",
"3/2/2021,237.009995,1907.769822\r\n",
"3/3/2021,232.160004,1907.769822\r\n",
"3/4/2021,226.740005,1907.769822\r\n",
"3/5/2021,229.520004,1907.769822\r\n",
"3/8/2021,231.369995,1907.769822\r\n",
"3/9/2021,232.880005,1907.769822\r\n",
"3/10/2021,237.000000,1904.409838\r\n",
"3/11/2021,234.960007,1904.409838\r\n",
"3/12/2021,234.009995,1904.409838\r\n",
"3/15/2021,234.960007,1904.409838\r\n",
"3/16/2021,236.279999,1914.969774\r\n",
"3/17/2021,236.149994,1914.969774\r\n",
"3/18/2021,232.559998,1914.969774\r\n",
"3/19/2021,231.020004,1914.969774\r\n",
"3/22/2021,230.270004,1914.969774\r\n",
"3/23/2021,237.490005,1954.409830\r\n",
"3/24/2021,237.850006,1954.409830\r\n",
"3/25/2021,235.300003,1954.409830\r\n",
"3/26/2021,231.550003,1954.409830\r\n",
"3/29/2021,236.589996,1994.729774\r\n",
"3/30/2021,233.529999,1994.729774\r\n",
"3/31/2021,232.910004,1994.729774\r\n",
"4/1/2021,238.470001,2034.249790\r\n",
"4/5/2021,242.759995,2034.249790\r\n",
"4/6/2021,247.610001,2034.249790\r\n",
"4/7/2021,247.809998,2034.249790\r\n",
"4/8/2021,252.770004,2034.249790\r\n",
"4/9/2021,252.869995,2034.249790\r\n",
"4/12/2021,254.710007,2034.249790\r\n",
"4/13/2021,257.260010,2034.249790\r\n",
"4/14/2021,257.480011,2034.249790\r\n",
"4/15/2021,257.929993,2034.249790\r\n",
"4/16/2021,259.470001,2034.249790\r\n",
"4/19/2021,260.190002,2034.249790\r\n",
"4/20/2021,257.820007,2034.249790\r\n",
"4/21/2021,258.940002,2034.249790\r\n",
"4/22/2021,260.209991,2034.249790\r\n",
"4/23/2021,257.880005,2034.249790\r\n",
"4/26/2021,261.660004,2034.249790\r\n",
"4/27/2021,261.579987,2034.249790\r\n",
"4/28/2021,256.079987,2034.249790\r\n",
"4/29/2021,255.460007,2034.249790\r\n",
"4/30/2021,249.740005,2034.249790\r\n",
"5/3/2021,253.399994,2034.249790\r\n",
"5/4/2021,250.970001,2034.249790\r\n",
"5/5/2021,249.059998,2034.249790\r\n",
"5/6/2021,246.449997,2034.249790\r\n",
"5/7/2021,252.149994,2034.249790\r\n",
"5/10/2021,250.869995,2034.249790\r\n",
"5/11/2021,244.550003,2034.249790\r\n",
"5/12/2021,242.169998,2034.249790\r\n",
"5/13/2021,241.800003,2034.249790\r\n",
"5/14/2021,245.580002,2034.249790\r\n",
"5/17/2021,246.550003,2034.249790\r\n",
"5/18/2021,246.270004,2034.249790\r\n",
"5/19/2021,239.309998,2034.249790\r\n",
"5/20/2021,243.960007,2034.249790\r\n",
"5/21/2021,247.570007,2034.249790\r\n",
"5/24/2021,247.789993,2034.249790\r\n",
"5/25/2021,251.770004,2050.489782\r\n",
"5/26/2021,251.429993,2050.489782\r\n",
"5/27/2021,251.169998,2050.489782\r\n",
"5/28/2021,251.000000,2050.489782\r\n",
"6/1/2021,251.229996,2050.489782\r\n",
"6/2/2021,248.130005,2050.489782\r\n",
"6/3/2021,245.220001,2050.489782\r\n",
"6/4/2021,247.759995,2070.809734\r\n",
"6/7/2021,249.979996,2070.809734\r\n",
"6/8/2021,255.160004,2070.809734\r\n",
"6/9/2021,253.809998,2070.809734\r\n",
"6/10/2021,254.289993,2070.809734\r\n",
"6/11/2021,257.989990,2070.809734\r\n",
"6/14/2021,257.899994,2070.809734\r\n",
"6/15/2021,259.769989,2070.809734\r\n",
"6/16/2021,259.399994,2070.809734\r\n",
"6/17/2021,256.070007,2070.809734\r\n",
"6/18/2021,259.630005,2070.809734\r\n",
"6/21/2021,259.820007,2070.809734\r\n",
"6/22/2021,262.720001,2070.809734\r\n",
"6/23/2021,265.989990,2070.809734\r\n",
"6/24/2021,266.160004,2070.809734\r\n",
"6/25/2021,266.230011,2070.809734\r\n",
"6/28/2021,266.190002,2070.809734\r\n",
"6/29/2021,268.869995,2070.809734\r\n",
"6/30/2021,270.690002,2070.809734\r\n",
"7/1/2021,269.609985,2070.809734\r\n",
"7/2/2021,272.820007,2070.809734\r\n",
"7/6/2021,278.029999,2070.809734\r\n",
"7/7/2021,279.399994,2070.809734\r\n",
"7/8/2021,276.899994,2070.809734\r\n",
"7/9/2021,275.720001,2070.809734\r\n",
"7/12/2021,279.160004,2070.809734\r\n",
"7/13/2021,277.519989,2070.809734\r\n",
"7/14/2021,282.350006,2070.809734\r\n",
"7/15/2021,282.000000,2070.809734\r\n",
"7/16/2021,282.070007,2070.809734\r\n",
"7/19/2021,278.929993,2070.809734\r\n",
"7/20/2021,278.029999,2070.809734\r\n",
"7/21/2021,278.899994,2070.809734\r\n",
"7/22/2021,283.839996,2070.809734\r\n",
"7/23/2021,287.369995,2070.809734\r\n",
"7/26/2021,289.000000,2070.809734\r\n",
"7/27/2021,289.429993,2070.809734\r\n",
"7/28/2021,288.989990,2070.809734\r\n",
"7/29/2021,286.239990,2070.809734\r\n",
"7/30/2021,285.170013,2070.809734\r\n",
"8/2/2021,286.359985,2070.809734\r\n",
"8/3/2021,285.420013,2070.809734\r\n",
"8/4/2021,286.220001,2070.809734\r\n",
"8/5/2021,286.880005,2070.809734\r\n",
"8/6/2021,288.510010,2070.809734\r\n",
"8/9/2021,289.750000,2070.809734\r\n",
"8/10/2021,288.799988,2070.809734\r\n",
"8/11/2021,287.209991,2070.809734\r\n",
"8/12/2021,286.630005,2070.809734\r\n",
"8/13/2021,289.480011,2070.809734\r\n",
"8/16/2021,293.190002,2070.809734\r\n",
"8/17/2021,292.390015,2070.809734\r\n",
"8/18/2021,292.040009,2070.809734\r\n",
"8/19/2021,288.690002,2070.809734\r\n",
"8/20/2021,299.720001,2070.809734\r\n",
"8/23/2021,303.250000,2070.809734\r\n",
"8/24/2021,305.019989,2070.809734\r\n",
"8/25/2021,304.299988,2070.809734\r\n",
"8/26/2021,300.989990,2070.809734\r\n",
"8/27/2021,298.989990,2070.809734\r\n",
"8/30/2021,301.119995,2070.809734\r\n",
"8/31/2021,304.420013,2070.809734\r\n",
"9/1/2021,302.869995,2070.809734\r\n",
"9/2/2021,302.200012,2070.809734\r\n",
"9/3/2021,300.989990,2070.809734\r\n",
"9/7/2021,301.010010,2070.809734\r\n",
"9/8/2021,299.779999,2070.809734\r\n",
"9/9/2021,300.820007,2070.809734\r\n",
"9/10/2021,298.420013,2070.809734\r\n",
"9/13/2021,297.549988,2070.809734\r\n",
"9/14/2021,299.559998,2070.809734\r\n",
"9/15/2021,303.260010,2099.849716\r\n",
"9/16/2021,303.760010,2099.849716\r\n",
"9/17/2021,304.170013,2099.849716\r\n",
"9/20/2021,296.329987,2099.849716\r\n",
"9/21/2021,295.690002,2099.849716\r\n",
"9/22/2021,296.730011,2099.849716\r\n",
"9/23/2021,298.850006,2099.849716\r\n",
"9/24/2021,298.230011,2099.849716\r\n",
"9/27/2021,296.140015,2099.849716\r\n",
"9/28/2021,289.799988,2099.849716\r\n",
"9/29/2021,285.100006,2099.849716\r\n",
"9/30/2021,285.709991,2099.849716\r\n",
"10/1/2021,282.119995,2099.849716\r\n",
"10/4/2021,287.399994,2099.849716\r\n",
"10/5/2021,284.049988,2099.849716\r\n",
"10/6/2021,285.779999,2099.849716\r\n",
"10/7/2021,295.179993,2091.799758\r\n",
"10/8/2021,296.220001,2091.799758\r\n",
"10/11/2021,292.920013,2091.799758\r\n",
"10/12/2021,295.339996,2108.739639\r\n",
"10/13/2021,294.910004,2108.739639\r\n",
"10/14/2021,299.209991,2108.739639\r\n",
"10/15/2021,302.339996,2108.739639\r\n",
"10/18/2021,303.570007,2108.739639\r\n",
"10/19/2021,308.350006,2108.739639\r\n",
"10/20/2021,309.209991,2108.739639\r\n",
"10/21/2021,307.170013,2108.739639\r\n",
"10/22/2021,310.399994,2108.739639\r\n",
"10/25/2021,309.359985,2108.739639\r\n",
"10/26/2021,311.000000,2108.739639\r\n",
"10/27/2021,316.000000,2108.739639\r\n",
"10/28/2021,324.329987,2108.739639\r\n",
"10/29/2021,324.130005,2108.739639\r\n",
"11/1/2021,331.359985,2108.739639\r\n",
"11/2/2021,330.309998,2108.739639\r\n",
"11/3/2021,333.899994,2108.739639\r\n",
"11/4/2021,332.890015,2108.739639\r\n",
"11/5/2021,338.510010,2108.739639\r\n",
"11/8/2021,337.299988,2108.739639\r\n",
"11/9/2021,337.109985,2108.739639\r\n",
"11/10/2021,334.570007,2108.739639\r\n",
"11/11/2021,331.250000,2108.739639\r\n",
"11/12/2021,333.920013,2108.739639\r\n",
"11/15/2021,337.540009,2108.739639\r\n",
"11/16/2021,335.679993,2108.739639\r\n",
"11/17/2021,338.940002,2108.739639\r\n",
"11/18/2021,338.179993,2108.739639\r\n",
"11/19/2021,342.640015,2108.739639\r\n",
"11/22/2021,344.619995,2108.739639\r\n",
"11/23/2021,337.049988,2108.739639\r\n",
"11/24/2021,336.279999,2108.739639\r\n",
"11/26/2021,334.350006,2108.739639\r\n",
"11/29/2021,334.940002,2108.739639\r\n",
"11/30/2021,335.320007,2108.739639\r\n",
"12/1/2021,335.130005,2108.739639\r\n",
"12/2/2021,330.299988,2108.739639\r\n",
"12/3/2021,331.989990,2108.739639\r\n",
"12/6/2021,323.950012,2108.739639\r\n",
"12/7/2021,331.640015,2108.739639\r\n",
"12/8/2021,335.309998,2114.499591\r\n",
"12/9/2021,334.410004,2114.499591\r\n",
"12/10/2021,334.980011,2114.499591\r\n",
"12/13/2021,340.679993,2152.119525\r\n",
"12/14/2021,333.220001,2152.119525\r\n",
"12/15/2021,328.609985,2152.119525\r\n",
"12/16/2021,335.709991,2167.059465\r\n",
"12/17/2021,320.880005,2167.059465\r\n",
"12/20/2021,320.049988,2167.059465\r\n",
"12/21/2021,323.290009,2167.059465\r\n",
"12/22/2021,328.299988,2167.059465\r\n",
"12/23/2021,332.750000,2238.279435\r\n",
"12/27/2021,335.459991,2238.279435\r\n",
"12/28/2021,343.149994,2238.279435\r\n",
"12/29/2021,341.299988,2238.279435\r\n",
"12/30/2021,341.910004,2238.279435\r\n",
"12/31/2021,338.510010,2238.279435\r\n",
"1/3/2022,335.350006,2238.279435\r\n",
"1/4/2022,334.829987,2238.279435\r\n",
"1/5/2022,325.859985,2238.279435\r\n",
"1/6/2022,313.149994,2238.279435\r\n",
"1/7/2022,314.149994,2238.279435\r\n",
"1/10/2022,309.489990,2238.279435\r\n",
"1/11/2022,313.380005,2238.279435\r\n",
"1/12/2022,319.670013,2238.279435\r\n",
"1/13/2022,320.470001,2238.279435\r\n",
"1/14/2022,304.250000,2238.279435\r\n",
"1/18/2022,304.070007,2238.279435\r\n",
"1/19/2022,306.290009,2238.279435\r\n",
"1/20/2022,309.070007,2238.279435\r\n",
"1/21/2022,302.690002,2238.279435\r\n",
"1/24/2022,292.200012,2238.279435\r\n",
"1/25/2022,291.519989,2238.279435\r\n",
"1/26/2022,307.989990,2238.279435\r\n",
"1/27/2022,302.660004,2238.279435\r\n",
"1/28/2022,300.230011,2238.279435\r\n",
"1/31/2022,308.950012,2238.279435\r\n",
"2/1/2022,310.410004,2145.579549\r\n",
"2/2/2022,309.630005,2145.579549\r\n",
"2/3/2022,309.489990,2145.579549\r\n",
"2/4/2022,300.209991,2145.579549\r\n",
"2/7/2022,306.170013,2145.579549\r\n",
"2/8/2022,301.250000,2145.579549\r\n",
"2/9/2022,309.869995,2213.199577\r\n",
"2/10/2022,304.040009,2213.199577\r\n",
"2/11/2022,303.190002,2213.199577\r\n",
"2/14/2022,293.769989,2213.199577\r\n",
"2/15/2022,300.010010,2213.199577\r\n",
"2/16/2022,298.369995,2213.199577\r\n",
"2/17/2022,296.359985,2213.199577\r\n",
"2/18/2022,293.049988,2213.199577\r\n",
"2/22/2022,285.000000,2213.199577\r\n",
"2/23/2022,290.179993,2213.199577\r\n",
"2/24/2022,272.510010,2213.199577\r\n",
"2/25/2022,295.140015,2213.199577\r\n",
"2/28/2022,294.309998,2213.199577\r\n",
"3/1/2022,296.399994,2213.199577\r\n",
"3/2/2022,295.359985,2213.199577\r\n",
"3/3/2022,302.890015,2205.149619\r\n",
"3/4/2022,294.290009,2205.149619\r\n",
"3/7/2022,288.529999,2205.149619\r\n",
"3/8/2022,277.799988,2205.149619\r\n",
"3/9/2022,283.440002,2205.149619\r\n",
"3/10/2022,283.019989,2205.149619\r\n",
"3/11/2022,287.959991,2205.149619\r\n",
"3/14/2022,280.339996,2205.149619\r\n",
"3/15/2022,280.350006,2205.149619\r\n",
"3/16/2022,289.109985,2205.149619\r\n",
"3/17/2022,293.290009,2198.149619\r\n",
"3/18/2022,295.369995,2198.149619\r\n",
"3/21/2022,298.890015,2198.149619\r\n",
"3/22/2022,299.799988,2198.149619\r\n",
"3/23/2022,300.510010,2198.149619\r\n",
"3/24/2022,299.140015,2198.149619\r\n",
"3/25/2022,305.230011,2198.149619\r\n",
"3/28/2022,304.329987,2198.149619\r\n",
"3/29/2022,313.910004,2198.149619\r\n",
"3/30/2022,313.760010,2198.149619\r\n",
"3/31/2022,313.899994,2198.149619\r\n",
"4/1/2022,309.369995,2198.149619\r\n",
"4/4/2022,310.089996,2198.149619\r\n",
"4/5/2022,313.269989,2198.149619\r\n",
"4/6/2022,305.190002,2198.149619\r\n",
"4/7/2022,296.660004,2198.149619\r\n",
"4/8/2022,300.440002,2198.149619\r\n",
"4/11/2022,291.790009,2198.149619\r\n",
"4/12/2022,289.239990,2198.149619\r\n",
"4/13/2022,282.730011,2198.149619\r\n",
"4/14/2022,288.089996,2198.149619\r\n",
"4/18/2022,278.910004,2198.149619\r\n",
"4/19/2022,279.380005,2198.149619\r\n",
"4/20/2022,289.399994,2198.149619\r\n",
"4/21/2022,288.579987,2198.149619\r\n",
"4/22/2022,281.679993,2198.149619\r\n",
"4/25/2022,273.290009,2198.149619\r\n",
"4/26/2022,277.500000,2198.149619\r\n",
"4/27/2022,282.100006,2198.149619\r\n",
"4/28/2022,285.190002,2198.149619\r\n",
"4/29/2022,288.609985,2198.149619\r\n",
"5/2/2022,277.709991,2198.149619\r\n",
"5/3/2022,283.959991,2198.149619\r\n",
"5/4/2022,282.589996,2198.149619\r\n",
"5/5/2022,285.540009,2120.309654\r\n",
"5/6/2022,274.809998,2120.309654\r\n",
"5/9/2022,270.059998,2120.309654\r\n",
"5/10/2022,271.690002,2120.309654\r\n",
"5/11/2022,265.679993,2120.309654\r\n",
"5/12/2022,257.690002,2120.309654\r\n",
"5/13/2022,257.350006,2120.309654\r\n",
"5/16/2022,259.959991,2120.309654\r\n",
"5/17/2022,266.109985,2120.309654\r\n",
"5/18/2022,263.000000,2120.309654\r\n",
"5/19/2022,253.899994,2120.309654\r\n",
"5/20/2022,257.239990,2120.309654\r\n",
"5/23/2022,255.490005,2120.309654\r\n",
"5/24/2022,257.890015,2120.309654\r\n",
"5/25/2022,258.140015,2120.309654\r\n",
"5/26/2022,262.269989,2120.309654\r\n",
"5/27/2022,268.480011,2075.999745\r\n",
"5/31/2022,272.529999,2075.999745\r\n",
"6/1/2022,275.200012,2075.999745\r\n",
"6/2/2022,264.450012,2075.999745\r\n",
"6/3/2022,270.309998,2117.019647\r\n",
"6/6/2022,272.059998,2117.019647\r\n",
"6/7/2022,266.640015,2117.019647\r\n",
"6/8/2022,271.709991,2117.019647\r\n",
"6/9/2022,267.779999,2117.019647\r\n",
"6/10/2022,260.579987,2117.019647\r\n",
"6/13/2022,245.110001,2117.019647\r\n",
"6/14/2022,243.860001,2117.019647\r\n",
"6/15/2022,248.309998,2117.019647\r\n",
"6/16/2022,245.979996,2117.019647\r\n",
"6/17/2022,244.699997,2117.019647\r\n",
"6/21/2022,250.259995,2117.019647\r\n",
"6/22/2022,251.889999,2117.019647\r\n",
"6/23/2022,255.570007,2117.019647\r\n",
"6/24/2022,261.809998,2126.859735\r\n",
"6/27/2022,268.209991,2126.859735\r\n",
"6/28/2022,263.980011,2126.859735\r\n",
"6/29/2022,257.589996,2126.859735\r\n",
"6/30/2022,257.049988,2126.859735\r\n",
"7/1/2022,256.390015,2126.859735\r\n",
"7/5/2022,256.160004,2126.859735\r\n",
"7/6/2022,263.750000,2176.139767\r\n",
"7/7/2022,265.119995,2176.139767\r\n",
"7/8/2022,264.790009,2176.139767\r\n",
"7/11/2022,265.649994,2176.139767\r\n",
"7/12/2022,265.880005,2176.139767\r\n",
"7/13/2022,250.190002,2176.139767\r\n",
"7/14/2022,250.570007,2176.139767\r\n",
"7/15/2022,255.720001,2176.139767\r\n",
"7/18/2022,259.750000,2252.619751\r\n",
"7/19/2022,257.579987,2252.619751\r\n",
"7/20/2022,259.899994,2271.179807\r\n",
"7/21/2022,259.790009,2271.179807\r\n",
"7/22/2022,265.239990,2271.179807\r\n",
"7/25/2022,261.000000,2271.179807\r\n",
"7/26/2022,259.859985,2271.179807\r\n",
"7/27/2022,261.160004,2271.179807\r\n",
"7/28/2022,269.750000,2271.179807\r\n",
"7/29/2022,277.700012,2271.179807\r\n",
"8/1/2022,277.820007,2271.179807\r\n",
"8/2/2022,276.000000,2271.179807\r\n",
"8/3/2022,276.760010,2271.179807\r\n",
"8/4/2022,281.799988,2271.179807\r\n",
"8/5/2022,279.149994,2271.179807\r\n",
"8/8/2022,284.049988,2271.179807\r\n",
"8/9/2022,279.640015,2271.179807\r\n",
"8/10/2022,288.170013,2271.179807\r\n",
"8/11/2022,290.850006,2271.179807\r\n",
"8/12/2022,288.480011,2271.179807\r\n",
"8/15/2022,291.000000,2271.179807\r\n",
"8/16/2022,291.989990,2271.179807\r\n",
"8/17/2022,289.739990,2271.179807\r\n",
"8/18/2022,290.190002,2271.179807\r\n",
"8/19/2022,288.899994,2271.179807\r\n",
"8/22/2022,282.079987,2271.179807\r\n",
"8/23/2022,276.440002,2271.179807\r\n",
"8/24/2022,275.410004,2271.179807\r\n",
"8/25/2022,277.329987,2271.179807\r\n",
"8/26/2022,279.079987,2271.179807\r\n",
"8/29/2022,265.850006,2271.179807\r\n",
"8/30/2022,266.670013,2271.179807\r\n",
"8/31/2022,265.390015,2271.179807\r\n",
"9/1/2022,258.869995,2271.179807\r\n",
"9/2/2022,261.700012,2271.179807\r\n",
"9/6/2022,256.200012,2271.179807\r\n",
"9/7/2022,254.699997,2271.179807\r\n",
"9/8/2022,257.510010,2271.179807\r\n",
"9/9/2022,260.500000,2271.179807\r\n",
"9/12/2022,265.779999,2271.179807\r\n",
"9/13/2022,258.839996,2271.179807\r\n",
"9/14/2022,253.529999,2271.179807\r\n",
"9/15/2022,249.770004,2271.179807\r\n",
"9/16/2022,244.259995,2271.179807\r\n",
"9/19/2022,242.470001,2271.179807\r\n",
"9/20/2022,242.070007,2271.179807\r\n",
"9/21/2022,244.270004,2271.179807\r\n",
"9/22/2022,237.869995,2271.179807\r\n",
"9/23/2022,239.539993,2271.179807\r\n",
"9/26/2022,237.050003,2271.179807\r\n",
"9/27/2022,239.979996,2271.179807\r\n",
"9/28/2022,236.809998,2271.179807\r\n",
"9/29/2022,238.889999,2271.179807\r\n",
"9/30/2022,238.289993,2271.179807\r\n",
"10/3/2022,235.410004,2271.179807\r\n",
"10/4/2022,245.089996,2271.179807\r\n",
"10/5/2022,245.990005,2027.579831\r\n",
"10/6/2022,247.929993,2027.579831\r\n",
"10/7/2022,240.899994,2027.579831\r\n",
"10/10/2022,233.050003,2027.579831\r\n",
"10/11/2022,227.619995,2027.579831\r\n",
"10/12/2022,225.399994,2027.579831\r\n",
"10/13/2022,219.850006,2027.579831\r\n",
"10/14/2022,235.539993,2027.579831\r\n",
"10/17/2022,235.820007,2027.579831\r\n",
"10/18/2022,243.240005,2046.299919\r\n",
"10/19/2022,237.039993,2046.299919\r\n",
"10/20/2022,235.770004,2046.299919\r\n",
"10/21/2022,234.740005,2046.299919\r\n",
"10/24/2022,243.759995,2100.059935\r\n",
"10/25/2022,247.259995,2100.059935\r\n",
"10/26/2022,231.169998,2100.059935\r\n",
"10/27/2022,231.039993,2100.059935\r\n",
"10/28/2022,226.240005,2100.059935\r\n",
"10/31/2022,233.759995,2100.059935\r\n",
"11/1/2022,234.600006,2100.059935\r\n",
"11/2/2022,229.460007,2100.059935\r\n",
"11/3/2022,220.089996,2100.059935\r\n",
"11/4/2022,217.550003,2100.059935\r\n",
"11/7/2022,221.990005,2100.059935\r\n",
"11/8/2022,228.699997,2100.059935\r\n",
"11/9/2022,227.369995,2100.059935\r\n",
"11/10/2022,235.429993,2138.399890\r\n",
"11/11/2022,242.990005,2138.399890\r\n",
"11/14/2022,241.990005,2138.399890\r\n",
"11/15/2022,245.660004,2138.399890\r\n",
"11/16/2022,242.789993,2138.399890\r\n",
"11/17/2022,237.779999,2138.399890\r\n",
"11/18/2022,243.509995,2138.399890\r\n",
"11/21/2022,241.429993,2138.399890\r\n",
"11/22/2022,243.589996,2138.399890\r\n",
"11/23/2022,245.110001,2138.399890\r\n",
"11/25/2022,247.309998,2138.399890\r\n",
"11/28/2022,246.080002,2138.399890\r\n",
"11/29/2022,241.399994,2138.399890\r\n",
"11/30/2022,240.570007,2138.399890\r\n",
"12/1/2022,253.869995,2138.399890\r\n",
"12/2/2022,249.820007,2138.399890\r\n",
"12/5/2022,252.009995,2138.399890\r\n",
"12/6/2022,250.820007,2138.399890\r\n",
"12/7/2022,244.830002,2138.399890\r\n",
"12/8/2022,244.839996,2138.399890\r\n",
"12/9/2022,244.699997,2138.399890\r\n",
"12/12/2022,247.449997,2160.399890\r\n",
"12/13/2022,261.690002,2160.399890\r\n",
"12/14/2022,257.130005,2160.399890\r\n",
"12/15/2022,253.720001,2160.399890\r\n",
"12/16/2022,248.550003,2160.399890\r\n",
"12/19/2022,244.860001,2160.399890\r\n",
"12/20/2022,239.399994,2160.399890\r\n",
"12/21/2022,241.690002,2160.399890\r\n",
"12/22/2022,241.259995,2160.399890\r\n",
"12/23/2022,236.110001,2160.399890\r\n",
"12/27/2022,238.699997,2160.399890\r\n",
"12/28/2022,236.889999,2160.399890\r\n",
"12/29/2022,235.649994,2160.399890\r\n",
"12/30/2022,238.210007,2160.399890\r\n",
"1/3/2023,243.080002,2160.399890\r\n",
"1/4/2023,232.279999,2160.399890\r\n",
"1/5/2023,227.199997,2160.399890\r\n",
"1/6/2023,223.000000,2160.399890\r\n",
"1/9/2023,226.449997,2160.399890\r\n",
"1/10/2023,227.759995,2160.399890\r\n",
"1/11/2023,231.289993,2160.399890\r\n",
"1/12/2023,235.259995,2160.399890\r\n",
"1/13/2023,237.000000,2097.519882\r\n",
"1/17/2023,237.970001,2097.519882\r\n",
"1/18/2023,241.570007,2097.519882\r\n",
"1/19/2023,233.779999,2097.519882\r\n",
"1/20/2023,234.860001,2097.519882\r\n",
"1/23/2023,241.100006,2156.079938\r\n",
"1/24/2023,242.500000,2156.079938\r\n",
"1/25/2023,234.479996,2156.079938\r\n",
"1/26/2023,243.649994,2238.609920\r\n",
"1/27/2023,248.990005,2238.609920\r\n",
"1/30/2023,244.509995,2238.609920\r\n",
"1/31/2023,243.449997,2238.609920\r\n",
"2/1/2023,248.000000,2238.609920\r\n",
"2/2/2023,258.820007,2238.609920\r\n",
"2/3/2023,259.540009,2238.609920\r\n",
"2/6/2023,257.440002,2238.609920\r\n",
"2/7/2023,260.529999,2238.609920\r\n",
"2/8/2023,273.200012,2238.609920\r\n",
"2/9/2023,273.799988,2238.609920\r\n",
"2/10/2023,261.529999,2238.609920\r\n",
"2/13/2023,267.640015,2238.609920\r\n",
"2/14/2023,272.670013,2238.609920\r\n",
"2/15/2023,268.320007,2238.609920\r\n",
"2/16/2023,264.019989,2238.609920\r\n",
"2/17/2023,259.390015,2238.609920\r\n",
"2/21/2023,254.479996,2238.609920\r\n",
"2/22/2023,254.089996,2238.609920\r\n",
"2/23/2023,255.559998,2238.609920\r\n",
"2/24/2023,249.960007,2238.609920\r\n",
"2/27/2023,252.460007,2238.609920\r\n",
"2/28/2023,249.070007,2238.609920\r\n",
"3/1/2023,250.759995,2238.609920\r\n",
"3/2/2023,246.550003,2238.609920\r\n",
"3/3/2023,252.190002,2238.609920\r\n",
"3/6/2023,256.429993,2238.609920\r\n",
"3/7/2023,256.299988,2238.609920\r\n",
"3/8/2023,254.039993,2238.609920\r\n",
"3/9/2023,255.820007,2238.609920\r\n",
"3/10/2023,251.080002,2238.609920\r\n",
"3/13/2023,247.399994,2238.609920\r\n",
"3/14/2023,256.750000,2256.769952\r\n",
"3/15/2023,259.980011,2256.769952\r\n",
"3/16/2023,265.209991,2256.769952\r\n",
"3/17/2023,278.260010,2256.769952\r\n",
"3/20/2023,276.980011,2256.769952\r\n",
"3/21/2023,274.880005,2256.769952\r\n",
"3/22/2023,273.399994,2256.769952\r\n",
"3/23/2023,277.940002,2256.769952\r\n",
"3/24/2023,277.239990,2256.769952\r\n",
"3/27/2023,280.500000,2256.769952\r\n",
"3/28/2023,275.790009,2256.769952\r\n",
"3/29/2023,278.959991,2256.769952\r\n",
"3/30/2023,284.230011,2256.769952\r\n",
"3/31/2023,283.730011,2256.769952\r\n",
"4/3/2023,286.519989,2256.769952\r\n",
"4/4/2023,287.230011,2256.769952\r\n",
"4/5/2023,285.850006,2256.769952\r\n",
"4/6/2023,283.209991,2256.769952\r\n",
"4/10/2023,289.209991,2256.769952\r\n",
"4/11/2023,285.750000,2256.769952\r\n",
"4/12/2023,284.790009,2256.769952\r\n",
"4/13/2023,283.589996,2256.769952\r\n",
"4/14/2023,287.000000,2256.769952\r\n",
"4/17/2023,289.929993,2256.769952\r\n",
"4/18/2023,291.570007,2256.769952\r\n",
"4/19/2023,285.989990,2256.769952\r\n",
"4/20/2023,285.250000,2256.769952\r\n",
"4/21/2023,285.010010,2256.769952\r\n",
"4/24/2023,282.089996,2256.769952\r\n",
"4/25/2023,279.510010,2256.769952\r\n",
"4/26/2023,296.700012,2373.650080\r\n",
"4/27/2023,295.970001,2373.650080\r\n",
"4/28/2023,304.010010,2373.650080\r\n",
"5/1/2023,306.970001,2373.650080\r\n",
"5/2/2023,307.760010,2373.650080\r\n",
"5/3/2023,306.619995,2373.650080\r\n",
"5/4/2023,306.239990,2373.650080\r\n",
"5/5/2023,305.720001,2373.650080\r\n",
"5/8/2023,310.130005,2373.650080\r\n",
"5/9/2023,308.000000,2373.650080\r\n",
"5/10/2023,308.619995,2373.650080\r\n",
"5/11/2023,310.100006,2373.650080\r\n",
"5/12/2023,310.549988,2373.650080\r\n",
"5/15/2023,309.100006,2373.650080\r\n",
"5/16/2023,309.829987,2373.650080\r\n",
"5/17/2023,312.290009,2373.650080\r\n",
"5/18/2023,314.529999,2373.650080\r\n",
"5/19/2023,316.739990,2373.650080\r\n",
"5/22/2023,318.600006,2373.650080\r\n",
"5/23/2023,320.029999,2373.650080\r\n",
"5/24/2023,314.730011,2373.650080\r\n",
"5/25/2023,323.239990,2373.650080\r\n",
"5/26/2023,324.019989,2373.650080\r\n",
"5/30/2023,335.230011,2373.650080\r\n",
"5/31/2023,332.290009,2373.650080\r\n",
"6/1/2023,325.929993,2373.650080\r\n",
"6/2/2023,334.250000,2373.650080\r\n",
"6/5/2023,335.220001,2373.650080\r\n",
"6/6/2023,335.329987,2373.650080\r\n",
"6/7/2023,331.649994,2373.650080\r\n",
"6/8/2023,323.940002,2373.650080\r\n",
"6/9/2023,324.989990,2373.650080\r\n",
"6/12/2023,328.579987,2373.650080\r\n",
"6/13/2023,334.470001,2373.650080\r\n",
"6/14/2023,334.339996,2373.650080\r\n",
"6/15/2023,337.480011,2373.650080\r\n",
"6/16/2023,351.320007,2373.650080\r\n",
"6/20/2023,339.309998,2373.650080\r\n",
"6/21/2023,336.369995,2373.650080\r\n",
"6/22/2023,334.119995,2373.650080\r\n",
"6/23/2023,334.359985,2373.650080\r\n",
"6/26/2023,333.720001,2373.650080\r\n",
"6/27/2023,331.859985,2373.650080\r\n",
"6/28/2023,334.660004,2393.250213\r\n",
"6/29/2023,334.709991,2393.250213\r\n",
"6/30/2023,337.750000,2393.250213\r\n",
"7/3/2023,339.190002,2393.250213\r\n",
"7/5/2023,335.089996,2393.250213\r\n",
"7/6/2023,337.299988,2393.250213\r\n",
"7/7/2023,339.320007,2393.250213\r\n",
"7/10/2023,334.600006,2393.250213\r\n",
"7/11/2023,331.059998,2393.250213\r\n",
"7/12/2023,336.600006,2407.250213\r\n",
"7/13/2023,339.559998,2407.250213\r\n",
"7/14/2023,347.589996,2407.250213\r\n",
"7/17/2023,345.679993,2407.250213\r\n",
"7/18/2023,345.829987,2407.250213\r\n",
"7/19/2023,361.750000,2407.250213\r\n",
"7/20/2023,353.570007,2407.250213\r\n",
"7/21/2023,349.149994,2407.250213\r\n",
"7/24/2023,345.850006,2407.250213\r\n",
"7/25/2023,347.109985,2407.250213\r\n",
"7/26/2023,341.440002,2407.250213\r\n",
"7/27/2023,340.480011,2407.250213\r\n",
"7/28/2023,333.670013,2407.250213\r\n",
"7/31/2023,336.920013,2407.250213\r\n",
"8/1/2023,335.190002,2407.250213\r\n",
"8/2/2023,333.630005,2407.250213\r\n",
"8/3/2023,326.000000,2407.250213\r\n",
"8/4/2023,331.880005,2407.250213\r\n",
"8/7/2023,328.369995,2407.250213\r\n",
"8/8/2023,326.959991,2407.250213\r\n",
"8/9/2023,326.470001,2407.250213\r\n",
"8/10/2023,326.019989,2407.250213\r\n",
"8/11/2023,320.260010,2407.250213\r\n",
"8/14/2023,321.390015,2407.250213\r\n",
"8/15/2023,323.000000,2407.250213\r\n",
"8/16/2023,320.799988,2407.250213\r\n",
"8/17/2023,320.540009,2407.250213\r\n",
"8/18/2023,314.489990,2407.250213\r\n",
"8/21/2023,317.929993,2407.250213\r\n",
"8/22/2023,325.500000,2407.250213\r\n",
"8/23/2023,323.820007,2407.250213\r\n",
"8/24/2023,332.850006,2347.120241\r\n",
"8/25/2023,321.470001,2347.120241\r\n",
"8/28/2023,325.660004,2376.450262\r\n",
"8/29/2023,321.880005,2376.450262\r\n",
"8/30/2023,328.670013,2423.980318\r\n",
"8/31/2023,329.200012,2423.980318\r\n",
"9/1/2023,331.309998,2423.980318\r\n",
"9/5/2023,329.000000,2423.980318\r\n",
"9/6/2023,333.380005,2423.980318\r\n",
"9/7/2023,331.290009,2423.980318\r\n",
"9/8/2023,330.089996,2423.980318\r\n",
"9/11/2023,337.239990,2423.980318\r\n",
"9/12/2023,335.820007,2423.980318\r\n",
"9/13/2023,331.309998,2423.980318\r\n",
"9/14/2023,339.149994,2423.980318\r\n",
"9/15/2023,336.920013,2423.980318\r\n",
"9/18/2023,327.799988,2423.980318\r\n",
"9/19/2023,326.170013,2423.980318\r\n",
"9/20/2023,329.510010,2423.980318\r\n",
"9/21/2023,319.260010,2423.980318\r\n",
"9/22/2023,321.320007,2423.980318\r\n",
"9/25/2023,316.589996,2423.980318\r\n",
"9/26/2023,315.130005,2423.980318\r\n",
"9/27/2023,312.299988,2423.980318\r\n",
"9/28/2023,310.989990,2423.980318\r\n",
"9/29/2023,317.750000,2423.980318\r\n"
],
"text/html": [
"<table><thead><tr><td><span>Date</span></td><td><span>Price</span></td><td><span>Balance</span></td></tr></thead><tbody><tr><td><time datetime=\"2018-11-05\">Nov 05, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.370003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1000</pre></div></td></tr><tr><td><time datetime=\"2018-11-06\">Nov 06, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.379997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1000</pre></div></td></tr><tr><td><time datetime=\"2018-11-07\">Nov 07, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.440002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-08\">Nov 08, 2018</time></td><td><div class=\"dni-plaintext\"><pre>111.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-09\">Nov 09, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.849998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-12\">Nov 12, 2018</time></td><td><div class=\"dni-plaintext\"><pre>109.419998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-13\">Nov 13, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.550003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1033.750000</pre></div></td></tr><tr><td><time datetime=\"2018-11-14\">Nov 14, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.099998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-15\">Nov 15, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.989998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-16\">Nov 16, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.080002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1038.699955</pre></div></td></tr><tr><td><time datetime=\"2018-11-19\">Nov 19, 2018</time></td><td><div class=\"dni-plaintext\"><pre>108.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-20\">Nov 20, 2018</time></td><td><div class=\"dni-plaintext\"><pre>101.800003</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-21\">Nov 21, 2018</time></td><td><div class=\"dni-plaintext\"><pre>103.599998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-23\">Nov 23, 2018</time></td><td><div class=\"dni-plaintext\"><pre>102.169998</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-26\">Nov 26, 2018</time></td><td><div class=\"dni-plaintext\"><pre>104.790001</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-27\">Nov 27, 2018</time></td><td><div class=\"dni-plaintext\"><pre>106.269997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1068.219946</pre></div></td></tr><tr><td><time datetime=\"2018-11-28\">Nov 28, 2018</time></td><td><div class=\"dni-plaintext\"><pre>107.889999</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-11-29\">Nov 29, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.330002</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-11-30\">Nov 30, 2018</time></td><td><div class=\"dni-plaintext\"><pre>110.699997</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td><time datetime=\"2018-12-03\">Dec 03, 2018</time></td><td><div class=\"dni-plaintext\"><pre>113.000000</pre></div></td><td><div class=\"dni-plaintext\"><pre>1129.119906</pre></div></td></tr><tr><td colspan=\"3\"><i>(1213 more)</i></td></tr></tbody></table><style>\r\n",
".dni-code-hint {\r\n",
" font-style: italic;\r\n",
" overflow: hidden;\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview {\r\n",
" white-space: nowrap;\r\n",
"}\r\n",
".dni-treeview td {\r\n",
" vertical-align: top;\r\n",
" text-align: start;\r\n",
"}\r\n",
"details.dni-treeview {\r\n",
" padding-left: 1em;\r\n",
"}\r\n",
"table td {\r\n",
" text-align: start;\r\n",
"}\r\n",
"table tr { \r\n",
" vertical-align: top; \r\n",
" margin: 0em 0px;\r\n",
"}\r\n",
"table tr td pre \r\n",
"{ \r\n",
" vertical-align: top !important; \r\n",
" margin: 0em 0px !important;\r\n",
"} \r\n",
"table th {\r\n",
" text-align: start;\r\n",
"}\r\n",
"</style>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"var filled =\n",
" from e in\n",
" merged.Prepend(new { Date = DateOnly.MinValue,\n",
" Price = 0m,\n",
" Balance = (decimal?)initialBalance })\n",
" .FillForward(e => e.Balance is null,\n",
" (e, f) => new { e.Date, e.Price, Balance = e.Balance ?? f.Balance })\n",
" .Skip(1) // skip the initial balance bootstrapping row\n",
" select new\n",
" {\n",
" e.Date,\n",
" e.Price,\n",
" Balance = (decimal)e.Balance, // never null anymore so safe to cast to a decimal!\n",
" };\n",
"\n",
"filled.Lead(2, (curr, peek) => (Current: curr, Peek: peek))\n",
" .SkipWhile(e => e is (_, { Balance: var b }) && b == initialBalance)\n",
" .Select(e => e.Current)\n",
" .ToTabularDataResource()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"And that's it! Now we have two continuous and aligned time series of the price action and our strategy's performance so let's plot them together to see the evolution over time:"
]
},
{
"cell_type": "code",
"execution_count": 135,
"metadata": {
"dotnet_interactive": {
"language": "csharp"
},
"polyglot_notebook": {
"kernelName": "csharp"
},
"vscode": {
"languageId": "polyglot-notebook"
}
},
"outputs": [
{
"data": {
"text/html": [
"<img src=\"\"></img>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"if (isWindows)\n",
"{\n",
" var plot = new Plot(1000, 400);\n",
" plot.XAxis.DateTimeFormat(true);\n",
" plot.YAxis.Label(\"Price\");\n",
" plot.YAxis2.Label(\"Balance\");\n",
" plot.YAxis2.Ticks(true);\n",
"\n",
" plot.AddScatter(data.Select(e => e.Date.ToOADate()).ToArray(),\n",
" data.Select(e => (double)e.Price).ToArray(),\n",
" markerShape: MarkerShape.none);\n",
"\n",
" plot.AddScatter(mavg.Select(e => e.Date.ToOADate()).ToArray(),\n",
" mavg.Select(e => (double)e.Avg).ToArray(),\n",
" markerShape: MarkerShape.none);\n",
"\n",
" plot.AddScatter(filled.Select(e => e.Date.ToOADate()).ToArray(),\n",
" filled.Select(e => (double)e.Balance).ToArray(),\n",
" markerShape: MarkerShape.none)\n",
" .YAxisIndex = 1;\n",
"\n",
" plot.Display();\n",
"}"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Hope you enjoyed this tutorial and that it provided you with some valuable insights into the kind of operations and extensions that [MoreLINQ] has to offer. If you want to learn more, [Mark Heath] has an [awesome series of videos][mh-intro-series] and [blog entries][mh-blog-series] on some of the MoreLINQ operators discussed here and many more!\n",
"\n",
"Happy LINQ-ing!\n",
"\n",
"[MoreLINQ]: https://morelinq.github.io/\n",
"[Mark Heath]: https://markheath.net/\n",
"[mh-intro-series]: https://morelinq.github.io/#intro-series\n",
"[mh-blog-series]: https://markheath.net/category/MoreLINQ"
]
}
],
"metadata": {
"language_info": {
"name": "csharp"
}
},
"nbformat": 4,
"nbformat_minor": 2
}
@atifaziz
Copy link
Author

If you enjoyed this, give it (and MoreLINQ) a star! ⭐

@antonburger-alcove
Copy link

antonburger-alcove commented Dec 29, 2023

This was a great demo, thanks for taking the time to put it together! Especially for some of the more esoteric MoreLINQ operators (had never really considered Lead or FillForward, but seeing how they're used here makes me realise they fit some scenarios I've seen before), but also for things like ToTabularDataResource, and formatting and plotting in notebooks - really good stuff.

@atifaziz
Copy link
Author

This was a great demo, thanks for taking the time to put it together! Especially for some of the more esoteric MoreLINQ operators (had never really considered Lead or FillForward, but seeing how they're used here makes me realise they fit some scenarios I've seen before), but also for things like ToTabularDataResource, and formatting and plotting in notebooks - really good stuff.

@antonburger-alcove Thanks for taking the time to write the comment! Made my day to know it helped in the way it was intended.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment