About

This worksheet is your warm-up exercises to getting started with some R for finance, based on examples from the book. It is also your getting started with problems solving (no R required) and expressing your methods/answers using proper mathematical symbols and representations.

Setup

Remember to always set your working directory to the source file location. Go to ‘Session’, scroll down to ‘Set Working Directory’, and click ‘To Source File Location’. Read carefully the below and follow the instructions to complete the tasks and answer any questions. Submit your work to RPubs as detailed in previous notes.

Note

For clarity, tasks/questions to be completed/answered are highlighted in red color (color visible only in preview mode) and numbered according to their particular placement in the task section. Type your answers outside the red color tags!

Quite often you will need to add your own code chunk. Execute sequentially all code chunks, preview, publish, and submit link on Sakai following the naming convention. Make sure to add comments to your code where appropriate. Use own language!

Any sign of plagiarism, will result in dissmissal of work!


Task 1: Charting Stock Time Series

This task follows the book’s R Example 1.1/p. 8 also exhibited in the R-Labs section R Labs1 from the book’s website (*). In order to work with R in finance we need to first install the package quantmod that allows us to retrieve financial data and conduct various statistical analysis.

# Require will load the package only if not installed 
# Dependencies = TRUE makes sure that dependencies are install
if(!require("quantmod",quietly = TRUE))
  install.packages("quantmod",dependencies = TRUE, repos = "https://cloud.r-project.org")

##### 1A) Insert in the code chunk below the rest of the code to calculate and chart the time series for stock GE. Follow the example in the book. Add comments, where appropriate, explaining what the particular line(s) of code is/are executing/solving for.

library("quantmod")
##retrieve historical price data for General Electric Co. from Yahoo Finance
getSymbols('GE',src='yahoo', from="2000-01-01", to="2009-12-30")
[1] "GE"
##to see headers of file (OHLCV type)
names(GE)
[1] "GE.Open"     "GE.High"     "GE.Low"      "GE.Close"    "GE.Volume"   "GE.Adjusted"
## extract Adjusted Close
geAdj = GE$GE.Adjusted["2000-01-01/2000-01-20"]
##compute max, min and mean
max(geAdj); min(geAdj); mean(geAdj)
[1] 28.06313
[1] 26.23787
[1] 27.1946
## draw a chart
chartSeries(GE)

 
##to save data to your disk use
saveRDS(GE,file="GE.rds")

Task 2: Comparing Performance of Stocks Time Series

This follows the book’s example 1.3.4 R Lab/p. 34 also R Labs 1 from the book’s website (*).

##### 2A) Insert the code chunk to chart instead the performance of Value Line Index VLIC (sort of benchmark), and four other stocks of your choice over a time period dating back one year from present date.

library("quantmod")
symbols=c('^VLIC','AMZN','FB','T','MSFT')
getSymbols(symbols,src='yahoo',from="2012-02-01",to="2013-02-01")
[1] "VLIC" "AMZN" "FB"   "T"    "MSFT"
 #obtain adjusted closed
VLICad = VLIC$VLIC.Adjusted; AMZNad= AMZN$AMZN.Adjusted;
  FBad=FB$FB.Adjusted; Tad=T$T.Adjusted;
  MSFTad = MSFT$MSFT.Adjusted
 #compute cumulative sum (cumsum) of daily returns (Delt)
 #Remove first term of the series, with [-1,], since cumsum is not defined for it.
vl = cumsum((Delt(VLICad)*100)[-1,])
amzn = cumsum((Delt(AMZNad)*100)[-1,])
fb = cumsum((Delt(FBad)*100)[-1,])
t = cumsum((Delt(Tad)*100)[-1,])
msft = cumsum((Delt(MSFTad)*100)[-1,])
 
###range of values for the plot
lim = c(min(vl,amzn,fb,t,msft),max(vl,amzn,fb,t,msft))
###the plot
plot(vl,main="",ylim=lim,xlab="dates",ylab="% benefits")

lines(amzn,col="green"); lines(fb,col="red")

lines(t,col="violet"); lines(msft,col="yellow")

legend(x="topleft",cex=0.4,c("VLIC","AMZN","FB","T","MSFT"),
   lty=1, col=c("black","green","red","violet","yellow"))

##### 2B) Write the mathematical form/representation, using proper math symbols, to describe the formula being calculated and plotted in the code

\[R_{t}= \sum_{t=1}^{n}\frac{P_{t}}{P_{t-1}}-1\]

##### 2C) Write a paragraph, in your own words, comparing the stock performances based on your assessment of the companies general business and their valuation vis-a-vis the market overall performance, and pertinent econonomical factors.

From the chart it is clear that Amazon and AT&T have outperformed the markets upwards of 20% and 40% respectively. This is driven by dominant market share with Amazon’s ability to conitinue to innovate. Additonally, due to strong user growth and growing distribution channels, Amazon had a competitive advantage that led to the outperfomance of the market. AT&T’s ability to expand their services nationwide has helped them to grow their brand image and tap into new customer channels leading to increased revenue. The economies of scale compared to other competitors allows the comaonay to have diversified offerings for various customers. All these factors are drivers of growth and revenue. MSFT underpeformed during 2012-2013 despite strong financials due to investors expectation that the company could not continue to compete or innovate. Additonally, with other players entering the mobile space and Microsoft steering away, investors lost belief in the growth potential. FB had its IPO in 2012 and suffered a big dip despite expectations. However, this is common with IPOs as the market is trying to figure out where to price the stock.

To add math symbols in R Markdown check the link MathinRmd.html. Many other examples are on Google. Following is an example: \(\sum_{n=1}^{10} n^2\). Other, less preferred options, is to neatly handwrite your equations on a paper or use own preferred tools like Microsoft Word, take a clear image capture of your work and include here. Hard to read work will be dismissed.

Below is an example on how to include an image. It is assumed that the image resides in the same folder as the worksheet. Otherwise the path to the folder where the image resides needs to be included in the name referencing below.

Task 3: Problem(s) Solving

This task does not require use of R code. You will however need to type your work here, using proper mathematical symbols and representations, or include a clear image capture of your work.

##### 3A) Solve for 1.3.8 Problem/p. 36.

\[C_u=S_u-K=40-20=20\] \[C=0.8*25 - 11.43 = 8.57\] \[P=C+Ke^{rT}-S_t = 8.57 + 20e^{-0.06}-25=2.6\]

##### 3B) Solve for 1.3.9 Problem/p. 36 \[P+S_t=C+Ke^{rT}\] \[\frac{\partial}{\partial S}(C-P) = \frac{\partial}{\partial S}(S_t-Ke^{rT})\] \[\Delta C-\Delta P = 1\] \[\Delta P = \Delta C + 1\]

*http://computationalfinance.lsi.upc.edu

LS0tCnRpdGxlOiAiRklOQzYyMSBXaW50ZXIgMjAxOC0xOSBMYWIgV29ya3NoZWV0IDAxIgphdXRob3I6ICJDaHJpc3RvcGhlciBGcmFuY2lzIgpkYXRlOiAiTm92ZW1iZXIgMTIsMjAxOCIKb3V0cHV0OgogIGh0bWxfbm90ZWJvb2s6IGRlZmF1bHQKICBwZGZfZG9jdW1lbnQ6IGRlZmF1bHQKICBodG1sX2RvY3VtZW50OiBkZWZhdWx0CnN1YnRpdGxlOiBFeHBsb3JhdGlvbiBvZiBSIGluIEZpbmFuY2UgKGZpbmM2MjEtbGFiMDEpCi0tLQoKIyMjIEFib3V0CgpUaGlzIHdvcmtzaGVldCBpcyB5b3VyIHdhcm0tdXAgZXhlcmNpc2VzIHRvIGdldHRpbmcgc3RhcnRlZCB3aXRoIHNvbWUgUiBmb3IgZmluYW5jZSwgYmFzZWQgb24gIGV4YW1wbGVzIGZyb20gdGhlIGJvb2suIEl0IGlzIGFsc28geW91ciBnZXR0aW5nIHN0YXJ0ZWQgd2l0aCBwcm9ibGVtcyBzb2x2aW5nIChubyBSIHJlcXVpcmVkKSBhbmQgZXhwcmVzc2luZyB5b3VyIG1ldGhvZHMvYW5zd2VycyB1c2luZyBwcm9wZXIgbWF0aGVtYXRpY2FsIHN5bWJvbHMgYW5kIHJlcHJlc2VudGF0aW9ucy4KCiMjIyBTZXR1cAoKUmVtZW1iZXIgdG8gYWx3YXlzIHNldCB5b3VyIHdvcmtpbmcgZGlyZWN0b3J5IHRvIHRoZSBzb3VyY2UgZmlsZSBsb2NhdGlvbi4gR28gdG8gJ1Nlc3Npb24nLCBzY3JvbGwgZG93biB0byAnU2V0IFdvcmtpbmcgRGlyZWN0b3J5JywgYW5kIGNsaWNrICdUbyBTb3VyY2UgRmlsZSBMb2NhdGlvbicuIFJlYWQgY2FyZWZ1bGx5IHRoZSBiZWxvdyBhbmQgZm9sbG93IHRoZSBpbnN0cnVjdGlvbnMgdG8gY29tcGxldGUgdGhlIHRhc2tzIGFuZCBhbnN3ZXIgYW55IHF1ZXN0aW9ucy4gIFN1Ym1pdCB5b3VyIHdvcmsgdG8gUlB1YnMgYXMgZGV0YWlsZWQgaW4gcHJldmlvdXMgbm90ZXMuIAoKIyMjIE5vdGUKCkZvciBjbGFyaXR5LCB0YXNrcy9xdWVzdGlvbnMgdG8gYmUgY29tcGxldGVkL2Fuc3dlcmVkIGFyZSBoaWdobGlnaHRlZCBpbiByZWQgY29sb3IgKGNvbG9yIHZpc2libGUgb25seSBpbiBwcmV2aWV3IG1vZGUpIGFuZCBudW1iZXJlZCBhY2NvcmRpbmcgdG8gdGhlaXIgcGFydGljdWxhciBwbGFjZW1lbnQgaW4gdGhlIHRhc2sgc2VjdGlvbi4gIFR5cGUgeW91ciBhbnN3ZXJzIG91dHNpZGUgdGhlIHJlZCBjb2xvciB0YWdzIQoKUXVpdGUgb2Z0ZW4geW91IHdpbGwgbmVlZCB0byBhZGQgeW91ciBvd24gY29kZSBjaHVuay4gRXhlY3V0ZSBzZXF1ZW50aWFsbHkgYWxsIGNvZGUgY2h1bmtzLCBwcmV2aWV3LCBwdWJsaXNoLCBhbmQgc3VibWl0IGxpbmsgb24gU2FrYWkgZm9sbG93aW5nIHRoZSBuYW1pbmcgY29udmVudGlvbi4gTWFrZSBzdXJlIHRvIGFkZCBjb21tZW50cyB0byB5b3VyIGNvZGUgd2hlcmUgYXBwcm9wcmlhdGUuIFVzZSBvd24gbGFuZ3VhZ2UhCgoqKkFueSBzaWduIG9mIHBsYWdpYXJpc20sIHdpbGwgcmVzdWx0IGluIGRpc3NtaXNzYWwgb2Ygd29yayEqKgoKLS0tLS0tLS0tLS0tLS0KCiMjIyBUYXNrIDE6IENoYXJ0aW5nIFN0b2NrIFRpbWUgU2VyaWVzIAoKVGhpcyB0YXNrIGZvbGxvd3MgdGhlIGJvb2sncyBSIEV4YW1wbGUgMS4xL3AuIDggYWxzbyBleGhpYml0ZWQgaW4gdGhlIFItTGFicyBzZWN0aW9uIFIgTGFiczEgZnJvbSB0aGUgYm9va+KAmXMgd2Vic2l0ZSAoKikuIEluIG9yZGVyIHRvIHdvcmsgd2l0aCBSIGluIGZpbmFuY2Ugd2UgbmVlZCB0byBmaXJzdCBpbnN0YWxsIHRoZSBwYWNrYWdlIGBxdWFudG1vZGAgdGhhdCBhbGxvd3MgdXMgdG8gcmV0cmlldmUgZmluYW5jaWFsIGRhdGEgYW5kIGNvbmR1Y3QgdmFyaW91cyBzdGF0aXN0aWNhbCBhbmFseXNpcy4KCmBgYHtyfQojIFJlcXVpcmUgd2lsbCBsb2FkIHRoZSBwYWNrYWdlIG9ubHkgaWYgbm90IGluc3RhbGxlZCAKIyBEZXBlbmRlbmNpZXMgPSBUUlVFIG1ha2VzIHN1cmUgdGhhdCBkZXBlbmRlbmNpZXMgYXJlIGluc3RhbGwKaWYoIXJlcXVpcmUoInF1YW50bW9kIixxdWlldGx5ID0gVFJVRSkpCiAgaW5zdGFsbC5wYWNrYWdlcygicXVhbnRtb2QiLGRlcGVuZGVuY2llcyA9IFRSVUUsIHJlcG9zID0gImh0dHBzOi8vY2xvdWQuci1wcm9qZWN0Lm9yZyIpCmBgYAoKCgo8c3BhbiBzdHlsZT0iY29sb3I6cmVkIj4KIyMjIyMgMUEpIEluc2VydCBpbiB0aGUgY29kZSBjaHVuayBiZWxvdyB0aGUgcmVzdCBvZiB0aGUgY29kZSB0byBjYWxjdWxhdGUgYW5kIGNoYXJ0IHRoZSB0aW1lIHNlcmllcyBmb3Igc3RvY2sgR0UuICBGb2xsb3cgdGhlIGV4YW1wbGUgaW4gdGhlIGJvb2suIEFkZCBjb21tZW50cywgd2hlcmUgYXBwcm9wcmlhdGUsIGV4cGxhaW5pbmcgd2hhdCB0aGUgcGFydGljdWxhciBsaW5lKHMpIG9mIGNvZGUgaXMvYXJlIGV4ZWN1dGluZy9zb2x2aW5nIGZvci4KPC9zcGFuPgoKYGBge3J9CmxpYnJhcnkoInF1YW50bW9kIikKIyNyZXRyaWV2ZSBoaXN0b3JpY2FsIHByaWNlIGRhdGEgZm9yIEdlbmVyYWwgRWxlY3RyaWMgQ28uIGZyb20gWWFob28gRmluYW5jZQpnZXRTeW1ib2xzKCdHRScsc3JjPSd5YWhvbycsIGZyb209IjIwMDAtMDEtMDEiLCB0bz0iMjAwOS0xMi0zMCIpCiMjdG8gc2VlIGhlYWRlcnMgb2YgZmlsZSAoT0hMQ1YgdHlwZSkKbmFtZXMoR0UpCiMjIGV4dHJhY3QgQWRqdXN0ZWQgQ2xvc2UKZ2VBZGogPSBHRSRHRS5BZGp1c3RlZFsiMjAwMC0wMS0wMS8yMDAwLTAxLTIwIl0KIyNjb21wdXRlIG1heCwgbWluIGFuZCBtZWFuCm1heChnZUFkaik7IG1pbihnZUFkaik7IG1lYW4oZ2VBZGopCiMjIGRyYXcgYSBjaGFydApjaGFydFNlcmllcyhHRSkKIAojI3RvIHNhdmUgZGF0YSB0byB5b3VyIGRpc2sgdXNlCnNhdmVSRFMoR0UsZmlsZT0iR0UucmRzIikKYGBgCgojIyMgVGFzayAyOiBDb21wYXJpbmcgUGVyZm9ybWFuY2Ugb2YgU3RvY2tzIFRpbWUgU2VyaWVzCgpUaGlzIGZvbGxvd3MgdGhlIGJvb2vigJlzIGV4YW1wbGUgMS4zLjQgUiBMYWIvcC4gMzQgYWxzbyBSIExhYnMgMSBmcm9tIHRoZSBib29r4oCZcyB3ZWJzaXRlICgqKS4gCgo8c3BhbiBzdHlsZT0iY29sb3I6cmVkIj4KIyMjIyMgMkEpIEluc2VydCB0aGUgY29kZSBjaHVuayB0byBjaGFydCBpbnN0ZWFkIHRoZSBwZXJmb3JtYW5jZSBvZiBWYWx1ZSBMaW5lIEluZGV4IFZMSUMgKHNvcnQgb2YgYmVuY2htYXJrKSwgYW5kIGZvdXIgb3RoZXIgc3RvY2tzIG9mIHlvdXIgY2hvaWNlIG92ZXIgYSB0aW1lIHBlcmlvZCBkYXRpbmcgYmFjayBvbmUgeWVhciBmcm9tIHByZXNlbnQgZGF0ZS4KPC9zcGFuPgpgYGB7cn0KbGlicmFyeSgicXVhbnRtb2QiKQpzeW1ib2xzPWMoJ15WTElDJywnQU1aTicsJ0ZCJywnVCcsJ01TRlQnKQpnZXRTeW1ib2xzKHN5bWJvbHMsc3JjPSd5YWhvbycsZnJvbT0iMjAxMi0wMi0wMSIsdG89IjIwMTMtMDItMDEiKQogI29idGFpbiBhZGp1c3RlZCBjbG9zZWQKVkxJQ2FkID0gVkxJQyRWTElDLkFkanVzdGVkOyBBTVpOYWQ9IEFNWk4kQU1aTi5BZGp1c3RlZDsKICBGQmFkPUZCJEZCLkFkanVzdGVkOyBUYWQ9VCRULkFkanVzdGVkOwogIE1TRlRhZCA9IE1TRlQkTVNGVC5BZGp1c3RlZAogI2NvbXB1dGUgY3VtdWxhdGl2ZSBzdW0gKGN1bXN1bSkgb2YgZGFpbHkgcmV0dXJucyAoRGVsdCkKICNSZW1vdmUgZmlyc3QgdGVybSBvZiB0aGUgc2VyaWVzLCB3aXRoIFstMSxdLCBzaW5jZSBjdW1zdW0gaXMgbm90IGRlZmluZWQgZm9yIGl0Lgp2bCA9IGN1bXN1bSgoRGVsdChWTElDYWQpKjEwMClbLTEsXSkKYW16biA9IGN1bXN1bSgoRGVsdChBTVpOYWQpKjEwMClbLTEsXSkKZmIgPSBjdW1zdW0oKERlbHQoRkJhZCkqMTAwKVstMSxdKQp0ID0gY3Vtc3VtKChEZWx0KFRhZCkqMTAwKVstMSxdKQptc2Z0ID0gY3Vtc3VtKChEZWx0KE1TRlRhZCkqMTAwKVstMSxdKQogCiMjI3JhbmdlIG9mIHZhbHVlcyBmb3IgdGhlIHBsb3QKbGltID0gYyhtaW4odmwsYW16bixmYix0LG1zZnQpLG1heCh2bCxhbXpuLGZiLHQsbXNmdCkpCiMjI3RoZSBwbG90CnBsb3QodmwsbWFpbj0iIix5bGltPWxpbSx4bGFiPSJkYXRlcyIseWxhYj0iJSBiZW5lZml0cyIpCmxpbmVzKGFtem4sY29sPSJncmVlbiIpOyBsaW5lcyhmYixjb2w9InJlZCIpCmxpbmVzKHQsY29sPSJ2aW9sZXQiKTsgbGluZXMobXNmdCxjb2w9InllbGxvdyIpCmxlZ2VuZCh4PSJ0b3BsZWZ0IixjZXg9MC40LGMoIlZMSUMiLCJBTVpOIiwiRkIiLCJUIiwiTVNGVCIpLAogICBsdHk9MSwgY29sPWMoImJsYWNrIiwiZ3JlZW4iLCJyZWQiLCJ2aW9sZXQiLCJ5ZWxsb3ciKSkKYGBgCgo8c3BhbiBzdHlsZT0iY29sb3I6cmVkIj4KIyMjIyMgMkIpIFdyaXRlIHRoZSBtYXRoZW1hdGljYWwgZm9ybS9yZXByZXNlbnRhdGlvbiwgdXNpbmcgcHJvcGVyIG1hdGggc3ltYm9scywgdG8gZGVzY3JpYmUgdGhlIGZvcm11bGEgYmVpbmcgY2FsY3VsYXRlZCBhbmQgcGxvdHRlZCBpbiB0aGUgY29kZSAgCjwvc3Bhbj4KCiQkUl97dH09IFxzdW1fe3Q9MX1ee259XGZyYWN7UF97dH19e1Bfe3QtMX19LTEkJAoKCjxzcGFuIHN0eWxlPSJjb2xvcjpyZWQiPgojIyMjIyAyQykgV3JpdGUgYSAgcGFyYWdyYXBoLCBpbiB5b3VyIG93biB3b3JkcywgY29tcGFyaW5nIHRoZSBzdG9jayBwZXJmb3JtYW5jZXMgYmFzZWQgb24geW91ciBhc3Nlc3NtZW50IG9mIHRoZSBjb21wYW5pZXMgZ2VuZXJhbCBidXNpbmVzcyBhbmQgdGhlaXIgdmFsdWF0aW9uIHZpcy1hLXZpcyB0aGUgbWFya2V0IG92ZXJhbGwgcGVyZm9ybWFuY2UsIGFuZCBwZXJ0aW5lbnQgZWNvbm9ub21pY2FsIGZhY3RvcnMuCjwvc3Bhbj4KCkZyb20gdGhlIGNoYXJ0IGl0IGlzIGNsZWFyIHRoYXQgQW1hem9uIGFuZCBBVCZUIGhhdmUgb3V0cGVyZm9ybWVkIHRoZSBtYXJrZXRzIHVwd2FyZHMgb2YgMjAlIGFuZCA0MCUgcmVzcGVjdGl2ZWx5LiBUaGlzIGlzIGRyaXZlbiBieSBkb21pbmFudCBtYXJrZXQgc2hhcmUgd2l0aCBBbWF6b24ncyBhYmlsaXR5IHRvIGNvbml0aW51ZSB0byBpbm5vdmF0ZS4gQWRkaXRvbmFsbHksIGR1ZSB0byBzdHJvbmcgdXNlciBncm93dGggYW5kIGdyb3dpbmcgZGlzdHJpYnV0aW9uIGNoYW5uZWxzLCBBbWF6b24gaGFkIGEgY29tcGV0aXRpdmUgYWR2YW50YWdlIHRoYXQgbGVkIHRvIHRoZSBvdXRwZXJmb21hbmNlIG9mIHRoZSBtYXJrZXQuIEFUJlQncyBhYmlsaXR5IHRvIGV4cGFuZCB0aGVpciBzZXJ2aWNlcyBuYXRpb253aWRlIGhhcyBoZWxwZWQgdGhlbSB0byBncm93IHRoZWlyIGJyYW5kIGltYWdlIGFuZCB0YXAgaW50byBuZXcgY3VzdG9tZXIgY2hhbm5lbHMgbGVhZGluZyB0byBpbmNyZWFzZWQgcmV2ZW51ZS4gVGhlIGVjb25vbWllcyBvZiBzY2FsZSBjb21wYXJlZCB0byBvdGhlciBjb21wZXRpdG9ycyBhbGxvd3MgdGhlIGNvbWFvbmF5IHRvIGhhdmUgZGl2ZXJzaWZpZWQgb2ZmZXJpbmdzIGZvciB2YXJpb3VzIGN1c3RvbWVycy4gQWxsIHRoZXNlIGZhY3RvcnMgYXJlIGRyaXZlcnMgb2YgZ3Jvd3RoIGFuZCByZXZlbnVlLiBNU0ZUIHVuZGVycGVmb3JtZWQgZHVyaW5nIDIwMTItMjAxMyBkZXNwaXRlIHN0cm9uZyBmaW5hbmNpYWxzIGR1ZSB0byBpbnZlc3RvcnMgZXhwZWN0YXRpb24gdGhhdCB0aGUgY29tcGFueSBjb3VsZCBub3QgY29udGludWUgdG8gY29tcGV0ZSBvciBpbm5vdmF0ZS4gQWRkaXRvbmFsbHksIHdpdGggb3RoZXIgcGxheWVycyBlbnRlcmluZyB0aGUgbW9iaWxlIHNwYWNlIGFuZCBNaWNyb3NvZnQgc3RlZXJpbmcgYXdheSwgaW52ZXN0b3JzIGxvc3QgYmVsaWVmIGluIHRoZSBncm93dGggcG90ZW50aWFsLiBGQiBoYWQgaXRzIElQTyBpbiAyMDEyIGFuZCBzdWZmZXJlZCBhIGJpZyBkaXAgZGVzcGl0ZSBleHBlY3RhdGlvbnMuIEhvd2V2ZXIsIHRoaXMgaXMgY29tbW9uIHdpdGggSVBPcyBhcyB0aGUgbWFya2V0IGlzIHRyeWluZyB0byBmaWd1cmUgb3V0IHdoZXJlIHRvIHByaWNlIHRoZSBzdG9jay4KCgpUbyBhZGQgbWF0aCBzeW1ib2xzIGluIFIgTWFya2Rvd24gY2hlY2sgdGhlIGxpbmsgW01hdGhpblJtZC5odG1sXSggaHR0cHM6Ly93d3cuY2FsdmluLmVkdS9+cnBydWltL2NvdXJzZXMvczM0MS9TMTcvZnJvbS1jbGFzcy9NYXRoaW5SbWQuaHRtbCkuCk1hbnkgb3RoZXIgZXhhbXBsZXMgYXJlIG9uIEdvb2dsZS4gRm9sbG93aW5nIGlzIGFuIGV4YW1wbGU6ICRcc3VtX3tuPTF9XnsxMH0gbl4yJC4gIE90aGVyLCBsZXNzIHByZWZlcnJlZCBvcHRpb25zLCBpcyB0byBuZWF0bHkgaGFuZHdyaXRlIHlvdXIgZXF1YXRpb25zIG9uIGEgcGFwZXIgb3IgdXNlIG93biBwcmVmZXJyZWQgdG9vbHMgbGlrZSBNaWNyb3NvZnQgV29yZCwgdGFrZSBhIGNsZWFyIGltYWdlIGNhcHR1cmUgb2YgeW91ciB3b3JrIGFuZCBpbmNsdWRlIGhlcmUuICBIYXJkIHRvIHJlYWQgd29yayB3aWxsIGJlIGRpc21pc3NlZC4gCgpCZWxvdyBpcyBhbiBleGFtcGxlIG9uIGhvdyB0byBpbmNsdWRlIGFuIGltYWdlLiAgSXQgaXMgYXNzdW1lZCB0aGF0IHRoZSBpbWFnZSByZXNpZGVzIGluIHRoZSBzYW1lIGZvbGRlciBhcyB0aGUgd29ya3NoZWV0LiBPdGhlcndpc2UgdGhlIHBhdGggdG8gdGhlIGZvbGRlciB3aGVyZSB0aGUgaW1hZ2UgcmVzaWRlcyBuZWVkcyB0byBiZSBpbmNsdWRlZCBpbiB0aGUgbmFtZSByZWZlcmVuY2luZyBiZWxvdy4KCgojIyMgVGFzayAzOiBQcm9ibGVtKHMpIFNvbHZpbmcKClRoaXMgdGFzayBkb2VzIG5vdCByZXF1aXJlIHVzZSBvZiBSIGNvZGUuICBZb3Ugd2lsbCBob3dldmVyIG5lZWQgdG8gdHlwZSB5b3VyIHdvcmsgaGVyZSwgdXNpbmcgcHJvcGVyIG1hdGhlbWF0aWNhbCBzeW1ib2xzIGFuZCByZXByZXNlbnRhdGlvbnMsIG9yIGluY2x1ZGUgYSBjbGVhciBpbWFnZSBjYXB0dXJlIG9mIHlvdXIgd29yay4KCgo8c3BhbiBzdHlsZT0iY29sb3I6cmVkIj4KIyMjIyMgM0EpIFNvbHZlIGZvciAxLjMuOCBQcm9ibGVtL3AuIDM2LiAKPC9zcGFuPgoKJCRDX3U9U191LUs9NDAtMjA9MjAkJAokJEM9MC44KjI1IC0gMTEuNDMgPSA4LjU3JCQKJCRQPUMrS2Vee3JUfS1TX3QgPSA4LjU3ICsgMjBlXnstMC4wNn0tMjU9Mi42JCQKCjxzcGFuIHN0eWxlPSJjb2xvcjpyZWQiPgojIyMjIyAzQikgU29sdmUgZm9yIDEuMy45IFByb2JsZW0vcC4gMzYKPC9zcGFuPgokJFArU190PUMrS2Vee3JUfSQkCiQkXGZyYWN7XHBhcnRpYWx9e1xwYXJ0aWFsIFN9KEMtUCkgPSBcZnJhY3tccGFydGlhbH17XHBhcnRpYWwgU30oU190LUtlXntyVH0pJCQKJCRcRGVsdGEgQy1cRGVsdGEgUCA9IDEkJAokJFxEZWx0YSBQID0gXERlbHRhIEMgKyAxJCQKCgoKKltodHRwOi8vY29tcHV0YXRpb25hbGZpbmFuY2UubHNpLnVwYy5lZHUgXShodHRwOi8vY29tcHV0YXRpb25hbGZpbmFuY2UubHNpLnVwYy5lZHUpCg==