-
Notifications
You must be signed in to change notification settings - Fork 308
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
MEI: Have a visualization of the time series of maintenance effectiveness values, aggregated by different teams/components #3717
Comments
@jensstutte and @suhaibmujahid. I am new to this and have started looking into this issue. |
@gothwalritu this issue is pretty complex, I'd suggest picking something else. |
@marco-c, I have some experience with time series analysis, and I would like to give it a shot. |
@gothwalritu unfortunately there are quite a few other things to do, which require context, in order to retrieve the data to analyze, and then the actual work for this issue can start. |
@marco-c, @suhaibmujahid I have been trying to understand the problem and the associated data. In the "element chat room" @jpangas mentioned a few links to go through first to develop an understanding of this task. I did the same and so far, I could understand that there are different products, component and teams.
0 Fennec Mozilla Untriaged Bugs The bugs are categorized in them. The objective is to create a visualization of the time series of maintenance effectiveness indicator (MEI) values. So, first I will try to work with a one team, maybe "mozilla". The function to calculate MEI is defined in "bugzilla.py", I can use it to calculate the MEI. Import the function calculate_maintenance_effectiveness_indicator and any other necessary libraries or modulesDefine the teamteam = 'Mozilla' Define the date rangestart_year = 2000 Create an empty dictionary to hold the MEI values for each yearmei_values = {} I tried plotting the graph as: Add title and labelsplt.title('Maintenance Effectiveness Indicator (MEI) Over Years for team: mozilla') And I am planning to do the time series analysis maybe using ARIMA for the same team. |
This looks promising. I will have to update a bit the requirements such that it is more clear what actually we want to see here based on which calculations (cadence and time delta) and how to put that together, please expect that to happen by Friday. Note that ultimately we will want to integrate this into bugbug's UI, but for now we are happy to have a standalone PoC. |
Thank you so much! I will try with DOM LWS. |
So for a given
Note that we want to calculate all those values ad-hoc on the latest data we have in bugzilla, even if they seem to be historical (bugs might move between components, change severity, etc). This gives us a series of 3 value quintuples for each week over the For the Incoming and Closed values we should chose only one delta and scale the value up to 12 months. I'd probably try to do so for the 1 month values (not only for the ease of calculation but also for the medium dynamic I expect). This yields for each week the percentage of bugs that would have been incoming/closed for an entire year (if done at at the same rate) compared to our defect backlog. It gives an immediate feeling of "how big is my technical debt backlog" in relation to active work and incoming bugs. |
Infinite values for BDTime/WBDTime can appear and may just be ignored for now, but sooner or later we'll need a good way to show them in order to make clear "here is a problem". |
@jensstutte, thank you for the explanation. It really helped me a lot to dive deeper into this. Here are the steps I will be following:
Let me know if that is good enough for the start. |
That sounds right. We can probably have BDTime and WBDTime on the same chart from the beginning, as they have the same scale and should have a comparable order of magnitude (and if not we would want to directly know). I think in the end I'd like to combine the burn down chart with the Incoming/Closed data as second vertical scale as supporting information. But let's first see how dense the information gets on single charts. |
Ok. So, far I am able to produce these results with:
I plotted the graph for MEI value I am working on the burn down chart now will update you as soon as I am finished with it. In the meantime, I would greatly appreciate your feedback. Thanks so much! |
Sorry for not coming back earlier here (actually I was convinced I had answered already time ago but I do not see the answer, so maybe I did not hit the send button or such?)! This looks all very promising. I think in general we do not need to go back such a long period in time, 12 months should be enough. And we mostly want to look at the 3 months delta value in practice, so to keep things more readable we could remove the 1-month-delta curve everywhere. The weekly values then show the peaks and the 3-months-value shows the average we want to move to our target.
Thank you! |
No problem at all! I appreciate your feedback and clarifications. It sounds like we're on the right track. I'll make the adjustments as per your suggestions: focusing on 12 months, removing the 1-month-delta curve, and emphasizing the 3-months-delta curve in the MEI and (W)BD Time charts. We'll also limit the scales and add graphical indicators as needed. I'll work on these refinements and will keep you updated on the progress. Just a heads up, I'll be on vacation for the next couple of weeks, so there might be a brief delay in my responses during that time. Thank you for your understanding! |
I modified the MEI chart accordingly and here is the result: @jensstutte, @marco-c Let me know your feedback on this. I am working on the other two charts, will update you once I am ready. Thank you. |
That looks very good, thank you! |
@jensstutte, I am glad that I am able to produce these results with your guidance. In this chart I removed the vertical space below 0 in MEI and have used the 12 months of 2023. Here is the updated chart for MEI over weeks for team " DOM LWS". |
@jensstutte, here is the chart for BDT and WBDT over 12 months of 2023 with 3-Month Delta for team DOM LWS with limited scale to 15years: I am working on other charts as well. I will update the progress accordingly. Please let me know your comments on the previous charts. Thank you! |
I think that nails it, thanks! |
That looks fine, too. It is interesting to see how higher severity bugs can move the needle fast for WBDTime but less fast for BDTime. And one can clearly see the correlation of MEI going close to 100% and WBDTime spiking up, which is what I expected to see.
Thank you! |
@jensstutte, yes it's fascinating to observe how higher severity bugs impact WBDTime differently than BDTime. The correlation between MEI approaching 100% and the spike in WBDTime indicating a strong connection between maintenance effectiveness and the time to resolve bugs. Here is the chart for Incoming and Closed. First calculated the scaled values for Incoming and Closed by dividing them by 52 (the number of weeks in a year) and then multiplying by 100 to represent them as percentages. These scaled values indicated how many bugs are being processed in a week relative to the entire defects backlog for the year. Then, created a line plot for Scaled Incoming and Scaled Closed, adding labels, a title, a legend, and grid lines for better visualization. Here is the chart: |
@gothwalritu just wanted to say great work, sorry I initially tried to ask you to work on something else :) |
@marco-c, Thank you so much for your kind words! I believe we do everything with our best intentions.. so please don't apologize :) |
@jensstutte, I think there is some mistake I did in the last chart. Let me work on this and will get back to you ASAP. |
@jensstutte, here is the chart for Incoming and Closed for the weekly values. First calculated the scaled values for Incoming and Closed by dividing them by 52 (the number of weeks in a year) and then multiplying by 100 to represent them as percentages. These scaled values indicated how many bugs are being processed in a week relative to the entire defects backlog for the year. Then, created a line plot for Scaled Incoming and Scaled Closed, adding labels, a title, a legend, and grid lines for better visualization. Here is the chart: The previous chart had the data points of 7 days and 90 days, that is why it was in the zigzag pattern. |
Thank you, that looks much better! |
@jensstutte, I appreciate your comments. I plotted the Scaled incoming and scaled closed for 90 days/3months- delta values. Here is the graph: and the combined chart of scaled incoming/closed and BD Time/WBD Time over 12 months (2023) for 3-months-delta: Let me know your feedback on this. Thank you so much! |
Hello @jensstutte, do I need to do anything else in this issue? Let me know. |
Hi @gothwalritu ! In order to better judge how we can integrate your code in our systems, would you mind sharing it via a PR here ? The ultimate goal would be to add some of these diagrams to our bugbug UI, but for now a separate script will do. Thank you! |
Once we have a time series, we could construct a nice graph visualizing the trend for some of of those values.
It should be possible to aggregate/filter as usually in bugbug UI.
Updated requirements for the graph:
For a given
team
(or other component selection) like "DOM LWS" and a given time periodgraphduration
(say a year as example) we want to:Note that we want to calculate all those values ad-hoc on the latest data we have in bugzilla, even if they seem to be historical (bugs might move between components, change severity, etc).
This gives us a series of 3 value quintuples for each week over the
graphduration
. We can directly plot (with different colors forweek
,month
and3 months
delta) the values forME
,BDTime
andWBDTime
.For the Incoming and Closed values we should chose only one delta and scale the value up to 12 months. I'd probably try to do so for the 1 month values (not only for the ease of calculation but also for the medium dynamic I expect). This yields for each week the percentage of bugs that would have been incoming/closed for an entire year (if done at at the same rate) compared to our defect backlog. It gives an immediate feeling of "how big is my technical debt backlog" in relation to active work and incoming bugs.
The text was updated successfully, but these errors were encountered: