I don't want here to discuss the many designing methods, but I write in this page about some "tricks", I applied in the past, which always work.
There are many ways of designing and running projects and I've applied many ways and better, I've combined many design and management methods to get to the end product. The above two methods are the most used and have always led to successful projects with excellent products.
Method 1
This method I apply many times when the customer is not technical (and not disciplined for software development).- I don't choose for the Extreme Programming Method, because it leads to an uncontrolled project (read: chaos)
- I get myself a graphical designer and a QC person (who might become the QC manager).
- The three of us go to the customer and ask what he wants
- The graphical designer makes the screens in a way, that the customer is more then happy (the whole thing with colors and pretty pictures and nice designs)
- The QC person/manager is the one, who needs to be involved from the start of the project
- If the customer is satisfied, and we have all the pretty pictures, we apply "reversed engineering on the pictures"
- We give the customers the design documentation (will probably not read, especially after revisions), and tell him or her how long it will take and how much it will cost and a simple list of instructions for the customer
- The QC person/manager makes his documentation and scripts to guarantee that the pretty drawings will represent also the software or product to be developed
- I take an experienced GUI programmer and let him or her program the screens (being drawn by the graphical designer) (and this is not a prototype)
- Then I get myself programmers and QC people and fill in the blanks (most of the development time is wasted in GUI programming, the harest part of programming a generic program)
Method 2
This method I apply many times when the customer is technical oriented and knows exactly what they want. In practice this means that they know the technologies, but they have no idea about managing a team of developers.- Team building. I take the development team and start teaching them development in team and groups effort.
- The team will be involved in the creation of the design process, which involves of course requirements, functional and technical design
- I teach the team project management and administration
- I take the team members and their families and have at least once a month a social outing (picnicking, I love barbeques). When the spouses get involved, that means that I have much better motivated people in the project. The results are even better then giving anyone a raise of salary!
- Software testers
- Graphical designer(s)
- Team leaders (and in some cases with multiple teams, groups leaders)
- Developers (senior and beginning developers)
- Coders
- The database specialist (mostly is also a developer)
- The network specialist
- Administrative people. I like control and monitor the project.
- The development project really starts. In the project, their are several safety-nets installed, which results in high quality work and a schedule, which will be on time, spot on.
- All project members work relaxed and professional and when they don't, I simply educate them. Nobody gets fired, only corrected and all of that with a smile on the face and fun at work
- At the end of a normal (project) day, I know what everyone did for work, I have their source code and bug reports and images and databases, etc. I know if the project is behind, ahead or right on time and I know if the productivity is good.
- At the end of each project day, I produce a health indicator (a number, representing the health of the project effort) and a productivity percentage.
- Those numbers are then for everyone (like customers and general management)
- But my personal, professional statistics go much further. I've detailed statistics on each module and program and system
- I've detailed statistics about each project member and the sub-groups and know what I can expect
- I will know how many bugs a programmer will produce before he or she starts developing and I know how many bugs the QC will catch and how many bugs are hidden.
- I'm in control of the project (it's people and the end product) and that makes me feel good.
There are many ways of designing and running projects and I've applied many ways and better, I've combined many design and management methods to get to the end product. The above two methods are the most used and have always led to successful projects with excellent products.
Related articles
- Graphic Design Process: Inspire ~ Create ~ Design (dawncarlton.wordpress.com)
- The Four Steps of Graphic Design (givemehelp.wordpress.com)
- Asshole Driven Development (scottberkun.com)
- DIY Process (cognition.happycog.com)
- Agile Team and Specialization (tridibesh.wordpress.com)
- Mediapost- 10 Attributes Of A High-Performance Email Marketing Team (shanecrombie.com)
No comments:
Post a Comment