Skip to content

Using Python and Machine Learning to identify trends in small cap stocks under $25 and possible swing trades

License

Notifications You must be signed in to change notification settings

jabez007/Swing_Oracle

Repository files navigation

Swing_Oracle

Using Python and Machine Learning to identify trends in small cap stocks under $25 and possible swing trades

Resources

Outline

Training

We will use the screener API to search for securities that have a 52 Week Low >= $1.00 and a 52 Week High <= $25.00, with a Market Capitalization between $300,000,000 and $2,000,000,000, and an Average Daily Volume over 500,000

https://api.intrinio.com/securities/search?conditions=52_week_low~gte~1.00,52_week_high~lte~25.00,marketcap~gte~300000000,marketcap~lte~2000000000,average_daily_volume~gte~500000

to get out our list of ticker symbols. With that list of tickers, we will go through each one to pull the last 100 days worth of data from Alpha Vantage

https://www.alphavantage.co/query?function=TIME_SERIES_DAILY&symbol={symbol}&apikey={apikey}

And those 100 days will then be split on a Sequence Size of 20 to train our Recurrent Neural Network LSTM model

Forecasting

Here we will again use the screener API to search for securities that have a 52 Week Low >= $1.00 and a 52 Week High <= $25.00 with a Market Capitalization between $300,000,000 and $2,000,000,000, and an Average Daily Volume over 500,000

https://api.intrinio.com/securities/search?conditions=52_week_low~gte~1.00,52_week_high~lte~25.00,marketcap~gte~300000000,marketcap~lte~2000000000,average_daily_volume~gte~500000

to get out our list of ticker symbols, and with that list of tickers pull the last 100 days worths of data from Alpha Vantage

https://www.alphavantage.co/query?function=TIME_SERIES_DAILY&symbol={symbol}&apikey={apikey}

From there, we will take only the last 20 days of data from each ticker to seed our model and run a forecast for the next 20 days. We will then plot and analyze the forecasts looking for potential long term swing trades.

Technical

Training

  • 2 -> Can represent an arbitrary decision boundary to arbitrary accuracy with rational activation functions and can approximate any smooth mapping to any accuracy.
  • >2 -> Additional layers can learn complex representations (sort of automatic feature engineering) for layer layers.
  • The number of hidden neurons should be between the size of the input layer and the size of the output layer.
  • The number of hidden neurons should be 2/3 the size of the input layer, plus the size of the output layer.
  • The number of hidden neurons should be less than twice the size of the input layer.

Since our input is going to be (20, 5) and our output is (1, 5), it seems like our number of neurons should be in the 128 to 256 range. We can bump up the number of neurons to the 512 to 1024 range as long as we include Dropout layers to avoid overfitting.

  • linear
  • tanh -> squashes a real-valued number to the range [-1, 1] so its output is zero-centered.
  • ReLU (leaky Rectified Linear Unit) -> this function computes f(x)=1(x<0)(αx)+1(x>=0)(x) where α is a small constant.
  • mean squared error (mse) ->
  • mean absolute error (mae) ->
  • mean absolute percentage error (mape) -> we want to minimize the percentages that our true is off from our prediction
  • adam

About

Using Python and Machine Learning to identify trends in small cap stocks under $25 and possible swing trades

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages