User:Mfasi

From Octave
Jump to navigation Jump to search

Introduction

  • I guess the three required sentences are on current studies, spoken languages and overall background. So:
    • I am a student at "Ecole Normale Superieure" in Lyon (FR), second year of Master in Computer Science.
    • Italian is my mother tongue, I use somehow English and French.
    • I would say that my field is numerical analysis.
  • As the project I am intested in is related to the domain I would apply for my Phd, I hope to boost a little my application. Moreover, I used the Octave functions I would work with for some Octave code I wrote
  • No previous experience with the Google Summer of Code
  • I am choosing Octave on the one hand because out of the possible organizations is the one I am most interested in, on the other hand because is probaly the one I know better among them. Moreover, I have used it a lot before (for example for my bachelor thesis TODO add link)

Contact

  • My nickname on IRC will be mfasi.
  • I think my time zone will be UTC+1
  • Just now, I am working for an internship and I go to my office at 7.00 and leave at 18.00 (in UTC+0), but I do not spend all of the time coding. I guess I spend usually the last 4/5 hours coding, while in the morning I prefer reading papers or doing developing some ideas (that will be coded later on).

Coding experience

  • Experience with C++, Octave or Matlab m-scripts, OpenGL and Qt.

C++ and OpenGL where subjects of two university courses I've attended. I have used Octave to write my Bachelor Thesis.

  • As a computer science student, I have had to work with many different languages:
    • Imperative: pascal, C, Bash scripting, Java, JavaScript, PHP
    • Functional: OCaml, HOPE
    • Markup: LaTeX, XML, XSL, HTML
    • Other: some SQL-based languages
  • I have never took part to an open-source project, but some of the computer science courses I've followed required to to present some team developed programming projects.
  • Please describe the biggest project you have written code for and what you learned by doing so. Also describe your role in that project over time.
  • No contribution to Octave so far.

Feeling fine

  • Please describe (in short) your experience with the following tools: We only use this question to determine where you need guidance, not for rating! We by no means expect you to be familiar with all of these and you'll won't necessarily need them while working with us.
    • IRC and mailing lists
    • Mercurial or other source code management systems
    • Mediawiki or other wiki software
    • make, gcc, gdb or other development tools
  • What will make you actively stay in our community after this GSoC is over? You can also tell us after applications close and we'll happily try to fulfill :-)

Only out of interest

  • Actully I have been using Octave for four years now, but just as a user. I think you could advertise in math forums, there is plenty of them.
  • I had trouble finding a GUI, but that is no longer the case. In general everything is well documented. I had some troubles, years ago, when trying to use the symbolic packagem that was not very well documented, as far as I remember.

Prerequisites

  • I am granted the access to use any Linux Distribution (I can just install it on a PC), but the ones I've used are Debian, Ubuntu, Arch and Gentoo. I have also access machines with Windows 7 and 8.
  • I think I will not have problems accessing a pc with internet during the GSoC period.
  • I will be free to install new programs on all the operating systems described above.

Self-assessment

  • Please describe how useful criticism looks from your point of view as committing student.
  • How autonomous are you when developing? If you answer both subquestions with "Yes, definitely", we are a tad confused. ;-)
    • Do you like to discuss changes intensively and not start coding until you know what you want to do?
    • Do you like to code a proof of concept to 'see how it turns out', modifying that and taking the risk of having work thrown away if it doesn't match what the project or original proponent had in mind?

Your task

  • The project I would like to work on is Improve logm, sqrtm, funm.

I would implement such functions, using known algorithms for matrix functions. In particular, I would like to start implementing the Schur-Parlett recurrence for general matrix functions, that is known to be O(n^4), and then implementing better - specific - algorithms for the other two functions. For the matrix logarithm I do not know wether there is something better than the scaling and squaring method devised by Higham in Functions of Matrices: Theory and Computation, while for the p-th root there is a recent work [1] that has a lower asymptotical complexity (but seems rather involved, so I cannot say anything about the real performances).


  • Please provide a rough estimated timeline for your work on the task. This should include the GSoC midterms and personal commitments like exams or vacation ("non-coding time"). Optionally include two or three milestones you expect.