I've been fighting with this bug for a while now. The problem is that a graph where the x-axis follows a logarithmic scale, the minimum value allowed is 20. The x-axis on this graph represents the frequency of sound in Hz, and it makes sense, to me (and probably the original designers), to have the lower limit be 20 Hz because that is the lowest frequency that the human ear can hear. However, some of the developers think that it might be useful to have it be zero for people who might use Audacity for reasons other than audio recording. You can test bass speakers at frequencies below 20 Hz and watch them slowly move back and forth trying to produce the sound. I found the 'equalization' effect source code, which a lot of it seems relevant to the bug (the graph is used for equalization and comes up when you select the 'Equalization' effect from the effects menu), but I'm having trouble understanding most of the source code included in it. The file is over 3000 lines of code, after all... I've found a few things in it that I could almost swear would cause the problem, but when I save and rebuild, the lower limit is still at 20 Hz. The first thing I found was an array of doubles, which starts with 20.0, and the rest of the numbers in the array highly correlate to the values along the x-axis, so I tried changing the head value (again, 20.0) to 0, but nothing happened. There's also some places in the code which set a 'lowLog' equal to the log base 10 of 20.0. I changed these to 1.0 instead of 20.0 because the log of 1 = 0, which is what they were hoping the lower bound would be. Nothing has worked, however. A couple of times after re-building the code, it returned compile errors - so I had to undo my changes. It looks like some of the output from Equilization.cpp goes to another file Equilization.o (object?), which is affected by some changes and causes errors there.
That's about everything I've been up to, personally. John made an outline for the online tutorial we'll be writing, which turned out good. I'm looking forward to seeing how that turns out. I suspect I'll be doing most of the editing for it after he and Joseph have some substance to it - for some reason I love proofreading other people's writing... We're also planning on meeting to work out some details for the poster. We need to figure out which program we're going to use to design it. I don't think anyone in the group has Photoshop, but perhaps there's an open-source solution out there that will suffice!
Monday, March 24, 2014
Thursday, March 20, 2014
Planning to Meet Charleston
There
were a few groups from the list that I was interested in attending meetings
for. My first choice is the Agile Group. Agile development seems to be the most
desirable type of development for today’s employers and I think that being a
part of that group would not only help increase my understanding and skills on
the subject, but also look pretty good on a resume. Unfortunately, they do not
have an open calendar, so I submitted a request to join their LinkedIn group. There
were a couple of familiar faces from my contacts who are already a part of the
group. We’ll see what their meeting schedule is like once I get an invitation.
The
second group I was interested in was the Charleston Tech Group. This group
seems a bit more broad as far as topics covered, but upon looking at their ‘meetup’
website, I was pleased to find that they had a great range of interesting things
in their meetings. Topics covered everything from 3D printing to Java games to
Android UI development and more. There are two meetings that are being planned
at the moment. The first is for JVM languages (such as Clojure) which I thought
was interesting because that is what Jason’s group is using in their project
this semester. The other is about UML / Graphic design tools to model process
flow. This might not be the most exciting talk to attend, but I do feel that it
would be educational. There is a lot of automation possible when you model a
program in UML tool that can generate code based off of the UML relationships.
Sadly, neither of these meetings have dates pinned to them yet, so I’m not sure
when/if they’ll actually happen. It looks like their last meeting was almost
exactly 11 months ago, so I’m not sure how active they are.
The
third group I was pretty excited about was the SCSLUG group – Charleston South
Carolina Linux Users Group. There was a funny post on their Google+ page by
someone who said: “…my Linux pimp hand is not as strong as I would like…”. It’s
pretty funny, but it’s also similar to how I feel. When I first started using
Linux in ’07 I was very intrigued, but also a little apprehensive. My friend
that showed it to me was very intelligent and I was a little intimidated by it,
almost thinking that it was only for smart people to use. I don’t think the
same way about it nowadays, but I still don’t know how to fully leverage the
strong points of Linux, so I think attending this group would be a great
learning experience. By looking at all of the pictures they had up on Flikr, it
seems like a pretty friendly group as well! Apparently, they meet every second Saturday
of the month, though, so it won’t be until April 12th before they
have their next meeting. Hopefully one of the other groups will have a meeting
coming up sooner. If not, I might talk to some classmates and see if they found
anything else interesting that is coming up sooner.
Thursday, March 13, 2014
After the break...
Going into the break I was pretty depressed about how my semester was going. I was doing poorly in multiple classes due to my poor attendance caused by my chronic illness. I had missed tests, assignments, and I just didn't feel good about any or it. During the break, though, the medicine I had started a while back finally started showing progress and now I'm feeling much better (still not 100%, but a big improvement). I've spoken with my professors and am allowed to make up the missed work and I'm feeling great about getting back on track. I also got an email from a recruiter at Google asking for my resume and transcript, so that is also very exciting!
Aside from all the non-coding related stuff, I was able to build our project from source and started looking at a particular bug. I believe I've found the exact file in which the bug occurs, now the only thing left is to pinpoint it. The file is quite but - 3600 lines of code - but I don't think it will be that bad. After reading a few hundred lines of it, I'm beginning to get a feel for the project and how it works. Some of the code was commented out, and there has been decent documentation within the code to let you know what it's doing, but of course it could be better. The code itself is descriptive as well, which helps a ton, so I'm pretty confident about fixing this but, which will be the first one for our group. It's also exciting because my group was getting nervous about my attendance and wasn't sure what was going on - I was kinda MIA, so if I fix a bug it will probably be a big relief to them, and myself as well of course.
Tuesday, March 11, 2014
Reflections on my Progress
So far this semester has been slow. Sometimes I feel like I can be a little more critical on myself than is necessary, but I feel like our group has not accomplished much compared to the others. We've contributed to the Audacity wiki, and built the source code on all the operating systems as well as put the source code up on a Github repository, but have yet to do much else. The group also seems to be a little divided as far as vision for the project. There seems to be too many ambitions among us all. Some just want to fix a few bugs and keep it plain, some have thrown the idea out of writing a nyquist plugin, and another idea came up recently of writing an online textbook (much like the one we've been reading this semester) that uses nyquist as a gateway language to teach non-programmers how to program. Nyquist is a functional language that you can use to basically generate sounds and manipulate them. Apparently, even though Audacity is written in C++, it actually handles all of the audio code with nyquist - the C++ is mostly the interface and file managing. One of the challenging things I find about this project is that because Audacity is cross platform, some of the bugs are only specific to one operating system. This means that when I'm reading a bug on the BugZilla and trying to reproduce it in Linux, I find one behavior and I think I know how to approach it, but then I check the same bug on Windows and find something unexpected and I am no longer sure of my strategy, or if a fix that I apply might break it on the OS in which is was originally working.
The group has decided on a couple of bugs to focus on, thankfully, which we hope to have figured out by the end of the break - one involving a frequency scale that does not accept a value below 20 Hz, and another more interface related one that deals with button shading so that it's more obvious to the user what is selected. Also, I'd like to catch up on my blog posts (needless to say...) not only for the grade aspect of it, but blogging also helps me to gather my thoughts about the project, the group, and everything else that's going on. It helps me reset my perspective, which in turn makes me think more clearly about the project and gives me a little boost in confidence - not to be taken lightly!
The group has decided on a couple of bugs to focus on, thankfully, which we hope to have figured out by the end of the break - one involving a frequency scale that does not accept a value below 20 Hz, and another more interface related one that deals with button shading so that it's more obvious to the user what is selected. Also, I'd like to catch up on my blog posts (needless to say...) not only for the grade aspect of it, but blogging also helps me to gather my thoughts about the project, the group, and everything else that's going on. It helps me reset my perspective, which in turn makes me think more clearly about the project and gives me a little boost in confidence - not to be taken lightly!
Tuesday, February 25, 2014
That could be me in a year!
Here I comment on the Alumni Symposium. My class schedule this semester did not allow me to attend this time, so the only thing I know of it is the speaker lineup. I'll mainly comment on a symposium I attended a couple of years ago. The first thing I want to mention is that the age of the speakers is vastly different. The symposium I attended earlier in my college career featured many older graduates, mostly from the graduating classes before 2000, whereas the recent symposium had several students who graduated within the past couple of years. Many of them stayed in Charleston as well. Most of the speakers talked about their job, and there was one who spoke of graduate school. I remember one speaker worked in the defense industry and spoke of the potential of jobs in the security sector. There was another interesting alumni who apparently did not originally graduate with a computer science degree. He was a construction worker for a long time, but realized that he didn't want to be doing it his whole life and went back to school for computer science. You would never guess that he was a computer scientist by looking at him, which just proves the saying "You can't judge a book by its cover." Dr. Starr said that he did all of the homework problems at the back of the book instead of just the ones that were assigned as he was really committed to his education and making it work for him. He was probably the most impressive speaker to me. The last speaker that I remember was a graduate student, I think going for his Masters degree, who specialized in optimization of the workstation, or something similar. I think I remember that he was all about having multiple monitors in some particular orientation to maximize productivity. At the time, I remember thinking that it seemed kind of silly, because everyone knows that having two monitors over one increases productivity. We employ this strategy at the helpdesk, the lab was recently implemented it, and at the time, I thought it was already pretty much common knowledge.
I'm not sure I personally identify with any of the speakers that I remember. I don't see myself going to graduate school, or at least not right after I get my Bachelor's degree. I don't think I'd like the security sector that much, although I'm sure your job would also be very secure if you were in that industry. I want to somehow contribute to society with my skills. I don't mean to say that programming jobs don't contribute, because surely they do, in one way or another, but I mean in a sense that makes the world a better, easier, more healthy, or environmentally friendly place to live. Not just work for a random for-profit company that writes and provides program x to a particular market. I think I made a post last semester about the point of sale software that Papa John's uses. I don't want to be on the team that writes programs like that, I want to be on the team that writes, for example, software that helps reduce emissions, or guides solar energy panels during different weather conditions for the maximum output. Maybe not in a year, but some day, I hope.
I'm not sure I personally identify with any of the speakers that I remember. I don't see myself going to graduate school, or at least not right after I get my Bachelor's degree. I don't think I'd like the security sector that much, although I'm sure your job would also be very secure if you were in that industry. I want to somehow contribute to society with my skills. I don't mean to say that programming jobs don't contribute, because surely they do, in one way or another, but I mean in a sense that makes the world a better, easier, more healthy, or environmentally friendly place to live. Not just work for a random for-profit company that writes and provides program x to a particular market. I think I made a post last semester about the point of sale software that Papa John's uses. I don't want to be on the team that writes programs like that, I want to be on the team that writes, for example, software that helps reduce emissions, or guides solar energy panels during different weather conditions for the maximum output. Maybe not in a year, but some day, I hope.
Tuesday, February 18, 2014
Squashed?
This post is supposed to be a report on a bug we fixed and submitted. I am sad to say that has yet to happen with our group - at least for a legitimate bug. We created a Google+ group a while back and have tossed around several bugs to examine more closely from the Audacity Bugzilla, but have yet to make any changes to the code. The most significant thing we've contributed to the community, and so far the only thing that I'm aware of, was getting them to update the wiki with proper instructions on joining the IRC chat. I've recently created a GitHub repository for our group to use for our bug fixes, and possibly a Nyquist plugin that we'd like to write. I figured we'd try GitHub instead of Subversion this semester just to get more exposure and experience with more tools. So far, 3 out of 4 of us have successfully built Audacity from the source code, with me being the one left out. John and Joe used Ubuntu or a virtualized version of Ubuntu to build it, while Matthew used Visual Studio on Windows. I think the main reason that it's not working for me is that I am running Mint Linux, which somehow complicated the build process. I've been on the Audacity forums getting some help, but so far have still been unsuccessful. I plan on reformatting my computer and just putting Ubuntu on it instead. I think I like Ubuntu more anyway...
Thursday, January 23, 2014
Joining the Project
So this has been a fun night of signing up for all of the different collaboration venues available to the Audacity community. This includes the forums here: http://forum.audacityteam.org/, the IRC channel using the Pidgin chat client, and the developer mailing list. I can't say it was all that eventful, but I did come across a couple of interesting things. First off, joining the mailing list was a piece of cake, just put in your email address, then reply to the activation email that they send you. I have yet to get any messages from them, and I've been on it for a few days now, but I doubt they will send too many emails. Probably only when something relatively big is going on with the project. The next thing I did was sign up for the IRC chat. This was also pretty easy to do following the directions posted on the wiki. There was one thing that didn't match up with the direction, however. One of the steps asks you to register your username so that someone else cannot choose it and impersonate you, and the way to do that is by using NickServ, which was built into Pidgin, from what I understand. As soon as you create your username, it warns you that it is not yet registered, although you can choose to ignore it. The wiki instructed me to use the command:
/msg NickServ register password
where password is the password you used when you created your username. This did not work, however. The error message said that the syntax was wrong and that I needed to include an email after the password in order to register. So I did that, and got an email with another command to paste in the chat client that contained a registration code to complete the registration. I think my first suggestion to the community is going to be to update the IRC instructions to reflect what I experienced, even though it really isn't hard to fix given the error message when you try to do what the wiki says.
The final thing I've done tonight was sign up on the forums, which is where all the meat is. There were 16 people in the IRC chat when I logged on, but nobody was saying anything, so I started reading the forums. After I signed up, I immediately found the perfect subject to read up on: How to Compile Audacity! Earlier tonight I spent a significant amount of time trying to build and compile Audacity from the source code, but haven't yet been successful, although I think I'm really close. Audacity requires the wxWidgets 2.8.x library and a C++ compiler, CMake, to successfully build. 2.8 is actually not the newest version of the wxWidgets library, it is now up to 3.0, which is the one I downloaded, assuming it would work. Installing this library also required me to install yet another dependency, of course. So after doing that, I figured out how to install the library. Installing CMake was easy, as it's just a simple sudo apt-get install command. Now with all of the dependencies installed, I go to try and build Audacity, but it cannot seem to find the wxWidgets library. Turns out, it doesn't work with 3.0 yet, so I went and downloaded/installed 2.8, but it is still giving me the same thing. It doesn't seem to see it. Funny thing is, "Moving to wxWidgets 3.0" is on the front page of the Compiling Audacity section of the forum, haha. Once I finally get this thing built, I'm going to write a step-by-step how to so my groupmates can simulate it.
/msg NickServ register password
where password is the password you used when you created your username. This did not work, however. The error message said that the syntax was wrong and that I needed to include an email after the password in order to register. So I did that, and got an email with another command to paste in the chat client that contained a registration code to complete the registration. I think my first suggestion to the community is going to be to update the IRC instructions to reflect what I experienced, even though it really isn't hard to fix given the error message when you try to do what the wiki says.
The final thing I've done tonight was sign up on the forums, which is where all the meat is. There were 16 people in the IRC chat when I logged on, but nobody was saying anything, so I started reading the forums. After I signed up, I immediately found the perfect subject to read up on: How to Compile Audacity! Earlier tonight I spent a significant amount of time trying to build and compile Audacity from the source code, but haven't yet been successful, although I think I'm really close. Audacity requires the wxWidgets 2.8.x library and a C++ compiler, CMake, to successfully build. 2.8 is actually not the newest version of the wxWidgets library, it is now up to 3.0, which is the one I downloaded, assuming it would work. Installing this library also required me to install yet another dependency, of course. So after doing that, I figured out how to install the library. Installing CMake was easy, as it's just a simple sudo apt-get install command. Now with all of the dependencies installed, I go to try and build Audacity, but it cannot seem to find the wxWidgets library. Turns out, it doesn't work with 3.0 yet, so I went and downloaded/installed 2.8, but it is still giving me the same thing. It doesn't seem to see it. Funny thing is, "Moving to wxWidgets 3.0" is on the front page of the Compiling Audacity section of the forum, haha. Once I finally get this thing built, I'm going to write a step-by-step how to so my groupmates can simulate it.
Tuesday, January 21, 2014
Foss Experiences and Reflections
So today's assignment was to install a new FOSS program and fiddle with it some as well as read The Cathedral and the Bazaar and blog about both. As for the FOSS program, I chose Audacity, naturally. I can justify this choice, as even though it was our group's chosen project to work on, I have never really used it before, so it is indeed new to me! I think actually, at some point I have downloaded it - probably back in '07 and '08 when I ran Ubuntu as my main OS, but I didn't really do much with it. My initial findings with the program is that for one, it is not very aesthetically appealing. All of the buttons and menu selections look like pre-Windows XP styled options. Of course, this isn't really that big of a deal as long as it works, but why not make it look pretty? One of the other things that I noticed in my short little tinker session is that when you import an audio file (I used an mp3 song) and increase the playback speed, the pitch of the sounds also goes up, much like old keyboards with pre-recorded songs and a tempo increase button. I found this a bit odd, as from my understanding, it is much more preferable to keep the pitch unchanged from the original, regardless of playback speed. I supposed there are situations for justifying it, like wanting to sound like a chipmunk, but there should at least be an option for enabling/disabling the pitch change effect. It also may be that there actually is some option to achieve this effect that I simply haven't yet discovered, because it really seems outdated if there isn't - just like an old keyboard.
The second half of the blog will be about the read, which I found delightful. It was a great contrast to the Mythical Man Month, which we read last semester. Just reading about open-source development makes me want to switch back to Ubuntu and get my hands dirty again. I used to use exclusively open-source programs and for those that I couldn't, I would use a Windows emulator (which is probably obsolete now, with virtual machines being all the rage) called WINE (WINdows Emulator) to run the programs that were Windows-exclusive which I still needed. Ubuntu blew my mind at the time, with things like multiple desktop workspaces, a ton of keyboard shortcuts, and seemingly endless addons to customize your desktop, which I loved. Anyhow, that is a little off topic from the reading. I overall enjoyed reading it very much, especially the author's experience in dealing with a (relatively) large base of contributors to his "fetchmail" program. The open-source methodology is so contradictory to what seems intuitive. Lots of developers working on the same project with high turnover seems like it would be a total disaster, but in reality, it is the opposite. Learning how debugging can be solved with a parallel approach was especially epitomic. Multiple developers investigating several different error traces to find the bug and when one will invariably find it, the others can stop tracing. The debugging time scales (logarithmically) with the amount of people debugging! Amazing!
The second half of the blog will be about the read, which I found delightful. It was a great contrast to the Mythical Man Month, which we read last semester. Just reading about open-source development makes me want to switch back to Ubuntu and get my hands dirty again. I used to use exclusively open-source programs and for those that I couldn't, I would use a Windows emulator (which is probably obsolete now, with virtual machines being all the rage) called WINE (WINdows Emulator) to run the programs that were Windows-exclusive which I still needed. Ubuntu blew my mind at the time, with things like multiple desktop workspaces, a ton of keyboard shortcuts, and seemingly endless addons to customize your desktop, which I loved. Anyhow, that is a little off topic from the reading. I overall enjoyed reading it very much, especially the author's experience in dealing with a (relatively) large base of contributors to his "fetchmail" program. The open-source methodology is so contradictory to what seems intuitive. Lots of developers working on the same project with high turnover seems like it would be a total disaster, but in reality, it is the opposite. Learning how debugging can be solved with a parallel approach was especially epitomic. Multiple developers investigating several different error traces to find the bug and when one will invariably find it, the others can stop tracing. The debugging time scales (logarithmically) with the amount of people debugging! Amazing!
Tuesday, January 14, 2014
First Impressions
My FOSS Preferences
Plainly, my top three FOSS projects choices are Audacity, Firefox, and Filezilla.
I'm excited to get started this semester for several reasons. For one, I stopped working so much. I'm only working probably 2 nights a week, 3 tops, and I only have job instead of three. I should have much more time to commit to school, which is exactly what I want. Last semester is probably the worst semester I've had at College of Charleston.
The second reason is that my group seems very excited and ambitious. I've had classes with John before, and he's a great teammate as well as really smart. Stephen and Matt also seem like great guys. When we were discussing which projects to choose, Matt through out the idea of Audacity and immediately, Stephen was stoked. Apparently he is big into audio processing on his own - he's got an idea of writing a plugin that would fill a big need that he says hasn't been done before, or at least to his knowledge. Working on Audacity also tailors to my interests. I have a pretty large musical background. I was in choir all through middle, high school, and a couple years in college as well. I taught myself how to play the guitar in high school and have been playing off and on since. I can read music, although not fluently, given time I can figure it out. Another great thing about this project is that if we succeed, Stephen says we could make money off of it, which would be awesome and a great resume builder.
Some of the resources for the reading today was pretty familiar to me. Everyone knows what wikis and blogs are, but I had to look up planets. It's basically a feed aggregator which displays posts from other web-blogs and internet communities on a separate new webpage. I'm also familiar with listsrvs. As I work at the helpdesk, there are several times I've dealt with them. Sometimes, when people graduate, they're email is still on the enrolled student listsrv, so they still get emails even after they've graduated. There's also listsrvs for department faculty, all faculty, certain student body groups, among many others. They are incredibly useful when trying to communicate to a group of people.
Plainly, my top three FOSS projects choices are Audacity, Firefox, and Filezilla.
I'm excited to get started this semester for several reasons. For one, I stopped working so much. I'm only working probably 2 nights a week, 3 tops, and I only have job instead of three. I should have much more time to commit to school, which is exactly what I want. Last semester is probably the worst semester I've had at College of Charleston.
The second reason is that my group seems very excited and ambitious. I've had classes with John before, and he's a great teammate as well as really smart. Stephen and Matt also seem like great guys. When we were discussing which projects to choose, Matt through out the idea of Audacity and immediately, Stephen was stoked. Apparently he is big into audio processing on his own - he's got an idea of writing a plugin that would fill a big need that he says hasn't been done before, or at least to his knowledge. Working on Audacity also tailors to my interests. I have a pretty large musical background. I was in choir all through middle, high school, and a couple years in college as well. I taught myself how to play the guitar in high school and have been playing off and on since. I can read music, although not fluently, given time I can figure it out. Another great thing about this project is that if we succeed, Stephen says we could make money off of it, which would be awesome and a great resume builder.
Some of the resources for the reading today was pretty familiar to me. Everyone knows what wikis and blogs are, but I had to look up planets. It's basically a feed aggregator which displays posts from other web-blogs and internet communities on a separate new webpage. I'm also familiar with listsrvs. As I work at the helpdesk, there are several times I've dealt with them. Sometimes, when people graduate, they're email is still on the enrolled student listsrv, so they still get emails even after they've graduated. There's also listsrvs for department faculty, all faculty, certain student body groups, among many others. They are incredibly useful when trying to communicate to a group of people.
Subscribe to:
Posts (Atom)