Search This Blog

Monday, August 17, 2009

My Interview by Ritesh Tamrakar

The following is a written interview taken by Mr. Ritesh M. Tamrakar on me following Open Source Challenge Nepal (OSCN), 2009 where I (Sumit Shrestha) gained first position for the project Live Event Broadcast using Peer to Peer. This interview discusses various factors about competition from my perspective and suggestions for others. Mr. Ritesh M. Tamrakar is another participant of OSCN with project Saral Scrum. He conducted this interview through email. According to him, the need for this interview was to inform the Nepalese developers about OSCN and share experience of its participants for others to follow which Nepalese media failed to do so.

Can you please briefly give your introduction? What are you currently doing?

Well to begin with; my home is Pokhara. It has been my home place since 6 years since I shifted to Nepal from India (Mumbai) where I was born and studied till 10. I did my ISc under Math Group in Prithvi Narayan Campus (PNC), Pokhara.

I am currently a Student of Gandaki College of Engineering and Science (GCES), Lamachaur, Pokhara studying BE in Software Engineering under the affiliation of Pokhara University. Currently, I am in Final Semester that ends by November (including Final Year Project). As final year student, I am currently doing major project on Chameleon, an Adaptive E-Mall in a Team of four. It is basically an adaptive online shopping system just like Amazon but in Nepalese context. Besides Live Event Broadcast Using P2P, My major past projects include Pokhara University Exam Routine Generator (June, 2008- December 2008 and to be submitted as research paper in NaSCoIT, 2009), Front End for MySQL (July, 2007-March, 2008 and open sourced in Source Forge), Gandaki Store Keeping System (February, 2009-June, 2009 which was my minor project done in a team of 2) and Nepali Text to Speech (TTS) (December, 2006-March, 2007).

I would describe myself as Java Programmer who likes evolutionary Software engineering techniques like Agile, Unified Process and believes in Open source Philosophy.

What is your project? Can you please briefly describe it?

My OSCN project is 'Live Event Broadcast Using Peer to Peer'. In one line, this project aims at broadcasting Live Event over internet using IP based tools using Peer to Peer infrastructure. This project can be considered as coalition of two different aims. The first is replacing past broadcasting technologies in internet (Client server) by point to point connection so that network bandwidth requirements gets distributed among peer users and server bottleneck is removed. The second is to analyze new generation of peer to peer system for sharing streaming files (which is used as they are obtained and has strict timing limits) over traditional static (offline and fixed sized files like video or document) file sharing (eg. Torrent, Napster). The first aim is industrial while second aim is research.

My System is as follows. The whole system is divided into two parts; Broadcaster and peer. Broadcaster is basically a computer with broadcaster program and Video Lan (VLC) publicly visible to others (it must not be confused with Server or distributing channel). VLC is used to stream live media from device or file into UDP packets into the broadcaster program. The program basically displays the stream locally for monitoring and creates an Advertisement File (Adv) which is an xml file equivalent to Torrent File containing human readable description of broadcasting company and IP address of broadcaster and port where it runs. This Adv file can be uploaded into broadcasting company's public site where people surf and download it. The P2P network is implemented over Free Pastry. The peers are managed through it. Each peer basically is just client which uses Adv file to connect to p2p network. The Adv file gives it the broadcaster location to which it first sends requests. The broadcaster uses underlying pastry node to forward the request to the free peer in the network. Thus, the system can support any number of peers and thus is massively scalable.

What motivate you to choose this particular project for the competition?

Basically, working on peer to peer systems had been my dream since 2006 when I first read about them in Digit Magazine. Many articles in Digit that followed continuously discussed its power and need over client server architecture. I viewed it as new technology that could soon overcome existing client server applications (absolutely everything today is client server; Web server as just one example). It was challenged earlier with forcible ban of Napster. As a geek, there was always temptation over it and its working. This only increased with time and knowledge. By third year, I had known most of client server systems. But, with end of third year, I began on journey of quenching thirst of Peer to Peer that was still new in context of Nepal. My first aim was haphazard- just work on peer to peer system. But with continued research and understanding of p2p working I settled on new version of p2p system i.e. streaming file sharing. Broadcasting was one of such example where streaming file sharing was necessary. Thus, the project concept was born and this motivated throughout the project development period.

What benefit will the project have to Nepalese society or whole world?

This project has many uses at Nepalese and world scenario. The first affect of this system is distributing the bandwidth among peer users. This means small level broadcasting companies like local FM can broadcast in internet. Broadcasting companies do not need to buy large bandwidth or pay to distribution channels for distributing as in current internet radios. Instead, they can invest in making good programs to attract large customers. For good programs, customers has just to pay some value just to get streaming media from one peer and stream same to another peer in the network. This would not be high especially with newer internet technologies like ADSL which have given customers higher bandwidth for lower cost. Since, each peer has to sustain only another peer; this would not be heavy burden because it gets same from another peer. The broadcaster can be anyone and not just entertainment company like FM, Television or like. It can be used for Tele teaching where broadcaster can be school with teacher and peers can be distant schools with students but no teacher all learning simultaneously under same teacher. In this aspect, it can be used for Mahavir Pun's Dream project of implementing Tele teaching in Myagdi district where wireless network has been established but distant villages still do not have teachers to teach. Though this project does not support bidirectional communication but by the spirit of Open source I urge people to please collaborate into it and modify it to allow bidirectional communication. Besides Tele teaching, there are so many broadcasting applications like Company presentation or political campaigns. The fields of broadcasting are immense. One has just to implement them as necessary.

Did you face any difficulty during the competition? If yes, can you please give some example of it?

I think the only thing that kept me throughout the project was difficulty. This project was in my opinion one with most difficulty. The first main difficulty was that the project was network project. Every test made had to be done in network with two or more computers at hand. This is clearly not possible at home. So, unlike other project mentioned earlier, entire coding of project was done at College LAN only (during lab hours)!! Since 11th January, 16hrs load shedding began. This even reduced development hours. Though fortunately my college had generator, there was still politics over its use and I honestly had to struggle lot for its use. Sometimes generator would overheat and even burn away keeping me days away from development!! The second problem was finding adequate P2P middleware. There were about a dozens of them with JXTA, pastry, Tapestry, Chord just few to mention. As Sun Microsystems development, my default choice was JXTA. But JXTA was not what I needed. After a month of working I realized it was not useful mainly due to its low performance of streaming using propagation pipes. After hopelessly trying out alternatives, I got to Pastry. It was not as good as JXTA but efficient for use atleast at LAN level (lets not talk what happens over firewall, I have not tested them at all!!). The third problem was breaking live media into UDP packets in real time and then caching them for displaying at client side. JMF provided many helps but still it was not completely useful. So, I used open source VLC. It did all things automatically. I just had to interface with it. These were my elaboration problems where I was finding hard to stabilize project baseline. The competition was to start by March as planned. I had registered for it with that purpose. But, somehow it shifted away. Now problem was my semester exams. They were to start in april. Since, exams ends by first week of May all would be okay – just 10 days leave of project work and then all clear to work fine. But, my nightmare began when exams too shifted to mid of May. Since the exam duration was one month, clearly I won't get any time because two days after exams and final submission (i.e. 1 June). Competition is impossible now. My dream of getting to top ten is impossible now!! I used the time before exam as much as possible to code things up and my activity rose higher. i prepared stuffs for first submission of documents. After that my exams started and had to leave the work for it. It was the worst time for me. Being away from competition really hurts a lot. During exams my visit was very limited. Finally, the exam finished and I hurriedly prepared final report in two days. But, to my surprise the final submission date shifted by a month. It was my happiest moment. I was free now and focus onto my work. Initially I used singleton pattern in my project so that all the control classes created only single instance of each other through get function. This was done in hurry. But, later I realized its problem when I wanted to view more than one broadcaster simultaneously at peer side. This was not possible with singleton classes because their only instance dealt with one channel only. For multiple channels, multiple instances were required. So, I had to change about 5 singleton control classes into non-singleton ones. The problem with this task was that they all were linked with each other in network. In Addition, the flow was hard to analyze and especially the sequence of initialization!! All this hampered this work which took lot of time to fix. The final problem was me being a pokhara participant. I had no clue what was going on D2Labs. I had not attended any seminars organized by D2Labs regarding OSCN. Till end, I communicated through emails. Though 190KM was not great distance, but many problems in way and also in valley prevented my visit. Finally, at my grand finale visit, I had to test demo prior to finale just for confidence. This could have been done easily in D2 Hawkeye lab. But, D2 too had just shifted into new building and lab was just being set up and testing was impossible there. I had nowhere to test. Finally, at grand finale, the laptops provided for demo were all Ubuntu systems. But, I needed XP systems and aleast two of them!! Also, the demo time must have started from morning i.e. from 7. With only less hours of preparation for demo caused me completely focus on it and miss earlier presentations.

What is your development methodology for the project? Did you use any particular SDLC?

I used Rational Unified Process for developing this project as in my earlier past projects. The main reason for it was the research nature of project and ever changing nature of network so that no single fixed requirements work. The whole project development evolves over time refining ideas with implementation and feedback. May be my course subject of UP was reason for its use. My SDLC according to UP be iterative and incremental. Every iteration focused on one aim (may be fixing bugs in bug list or adding features or restructuring codes) and released new versions (increments).

What benefit will your project have by choosing open source licensing than choosing closed source?

Open source projects all shares same benefit as Eric Raymond observed "Given more eye balls, all bugs are shallow". The project is research in nature with many technologies to work with. More ever, these technologies change with time. So, the project needs to adapt and update with time. This cannot be supported by single developer. All we need is a collaboration of open source developer community who devote their extra time for cause. The project needs them not only for future development but for support to customers who trust this system so as to apply it to marketing aspects. Currently, this project is just small level testing with no great real time use features. So, with open source there is hope that it continues to expand into really great system to be used over internet. This is clearly impossible with closed license which will limit it to a hobby project only.

What are the factors do you think as main reason for your success?

There were many factors behind getting first in OSCN. Firstly, there was no great change in project. I did not waste any time learning new language or tool. Since, it was java program using Netbeans which has all integrated support for the project including SVN support, I found no big change. Secondly, I started my project quite early from January. This allowed me time to save research on important parts during formal project time. All was already done much ahead. So, inspite of the above mentioned problems, I was just as cool as other project throughout. Thirdly, my attempt to take part in GSOC last year was one important factor behind success. Though I was not selected, I had learnt global open source competition and way of expressing. Fourthly, I would mention my college (especially Prasanna David Sir) for developing open source culture in me. My presentation was never commercial like others. I presented from the perspective of open source. I never feared saying that my project had bug because that is the spirit of open source to freely accept fault to allow people to correct it through collaborative practice as different to cathedral style where you hide your bugs behind bars and only show your project merits. This was not normal project presentation where people try to amuse venture capitalists and fool them with features while hiding them the main bugs which are later uncovered by user while using (just think of windows XP!!). I focused on explaining my system model because that was what my system was. People could look at it and easily pin point errors in it so that they could later fix it (well immediately I got many suggestions from audience, judges and other participants of how to change architecture to make it more robust). Even one of the judges i.e. Prof Timila Yami Ma'am agreed on it. Fifth, my project concept was unique and parallel with open source philosophy. As explain later by D2 representative judge Mr. Hitesh Karki, open source development is also a peer to peer collaboration between developers which was what my projects all about. This was missing with others though my implementation was not as perfect as others.

What is your future development plan for the project?

As mentioned earlier, there are many domains in which this project can be forwarded. After my demo experience, I have realized that interfacing with VLC is pretty problem. Instead JMF will be a better solution. The JMF must be used to capture and stream online at broadcasting side. Also, at peer side it must receive packets and play. Also, JXTA is much better than Pastry because it can cross Firewall boundaries much easier. Work has begun in newer versions of JXTA to include streaming file sharing. So, it is quite possible to do same using JXTA. Third important thing to do is to expand the project to make it run on other OS besides XP. My college PC was XP. So, I had only single option to develop it in XP only especially in such a short time. But, I realized the problem during demo where most of available PC was ubuntu. My system is Java and can run in any system. The problem is VLC and especially version 0.8.6c with which my system has to interface at both broadcasting and peer side. Once VLC is removed then this job will be default done. Besides, I would mention some that I got as feedback after presentation. One was dealing with peer failures and more specifically with fraud peers that try to cheat the system. If any peer stops in middle then immediate peer stop getting packets too. My current effort helps in detecting it and automatically informing user about it. For future, system must automatically allow the stopped peer to be removed and the immediate peer to receive stream from peer streaming to the stopped peer. For this many decisions has to be taken as how it could be achieved i.e. locally by peers or it involve broadcaster also. About fraud peer who do not serve new peer, the system model requires to be more fault tolerant. In such cases, decisions like allowing broadcaster to intervene or local removal has to be taken. Thus, there are many dimensions for developing this project. It is only help from developers that will make it possible in the future.

Do you have any suggestion for anyone thinking to take part in such competition in future?

My very suggestions from my own experience are; this is open source competition. Your main aim is to bring about the open source spirit in project to win. Open source spirit means not only using open source tools in your project. It means much more. Open source spirit is projecting the need for open collaboration. This can be done by being ready to provide anyone interested in the project with the necessary documents for contributing into it. D2Labs provided such a wonderful platform for open source that I really appreciate it. Each new activity can be listed in To Do list and each new bug can be listed in bug list. The presentation should be to attract DEVELOPERS and not just CUSTOMERS or USERS. With commercial project, customers would be everything but for open source the power to attract developers into it is what important. Your system need not be perfectly correct because in this imperfect world nothing is perfect. So, just accept it and do not hide it or feel shame for it. If your system was perfect why would you open source it – just for money sake or competition sake. No, because your imperfect system has to become perfect through collaborative works that open source can only provide. You must present in this sense without fear and never ever think of winning. Taking part itself is big thing because you are providing rest a path to follow. If your project gets developers working onto it, even if you don't win it does not matters. You have won actual war – war against very PROPRIETARY concept in developer's mind that killed software engineering for decades. After my presentation, when I got feedback for judges, participants and audience (D2 volunteers) alike I felt like real winner because feedbacks were what I would be taking with me for future development of my project and refinement of my concept.

Do you have any blog, tweet or website where you actively contribute to development of open source project?

My blog is http://sumitshresblog.blogspot.com/ though it is not regular but I will try discussing new ideas on open source as they come.    

My tweeter is http://www.twitter.com/sumitshresth

My D2Labs Live event Broadcast using P2P project site is http://collaborate.d2labs.org/projects/p2plivebdcast/

My First ever open source project Frontend for MySQL where I still regularly work is http://sourceforge.net/projects/frontend4mysql/

My Email id is sumitshresth@rocketmail.com or rhs4shr@gmail.com


Share/Bookmark
Comments
0 Comments

0 comments: