https://bugs.kde.org/show_bug.cgi?id=303994
Bug ID: 303994 Severity: normal Version: unspecified Priority: NOR Assignee: [hidden email] Summary: Many face tag comboboxes and may tags, will have an impact on performance Classification: Unclassified OS: Linux Reporter: [hidden email] Hardware: Other Status: UNCONFIRMED Component: Face Management Product: digikam Adding a lot of face tags on an image, and having a lot of tags in 'My tags', will hurt the performance of digikam. How to reproduce: ============== 1) Start digikam, make sure you have +100 tags in 'My tags' 2) Add 2 images to a album 3) View image 1 by clicking on it (preview) 4) Enable 'Show Face Tags' 5) Manually add a 50 face tags to image 1. (Do not assign any tags, only add the face tag with the combo boxes) 6) Switch to preview image 2 7) Switch back to preview image 1 8) Repeat steps 6) and 7), and notice how the loading of image 1 gets slower and slower I tried to troubleshoot this behavior, but did not manage to solve it. I noticed though, that digikam spent a lot of time in ModelCompletion::sync [core/libs/widgets/common/modelcompletion.cpp] I enabled (un-commenting) the 2 kDebug() @ lines 244-245 and 260, saw what to me appeared a growth of calls to ModelCompletion::sync for each added [d->addItem(face); ==> core/utilities/facedetection/facegroup.cpp @ line 617] AssignNameWidgets. But I failed to understand why so many calls where made to ModelCompletion::sync, and from where they originated. This never stopped growing, so that explained why digikam ran slower and slower when opening an image with a lot of AssignNameWidgets in it. Reproducible: Always -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
https://bugs.kde.org/show_bug.cgi?id=303994
--- Comment #1 from Kristian Karl <[hidden email]> --- Created attachment 72721 --> https://bugs.kde.org/attachment.cgi?id=72721&action=edit Sceenshot of an image with a lot of face tag combo boxes. I used this image to reproduce the problem. The problem also occurs with images with only a few face tag combo boxes on it, it only takes longer for the problem to occur. -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
Gilles Caulier <[hidden email]> changed: What |Removed |Added ---------------------------------------------------------------------------- CC| |[hidden email] Version|unspecified |2.7.0 -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
--- Comment #2 from Marcel Wiesweg <[hidden email]> --- CPU or memory usage? -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
--- Comment #3 from Kristian Karl <[hidden email]> --- CPU usage. When I enabled the logging I mentioned above, I easily came to millions of calls to ModelCompletion::sync(QAbstractItemModel* model, const QModelIndex& index) [core/libs/widgets/common/modelcompletion.cpp @ line number257] -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
--- Comment #4 from Kristian Karl <[hidden email]> --- Created attachment 72805 --> https://bugs.kde.org/attachment.cgi?id=72805&action=edit Don't sync if it's already performed This patch fixes the performance problem. But I'm not claiming it to be a final solution, because I do not fully understand the implications or any side effects of this patch. -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
Gilles Caulier <[hidden email]> changed: What |Removed |Added ---------------------------------------------------------------------------- Summary|Many face tag comboboxes |Many face tag comboboxes |and may tags, will have an |and may tags, will have an |impact on performance |impact on performance | |[patch] -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
--- Comment #5 from Marcel Wiesweg <[hidden email]> --- Git commit a9aaa60c26b03e5f0b445aa78bea97fb165ebc36 by Marcel Wiesweg. Committed on 29/07/2012 at 14:57. Pushed by mwiesweg into branch 'master'. Check that the new source model is not actually already the source model. Qt does not seem to make this test. M +9 -3 libs/models/albumfiltermodel.cpp http://commits.kde.org/digikam/a9aaa60c26b03e5f0b445aa78bea97fb165ebc36 -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
--- Comment #6 from Marcel Wiesweg <[hidden email]> --- I believe this is the problem: We have 1 set of models and n completion objects. When creating each new widget, the two filter models change their source model, which resets the model, even if there is no actual change and the source model is already set. As we share the model, adding widget x will resync all 1..x completion objects, which means we will resync n + (n-1) + (n-2) + ... times. Please check if my fix solves the problem. -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
--- Comment #7 from Kristian Karl <[hidden email]> --- Yes, this solves the problem. (In reply to comment #6) > I believe this is the problem: We have 1 set of models and n completion > objects. When creating each new widget, the two filter models change their > source model, which resets the model, even if there is no actual change and > the source model is already set. As we share the model, adding widget x will > resync all 1..x completion objects, which means we will resync n + (n-1) + > (n-2) + ... times. > Please check if my fix solves the problem. -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
Gilles Caulier <[hidden email]> changed: What |Removed |Added ---------------------------------------------------------------------------- Status|UNCONFIRMED |RESOLVED Version Fixed In| |2.8.0 Resolution|--- |FIXED -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
In reply to this post by Kristian Karl
https://bugs.kde.org/show_bug.cgi?id=303994
Kristian Karl <[hidden email]> changed: What |Removed |Added ---------------------------------------------------------------------------- Status|RESOLVED |CLOSED -- You are receiving this mail because: You are the assignee for the bug. _______________________________________________ Digikam-devel mailing list [hidden email] https://mail.kde.org/mailman/listinfo/digikam-devel |
Free forum by Nabble | Edit this page |