The group took a liking to the work I did and I went ahead and submitted it. However, we're still at the same location we were before where we need to display the Google map, Jason is primarily working on this while I finish up my code. I was really satisfied with how my stuff is working. When I ran a couple of tests it was actually close to the distance Google Maps posted.
We also made our site live and for the most part it works, but there are a few quirks to it. However, things feel like they're moving a lot more smoothly now and we may be done by the end of the week and can begin testing next week. We'll see how that goes!
On a side note, I'm going to get busy again with other classes so hopefully I can put in some decent hours here. CS451 is kicking my ass and with a measly 28 on the f'n midterm, I'm a little concerned so I'm trying to give it a little more prime time than before.
Last semester sucks!
Tuesday, April 22, 2008
Monday, April 21, 2008
Some surprsing progress (for me)
I've managed to have broken the PHP barrier and have begun to understand how it's functionality works - however the Drupal connection still doesn't make sense to me, not entirely.
I spent the rest of Sunday night trying to come up with a clever way to implement the Find module. Since we want to find all of the CD's within a distance of a user's current location, I figure we can use Google maps' latitude and longitude measurements and some calculation to pick out the CD's nearest the search location. As far as I know, the call to Google we're making and the values we're pulling from the return are in degrees so using something like the Great Circle Distance Formula may actually feasible. Here are some steps I think can be followed:
I think it should work, but there is an issues we'll have to contend with. If we're searching through a city, there may be many CDs that are returned. The Great-Circle Distance formula uses sine, cosine, and arcosine to calculate the distance, this may cause some inefficiencies.
I have to run this approach with the rest of the group. As I've mentioned before, Jason is working on this as well, but I have not heard anything from him, so I'm not sure what kind of progress he's made. If this works and the group goes along with it, all we would need to do is put the Google map on the page and it should be working (I've managed to have gotten most everything working, just have to double check the distances).
One final note, I'll have to double check and make sure this matches the requirements document. Don't want to go about just adding things al troche-moche. But we'll see!
I spent the rest of Sunday night trying to come up with a clever way to implement the Find module. Since we want to find all of the CD's within a distance of a user's current location, I figure we can use Google maps' latitude and longitude measurements and some calculation to pick out the CD's nearest the search location. As far as I know, the call to Google we're making and the values we're pulling from the return are in degrees so using something like the Great Circle Distance Formula may actually feasible. Here are some steps I think can be followed:
- Have the user input the address they're located, city, state, and maybe zip code
- Search the data base for CD's in given location (more on this regarding problems in a bit)
- Go through list and calculate distances, only keeping points that are within specified distance
- Render map with points on it (have info regarding distance of sorts)
I think it should work, but there is an issues we'll have to contend with. If we're searching through a city, there may be many CDs that are returned. The Great-Circle Distance formula uses sine, cosine, and arcosine to calculate the distance, this may cause some inefficiencies.
I have to run this approach with the rest of the group. As I've mentioned before, Jason is working on this as well, but I have not heard anything from him, so I'm not sure what kind of progress he's made. If this works and the group goes along with it, all we would need to do is put the Google map on the page and it should be working (I've managed to have gotten most everything working, just have to double check the distances).
One final note, I'll have to double check and make sure this matches the requirements document. Don't want to go about just adding things al troche-moche. But we'll see!
Sunday, April 20, 2008
Spend a night in the box
I've spent part of Saturday and a good portion of Sunday going over PHP tutorials and some Drupal stuff so I can stop fighting over this code (for the record, my ass hurts, and I'm tired of this office). One of the books we got from Prof. Bridges, Drupal: Creating Blogs, Forums, Portals, and Community Websites hasn't been as helpful as I was hoping. I think the other book may help some. Anyways, I spent a good deal looking at the tutorials and seeing how or what our code is doing in relation to this. I've gotten a better grasp of stuff, i.e. I understand how arrays work. But the Drupal connection still isn't solid for me. Jared keeps saying it uses hooks, so where are these hooks called? What change can I make and how can I see it? Yarr!
The code Jared had written does everything we need and all we have to do now is just display a Google map with those marker locations. I'm trying to figure this out, but still not sure how. I can't find where this is done in the other modules, but I'm still searching.
So I can stop wasting time I've done the following things:
I'm very conscientious about what I provide to the group, so right now it's killing me that I haven't produced code. I hope, that by providing other types of support I can still pass this class and not be seen as a bad engineer.
The code Jared had written does everything we need and all we have to do now is just display a Google map with those marker locations. I'm trying to figure this out, but still not sure how. I can't find where this is done in the other modules, but I'm still searching.
So I can stop wasting time I've done the following things:
- Asked Jason if he's still working on the find module (as far as I know he is) and if he needs me to do anything. I don't want to work on something and it turn out that he had finished it all along.
- Emailed the rest of the group if there's anything else I can do. I don't want to hold up the process and I want to stop feeling like I'm not contributing anything. Also, hopefully by doing this the group will realize I'm not slacking and am trying to be a providing member.
- Start reviewing documents and see what else can or should be done. Also, at this point, I guess I'll be a language lawyer but only in the sense of the project.
I'm very conscientious about what I provide to the group, so right now it's killing me that I haven't produced code. I hope, that by providing other types of support I can still pass this class and not be seen as a bad engineer.
Infinite frustration
For the former part of the week I got stuck working on a parallel programming project so that took up a lot of my time. I finished that up Wednesday night and started "working" on the MixCD project on Thursday... to no avail.
For the most part I'm still confused on the PHP, I'm trying really hard on figuring out how Drupal interacts with the code we write. Jared has explained it a few times, but I still fail to see the connection.
But back to the project and the Find module I'm supposed to be working on with Jason. I've tried to get a hold of Jason so we can collaborate on the module, but I can't seem to get a response. He had sent a message to the group, primarily to Jared, regarding some info on the module, but he didn't state if he had made any progress on it either or if he wanted me to do anything. I'll try again to message him and see what I can do to help.
Speaking of Jared, on Thursday I spoke with him and apparently he wrote a good 80% of the find module. It basically takes information out of the database, based on Zip code or State and, for the moment, prints out the returned array. This has utterly made me feel useless and my frustration is growing that I haven't actually produced any code or anything tangible (aside from documentation).
I'll keep looking at what we have and try and figure stuff out. However, I may have to request to work on something else. Maybe do more documentation or figure out a way to test the site. I'll see what the group says.
For the most part I'm still confused on the PHP, I'm trying really hard on figuring out how Drupal interacts with the code we write. Jared has explained it a few times, but I still fail to see the connection.
But back to the project and the Find module I'm supposed to be working on with Jason. I've tried to get a hold of Jason so we can collaborate on the module, but I can't seem to get a response. He had sent a message to the group, primarily to Jared, regarding some info on the module, but he didn't state if he had made any progress on it either or if he wanted me to do anything. I'll try again to message him and see what I can do to help.
Speaking of Jared, on Thursday I spoke with him and apparently he wrote a good 80% of the find module. It basically takes information out of the database, based on Zip code or State and, for the moment, prints out the returned array. This has utterly made me feel useless and my frustration is growing that I haven't actually produced any code or anything tangible (aside from documentation).
I'll keep looking at what we have and try and figure stuff out. However, I may have to request to work on something else. Maybe do more documentation or figure out a way to test the site. I'll see what the group says.
(group) Meeting 2 (Wednesday 4/23)
We've accomplished a great deal on our site and the meeting was mostly what we should be doing and where we were at.
I have been assigned to help Jason with the MixCD find functionality. What this is is: A user who wants to search for a CD in his/her area can put in the city they are in, then their area code and the site will do a search through the database of CD's that may be in that Zip code. We would like to make it so it can do it at a certain radius, but for the moment we're sticking with the area code. This way a person can go searching for the CD.
I'm still confused with the Drupal/PHP concept here, so hopefully I'll be able to pick it up and make something useful.
I have been assigned to help Jason with the MixCD find functionality. What this is is: A user who wants to search for a CD in his/her area can put in the city they are in, then their area code and the site will do a search through the database of CD's that may be in that Zip code. We would like to make it so it can do it at a certain radius, but for the moment we're sticking with the area code. This way a person can go searching for the CD.
I'm still confused with the Drupal/PHP concept here, so hopefully I'll be able to pick it up and make something useful.
Meetings (Monday 14th)
Had a meeting with Bridges on this day. Obviously we discussed our project and how it was going. He was satisfied with the work we've done and liked our documents. However, he did say we need to relate our testing document back to our requirements document. Makes sense. I was responsible for the main test cases of the document, so I should have done that, but I was mostly in the mindset of "test the functionality of it". We'll make the appropriate updates as we continue on.
Only two more weeks though.... a little scary!
Only two more weeks though.... a little scary!
Tuesday, April 8, 2008
Extreme Programming
Since this is a blog about my Software Engineering class, I figured I would cover a Software Engineering strategy (?) called eXtreme Programming also known as XP. So what is XP?
extremeprogramming.org states:
There are 4 major rules/strategies that are followed:
We have covered different types of development cycles, i.e. Cascading/waterfall design, XP on the other hand is a bit different. Below is the flow chart used for development.
This type of methodology may seen like a good practice, it does have its own set of controversial aspects. Wikipedia lists some of them such as:
Personally, I have some reservations regarding this methodology and don't fully believe in all of the tenets. Also I believe testing is perhaps the most beneficial aspect. I haven't worked at any professional software development companies, so I am not sure how a lot of Software Engineering practices are put to use. The only real work I've done was with Pfizer, however, I was just an intern and was given my subset of work.
Finally, the name is horrible. I don't understand why they decided to use a name with 'extreme' in it. I feel like the creators of this methodology are trying to entice me to use it like Mountain Dew commercials. Should I be writing my code while skydiving, skateboarding, or even snowboarding? I don't think so. There is nothing extreme about this, it is only a different way of looking at doing things.
Have a nice day....
extremeprogramming.org states:
Extreme Programming (XP) is actually a deliberate and disciplined approach to software development....
XP is successful because it stresses customer satisfaction. The methodology is designed to deliver the software your customer needs when it is needed. XP empowers your developers to confidently respond to changing customer requirements, even late in the life cycle.
This methodology also emphasizes team work. Managers, customers, and developers are all part of a team dedicated to delivering quality software. XP implements a simple, yet effective way to enable groupware style development.
XP improves a software project in four essential ways; communication, simplicity, and courage. XP programmers communicate with their customers and fellow programmers. They keep their design simple and clean. They get feedback by testing their software starting on day one. They deliver the system to the customers as early as possible and implement changes as suggested. With this foundation XP programmers are able to courageously respond to changing requirements and technology.
XP is different. It is a lot like a jig saw puzzle. There are many small pieces. Individually the pieces make no sense, but when combined together a complete picture can be seen. This is a significant departure from traditional software development methods and ushers in a change in the way we program.
There are 4 major rules/strategies that are followed:
- Planning
- User stories are written.
- Release planning creates the schedule.
- Make frequent small releases.
- The Project Velocity is measured.
- The project is divided into iterations.
- Iteration planning starts each iteration.
- Move people around.
- A stand-up meeting starts each day.
- Fix XP when it breaks.
- Designing
- Simplicity.
- Choose a system metaphor.
- Use CRC cards for design sessions.
- Create spike solutions to reduce risk.
- No functionality is added early.
- Refactor whenever and wherever possible.
- Coding
- The customer is always available.
- Code must be written to agreed standards.
- Code the unit test first.
- All production code is pair programmed.
- Only one pair integrates code at a time.
- Integrate often.
- Use collective code ownership.
- Leave optimization till last.
- No overtime.
- Testing
- All code must have unit tests.
- All code must pass all unit tests before it can be released.
- When a bug is found tests are created.
- Acceptance tests are run often and the score is published.
We have covered different types of development cycles, i.e. Cascading/waterfall design, XP on the other hand is a bit different. Below is the flow chart used for development.
This type of methodology may seen like a good practice, it does have its own set of controversial aspects. Wikipedia lists some of them such as:
- Requirements are expressed as automated acceptance tests rather than specification documents.
- Requirements are defined incrementally, rather than trying to get them all in advance.
- Software developers are required to work in pairs.
- There is no Big Design Up Front. Most of the design activity takes place on the fly and incrementally, starting with "the simplest thing that could possibly work" and adding complexity only when it's required by failing tests. Critics fear this would result in more re-design effort than only re-designing when requirements change.
- A customer representative is attached to the project. This role can become a single-point-of-failure for the project, and some people have found it to be a source of stress. Also, there is the danger of micro-management by a non-technical representative trying to dictate the use of technical software features and architecture.
Personally, I have some reservations regarding this methodology and don't fully believe in all of the tenets. Also I believe testing is perhaps the most beneficial aspect. I haven't worked at any professional software development companies, so I am not sure how a lot of Software Engineering practices are put to use. The only real work I've done was with Pfizer, however, I was just an intern and was given my subset of work.
Finally, the name is horrible. I don't understand why they decided to use a name with 'extreme' in it. I feel like the creators of this methodology are trying to entice me to use it like Mountain Dew commercials. Should I be writing my code while skydiving, skateboarding, or even snowboarding? I don't think so. There is nothing extreme about this, it is only a different way of looking at doing things.
Have a nice day....
So it begins!
We have finally finished all of our documents. All that's left is to finish our site, update our documents to reflect any changes we made, test, debug, and ship! Yeah...easier said than done.
Jared, Jason, and to an extent Jonathan are well versed in PHP and how the tools work. Andy seems to have a basic understanding and I think Daniel understands it as well. Me, well, quite frankly, I know absolutely nothing about this. When I joined up I figured all this website stuff would be easy. We would write some HTML, which I knew little of to begin with, and have a fancy website running. Nope. Turns out there are all these tools, modules, scripts, servers, securities and stuff to take care of. There are a lot of tools available to help, but dag-nabbit, still goes over my head.
Through the first part of this project I've managed to keep busy by helping with the documents, but now as we have arrived to actually producing something, I'm a bit nervous. It should be ok though. We have a lot of resources at our disposal not to mention Jared and Jason seem to know what's going on, so I can always ask them. Currently, I have asked the team to assign me the easier stuff that won't be critical or highly depended on. This way I can contribute something but not be a hindrance to the rest of the team.
We'll see what happens, if I can't contribute to the core part, I'll help in other ways. There is still a document to maintain and people to manage... bwahaha :D
Jared, Jason, and to an extent Jonathan are well versed in PHP and how the tools work. Andy seems to have a basic understanding and I think Daniel understands it as well. Me, well, quite frankly, I know absolutely nothing about this. When I joined up I figured all this website stuff would be easy. We would write some HTML, which I knew little of to begin with, and have a fancy website running. Nope. Turns out there are all these tools, modules, scripts, servers, securities and stuff to take care of. There are a lot of tools available to help, but dag-nabbit, still goes over my head.
Through the first part of this project I've managed to keep busy by helping with the documents, but now as we have arrived to actually producing something, I'm a bit nervous. It should be ok though. We have a lot of resources at our disposal not to mention Jared and Jason seem to know what's going on, so I can always ask them. Currently, I have asked the team to assign me the easier stuff that won't be critical or highly depended on. This way I can contribute something but not be a hindrance to the rest of the team.
We'll see what happens, if I can't contribute to the core part, I'll help in other ways. There is still a document to maintain and people to manage... bwahaha :D
Making up for the past... Part II
Since the project has started we have submitted various documents. Following the Requirements document was the Management document. This covered how we would be managing the project - hence the name - and how we would we would schedule our time. Granted a bit of it seemed like fluff - how much experience can we, as 'young' students, claim? Also, our 'team organization' section essentially said that everyone would be doing everything, except for Andy, who's our team leader. But that's the only difference.
For this project/class given the time, to me, is a little silly. However, given a large corporation or development team, this would be invaluable. And it is good practice to see and write a document like this. So, although it seems like I'm complaining a tad bit, I see the value behind it.
ps. I kind of wish I could see if the company I work for has or had a document like this...maybe I should ask them.
For this project/class given the time, to me, is a little silly. However, given a large corporation or development team, this would be invaluable. And it is good practice to see and write a document like this. So, although it seems like I'm complaining a tad bit, I see the value behind it.
ps. I kind of wish I could see if the company I work for has or had a document like this...maybe I should ask them.
Tuesday, April 1, 2008
Making up for the past
It's been over a month since I last posted something, so hopefully I can make up for some of that with a decent review post...
MixCD
The last post I wrote covered what the project I am part of is about. Since then we have written the Requirements Document which detailed the requirements we wish to fulfill by the end of the semester. We defined certain aspects like users and how they would interact with the system, what language we would be using - essentially high level requirements.
As we develop our product - essentially a website - we will look back to this document and see if we have met the requirements. The requirements document is a living thing where it can change and evolve as we progress. However, the closer we get to and manage to meet our requirements the better we are. (Not that change is bad, sometimes requirements can be set to high or low and change may be required.)
Our project is fairly straightforward and easy to implement, I look forward to the finished product and see it in action.
MixCD
The last post I wrote covered what the project I am part of is about. Since then we have written the Requirements Document which detailed the requirements we wish to fulfill by the end of the semester. We defined certain aspects like users and how they would interact with the system, what language we would be using - essentially high level requirements.
As we develop our product - essentially a website - we will look back to this document and see if we have met the requirements. The requirements document is a living thing where it can change and evolve as we progress. However, the closer we get to and manage to meet our requirements the better we are. (Not that change is bad, sometimes requirements can be set to high or low and change may be required.)
Our project is fairly straightforward and easy to implement, I look forward to the finished product and see it in action.
Friday, February 29, 2008
MixCD
I have volunteered to be part of Andy's MixCD project. This seems like an easy enough proje with an interesting goal.
The idea behind the project is to make a website that people use to track Mix CD's they've left lying around for other people to discover. When someone finds the CD they can go to the address trackthismix.com on the CD and see what mix is on there. The person who left the CD can then be notified that their CD had been found. We feel this is an interesting if not entertaining way of sharing music. Not only do we get to see who and where the CD was left, but track it's progress. This is very similar to the Where's George website. There are some complications to it; will people actually burn CD's and be willing to leave them? Will the RIAA decide to sue us?
This project seems fun, but most importantly, easy to do. I'm one for challenges, but when you're in your Senior year in college, easy projects are very tempting. :D
On a side note, I would love to see this project done on Facebook. The reason being, it already has a set userbase and would be easier to spread the word through the website. But right now, we already have our website and we'll be given some freedom with our project.
We'll see where we go from here!
The idea behind the project is to make a website that people use to track Mix CD's they've left lying around for other people to discover. When someone finds the CD they can go to the address trackthismix.com on the CD and see what mix is on there. The person who left the CD can then be notified that their CD had been found. We feel this is an interesting if not entertaining way of sharing music. Not only do we get to see who and where the CD was left, but track it's progress. This is very similar to the Where's George website. There are some complications to it; will people actually burn CD's and be willing to leave them? Will the RIAA decide to sue us?
This project seems fun, but most importantly, easy to do. I'm one for challenges, but when you're in your Senior year in college, easy projects are very tempting. :D
On a side note, I would love to see this project done on Facebook. The reason being, it already has a set userbase and would be easier to spread the word through the website. But right now, we already have our website and we'll be given some freedom with our project.
We'll see where we go from here!
Mindstorm-XO fails
My proposal for this class almost past muster, but didn't make the cut. I'm not too surprised, it is a difficult project and would have taken a lot of work. The project was tied with two other projects - with two other projects having more votes than ours. The vote came down to a secondary vote and MXO only got 3 votes total. Like I said before, I'm ok with the project not being chosen, and frankly, I thought some of the other ones were more interesting than mine. However, I do think Chaz gesture project would have been a lot of fun to do (and useful) and Vince's Karma project also - much to Vince's chagrin.
All posts following this will cover the project I am on...which will be the topic of my next post.
All posts following this will cover the project I am on...which will be the topic of my next post.
Wednesday, February 13, 2008
I prefer a hefeweizen, but a draft will do
The rough draft has been completed. I'm not completely and totally satisfied with it but, I think it's decent. Prof. Bridges suggests that I make some corrections, add previous work like LabView into the main proposal, and make a more thorough time-line. Easy stuff that can be done rather easily. He also suggested having a back up plan unless we have trouble developing for the XO. Some kind of simple program for High School students or maybe even elementary students. Hopefully it won't come to that and we wont' have to worry about there being too much trouble with the XO.
Here are some excerpts from the draft:
On Motivation (suggested improving this section):
I like the idea I've come up with (although, I have to give a lot of credit to Jared Quintana for the original idea, I've essentially run with it). I was a little worried about it when I first wrote my concept paragraph, but now that I've fleshed out more ideas, it's kind of starting to grow on me. I really do wish I could have done some sensor network stuff, but this will be good too. I'll be honest with anyone actually reading this, it would be really cool if this project worked out so well it became part of the main packages or programs for XO. That would be awesome, but I'm certainly not going to hold my breath. (There are other issues with Mindstorms that come into play... i.e. the price.
Here are some excerpts from the draft:
On Motivation (suggested improving this section):
Currently there no is research or development for NXT on the XO. There has been a report that LEGO Education will be working with OLPC in Brazil [link], however, there is no indication – or guarantee – that they will port their current Microsoft Windows and Mac OS X compatible NXT software to the XO. LEGO Mindstorms NXT is an incredibly popular robotics kit with many schools from elementary to Universities utilizing the tools available.On Background:
The One Laptop per Child (OLPC) association is non-profit organization whose goal is to develop a low-cost laptop – the “$100 Laptop” or XO-1 – to revolutionize how we educate the world’s children. Their goal is to provide children around the world with new opportunities to explore, experiment, and express themselves [link].Background continued...
LEGO® Mindstorms NXT is a programmable robotics kit released by LEGO. The LEGO Mindstorms NXT software enables a user to program and upload instructions to the NXT – an intelligent computer-controlled LEGO brick and the brain of the Mindstorms robot –via USB or Bluetooth connectivity [link].Finally, on System Description:
The graphical user interface (GUI) will consist of large, easy to understand icons indicating what the Mindstorm robot will do. This icons will be laid out along one of the borders of the application, while the main window will display how or what the robot will do i.e., a road map, so to speak.So where do I go from here? I need to revise my draft so it's a little more coherent. Add some positive spin as per Prof. Bridges suggestions and, well, pray I can make more heads or tails out of this.
Initially a user can select multiple actions and specify the duration of the actions. For example, a child can select a forward motion and she will be prompted to specify the length of forward motion – either in seconds or distance. The child can then stack the instructions so it can do multiple actions in succession. As the child progresses and learns more about actions, sensors can be added and the child can decide what the robot will do. Continuing the previous example, the child has added a touch or ultrasonic sensor and she can now give the robot instructions to turn 90o whenever it bumps into something or comes within a certain distance of an obstruction.
I like the idea I've come up with (although, I have to give a lot of credit to Jared Quintana for the original idea, I've essentially run with it). I was a little worried about it when I first wrote my concept paragraph, but now that I've fleshed out more ideas, it's kind of starting to grow on me. I really do wish I could have done some sensor network stuff, but this will be good too. I'll be honest with anyone actually reading this, it would be really cool if this project worked out so well it became part of the main packages or programs for XO. That would be awesome, but I'm certainly not going to hold my breath. (There are other issues with Mindstorms that come into play... i.e. the price.
Thursday, February 7, 2008
A proposal
I finally came up with something to propose, I'm not entirely satisfied with what I went with or with what I wrote, but it may work. Here is what I currently wrote:
The last line is probably the most telling. If the libraries are well written and easy to add into an implementation then the project will (hopefully) go smoothly. But then one still has to worry how the XO laptop can handle something like this. Well I guess I will soon find out as I am now tasked with doing some in depth research on all of this for the big proposal due Monday.
Another idea I wish I could have proposed was working with sensor networks. Apparently Prof. Bridges has equipment that can take remote measurements. I wanted to do something like this but I didn't have a solid ideas at the time the proposal was due. However, typical for me, the ideas have poured into my head immediately after turning in the proposal up there. Although it's too late to actually submit this idea, I still would like to throw it out there for anyone to read.
LEGO Mindstorms for the One Laptop Per Child Project
I propose developing software that allows LEGO Mindstorms to work with the laptops created through the One Laptop Per Child (OLPC or XO) project. LEGO Mindstorms is a programmable robotics kit released by LEGO. Currently, Mindstorms is only programmable through NXT, software developed by LEGO that only runs on Windows and Macs. This project is aimed at the end-users of the OLPC, primarily children and teachers, so it would remain relatively simple to program and use. Currently there is no software or on going development for LEGO Mindstorms and OLPC although it has been suggested on the OLPC website wiki that a low cost version of LEGO Mindstorms system be built around the XO.
LEGO has various libraries and Software Development Kits (SDK) available on their Mindstorms website. There has also been some work done to make NXT UNIX compatible. The OLPC itself is UNIX compatible; it uses components from Red Hat’s Fedora Core 6 version of the Linux Operating system, so that may ease the development cycle. The biggest challenge for this project would be trying to get the Mindstorms hardware to communicate with the OLPC, however, if the Bluetooth and hardware libraries written by LEGO are thorough enough, it may prove to be simple.
The last line is probably the most telling. If the libraries are well written and easy to add into an implementation then the project will (hopefully) go smoothly. But then one still has to worry how the XO laptop can handle something like this. Well I guess I will soon find out as I am now tasked with doing some in depth research on all of this for the big proposal due Monday.
Another idea I wish I could have proposed was working with sensor networks. Apparently Prof. Bridges has equipment that can take remote measurements. I wanted to do something like this but I didn't have a solid ideas at the time the proposal was due. However, typical for me, the ideas have poured into my head immediately after turning in the proposal up there. Although it's too late to actually submit this idea, I still would like to throw it out there for anyone to read.
The project I thought of was to use a sensor network around the UNM campus to determine how much second hand smoke was in and around the buildings. For the past year or so, there has been a lot of debate about smoking on campus and how close people should smoke to a building. While, I am neutral on the issue, a system detecting second hand smoke, and possibly other types of hazardous gases, will help people make the proper decisions.In hindsight, I like this idea a lot more. It would have been a lot better for me since one of the graduate schools I'm looking at, has a program with monitoring ice flows using sensor networks. But, now that I've already turned in the LEGO thing, I'll stick with that and see what the other people have done.
The main aspect of the program would be to gather and produce data. Then it would be presented in a beneficial way to the end user. A large portion of the time to develop the system would be spent on a graphical user interface to present this data.
Monday, January 28, 2008
First Day and Software Ideas
Well, looks like I'm stuck. I'm looking forward to this class because I would like to learn the process of designing, writing, and implementing a project. However, I am cursed with a lack of creativity. Generally, I don't have ideas of stuff I want to create, but that's not to say I don't want to do anything. I like to write code, be part of the process of designing how the software should be done, get into the intricate details of what I'm writing. But like I said, I don't come up with my own stuff. Well, tough luck... I'll throw out some ideas as the week progresses, maybe I'll come up with something spiffy.
Here's hoping
Here's hoping
Subscribe to:
Posts (Atom)