[[BackLinksMenu]] [[TicketQuery(summary=GROUP_APP_PERFORMANCE_R2, format=table, col=summary|owner|status|type|component|priority|effort|importance, rows=description|analysis_owners|analysis_reviewers|analysis_score|design_owners|design_reviewers|design_score|implementation_owners|implementation_reviewers|implementation_score|test_owners|test_reviewers|test_score|)]] = Analysis = == Overview == The goal of this task is to propose and implement concrete performance optimizations for Sophie2. [[BR]] This should be achieved by either using a profiler or manually identifying potential optimization spots in the code. [[BR]] A '''sub'''goal of this task is to tweak our Profiler, and do a final try on existing profilers which can work with Sophie2 and produce useful results so they can be used for spotting potential optimization spots. == Task requirements == * Propose concrete optimization points in Sophie2 code and optimize them if possible * by either doing quick hacks * or proposing serious design changes (like the Aspects) and try to implement them if there's enough time. * Find a way to measure real method execution count (non-statistical). * Spend some more time with NetBeans Profiler and try to make it work with Sophie. * See if using any other existing profiler makes sense. * Actually, these profilers can turn out to have more features which could prove useful. * If none of the above works, try to incorporate bytecode instrumentation in our Profiler. This could waste a lot of time so do it only if really needed. * Consider implementing hit() behavior in the Profiler. * This means inserting a hit() statement in every method for which you want to get the real hit count. * This way you get the real hit count for a method, * and also you can get the last two elements in the stack trace and thus count how much times a given method A() has invoked another method B() in its body like: {{{ methodA() { for(int i = 0; i < 1000000000; ++i) { methodB(); } } }}} These could possibly be optimized in various ways like using findOne(), findAll() if used for lists, using some HashMaps etc. == Task result == * Working way to measure real hit count * Optimization proposals * Hopefully, implemented optimizations * Most probably, new functionality in our Profiler. == Implementation idea == * Look at (usage of) these methods in the code and try to optimize them (they proved to consume much time while profiling with '''hprof'''): * ''org.sophie2.core.modularity.SophieExtensionPoint.extensions'' -- there such be faster searching in this list maybe * ''org.sophie2.core.prolib.util.Registry.endReadTrack'' -- filtering out could be optimized maybe * ''org.sophie2.base.commons.util.ImmGradientPaint.*'' * ''org.sophie2.main.app.menus.MainAppMenusModule.defineExtensions'' * ''org.sophie2.core.prolib.util.Registry.registerRead'' * Look at usage of ''sun.java2d'' and try to optimize the drawing of Scenes. * Implement hit() inside our Profiler and count results in some map. * Look at JVMTI if you're going to do bytecode instrumentation. * Find a NetBeans guru and ask him questions on how to run the NetBeans Profiler with Sophie2. == Related == * [wiki:GROUP_APP_PERFORMANCE_R0] * [wiki:GROUP_APP_PERFORMANCE_R1] * [wiki:GROUP_PRO_LIB_PERFORMANCE_R0] == How to demo == * show upgraded reports from the upgraded Profiler * show optimization proposals and/or concrete optimization results = Design = * memoize locate change manager = Implementation = ^(Describe and link the implementation results here (from the wiki or the repository).)^ = Testing = ^(Place the testing results here.)^ = Comments = ^(Write comments for this or later revisions here.)