-
-
Notifications
You must be signed in to change notification settings - Fork 873
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update stats.py - fix cagr calculation #281
base: main
Are you sure you want to change the base?
Conversation
remove periods=252 paramter. cagr parameter done by dividing number of days by 365.
The assumption is that the index only iterates over business days for which there are around 252 in year (by convention) |
if we use this assumption then period between 01/07/2005 -- 22/05/2023 will be approx 26 years. Hence this is essentially overestimating the years. |
yes, this is exactly what is happening here.
the pull request is actually proposing to remove the periods parameter completely. the reason behind is that any value other than 365 will give the wrong number of years. And the wrong number of years impacts the CAGR. As the "A" in CARG stands for annual, then there is no need to have this as a parameter. Or at least, I can't think of a case where anything other than 365 would work. Unless the way of calculating |
Unless the way of calculating Yes |
@gnzsnz, the period parameter shouldn't be removed because it will allow users to evaluate portfolios based on the time frame that's being observed. The value that is needed for the actual calculation is An alternative approach is to use log returns, but it's best to stick with normal returns because quantstats uses normal returns for most of its calculations. I compared log returns and normal CAGR approach on daily period, and I got approximately the same result. Using the CAGR function currently implemented in quantstats gives a different result. If you could review your code and implement to version of CAGR discussed in the article, that would be great. |
@tiloye thanks for your feedback. you really got me thinking. i did quite some reading to understand this better, but i have to say that I still think that we should remove the periods parameter. I think is the best alternative, and I've just realized that I got it right in the first place just by chance. The thing is that Annualized Total Return and the Compound Annual Growth Rate (CAGR) are essentially the same. Now what really got me thinking was your point stating that we should be able to evaluate CAGR for any time period. And I realized that the periods parameter is not going to achieve that. Basically we need to calculate the number of years for the returns time series (returns parameter) and we could do that in two different ways, one would be to use the current logic and get the actual number of days between start and end date. Another option is what you propose to get the length of the time series, or number of periods. If we go for actual number of days as it's today, we need to use 365 as the denominator. if we use length we need use 252. But that's it it could be 365 or 252, and it should be aligned with the method used to calculate the number of days. But in any case having a parameter for periods (which is basically our denominator) can only cause problems. Because anything other than the default will return a wrong number. if we want to have the option to calculate returns over different periods, then we need to provide different periods in the returns series, not change the periods parameter. Hope my point is clear. As I said before, I did not realize this until I really went into it. |
@gnzsnz, I get your point. If we are going to use the difference between the dates, then 365 should be the denominator. I also confirmed it holds for return series that isn't up to a year. Thanks for pointing that out. |
@ranaroussi are you OK with this PR? |
This looks good to me, does this also take care of some other possible metrics miscalculations introduced with the period parameter changes? If everything else looks properly calculated with this PR, please merge asap |
@ranaroussi kind reminder |
is this project abandoned? tons of unsolved PRs |
#323 is still open |
Since this library no longer seems to be maintained, we have created a duplicate of it that we plan to maintain and improve over time. If you'd like to use our version check it out here: https://github.com/Lumiwealth/quantstats_lumi Please feel free to fork and send your pull request to this new library, we will be actively monitoring the library and approving PRs |
Cool library, Nice! I will surely take a look at it. |
Sounds good. Feel free to send over and PRs to this new library, we will be
monitoring and maintaining this library
Robert Grzesik 347-635-3416
…On Thu, Feb 1, 2024 at 2:14 AM Kaho Fan ***@***.***> wrote:
Since this library no longer seems to be maintained, we have created a
duplicate of it that we plan to maintain and improve over time. If you'd
like to use our version check it out here:
https://github.com/Lumiwealth/quanstats_lumi
*Please feel free to fork and send your pull request to this new library,
we will be actively monitoring the library and approving PRs*
Cool library, Nice! I will surely take a look at it.
—
Reply to this email directly, view it on GitHub
<#281 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAIYQKZO3ZHJAFEWR2IH6HDYRM6HHAVCNFSM6AAAAAA2LFNQ4OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMRQGY2TCMRZGM>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
have you included this PR on your repo? or shall i create a new PR on yours
please let me know, i'm happy to help
On Thu, Feb 1, 2024 at 9:53 PM Robert Grzesik ***@***.***>
wrote:
… Sounds good. Feel free to send over and PRs to this new library, we will
be
monitoring and maintaining this library
Robert Grzesik 347-635-3416
On Thu, Feb 1, 2024 at 2:14 AM Kaho Fan ***@***.***> wrote:
> Since this library no longer seems to be maintained, we have created a
> duplicate of it that we plan to maintain and improve over time. If you'd
> like to use our version check it out here:
> https://github.com/Lumiwealth/quanstats_lumi
>
> *Please feel free to fork and send your pull request to this new
library,
> we will be actively monitoring the library and approving PRs*
>
> Cool library, Nice! I will surely take a look at it.
>
> —
> Reply to this email directly, view it on GitHub
> <
#281 (comment)>,
> or unsubscribe
> <
https://github.com/notifications/unsubscribe-auth/AAIYQKZO3ZHJAFEWR2IH6HDYRM6HHAVCNFSM6AAAAAA2LFNQ4OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMRQGY2TCMRZGM>
> .
> You are receiving this because you commented.Message ID:
> ***@***.***>
>
—
Reply to this email directly, view it on GitHub
<#281 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AB75CQWTAK4QWM6WEBIMDLTYRP6EBAVCNFSM6AAAAAA2LFNQ4OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMRSGIZDIMZZHE>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
I believe the CAGR calculation is already fixed in the new library, but you
can double check if you want. The main reason I duplicated the quantstats
library was because of this issue.
Robert Grzesik
347-635-3416
…On Sat, Feb 3, 2024 at 5:48 AM gnzsnz ***@***.***> wrote:
have you included this PR on your repo? or shall i create a new PR on
yours
please let me know, i'm happy to help
On Thu, Feb 1, 2024 at 9:53 PM Robert Grzesik ***@***.***>
wrote:
> Sounds good. Feel free to send over and PRs to this new library, we will
> be
> monitoring and maintaining this library
>
> Robert Grzesik 347-635-3416
>
>
> On Thu, Feb 1, 2024 at 2:14 AM Kaho Fan ***@***.***> wrote:
>
> > Since this library no longer seems to be maintained, we have created a
> > duplicate of it that we plan to maintain and improve over time. If
you'd
> > like to use our version check it out here:
> > https://github.com/Lumiwealth/quanstats_lumi
> >
> > *Please feel free to fork and send your pull request to this new
> library,
> > we will be actively monitoring the library and approving PRs*
> >
> > Cool library, Nice! I will surely take a look at it.
> >
> > —
> > Reply to this email directly, view it on GitHub
> > <
>
#281 (comment)>,
>
> > or unsubscribe
> > <
>
https://github.com/notifications/unsubscribe-auth/AAIYQKZO3ZHJAFEWR2IH6HDYRM6HHAVCNFSM6AAAAAA2LFNQ4OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMRQGY2TCMRZGM>
>
> > .
> > You are receiving this because you commented.Message ID:
> > ***@***.***>
> >
>
> —
> Reply to this email directly, view it on GitHub
> <
#281 (comment)>,
> or unsubscribe
> <
https://github.com/notifications/unsubscribe-auth/AB75CQWTAK4QWM6WEBIMDLTYRP6EBAVCNFSM6AAAAAA2LFNQ4OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMRSGIZDIMZZHE>
> .
> You are receiving this because you were mentioned.Message ID:
> ***@***.***>
>
—
Reply to this email directly, view it on GitHub
<#281 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAIYQK7OXUQBGPVHBMF5TELYRYIWLAVCNFSM6AAAAAA2LFNQ4OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMRVGI3TGNZWGY>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
I don't have a good solution to this problem, but just wanted to note that setting This calculation: If these are not trading days, doing For example, lets choose a period 2020-01-01 to 2020-12-31. |
Thanks for letting me know. I think we already use periods=365 right?
Robert Grzesik 347-635-3416
…On Tue, Apr 9, 2024 at 7:19 AM matt-the-catt ***@***.***> wrote:
I don't have a good solution to this problem, but just wanted to note that
setting periods=365 will only make results more accurate, but will not
fix the problem entirely.
This calculation:
years = (returns.index[-1] - returns.index[0]).days / periods
wrongly assumes that the first and the last day is a trading day.
If these are not a trading days, doing returns.index[-1] -
returns.index[0] will always result in a number less than 365 and the
whole cagr calculation will result in a slight overestimation.
—
Reply to this email directly, view it on GitHub
<#281 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAIYQK7YG6MKZMG37XER5ADY4PFDJAVCNFSM6AAAAAA2LFNQ4OVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDANBUG44DSMZYG4>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
@grzesir have you considered PEP 541, you can keep pypi package name if you apply for it. I understand that you need to create an issue under pypi support and tag it as PEP 541, here is an example pypi/support#3932 |
np.product --> np.prod
remove periods=252 parameter. cagr calculation done by dividing number of days by 365.
'years = (returns.index[-1] - returns.index[0]).days / periods' there is no rational for dividing number of days by anything other than 365.
fix 273 and 275