<div dir="ltr">Hello Péter,<div><br></div><div>Sounds good to me. I'd also be interested in knowing the specifics of what you are planning to do.</div><div><br></div><div>Very happy to help at any point.</div><div><br></div><div>Thanks,</div><div class="gmail_extra"><br clear="all"><div><div class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><span style="color:rgb(0,0,0);font-family:'Segoe UI','Segoe UI Web Regular','Segoe UI Symbol','Helvetica Neue',Helvetica,Arial,sans-serif;font-size:13px;line-height:18.85px">Sean Eveson</span><br style="color:rgb(0,0,0);font-family:'Segoe UI','Segoe UI Web Regular','Segoe UI Symbol','Helvetica Neue',Helvetica,Arial,sans-serif;font-size:13px;line-height:18.85px"><span style="color:rgb(0,0,0);font-family:'Segoe UI','Segoe UI Web Regular','Segoe UI Symbol','Helvetica Neue',Helvetica,Arial,sans-serif;font-size:13px;line-height:18.85px">SN Systems - Sony Interactive Entertainment Group</span><br></div></div></div>
<br><div class="gmail_quote">On Thu, Mar 16, 2017 at 12:49 AM, Anna Zaks <span dir="ltr"><<a href="mailto:ganna@apple.com" target="_blank">ganna@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word">Hi Péter,<br><div><br></div><div>Better modeling of loops is definitely an interesting topic. My main concern would be having a specific proposal on what improvements you could complete in the GSoC timeframe. The next step here is to write down more specifics about what you intend to work on. Please, let me, Devin, and Artem know if you’d like to talk to us while figuring this out.</div><div><br></div><div>Cheers!</div><span class="HOEnZb"><font color="#888888"><div>Anna.</div></font></span><div><div class="h5"><div><br></div><div><br><div><blockquote type="cite"><div>On Mar 13, 2017, at 9:43 AM, Péter Szécsi <<a href="mailto:peterszecsi95@gmail.com" target="_blank">peterszecsi95@gmail.com</a>> wrote:</div><br class="m_-1237608075928966407Apple-interchange-newline"><div><div dir="ltr">Hello,<span class="m_-1237608075928966407gmail-gI"><span></span></span><span class="m_-1237608075928966407gmail-gI"><span> </span></span><br><br>I would love to work on a Clang Static Analyzer project during the summer by joining GSoC.<br>Let me introduce myself:<br>I'm Peter Szecsi, a third-year BSc student at Eötvös Loránd University, Budapest. It would be my first Summer of Code project but I have already contributed to clang:<br>During the last summer I have uploaded 2 patches:<br>- An accepted and merged clang-tidy checker [1] <br>- An accepted Clang SA checker [2]<br>Since then I am working on cross translational unit analysis as a university project (and because of that I`ve send some patches about the ASTImporter [3]). Furthermore I participated in the preparations of a talk that was accepted at the EuroLLVM conference. [4]<br>I found SA interesting since I like to work on algorithmic challenges and enjoy participating in programming competitions and there is a lot of algorithms in the Static Analyzer which could be optimized/made more precise by heuristics.<br><br>That is the reason why I would be most interested in project "Implement generalized loop execution modeling" from the Clang SA Open Projects page [5]. Hopefully it is a suitable project for GSoC and it is possible to achieve useful improvements during this time frame. <br>I have read the discussion at the "loop widening" patch [6] and the most important enhancements (and milestones in the project) would be invalidating only the possible modified values. In addition to that I was thinking to have some heuristics which would approximate if a loop is too complex to even use this kind of strategy because it would still lead to invalidate most of the values and result in a lot of false positives. Another small heuristic could be: when we already reached the maximum loop unroll number then in case we are sure that there is only a few loopsteps ahead we could unroll it to the end since probably this algorithm will not consume too much time/memory and the result state will not be much more complex. <br><br>What do you think about these ideas?<br><br>(I have CC'd everyone from the "loop widening" patch discussion.)<br><br>Best regards,<br>Peter<br><br>[1] <a href="https://reviews.llvm.org/D22507" target="_blank">https://reviews.llvm.org/<wbr>D22507</a><br>[2] <a href="https://reviews.llvm.org/D24246" target="_blank">https://reviews.llvm.org/<wbr>D24246</a><br>[3] <a href="https://reviews.llvm.org/D29612" target="_blank">https://reviews.llvm.org/<wbr>D29612</a>, <a href="https://reviews.llvm.org/D30876" target="_blank">https://reviews.llvm.org/<wbr>D30876</a>, <a href="https://reviews.llvm.org/D30877" target="_blank">https://reviews.llvm.org/<wbr>D30877</a><br>[4] <a href="http://llvm.org/devmtg/2017-03//2017/02/20/accepted-sessions.html#7" target="_blank">http://llvm.org/devmtg/2017-<wbr>03//2017/02/20/accepted-<wbr>sessions.html#7</a><br>[5] <a href="http://clang-analyzer.llvm.org/open_projects.html" target="_blank">http://clang-analyzer.llvm.<wbr>org/open_projects.html</a><br>[6] <a href="https://reviews.llvm.org/D12358" target="_blank">https://reviews.llvm.org/<wbr>D12358</a><br></div>
</div></blockquote></div><br></div></div></div></div></blockquote></div><br></div></div>