Monte Carlo Simulation of a Stock Portfolio with Python

Поделиться
HTML-код
  • Опубликовано: 17 мар 2021
  • What is Monte Carlo Simulation? In this video we use the Monte Carlo Method in python to simulate a stock portfolio value over time.
    ★ ★ Code Available on GitHub ★ ★
    GitHub: github.com/TheQuantPy
    Specific Tutorial Link: github.com/TheQuantPy/youtube...
    ★ ★ QuantPy GitHub ★ ★
    Collection of resources used on QuantPy RUclips channel. github.com/thequantpy
    ★ ★ Discord Community ★ ★
    Join a small niche community of like-minded quants on discord. / discord
    ★ ★ Support our Patreon Community ★ ★
    Get access to Jupyter Notebooks that can run in the browser without downloading python.
    / quantpy
    ★ ★ ThetaData API ★ ★
    ThetaData's API provides both realtime and historical options data for end-of-day, and intraday trades and quotes. Use coupon 'QPY1' to receive 20% off on your first month.
    www.thetadata.net/
    ★ ★ Online Quant Tutorials ★ ★
    WEBSITE: quantpy.com.au
    ★ ★ Contact Us ★ ★
    EMAIL: pythonforquants@gmail.com
    Disclaimer: All ideas, opinions, recommendations and/or forecasts, expressed or implied in this content, are for informational and educational purposes only and should not be construed as financial product advice or an inducement or instruction to invest, trade, and/or speculate in the markets. Any action or refraining from action; investments, trades, and/or speculations made in light of the ideas, opinions, and/or forecasts, expressed or implied in this content, are committed at your own risk an consequence, financial or otherwise. As an affiliate of ThetaData, QuantPy Pty Ltd is compensated for any purchases made through the link provided in this description.

Комментарии • 108

  • @thetagang6854
    @thetagang6854 2 года назад +4

    Best video on the internet on financial monte carlo simulation with python

  • @sergiopadronarellano5437
    @sergiopadronarellano5437 Месяц назад

    Direct and quick!!! Excellent!

  • @linghaoyi
    @linghaoyi Год назад

    Thank you for your excellent tutorials. Merry Christmas and Happy New Year!

  • @minkowski4d
    @minkowski4d 2 года назад +6

    Great video. You may directly create a multivariate distribution. And it’s always better to use e.g. a Student t Distribution with EWMA in order to estimate the covariance matrix. Otherwise you’re model is going to produce too many overshoots

  • @youssefouazzanichahdi2355
    @youssefouazzanichahdi2355 3 года назад +1

    Great video ! Thank you for your efforts, really helpful

  • @user-bk1wt8tt3f
    @user-bk1wt8tt3f 4 месяца назад

    nicely done, straight to the point

  • @deAraujoAndre
    @deAraujoAndre 2 года назад

    Amazing work! Thank you for sharing!

  • @FranklinNana
    @FranklinNana 2 года назад

    Great Video ! These are really really helpful

  • @johndavis8646
    @johndavis8646 2 года назад +69

    turn the background music down please next time, very distracting

  • @chilliking3424
    @chilliking3424 2 года назад

    Great stuff! thanks for sharing!

  • @LuanNguyen-pl2wf
    @LuanNguyen-pl2wf 2 года назад

    very neat, thank you for the video !

  • @maximfilev2982
    @maximfilev2982 Год назад +3

    Thank you for the video! How did you do the animation of mc in the beginning of the video? Sorry, if it is an easy question, I'm newbie in programming

  • @zehtre4716
    @zehtre4716 2 года назад +4

    really good video. question: could you calculate the historical variance of the portfolio and use that instead of the L matrix? something like portfolio_returns_t = portfolio_std*Z_t

  • @idhaslil920
    @idhaslil920 2 года назад

    Keep on the good stuff mate :)

  • @NarendraHegade
    @NarendraHegade 2 года назад +1

    Great video!

  • @AkashChauhan-rw1qh
    @AkashChauhan-rw1qh 3 года назад +3

    Great video thank you so much for sharing with us..........
    Could you please create a video on stress testing also while using MC + (VaR, ES)

  • @edwinkwok70
    @edwinkwok70 2 года назад +1

    Very useful video, are we assuming the randomness follows a geometric brownian motion ?

  • @frodewilkensen
    @frodewilkensen Год назад

    Great video! Is there a quick adjustment for me to replicate this code but only for a single security with a specified estimate on volatility?

  • @tteejayyful
    @tteejayyful 3 года назад +11

    Great video! It'd be interesting to see how you'd translate this into a back-testable strategy as well

    • @QuantPy
      @QuantPy  3 года назад +5

      Definitely only a simplified model - assuming returns are normally distributed. However a good back-test is to always be checking covariance parameters are aligned to current market conditions

    • @johannesporphyrius5739
      @johannesporphyrius5739 11 месяцев назад

      @@QuantPy Yeah, a backtesting video, if possible, would be assume. Thanks for your great work anyway (-:

    • @minkowski4d
      @minkowski4d 7 месяцев назад

      dePrado Deflated Sharpe Ratio and other Sharpe Ratio concepts.

  • @Kakben
    @Kakben 3 года назад +4

    Nice video with clear sound and good visuals. I'm not sure it's for you, but how would you feel about improving the algorithm by moving the Cholesky calculation out of the loop? It only needs to be calculated once, right?

    • @QuantPy
      @QuantPy  2 года назад +1

      Great suggestion. Yes the lower triangular matrix for the cholesky composition can be moved above and out of the loop.

  • @mehrankhoshnood1997
    @mehrankhoshnood1997 2 года назад +1

    hi thanks for impressive video. I am majoring in finance and i cant come up with research topic regarding portfolio optimization. can you help me with this issue? any recommendation from you can be really instructive

  • @arshsadh7332
    @arshsadh7332 Год назад +1

    Great explanation for Monte Carlo simulation.
    I was trying it out for a single stock but on my code it is showing :
    ModuleNotFoundError: No module named 'pandas_datareader'
    How can i rectify this?
    I downloaded pandas, numpy and matplotlib on the terminal but it's still not working.

  • @mahasleman5755
    @mahasleman5755 2 года назад +1

    Thank you ,

  • @TheOmnipotentDude
    @TheOmnipotentDude Год назад

    Could you explain what changes would be need to be made if my time series is monthly instead of daily?

  • @riadalhasanabir6716
    @riadalhasanabir6716 Год назад +8

    I am running your code in Jupiter Notebook. However, when I am running this line "meanReturns, covMatrix = get_data(stocks[0], startDate, endDate)", it gives me an error saying "TypeError: string indices must be integers." Can you suggest me how to solve this problem?

    • @Roman-bn9qv
      @Roman-bn9qv Год назад +1

      i have the same problem... can you solve??

    • @MicheleCedolin
      @MicheleCedolin Год назад

      Did you solve it ?

    • @yashprajapati70
      @yashprajapati70 Год назад

      getting the same error, can someone help me out?

    • @yashprajapati70
      @yashprajapati70 Год назад +5

      import pandas as pd
      import numpy as np
      import matplotlib.pyplot as plt
      import datetime as dt
      from pandas_datareader import data as pdr
      import yfinance as yf
      yf.pdr_override()
      use this code

    • @yashprajapati70
      @yashprajapati70 Год назад +5

      @@MicheleCedolin import pandas as pd
      import numpy as np
      import matplotlib.pyplot as plt
      import datetime as dt
      from pandas_datareader import data as pdr
      import yfinance as yf
      yf.pdr_override()
      use this

  • @vegasruan6640
    @vegasruan6640 Год назад

    Could you kindly explain if this process consider rebalancing the portfolio?

  • @superuser8636
    @superuser8636 Год назад

    When inserting a matrix/vector of zeroes you can use np.zeros()

  • @FRANKWHITE1996
    @FRANKWHITE1996 3 года назад +1

    thanks!

  • @kevinshao9148
    @kevinshao9148 5 дней назад

    Thanks for the GREAT video! One question if I may: at 11:42, would you please elaborate, or if you have another link, for this return formula + Cholesky application? Thanks a lot!

  • @kachunpang7543
    @kachunpang7543 22 дня назад

    Hi PyQuant! May I know is it possible to simulate stock prices using the same technique? In this video you assume the returns follows multivariate normal distribution and then do the Monte Carlo simulation for returns. I am wondering if I can do the same thing for stock prices by assuming certain distribution such as GBM?

  • @flyingsalmon
    @flyingsalmon 9 месяцев назад

    Cool video and walk-through. However, how do I make sense of the cool line chart with all simulation paths? The portfolio values in 100 days can be 4000 or 19000 for example. What is the chart telling me in terms of insights? Or would a histogram be more appropriate where we can at least see the buckets and frequency?

    • @SirHiss17
      @SirHiss17 5 месяцев назад

      Histogram would be more appropriate

  • @chriss4396
    @chriss4396 Год назад

    What number is typically used as pseudo-random numerical generator in portfolio theory of Monte Carlo?

  • @matthewwiles2996
    @matthewwiles2996 2 года назад

    If I wanted this in a fan chart showing confidence intervals what would I do.

  • @raining1975
    @raining1975 5 месяцев назад

    I am trying to create a retirement calculator for myself and one thing I would like to do is compare Roth Vs Traditional but for example with Roth IRA vs Trad IRA, you can't compare 6500 Roth vs 6500 Trad, you have to compare 6500 Roth vs 6500 Trad + Investing the difference into a brokerage ($6500 Roth vs $6500 Trad + $X in brokerage). I can kind of figuring out what X is by calculating take home with 6500 Trad and subtracting what the take home is for 6500 Roth, the problem is that most index funds have a dividend component. That doesn't matter in an IRA but that $X that would be in a brokerage would have you paying taxes on those dividends which would mess up the calculations. I would need to figure out what the taxes are on those dividends to make it so that the usable income is identical in both examples that I am comparing. I can figure out the taxes for LTCG on qualified dividends but I am not sure how to calculate how much of a dividend you get over time.
    Do you know of any good videos or articles on anything related to calculating dividends in python?

  • @svenhaile5946
    @svenhaile5946 14 дней назад

    portfolio_sims meaning portfolio of simulations? Tip: Use the typing module to explain types and use descriptive variables to make sense

  • @williamdhudson
    @williamdhudson 2 года назад +1

    Great video! With the function to create random weights for the portfolio, is there a way to alter it to make minimum weights? Also, what if I want to run a Monte Carlo on a portfolio where I already know the weights and don't want to generate random weights?

    • @QuantPy
      @QuantPy  2 года назад

      Please note that I’m not optimising the weights of this portfolio.
      I’m just assigning random weights once. You can replace that line with you individual weights in a list / numpy array.👍

    • @jeromeordona7549
      @jeromeordona7549 2 года назад

      If you want to specify your weights, you could make an array that has the same length as the number of stocks but just manually enter the weights. Just make sure the weights add up to 1. IE: weights=[.2, .2, .2, .1, .1, .2]

  • @stickle1727
    @stickle1727 Год назад

    How is the Monte carlo method different to the ARIMA and LSTM models?

  • @gustavofelicidade_
    @gustavofelicidade_ Год назад

    You are awesome

  • @giovannilarosa3327
    @giovannilarosa3327 2 года назад

    Is there a way to adapt the monte carlo simulation when there is a dynamic allocation of the portfolio. In much simpler words: I change the stocks in the portfolio with a weekly frequence following certain algorithms (technical, etc.) Is it possible to construct a code that can read the stocks in portfolio and calculate the max potential loss every week? Thanks for attention

    • @QuantPy
      @QuantPy  2 года назад

      Yes this is possible, honestly if you can define what you’d like to do, you can almost certainly implement a solution.
      Feel free to adjust the code as needed. Good luck

  • @saheedfalola3033
    @saheedfalola3033 3 года назад +1

    This is amazing. I have a question: do you need to connect to Bloomberg (or any other terminal) for this code to run?
    I am getting the following error message :
    print(meanReturns)
    Traceback (most recent call last):
    File "", line 1, in
    print(meanReturns)
    NameError: name 'meanReturns' is not defined

    • @QuantPy
      @QuantPy  3 года назад +2

      Definitely not 👍
      I can see here you are trying to print meanReturns (in line 1) without having defined it?
      Make sure you call the getData function and declare meanReturns variable.

    • @saheedfalola3033
      @saheedfalola3033 3 года назад

      @@QuantPy Thanks a lot. I am a bit stocked again.
      def get_data(stocks, start, end):
      stockData=pdr.get_data_yahoo(stocks, start, end)
      StockData=StockData['Close']
      returns=stockData.pct_change()
      meanReturns=returns.mean()
      covMatrix=returns.cov()
      return meanReturns, covMatrix
      stockList=['CBA', 'BHP','TLS','NAB','WBC','STO']
      stocks=[stock + '.AX'for stock in stockList]
      endDate=dt.datetime.now()
      startDate=endDate-dt.timedelta(days=300)
      meanReturns,covMatrix = get_data(stocks,startDate,endDate)
      print(meanReturns)
      Traceback (most recent call last):
      File "", line 14, in
      meanReturns,covMatrix = get_data(stocks,startDate,endDate)
      File "", line 3, in get_data
      StockData=StockData['Close']
      UnboundLocalError: local variable 'StockData' referenced before assignment
      It is now saying "local variable 'StockData' referenced before assignment
      " - not sure what I am getting wrong

    • @QuantPy
      @QuantPy  3 года назад +1

      You’ve typed stockData=stockData[‘Close’] incorrectly, you placed a capital letter on StockData. Python variables are case sensitive. My advice, read the error message and work through the code line by line next time 👍 good luck

    • @saheedfalola3033
      @saheedfalola3033 3 года назад +1

      @@QuantPy Wow, I just couldn't see that. The could has worked now!! Thanks! It is such a tremendous work you are doing. God bless

  • @helio7478
    @helio7478 2 года назад +1

    Nice video! Two quick questions tho:
    1) the length of the cov matrix is len(weights) x len(weights), right? so why the inner product (L,Z) works? should it not be inner(Z,L) since Z is (T,len(weights)? And therefore meanM can be (T, len(weights)) and not the transpose of that...
    2) Why is it necessary to sum the mean in the calculation of the daily returns? Couldn't I just use the inner product?

    • @helio7478
      @helio7478 2 года назад

      the second question I just checked is to make the new synthetic time series have the same mean as the original. If I don't do this I get a matrix with the same covariance but not the same mean. Do we want them to have the same mean as well?

  • @PaulConnor
    @PaulConnor 2 года назад +12

    This is seriously impressive & makes a lovely graph but can you explain how to use the output in practice?

    • @bohdanzhuravel5642
      @bohdanzhuravel5642 Год назад +2

      This stuff gives you an understanding, what can be with your portfolio, based on daily stocks returns

  • @andrewbloomfield6905
    @andrewbloomfield6905 3 года назад +1

    Hello, thanks for the video, very helpful. What Python environment are you using here?

    • @QuantPy
      @QuantPy  3 года назад

      I’m using anaconda’s conda for python environment, the IDE is Visual Studio Code.

    • @andrewbloomfield6905
      @andrewbloomfield6905 3 года назад +1

      @@QuantPy thank you!

  • @timmolendijk
    @timmolendijk 6 дней назад

    What's the point of complicating matters by throwing in abstractions/ indirections such as covariance matrix and cholesky decomposition, when we can just simulate portfolio returns by calculating cumprod of weighted stock returns directly?

  • @yashsharma7243
    @yashsharma7243 4 месяца назад

    What is the maximum no of simulations which we can run and does it depend on computing power?

  • @georgelampropoulos6642
    @georgelampropoulos6642 2 года назад +1

    Great attempt! In your video you don't mention anything about volatility. Have you made any specific assumptions on this matter?

    • @QuantPy
      @QuantPy  2 года назад +2

      Yes, we’ve made a significant assumption about volatility. The covariance matrix is where this comes in.
      By computing the historical covariance matrix using past stock data, we are assuming that the stock returns will follow these correlations and volatility with respect to each other, into the future.

    • @georgelampropoulos6642
      @georgelampropoulos6642 2 года назад +1

      @@QuantPy Big Thumbs Up!!You helped me understand MC simulation completely!! Keep up the exceptional work!

  • @15MuM
    @15MuM 3 года назад +1

    Hi there thanks for the video. If I want to change the Stock list e.g. TSM (available on yahooFinance) I get the following error: RemoteDataError: No data fetched using 'YahooDailyReader' . Any solutions or ideas there?

    • @QuantPy
      @QuantPy  3 года назад +2

      Think I may have mentioned in the video, you’ll need to remove “.AX” from the stock name. Just send “TSM” through 👍

  • @TheUndergraduateQuant
    @TheUndergraduateQuant 6 месяцев назад

    what re the titles of the books on the table?

  • @0xsuperman
    @0xsuperman 9 месяцев назад

    How do you memorize all your code?

  • @marku7z
    @marku7z 2 года назад

    What would be the strategy if we would want to optimize the weights in order to find the best Portfolio weights?

    • @QuantPy
      @QuantPy  2 года назад

      This video isn't about portfolio optimisation, but to answer your question you should look at maximising some kind of utility function with certain constraints. Famous optimisation solution to this is obviously Modern Portfolio Theory - check out my video on that for more

  • @jerryli631
    @jerryli631 3 года назад +2

    great video. Will you produce var calculation with mcs in python?

    • @QuantPy
      @QuantPy  3 года назад

      Will be the next video

  • @andreaardemagni6401
    @andreaardemagni6401 10 месяцев назад

    I have a doubt. Once you compute daily returns your portfolio weights change. Your code assume weights are constant and that doesn’t sound right to me. In other words, if a stock daily returns on any given day jump about 10% (extreme example) then its weight at the end of that day will be greater than the one at the beginning of the day. Thoughts?

    • @dnb_finance
      @dnb_finance 9 месяцев назад

      The weights are the weights of each stock in your portfolio, for example if you have 100 dollars total, 2 stocks, and the weights on those stocks are 0.5 and 0.5 you will have 50 dollars allocated to each stock.

  • @lex494
    @lex494 8 месяцев назад

    Hey man, there is an article on medium that ripped off your code 1:1.

  • @user-uv5lr7bk8n
    @user-uv5lr7bk8n 3 месяца назад

    the most important thing is action, like what can you actually do with that?

  • @Tyokok
    @Tyokok 7 часов назад

    Hi QuanPy, thanks for the great video! One question do you have any detailed explain or recommended material for the portfolio return at the t, the formula you show up on the right upper corner from 11:35? I know single stock Brownian Motion, but I am not following why portfolio return is in that form and why use timeseries mean return as level. Also should it depend on t as well as BM? Many Thanks!

  • @sayednab
    @sayednab Год назад

    why I can't add my own stocks?

  • @Kjon48
    @Kjon48 2 месяца назад

    Just to tell you that I could not see the code written on the screen because it is black and very small. I wish you had made it bigger, and you had made your picture not big. I was looking forward to learning from you.

  • @ButchCassidyAndSundanceKid
    @ButchCassidyAndSundanceKid 4 месяца назад +1

    @0:07 It's the top left, not top right screen. Well, my monitor at least.

  • @hkccp
    @hkccp Год назад

    How about a portfolio with equity and cds and bonds

  • @sarthaksarode3982
    @sarthaksarode3982 Месяц назад

    'NoneType' object has no attribute 'group' getting this error

  • @hendrikvanbrantegem7526
    @hendrikvanbrantegem7526 Год назад

    Great work man! but please remove that background sound

  • @maxhohenstein2602
    @maxhohenstein2602 Год назад

    well i tried the code but by loading the data from yahoo there comes the error no data fetched from yahoo finance does anybody know how to fix that?

  • @bogdan-remuspintilie5569
    @bogdan-remuspintilie5569 5 месяцев назад

    (Might help some of you)
    Ran into an issue with pandas_datareader when importing on VS code. It was because of the interpreter used on VS code.

  • @JianweiSu
    @JianweiSu Год назад

    I have a question. I am confused why you do +1 and np.cumprod? shouldn't np.inner(weights, dailyReturns.T) be the portfolio daily return?

  • @gogutier1
    @gogutier1 15 дней назад

    Nice! but te music is too loud.

  • @inconnuxtd
    @inconnuxtd Год назад

    i like your video but please lower the music ^^

  • @Sachinshastri
    @Sachinshastri Год назад

    What is the significance of covariance matrix here?

  • @al-azzouz309
    @al-azzouz309 28 дней назад

    Background music that last for two minutes is very noisy

  • @robertcasey1708
    @robertcasey1708 7 месяцев назад +1

    Dude your music is too loud

  • @stonecastle858
    @stonecastle858 Год назад

    I'd love this without the annoying background music at the start that is sometimes more audible than your voice!

  • @theanxiousinvestor4508
    @theanxiousinvestor4508 Месяц назад

    What is with the stupid background music?

  • @candy3935
    @candy3935 11 месяцев назад +3

    Hi! I'm having the following error:
    Traceback (most recent call last):
    File "D:/Programming/PycharmProjects/Modelos Computacionales 2021/Clase 8/Método de Monte carlo.py", line 24, in
    meanReturns, covMatrix = get_data(stocks, startDate, endDate)
    File "D:/Programming/PycharmProjects/Modelos Computacionales 2021/Clase 8/Método de Monte carlo.py", line 11, in get_data
    stockData = pdr.get_data_yahoo(stocks, start, end)
    File "C:\Users\marce\AppData\Local\Packages\PythonSoftwareFoundation.Python.3.8_qbz5n2kfra8p0\LocalCache\local-packages\Python38\site-packages\pandas_datareader\data.py", line 80, in get_data_yahoo
    return YahooDailyReader(*args, **kwargs).read()
    File "C:\Users\marce\AppData\Local\Packages\PythonSoftwareFoundation.Python.3.8_qbz5n2kfra8p0\LocalCache\local-packages\Python38\site-packages\pandas_datareader\base.py", line 258, in read
    df = self._dl_mult_symbols(self.symbols)
    File "C:\Users\marce\AppData\Local\Packages\PythonSoftwareFoundation.Python.3.8_qbz5n2kfra8p0\LocalCache\local-packages\Python38\site-packages\pandas_datareader\base.py", line 268, in _dl_mult_symbols
    stocks[sym] = self._read_one_data(self.url, self._get_params(sym))
    File "C:\Users\marce\AppData\Local\Packages\PythonSoftwareFoundation.Python.3.8_qbz5n2kfra8p0\LocalCache\local-packages\Python38\site-packages\pandas_datareader\yahoo\daily.py", line 153, in _read_one_data
    data = j["context"]["dispatcher"]["stores"]["HistoricalPriceStore"]
    TypeError: string indices must be integers
    And i'm not sure how to fix it

    • @thegundamkingr
      @thegundamkingr 7 месяцев назад +2

      Hi mate not sure if you figured it out but I put a comment above with the solution, you need to use YFinance instead of Pandas Data Reader
      Replace line 8 of his code with: import yfinance as yf
      Replace line 12 with: stockData = yf.download(stocks, start, end)

  • @user-lc3wl1iq1v
    @user-lc3wl1iq1v Год назад

    Great video!