What has happened in the past when the SPY opens 3.5% or more down?
I ran the numbers and have some code for doing it yourself. I found that there's typically a profitable day ahead, and even if not profitable, the day tends to have enough upside (Open to High) to be of great interest.
Here is a link to the code I used to calculate these results. You will want to grab the DataManager from Github to easily populate data for the study.
Check out the topic on the new forum if you have any suggestions or want to discuss the topic in more detail. Or if you just want to talk about your favorite beer :)
As always, consider signing up for the newsletter. It encourages me to produce more code and analysis, and will provide content not found on the site.
Sunday, August 30, 2015
Sunday, August 16, 2015
Downloading Stock Market News for Specific Symbols
Grabbing the data.
How do you grab the latest news on your favorite ticker symbol?
It all starts with the following URL.
You can add something like the following to the end if you'd like more articles returned. There is, however, a limit on the number returned.
When you download the above link, you're given an rss feed, which is in XML. If you don't know XML, it's basically a text document with various fields sorted by tags that look like "<tag>info</tag>" (e.g. <title>SPY Stock News</title>, <link>http://godelsmarket.blogspot.com</link>, etc).
The tags you'll be interested in start with <item>. Each <item> contains info on a single news article. Within the <item></item> tags, you'll find four tags that are probably of interest to you. They are:
Storing the data.
I'd store it in a database. You can also store it in flat files (.txt or .xml) if you prefer.
Create a table in your MySQL database (make sure you have MySQL installed! On Ubuntu Linux: sudo apt-get install msyql-server). This can be modified for other databases fairly easy.
Next we want to extract and insert. We'll use Python.
First, if you don't have the "pymysql" module installed you'll need to install it by typing: pip install pymysql. I also really like "timestring" for date/time parsing (run: pip install datestring).
Now for the lovely code :) This can be more easily consumed via the "godelsmarket" Github Repo.
import urllib2
from lxml import etree
import pymysql
import timestring
#connect to the database
connection = pymysql.connect(host='localhost',
user='root',
password='password',
db='stock_db')
#stock symbol you want to download news for
symbol = "SPY"
#this is the url where we grab the data
url_stub = "http://www.google.com/finance/company_news?output=rss&q="
#use urllib2 to download the data
response = urllib2.urlopen(url_stub + symbol)
xml = response.read()
#turn into an xml doc
doc = etree.fromstring(xml)
#we're only interested in tags under <item>
item_tags = doc.xpath('//channel/item')
for item in item_tags:
#split up by the four tags
date_tag = item.xpath('pubDate')
title_tag = item.xpath('title')
link_tag = item.xpath('link')
description_tag = item.xpath('description')
date_text = date_tag[0].text
title_text = title_tag[0].text
link_text = link_tag[0].text
description_text = description_tag[0].text
print 'date:' + date_text
print 'title:' + title_text
print 'link:' + link_text
print 'description:' + description_text
#insert into the database
with connection.cursor() as cursor:
sql = "INSERT INTO `stocknews` (`symbol`, `pubDate`, `title`, `link`, `description`) VALUES (%s, %s, %s, %s, %s)"
cursor.execute(sql, (symbol, str(timestring.Date(date_text)), title_text, link_text, description_text))
connection.commit()
How do you grab the latest news on your favorite ticker symbol?
It all starts with the following URL.
https://www.google.com/finance/company_news?q=SPY&output=rssYou'll want to change "q=SPY" to whatever symbol you're interested in.
You can add something like the following to the end if you'd like more articles returned. There is, however, a limit on the number returned.
&num=2000What the returned data means.
When you download the above link, you're given an rss feed, which is in XML. If you don't know XML, it's basically a text document with various fields sorted by tags that look like "<tag>info</tag>" (e.g. <title>SPY Stock News</title>, <link>http://godelsmarket.blogspot.com</link>, etc).
The tags you'll be interested in start with <item>. Each <item> contains info on a single news article. Within the <item></item> tags, you'll find four tags that are probably of interest to you. They are:
<title> This gives you the title of the article. (e.g. <title>S&P 500: Should You Buy the SPY ETF Now?</title>)
<link> This gives you the link to the article. (e.g. <link>http://investorplace.com/2015/06/spy-etf-sp-500/</link>)
<pubDate> This is the date the article was published online. (e.g. <pubDate>Tue, 30 Jun 2015 12:00:10 GMT</pubDate>)
<description> This is the description Google gives for the article. It is short but provides an idea without requiring you to download the entire article. (e.g. SPDR S&P 500 ETF Trust Sees Large Drop in Short Interest (SPY))What you'll likely want to do is download this data and extract it somewhere you can store and analyze it.
Storing the data.
I'd store it in a database. You can also store it in flat files (.txt or .xml) if you prefer.
Create a table in your MySQL database (make sure you have MySQL installed! On Ubuntu Linux: sudo apt-get install msyql-server). This can be modified for other databases fairly easy.
CREATE TABLE stocknews (symbol VARCHAR(5), pubDate DATETIME, title TEXT, link TEXT, description TEXT);The Code.
Next we want to extract and insert. We'll use Python.
First, if you don't have the "pymysql" module installed you'll need to install it by typing: pip install pymysql. I also really like "timestring" for date/time parsing (run: pip install datestring).
Now for the lovely code :) This can be more easily consumed via the "godelsmarket" Github Repo.
import urllib2
from lxml import etree
import pymysql
import timestring
#connect to the database
connection = pymysql.connect(host='localhost',
user='root',
password='password',
db='stock_db')
#stock symbol you want to download news for
symbol = "SPY"
#this is the url where we grab the data
url_stub = "http://www.google.com/finance/company_news?output=rss&q="
#use urllib2 to download the data
response = urllib2.urlopen(url_stub + symbol)
xml = response.read()
#turn into an xml doc
doc = etree.fromstring(xml)
#we're only interested in tags under <item>
item_tags = doc.xpath('//channel/item')
for item in item_tags:
#split up by the four tags
date_tag = item.xpath('pubDate')
title_tag = item.xpath('title')
link_tag = item.xpath('link')
description_tag = item.xpath('description')
date_text = date_tag[0].text
title_text = title_tag[0].text
link_text = link_tag[0].text
description_text = description_tag[0].text
print 'date:' + date_text
print 'title:' + title_text
print 'link:' + link_text
print 'description:' + description_text
#insert into the database
with connection.cursor() as cursor:
sql = "INSERT INTO `stocknews` (`symbol`, `pubDate`, `title`, `link`, `description`) VALUES (%s, %s, %s, %s, %s)"
cursor.execute(sql, (symbol, str(timestring.Date(date_text)), title_text, link_text, description_text))
connection.commit()
As always, if you have any questions feel free to comment! Hope you enjoyed!
If you enjoyed this article, consider signing up for the Gödel's Market Newsletter. I don't spam, and every signup is seen as a sign of support! Thank you!
Saturday, July 25, 2015
Finding Stock Splits and Ex-Dividends Using R
The following post shows you how to check for any stock splits and ex-dividends happening. It'll spit out a list of symbols. These can be used as alerts or piped into another script for updating your database as needed.
I want to thank pcavatore for suggesting this topic! Comments and suggestions help drive the content of this site. Now, onto the explanation. If you're just interested in the code, skip to the bottom or check out the github repo.
1. Requirements. We'll be using the "XML" library. In R, it makes it easy to extract tabular data from webpages. Running the following code will install "XML" if it isn't already installed. Then it will load the library for use.
if (!require(XML)) install.packages('XML')
library(XML)
2. URL selection. We'll need some online location from which to pull the data. Yahoo! has easy to grab stock split info; Nasdaq.com has easy to grab dividend info. So we'll use those.
#for stock split
url <- "http://biz.yahoo.com/c/s.html"
#or, for dividend information
url <- "http://www.nasdaq.com/dividend-stocks/dividend-calendar.aspx"
3. Download the data. We use the readHTMLTable function in order to grab the data.
tables <- readHTMLTable(url)
4. Extract desired data. The previous command will return more tables than you're interested in. Within those tables is also more data than we're interested in. So, we'll print out just the specific table and data column we'd like, now that the tables are stored in memory.
#for stock split data you only want the 6th table and the 3rd data column
tables[[6]][3]
#for the ex-dividend data you only want the "Table1" table and its 1st data column
tables[['Table1']][1]
5. The complete code. It can also be found on github, here.
if (!require(XML)) install.packages('XML')
library(XML)
# Check for stock splits
url <- "http://biz.yahoo.com/c/s.html"
tables <- readHTMLTable(url)
tables[[6]][3]
# Check for ex-dividend
url <- "http://www.nasdaq.com/dividend-stocks/dividend-calendar.aspx"
tables <- readHTMLTable(url)
tables[['Table1']][1]
6. Conclusion. You should now be able to get a printout of any stock splits or ex-dividend dates occurring. This can be used to help update your database or keep you alerted to potential trading opportunities.
7. Further. The above outline can be used to download other tabular data. The basic outline is: find a site with tabular date, download that data, and then extract the tables and columns you need.
(If you've enjoyed the above article, consider signing up for the Gödel's Market Newsletter. Every signup encourages me to write more. Thank you!)
Friday, July 17, 2015
All the gaps need to be filled: Marco Simioni
It's an old Wall Street saying--"All the gaps need to be filled"--and is widely known among traders both for its accuracy and its occasional fallacy. It holds true for many market indexes and many stocks. I'm primarily focusing on the S&P 500 etf: SPY. Gaps in SPX are not as clear as in the SPY graph, which is why I will be referring to the SPY.
Consider up gaps to occur when today's opening price is higher than yesterday's high; and, consider down gaps to be those with today's open lower than yesterday's low. It is clear how all down gaps have been closed by the market so far. Most of the gaps take just a few days to be covered, but some take years. Like big holes or magnets they attract prices back to them. Let's talk first about unfilled down gaps.
The was a guest article written by Marco Simioni of Nightly Patterns. Many thanks to him for his insights on gaps in the SPY.
Consider up gaps to occur when today's opening price is higher than yesterday's high; and, consider down gaps to be those with today's open lower than yesterday's low. It is clear how all down gaps have been closed by the market so far. Most of the gaps take just a few days to be covered, but some take years. Like big holes or magnets they attract prices back to them. Let's talk first about unfilled down gaps.
Unfilled down gaps have shown the most consistent behaviour. All of them have been closed by next markets' bullish moves. A bull market can take years to recover and close a gap, however, all bear markets have resumed to new all time highs. This is mainly due to the general upside bias of the economy.
The main problem is not if a down gap will be closed, but WHEN. Entering big bear markets like 1929, 2001 or 2008 too early results in huge losses because the down gap can take a lot of time, potentially years, to be filled. Past stock market behaviour has shown down gaps filling 100% of times and this must be considered as a strong potential warning with short trades during even the -50% or more bear markets. The down trend will resume to cover all unfilled down gaps. Concerning long side investments, down gap filling acts as an insurance: waiting for the highest down gap to be filled is neither a waste of money nor of time.
Moving on to unfilled up gaps, different results arise from their analysis.
I collected all the unfilled up gaps in the table below going back to SPY inception in 1993. The first unfilled up gap occurred on February the 3rd 1995. And since that time, it is still not covered. We can count 20 other unfilled gaps from then to the present. And we can count about 20 years since the first of them occurred. Filling in the lowest unfilled up gap, as it appears from the backtest below, would mean the SPY would have to lose more than 75% from today's close at 207,5 (time of writing). We could argue that neither 2001 nor 2008 bear markets managed to fill those gaps, and those 20 old gaps won't fill at all. Never.
Since SPY inception 268 up gaps were filled, with only 21 not filled. 92,73% of times the market acted as expected to. Markets act with symmetry, and I believe these gaps to be filled in order to equal 100% accuracy of down gaps; we can't know the time, but they will. In 1995 there were not only 1 but 6 unfilled gaps, and all of them pointing south more than 70%. I think about them as the most dangerous 6 holes in the Wall.
(If you're interested in more articles like this, subscribe to our newsletter! Newsletter subscribers received priority access to this article and will receive unique articles in the future. Thank you!)
The was a guest article written by Marco Simioni of Nightly Patterns. Many thanks to him for his insights on gaps in the SPY.
Sunday, July 5, 2015
How to Download Code from Any Public Github Repository
Before we get into any more coding, this post may be of use to some of you. The following guide will show you how to clone, i.e. download, any public repository on github.
If you find it useful, or if you like my other posts, please consider subscribing to Gödel's Market Newsletter. Every sign up is a sign of support!
1. Download and install git. Choose one of the following based on your operating system.
2. Find a repository you want to download off of github. For instance, the code for our last post is at https://github.com/godelsmarket/stock_database_updater.
3. Open up Git Bash if you're using Windows or Mac OSX. If you're using Linux you can use a standard terminal, because that's basically what Git Bash is.
4. Type the following:
5. You're done! You now have all the code in that directory for your use. Try downloading some other repositories.
In the future I'll show you how to create your own repository on Github and how to contribute to public repositories. It's really pretty simple.
If you enjoy these posts, consider subscribing to Gödel's Market Newsletter. It encourages me to write more!
If you find it useful, or if you like my other posts, please consider subscribing to Gödel's Market Newsletter. Every sign up is a sign of support!
1. Download and install git. Choose one of the following based on your operating system.
Windows: git-scm.com/downloads
Mac OSX: git-scm.com/downloads
Linux (ubuntu): sudo apt-get install git
2. Find a repository you want to download off of github. For instance, the code for our last post is at https://github.com/godelsmarket/stock_database_updater.
3. Open up Git Bash if you're using Windows or Mac OSX. If you're using Linux you can use a standard terminal, because that's basically what Git Bash is.
4. Type the following:
git clone https://github.com/godelsmarket/stock_database_updater.git git_codeYou can change "git_code" to whatever name you'd like. It is the directory (and path) that will be holding the code.
5. You're done! You now have all the code in that directory for your use. Try downloading some other repositories.
In the future I'll show you how to create your own repository on Github and how to contribute to public repositories. It's really pretty simple.
If you enjoy these posts, consider subscribing to Gödel's Market Newsletter. It encourages me to write more!
Saturday, June 20, 2015
Automated Daily Stock Database Updates Using The R Statistics Project
I received a request from pcavatore several posts ago. pcavatore was interested in "database update automation via R script." He wanted to know "how to run a daily task to update prices in the database."
In this article we'll be using R and the RMySQL package to access and update a MySQL database with stock information from Yahoo! Finance. If you do not have R installed, you can grab a copy at http://www.r-project.org/.
(If you're interested in more articles like this, sign up for the Gödel's Market Newsletter. Each sign up is a sign of support. Topic suggestions are always welcome; and, there are currently two other suggestions in the works).
1. Install RMySQL
In the R console run the following:
2. Test the connection to your MySQL database by running the following. Change the user, password, and database name to match your own.
3. Download data from Yahoo using the following:
The following assumes you are storing your data in a table called "stock_data" and that the table has the necessary fields.
Putting it all together we get something like the following script. Can also be seen at its github repo.
If you enjoyed this article and would like to see more like it, consider signing up for the Gödel's Market Newsletter. Each sign up is a sign of support. Topic suggestions are always welcomed and always encouraged.
In this article we'll be using R and the RMySQL package to access and update a MySQL database with stock information from Yahoo! Finance. If you do not have R installed, you can grab a copy at http://www.r-project.org/.
(If you're interested in more articles like this, sign up for the Gödel's Market Newsletter. Each sign up is a sign of support. Topic suggestions are always welcome; and, there are currently two other suggestions in the works).
1. Install RMySQL
In the R console run the following:
install.packages("RMySQL")Alternatively, you can go to "Packages" at the top of the R UI. Click "Install packages(s)..." and choose "RMySQL".
2. Test the connection to your MySQL database by running the following. Change the user, password, and database name to match your own.
library("RMySQL")
mydb = dbConnect(MySQL(), user='root', password='password', dbname='stockdb', host='localhost')Make sure to change the parameters to match your database details. Next run:
dbListTables(mydb)You should see a print out of the tables in your database.
3. Download data from Yahoo using the following:
stockcsv <- read.csv("http://real-chart.finance.yahoo.com/table.csv?s=SPY&a=05&b=17&c=2015&d=5&e=18&f=2015&g=d&ignore=.csv")Run the following to see the data:
stockcsv4. Insert downloaded data into your database. You'll use the dbGetQuery(mydb, query) function along with a query generated from the stockcsv data.
The following assumes you are storing your data in a table called "stock_data" and that the table has the necessary fields.
query = paste("INSERT INTO stock_data (symbol, date, open, high, low, close, volume, adj_close) VALUES('", stock_symbol, "', '", stockcsv$Date[1], "', ", stockcsv$Open[1], ", ", stockcsv$High[1], ", ", stockcsv$Low[1], ", ", stockcsv$Close[1], ", ", stockcsv$Volume[1], ", ", stockcsv$Adj.Close[1], ")", sep="")5. Generate url. Since we don't want to have to update the url every day, you can use the following to generate the Yahoo csv url for whatever happens to be the current date:
dbGetQuery(mydb, query)
todaydate <- Sys.Date()
today_day = format(todaydate, "%d")
#yahoo months start with Jan = 0, i.e. typical_month_num - 1
today_month = toString(as.numeric(format(todaydate, "%m")) -1)
today_year = format(todaydate, "%Y")
url_create = paste("http://real-chart.finance.yahoo.com/table.csv?s=", stock_symbol, "&a=", today_month, "&b=", today_day, "&c=", today_year, "&d=", today_month,"&e=", today_day, "&f=", today_year, "&g=d&ignore=.csv", sep="")6. The Script
Putting it all together we get something like the following script. Can also be seen at its github repo.
library("RMySQL")
mydb = dbConnect(MySQL(), user='root', password='password', dbname='stockdb', host='localhost')
#get today's date
todaydate <- Sys.Date()
today_day = format(todaydate, "%d")
#yahoo months start with Jan = 0, i.e. typical_month_num - 1
today_month = toString(as.numeric(format(todaydate, "%m")) -1)
today_year = format(todaydate, "%Y")
#stock symbol
stock_symbol = "SPY"
#creating the url
url_create = paste("http://real-chart.finance.yahoo.com/table.csv?s=", stock_symbol, "&a=", today_month, "&b=", today_day, "&c=", today_year, "&d=", today_month,"&e=", today_day, "&f=", today_year, "&g=d&ignore=.csv", sep="")
#print out url_create for sanity check
url_create
#download and read in the csv
stockcsv <- read.csv(url_create)
#create INSERT query
query = paste("INSERT INTO stock_data (symbol, date, open, high, low, close, volume, adj_close) VALUES('", stock_symbol, "', '", stockcsv$Date[1], "', ", stockcsv$Open[1], ", ", stockcsv$High[1], ", ", stockcsv$Low[1], ", ", stockcsv$Close[1], ", ", stockcsv$Volume[1], ", ", stockcsv$Adj.Close[1], ")", sep="")
#run query to insert into database
dbGetQuery(mydb, query)
#disconnect from db7. Automation. Run the script from a cron job or Windows task once a day after the market closes and your database will be kept up to date!
dbDisconnect(mydb)
If you enjoyed this article and would like to see more like it, consider signing up for the Gödel's Market Newsletter. Each sign up is a sign of support. Topic suggestions are always welcomed and always encouraged.
Tuesday, May 5, 2015
Calculate Number of Up Days Using MySQL Stock Database
I want to show a simple technique using a MySQL stock database. This could potentially be used to give insight into how a stock is currently trending. We will calculate the percentage of "up" days over a given interval.
- Choose your favorite symbol.
- If you already have day info in your database, skip this step. If you have minute info, you'll need to extract each day's open and close data. Use something like the following (switch in your favorite symbol for MSFT) :
CREATE TEMPORARY TABLE IF NOT EXISTS temp_open_close AS (
SELECT DATE(s1.date) as date, s1.open as open, s2.close as close
FROM stocks.stock_prices_minute s1
INNER JOIN stocks.stock_prices_minute s2
ON DATE(s1.date) = DATE(s2.date)
AND s1.symbol = s2.symbol
WHERE s1.date LIKE '%6:30:00'
AND s2.date LIKE '%12:59:00'
AND s1.symbol = 'MSFT') - Now that we have daily open and close info, let's calculate the day's up/down value. A "1" will represent an "up" day, and a "0" will represent an "unchanged"/"down" day. Use the following:
CREATE TEMPORARY TABLE IF NOT EXISTS temp_values AS (
SELECT date, CEIL(ln(close/open)) as upvalue
FROM temp_open_close)
- CEIL() is a function that rounds a value to the next highest integer. (Note: If you're dealing with stocks that increase >100% you will get more than "1" for those up days). - Now we want to find the total up days over a specified period of time.
SELECT COUNT(date), SUM(upvalue)/COUNT(date)
FROM temp_values
WHERE date >= SUBDATE('2013-11-11', INTERVAL 40 DAY)
Conclusion:
This will print out the number of trading days along with the fraction that were up. (This example starts on 2013-11-11, but could be started from any point in history). In this case I get
If you're interested in seeing code that will populate a table with rolling values of this data, sign up for the free Gödel's Market Newsletter. I will be sending out code later this week.
This will print out the number of trading days along with the fraction that were up. (This example starts on 2013-11-11, but could be started from any point in history). In this case I get
28 | trading days with a 53.57% of those being "up". |
If you're interested in seeing code that will populate a table with rolling values of this data, sign up for the free Gödel's Market Newsletter. I will be sending out code later this week.
Wednesday, April 8, 2015
Interviewing the Quants: Dan of Theta Trend
Welcome back to Interviewing the Quants. This is the third interview in the series. Many of you might know our guest from his blog on simple objective options trading. It is called Theta Trend. His name is Dan. He's provided some information to give us some insight into who he is, what he does, and how he does it.
(Note: If you enjoy the following, consider signing up for the free Gödel's Market Newsletter. Two more questions and replies from Dan will be released through the newsletter. For this exclusive content, sign up here.)
GM: What originally interested you about finance and the markets?
TT: I don't know that I ever remember not having an interest in financial markets. When I was really young, I remember my Dad explaining how to read Stock and Bond quotes in the newspaper. Note that this is well before the internet existed. I was always more interested in Bonds than Stocks because I liked the idea of receiving interest payments, but I have been interested in markets ever since I was introduced to them.
GM: What caused you to move towards options?
TT: Towards the end of High School, I set up an account to day trade stocks. It was sometime in the late 90's and I was hoping to skip college and become a professional trader. At the same time, I started reading some of the McMillan options books and became very interested in options. I didn't start trading options at that time, but I credit that for some of my background and initial interest.
When I was in Graduate school, I took a series of classes on trading and traded a small account of school funds. During that time I began trading options because I liked the ability to construct position that needed to be less directionally correct. I felt that options gave me a better a chance to win and I started combining options with other (mainly trend following) strategies.
GM: What type of hobbies, interests, and education background do you have?
TT: I have something of a one interest, compulsive personality and that's reflected in my small list of other interests. Outside of trading, I love to cycle, run, and be active outside. However, I have essentially no interest in any sport sport that involves a ball. Do cats constitute a hobby? I'm not sure, but I have two cats. They seem to like me most of the time, which I view as a compliment.
My educational background is a little mixed. I have an Undergraduate degree in Economics and a Master's degree in Accounting. I spent the majority of my time in Grad school watching the markets during class and pretending Accounting didn't exist. Strangely, after leaving Graduate school I became a CPA and worked as a Tax Accountant for 5 years. That experience helped me realize that I genuinely dislike working as an Accountant and I recently left my job to move and also pursue something more market related. There's a recent post on my site called, "What I've Learned From Living Wrong," that talks a little bit about my background and some of the changes I'm making.
GM: How long have you been trading?
TT: I have been trading on and off since the late 1990's and much more seriously since late 2007. Even when I wasn't trading I was watching markets and reading financial/economic news.
GM: What are some fundamental ideas or principles that arise in your work?
TT: I believe that markets trend and that it's essential to validate trading ideas. Additionally, it's incredibly important to always be asking questions and trying to learn. It's equally important to ask why something is working and why something is not working in the markets.
GM: What lead you to start Theta Trend? Do you find benefit from discussing your ideas in a relatively open and public setting?
TT: On a practical level, I started the blog primarily because I wanted to have a discussion about combining Trend Following with Options and it didn't seem like that discussion was taking place.
I have benefited from the blog in more ways than I ever imagined possible. The site has introduced me to numerous people and other writers who have an interest in markets. Those relationships combined with writing and reflecting continue to make me a better trader. I can't say enough good things about writing the blog; the experience continues to surprise me in positive ways.
--
To receive two more questions and answers from Dan at Theta Trends, sign up for the free Gödel's Market Newsletter. I will be sending them within the next few days.
Please thank Dan for the interview. For more information, insight, and knowledge, visit his site Theta Trend and check out his free guide to becoming a better trader.
(Note: If you enjoy the following, consider signing up for the free Gödel's Market Newsletter. Two more questions and replies from Dan will be released through the newsletter. For this exclusive content, sign up here.)
GM: What originally interested you about finance and the markets?
TT: I don't know that I ever remember not having an interest in financial markets. When I was really young, I remember my Dad explaining how to read Stock and Bond quotes in the newspaper. Note that this is well before the internet existed. I was always more interested in Bonds than Stocks because I liked the idea of receiving interest payments, but I have been interested in markets ever since I was introduced to them.
GM: What caused you to move towards options?
TT: Towards the end of High School, I set up an account to day trade stocks. It was sometime in the late 90's and I was hoping to skip college and become a professional trader. At the same time, I started reading some of the McMillan options books and became very interested in options. I didn't start trading options at that time, but I credit that for some of my background and initial interest.
When I was in Graduate school, I took a series of classes on trading and traded a small account of school funds. During that time I began trading options because I liked the ability to construct position that needed to be less directionally correct. I felt that options gave me a better a chance to win and I started combining options with other (mainly trend following) strategies.
GM: What type of hobbies, interests, and education background do you have?
TT: I have something of a one interest, compulsive personality and that's reflected in my small list of other interests. Outside of trading, I love to cycle, run, and be active outside. However, I have essentially no interest in any sport sport that involves a ball. Do cats constitute a hobby? I'm not sure, but I have two cats. They seem to like me most of the time, which I view as a compliment.
My educational background is a little mixed. I have an Undergraduate degree in Economics and a Master's degree in Accounting. I spent the majority of my time in Grad school watching the markets during class and pretending Accounting didn't exist. Strangely, after leaving Graduate school I became a CPA and worked as a Tax Accountant for 5 years. That experience helped me realize that I genuinely dislike working as an Accountant and I recently left my job to move and also pursue something more market related. There's a recent post on my site called, "What I've Learned From Living Wrong," that talks a little bit about my background and some of the changes I'm making.
GM: How long have you been trading?
TT: I have been trading on and off since the late 1990's and much more seriously since late 2007. Even when I wasn't trading I was watching markets and reading financial/economic news.
GM: What are some fundamental ideas or principles that arise in your work?
TT: I believe that markets trend and that it's essential to validate trading ideas. Additionally, it's incredibly important to always be asking questions and trying to learn. It's equally important to ask why something is working and why something is not working in the markets.
GM: What lead you to start Theta Trend? Do you find benefit from discussing your ideas in a relatively open and public setting?
TT: On a practical level, I started the blog primarily because I wanted to have a discussion about combining Trend Following with Options and it didn't seem like that discussion was taking place.
I have benefited from the blog in more ways than I ever imagined possible. The site has introduced me to numerous people and other writers who have an interest in markets. Those relationships combined with writing and reflecting continue to make me a better trader. I can't say enough good things about writing the blog; the experience continues to surprise me in positive ways.
--
To receive two more questions and answers from Dan at Theta Trends, sign up for the free Gödel's Market Newsletter. I will be sending them within the next few days.
Please thank Dan for the interview. For more information, insight, and knowledge, visit his site Theta Trend and check out his free guide to becoming a better trader.
Thursday, March 26, 2015
Setup Your First MySQL Stock Database
Today we’re going to setup a MySQL database, populate it with some data, and run a simple query. More complicated stuff to come, but this is a great start for those who have never used a relationship database management system (RDBMS) before.
(Note: Sign up for the new Gödel’s Market Newsletter if you find the following useful and want more articles on useful information, including interviews and research.)
Some may say that learning to use an RDBMS takes too much effort. But, depending on how you’re doing your data storage right now, an RDBMS could easily help you organize better (aren’t those CSV/TXT/Excel files piling up?), give you results faster and even give you greater insight into your data.
For this article we’re going to use MySQL. It is among the most popular RDBMS’ out there, and it is open source and free. Many sites use it, including Facebook, which serves over 1 billion people tons and tons of data.
Steps:
I’ll be posting more on how to continue on from here. In the meantime, sign up for the Gödel’s Market Newsletter. Information not available on the blog is sent out through the newsletter. Click here to sign up!
Best of luck.
(Note: Sign up for the new Gödel’s Market Newsletter if you find the following useful and want more articles on useful information, including interviews and research.)
Some may say that learning to use an RDBMS takes too much effort. But, depending on how you’re doing your data storage right now, an RDBMS could easily help you organize better (aren’t those CSV/TXT/Excel files piling up?), give you results faster and even give you greater insight into your data.
For this article we’re going to use MySQL. It is among the most popular RDBMS’ out there, and it is open source and free. Many sites use it, including Facebook, which serves over 1 billion people tons and tons of data.
Steps:
- You’ll want to download a copy at the following link:
http://dev.mysql.com/downloads/mysql/ (make sure to select the download appropriate for the operating system you are using).
- Installation should be fairly automated. Just click next and make sure you don’t install any “Ask Jeeves” adware…Make sure you do a full install which should include the MySQL Workbench. This will be our method for working with the MySQL Server.
- Next, grab some sample data from Yahoo. Go to your favorite stock ticker, and select “Historical Data” on the left hand side. Then go down to the bottom of the page and click on “Download to Spreadsheet”. Here’s a link for MSFT: http://finance.yahoo.com/q/hp?s=MSFT+Historical+Prices This will download a file called “table.csv” which is exactly what you want. If you open it up you’ll see your stock’s data (date, open, high, low, etc).
- Now open up MySQL Workbench CE 6.* (I’m using 6.2, but they should all be very similar). You should have a database called “local”. Double click on that. If you need to setup a database you’ll want to create one locally. There will be a “root” user which should be fine for our purposes at the moment. Assign a password and connect.
- Now that you’re connected to the database, take a look at the left side. You’ll see something called “Schemas”. We need to create a new one for stocks. You can either right click below the existing Schemas and select “Create Schema” or you can go up to the top bar and click the icon “Create a new schema in the connected server.”
- For your new schema, name it something like “stocks”. Use the default “Collation” and click “Apply”. Click “Apply” again on the creation script and again if needed. Then click “Finish” and you should have a new schema to the left.
- Click on the drop down arrow to the left of your new schema. Right click on “Tables” and choose “Create Table…” For table name choose something like “historicaldata”. Go down to Column Name and double click below it to add a new column. You’ll want a column for every row in your “table.csv” file. So one column for “Date”, “Open”, “High”, “Low”, “Close”, “Volume”, “Adj Close”.
For Datatypes, you’ll want “DATETIME” for “Date”. For “Volume” you’ll want to use “INT”. For the others you’ll want to use “DECIMAL(10,3)”. You can use other data types, but these work well enough for what we’re doing.
- Now right click on your new table “historicaldata” under “Tables” within your newly created schema on the left hand side. You’ll want to choose “Select Rows”. This will bring up all the data you currently have in the table, which should be none. Go to the middle portion where you’ll see some icons following “Result Grid”. Go to the “Export/Import” tag, and click on the “Import records from an external file” icon.
This will let you choose a “CSV” file for import. Before you choose “table.csv” open it up and remove the first line with the headers (i.e. Date, Open, High, etc etc). If you don’t, this will also get imported (there are ways around this, but I’m keeping this intro simple). Now you can choose your “table.csv” file for import. It’ll take a little bit to import and then should load up the data on screen.
- Now you can run your first query. Go up to the icon with “SQL” and a little plus on it. It should be right below “File” at the top. This should open a new tab for SQL queries. Type the following and press “CTRL” + “ENTER” or click the “Execute” icon (a little lightning bolt).
SELECT * FROM stocks.historicaldata
This should return everything from your table. Not very useful, but it’s a start. Next try something like:
SELECT * FROM stocks.historicaldata WHERE date > ‘2015-03-01’
Try:
SELECT * FROM stocks.historicaldata WHERE open > close
I’m sure you can come up with some more on your own! There will definitely be more on this in the future.
I’ll be posting more on how to continue on from here. In the meantime, sign up for the Gödel’s Market Newsletter. Information not available on the blog is sent out through the newsletter. Click here to sign up!
Best of luck.
Monday, February 16, 2015
Interviewing the Quants: Marco Simioni and Nightly Patterns
Welcome back to Interviewing the Quants. This will be
the second interview in the series. Many of you might know our guest from his trading
at Nightly Patterns (http://nightlypatterns.wordpress.com).
His name is Marco Simioni and he’s agreed to give us greater insight into what
he does and who he is.
(Note: This interview took place via email and
has been formatted as an article.)
GM: What lead you to
quantitative trading?
MS: Well, my first
approach to quantitative trading was while still at university during my first
Statistics course. I was used to math, but probabilistic theory completely changed my view on
trading. I remember before that course how focused I was on Elliot and Gann
theories. Both work, but what I was lacking was
an objective approach to trading. I switched from one oscillator to another,
indicators and classical technical analysis patterns. But I was still looking for a more systematic way to
trade. Finally I came across Michael Harris and Larry Connors' research.
GM: What's your background
academically?
MS: I
studied Mechanics at high school. Instead of going on with
engineering at university I changed my mind and started Economics. I got
a Bachelor Degree in Marketing and Management at Cà
Foscari University with a thesis in Statistics focusing on Auto Regressive
Integrated Moving Average processes. I then specialized with a
Master Degree in Economics and Finance with quantitative and risk
management oriented studies in the same University with a thesis
on a historical analysis of first days market behavior
of tech IPO's. All of this apart from my more than ten years of trading
studies...
MS: I've been trading since 2006. I am 28 years old. Despite my quantitative overnight trading I do use many other strategies too. I'm a fan of ETF rotational strategies, VIX ETP's quantitative systems, and mean reverting stock swing trading. My academic background led me through Graham fundamental studies, Greenblatt's formula, and O'shaughnessy's portfolios. I became an overnight trading researcher mainly because it’s uncorrelated to other strategies I use, which results in greater portfolio diversification. And it seemed nearly nobody cared about its profitability at all.
GM: Which principles do you find most useful?
MS: I believe there are two core market principles: a mean reverting regime and a trend following regime. Here sometimes financial academics studies are preceded by traders' experiences. The first more intuitive effect deals with overbought and oversold market conditions. Nearly 70% of all my patterns are mean reverting. I'm constantly researching momentum patterns too, but they are much more difficult to discover. I believe momentum market studies make the difference, because they can prevent false or losing mean reverting trades. So many systems do not work properly mainly because they are not able to detect the differences between these two key market principles.
GM: Are there any ideas that you find yourself going back to again and again? If so, what are they?
MS: Money management strategies. I'm referring to Kelley's formula, Vince works, Thorpe's studies, Larry Williams's or again Turtles' approaches. I could add many other equally brilliant researchers like Ziemba, Lundstrom and many others and still I would miss someone. I believe whatever system or strategy you trade, money management is vital to survive the markets and deal with high leverage. I'm constantly looking for a better position sizing technique, as I believe something more is still out there to be found.
GM: Why did you decide to create the NightlyPatterns blog?
MS: Trading successfully is difficult. I remember a study from Taiwan stock exchange that highlight the % of successful traders from their account’s net results. It seems that 95% of futures traders after 6 months end burning up all their starting equity. It takes years of researching and testing to build a consistent and successful trading strategy. And when a trader succeeds with it, he keeps it a secret. I started Nightly Patterns blog as a free trading diary, and then I decided to move it to a more professional service. There are so few really successful futures trading rooms that I decided to enter the business.
GM: What is something most people might find surprising about you or your trading style?
MS: Many traders and bloggers are surprised by my young age. Volatility has kept increasing during the last ten years. Huge algo-trading with “robot” volumes, high tech 2000 end bubble, subprime crisis, commodities crashes, sovereign debt crisis, zero interest behavior environment and currency wars completely changed many old market dynamics. Despite my ten year experience, I believe more in quantitative back testing than a thirty or forty year market experience. This is my "quant" view.
GM: Are there any suggestions you would give to an aspiring trader?
MS: Just read whatever you can about trading before trading. Do not trade first. Just read. Read a lot. Don't get lost in the academic finance research, but don't get lost in all those unhelpful trading books out there either. Read one academic paper from a university teacher on markets and investments and then one trading book from a trader. Do this again and again. Look for your own trading style. Take something from all the books and papers you read and collect everything. Then read blogs and all the website can teach you something. Your trading success will come to you before trading. And of course try to follow some well established traders and mirror them, you will survive the markets.
GM: Thank you for sharing with us today. Do you have any last thoughts?
MS: My last thoughts go to consistency and systems diversification. If you have a system, follow it. This is vital. Follow your system, not your gut. Do not cherry pick your strategies; this will lead you to bankruptcy. You will find yourself taking the worst trades and missing the best ones. If you have a winning system just trade it but always look for another one to add to your trading arsenal. This will lead your results to approach Shannons' Demon Effect. I wish you all a good trading. Thank you very much for your attention.
GM: Thank you again Marco. Thank you everyone else for reading, and please visit him at Nightly Patterns.
Sunday, January 11, 2015
Interviewing the Quants: An Inside Look With “Sanz Prophet”
Our first guest for the “Interviewing the Quants” series is
Vangelis Maderakis. Many of you probably know him as Sanz Prophet through the
eponymous blog (sanzprophet.blogspot.com). Recently, he became a partner at Logical Invest,
a successful business dedicated to logical, rules based investing.
I’ve asked him if he would answer some questions, hopefully giving
readers in the quantosphere greater insight into the mind of an online quant. So, even before we begin, please thank Vangelis Maderakis for
joining us today!
(Note: This interview takes place via
email and has been formatted as an article.)
GM: What experience did you have with finance before you started?
VM: Although I did start as an engineer and
hold a B.A. in Economics I ended up following my passion at the time, filmmaking.
I have trained as a director/producer and have directed commercials for a
living. I started trading and managing money during the 2007 crisis and
discovered I like the quant side of it. I have been developing systems and
trading ever since.
GM: How do you develop most of your ideas?
VM: Reading books, research papers and blogs.
I like to backtest all kinds of ideas. From obscure fx strategies to option strategies
that sound ‘logical’ but do not stand up to scrutiny. At one point you realize
the market is just a sum of all participants and will adapt onto itself. Then
you start asking simple questions: How will the rise of Wealthfront and other
similar services affect the market? Or as a private investor what are my
advantages vis-à-vis the larger players or even ETF issuers?
I believe there are good ideas to be found in the public sphere. Like
in many areas of life the difficulty is not in finding the idea. It is in
actually deploying it into the real world. Many people will stop at the first
stage.
GM: What inspired you to write a blog about finance?
VM: The quant blogging community. People like Michael Stokes of
MarketSci who was not just enlightening but also entertaining. I also felt the
need to reach out to other independent minded investors and bloggers and
exchange ideas.
GM: What is the most essential or fundamental lesson you've
learned from the markets?
VM: To have a plan or strategy. To simplify. To be patient. To
think outside the box. To try not to lose rather than trying to win. Also I
have learned that markets are counter-intuitive and extremely unjust. It’s like
flirting. Trying too much does not guarantee success. You need to be open
minded and flexible. You need to care. But you cannot be desperate.
GM: What is your favorite type of market and why?
VM: A sideways moving market. From a risk management perspective, a
bull market is as challenging as a bear market. A system developer who is
conservative will likely underperform a straight bull run because they need to
protect the account from a possible unexpected event.
In a sideways market one can trade with less risk since the
average participation time is usually low. So from a risk management point of
view, a side market can be desirable given one can find the system to exploit
it.
GM: What are ideas you find yourself returning to again and again?
VM: Under-deployment of funds and mismanagement of the
‘big-picture’. That is my most common concern.
A private investor will likely split up their available capital
and buy different kinds of assets, strategies, individual stocks, etc. It’s a
natural instinct to diversify and not put all eggs in one basket. The problem
is that there is no easy way to tell how her whole portfolio behaves. Is it
truly diversified? Is she deploying all available capital or risking too much
in small risky instruments while the bulk is sitting idle in cash?
So what I find myself looking for is a ‘total’ strategy that
supersedes sub-strategies and can track and adaptively allocate to them. A
meta-strategy of strategies. That is one of our goals at Logical Invest.
The other idea is more philosophical. I find myself thinking that
in trading as in life, the main truly scarce and non-tradable asset is time.
Since investment is really a compounding game, any mediocre young investor will
most likely outperform by a large margin anyone who is double his age. Of
course the young investor doesn’t know this. So the older person needs to guide
him.
GM: So that the younger person is able to utilize those extra years
wisely?
VM: Yes. It would be smart to invest early on but one doesn’t even
need to be that smart an investor. I would argue that on a 30+ year timeline
being mediocre is sufficient. The assumption, of course, is that the money
survives the course of unpredictable foolish human passions, socio-political
changes and all the things that hopefully our kids will get to experience that
are more interesting than money
.
GM: How did you come to join Logical Invest?
VM: As a quant blogger, I was exchanging ideas with Alex and
Scott. Part of those ideas were testing Frank Grossmann’s strategies.
Eventually we met Frank and he invited us to join Logical. So over at Logical, we
still develop strategies but now we can be challenged and disciplined into a
steady flow of production. It’s quite exciting. We feel we are operating in the
fringes of the financial world offering institutional+ level strategies for
$30. It’s quite outrageous, really. Some of our subscribers are wealth
managers. Recently a lot of physicians have joined. So you can say that at this
point we cater to self-minded, educated individuals.
GM: Do you have any final thoughts for readers?
VM: A quote by Dennis Richards:
“I don’t think trading strategies are as
vulnerable to not working if people know about them, as most traders believe.
If what you are doing is right, it will work even if people have a general idea
about it. I always say you could publish rules in a newspaper and no one would
follow them. The key is consistency and discipline.”
GM: Thank you very much for sharing with us
Vangelis
Maderakis. Please visit him at Logical Invest and his blog Sanz Prophet.
Subscribe to:
Posts (Atom)