GSoC 2009 - D1-1/GSoC Progress
See D1-1/GSoC_Information for an overview of the project.
This page has the latest charts and status reports: External Progress Page
In particular, see the Gantt chart for the approximate order in which I propose to tackle things.
Details of Planned Work
Here is a summary of the work I intend to carry out (not necessarily in chronological order), along with estimated time required.
- Provide a way for the script thread to delegate certain GUI actions (including display of error and progress dialogs) to the main thread
- Provide a way for error messages to be returned to the script when necessary.
(at option of mentors)
Track Views/Find Notes
- Refactor TrackArtist so that different WaveTrack views are drawn by separate classes, and provide a composite view which allows alternative views of the same track to be shown alongside one another.
- Optimise track drawing methods - for example, ensuring that buffered drawing is used and that analysis data is cached where it is beneficial - with the aim of making the more computationally intensive track views usable on less powerful machines.
- Improve the Find Notes algorithm to make it useful for the purpose of musical transcription. It should work well enough to be able to identify notes and chords in a solo piano recording with reasonable accuracy, and to display this to the user clearly. Amongst other things, it will need to be able to vary the number of notes detected adaptively.
- Fix the related bugs on the release checklist (e.g. P4 - Minimum and Maximum frequency settings don't work for Spectrum log(f) view)
- P3 Jack problems
- P3 Opening a second file while the first is playing
- P4 Linux build fails with EXPERIMENTAL_SCOREALIGN defined
- P3 Preferences dialog - clicking OK can sometimes cause a crash
- Some failed assertions I encountered, including
- Track.cpp(209) when deleting a label track
- A wxWidgets problem in BatchProcessDialog
- P3 Desynchronisation problem when pasting with audio and a label track
- P2 Labels should move appropriately when timeline-changing effects are applied
- P3 Ensure tooltips are updated when language is changed in preferences
- Solve more of the issues from the release checklist or the 'not aiming' list.
- Further extend the capabilities of the scripting module, for example to allow automatic taking of screenshots.
- Refactor or optimise other areas of the code, if it becomes apparent that this would be useful.
- Allow transfer of detected notes to a MIDI track, export of note names, or of a MIDI file.
- Provide a general way of allowing alternative colourings to be used in spectrum view and other places.
Due to the time constraints imposed by my exams, the bulk of the work would necessarily be completed in the period after the midterm evaluation. My main deliverable for the midterm period would be enhancements to the scripting module. I would provide code for a module which works on at least the windows platform and allows a perl script to control import and export of wav files as well as application of effects, and returns an error message to the script if a command was not recognised. In addition I would provide fixes for at least three items from the release checklist.
The two main patches I submitted were:
- A modification to TimeTextCtrl to ensure that the first non-zero digit is focused initially, rather than the first digit
- A larger patch which refactored the generator effects and resolved a problem when the duration was zero
My primary development platform is Arch Linux, but I can also test/develop on Windows XP if necessary. I have no way of tackling any Mac-only bugs, or other issues which I cannot reproduce for whatever reason.