Saturday, June 10, 2006

How to Hire Talent

I may be in the software industry, but this is a problem that affects every manager in every field. How do you recruit and hire the best talent? There are the general cliche's like "Hire people smarter than you" or "Hire someone you could work for," but these don't actually give any information you could use.

Everyone has their own process for hiring and I've been through several as both a candidate and an employer. The best tip that I can offer for how to run an interview is that the candidate should meet with several people, and all on the same day. This makes it a one-stop shop for the candidate, and allows the company to react quickly if they decide to move ahead with an offer. I'll make a future post on my idea of a recruiting / interview process.

Anyone who's ever given an interview should know that they are walking into the interview preparing to answer one question when they're finished: "Should the company hire this candidate?" The question sounds fairly easy to answer, but the process to get there is complex, and sometimes requires a crash course in psychology 101. I've compiled some tips below that I try to follow with each interview I give.

First, let me put my interviewing frequency in context. I am one of the key interviewers for my company, usually giving 5 - 10 interviews / week, ranging in candidates like test engineers, software engineers, software architects, project managers, program managers, and product managers. While a typical interview with me lasts for 45 minutes, I probably have 2 - 3 hours worth of interview material.

The biggest struggle that I see, especially in first time managers, is the ability to recognize talent. Senior people are always easy to hire; they know their area of expertise, they pass all of the technical interviews, they have the experience of several software projects, and they are mature enough to give the expected answers during the interview. For them, it just comes down to personality fit and they either mesh with your team or they don't.

It's the diamond in the rough that seems to be the most difficult to identify. And these people are the most critical to your project; the 'B' players; the group who makes up 70 - 80% of your team; the group who'd you love to see a few grow into 'A' players. So how do you sort out the candidates with potential from the ones who are just repeating what they memorized in the latest programming book they read. The basic knowledge is usually the same. The candidates most all be competent in your technology of choice, they must get along with your team, and they must fit your budget range. Now the hard part, once you've identified a few candidates that fit these basic criteria, how do you know who will really succeed? Who will improve your team? Who will exceed your expectations?

  1. Evaluate Problem Solving. Try and find out how the candidate works through a problem that they don't know the answer. How do you weigh a 747? Why are manhole covers round? How many cars are there in New York City? Questions like this are not designed to reach the answer, but to see how the candidate thinks. How do they respond to help? Do they ask questions? Do they break down the question logically or randomly? These are some key indicators for imaging the candidate 6 months down the road when you have to develop a solution that no one on the team has ever seen before. Maybe an obscure defect that you can't reproduce These situations will inevitably come up, and you want your team best prepared to handle the unknown, and be able to breakdown a problem logically.
  2. Hire Smart People. When in doubt, hire based on intelligence. Generally speaking, intelligence has a direct correlation to ability, adaptability, and efficiency. I'm not saying this is a black and white issue, but when you can't decide between a few candidates, the smarter candidates have a higher probability of success
  3. Admitting Ignorance. Throw out some questions that the candidate has no way to answer. Don't throw out a brain teaser for this one, but throw out something extremely technical or deep, or on a technology just outside of their knowledge level. You already know that they don't know the answer, the test is whether they'll admit it, try to dance around it, or engage you in a conversation to get to the answer. As a rule, anyone who tries to give me a b.s. answer, I immediately won't hire. Anyone who can admit they don't know something when they are engaged in an interview is someone with the maturity you are looking for. Professional maturity is a great indicator for future success, knowledge transfer, and constant growth.
  4. Communication Counts. Try to get the candidate to explain something complex to you. Did you understand it? Was the information presently structurally or randomly? How long did he consider his answer? Was he comfortable launching into a diatribe? At the end of the day, communication is key for any team, and yours is not any different. As long as someone can clearly express their status, position, opinion, thoughts, really anything, then your chances for team success have just gone up exponentially.
  5. Career Goals are Good. Senior talent generally know what they are looking for, and have usually already achieved some career goals. Entry level people probably have no idea what they're looking for, but just have some skills out of school and are looking to learn. Again, it's the middle group who really have something to prove. You want to make sure that your candidate has some goals, and he's on the path to reach them. The actual goals aren't very important, it is that there is a career plan being executed. It shows forethought, direction, and purpose. The one exception to this rule is if the candidate's career goals don't map to your field. For example, if someone came in and told me their ultimate goal was to save up some money and move to Outer Mongolia, and they are 4 months away, I probably wouldn't hire them. Outside of that, you're in good shape.

I'm sure that there are other beneficial characteristics to look for, but these are a few that I use. Anyone who'd like to post more tips, please comment this post. And remember, interviews can never determine if someone will be a successful candidate or not. Interviews can only increase your probability of selecting a good candidate, and all you are trying to do as the hiring manager is to hire the candidate with the highest likelihood of succeeding.

Here are some other links around the web that I've found as good reading.

  • Guy posted a reader's email - Link
  • About.com article - Link

This will be a future post, but here are some postings about how to retain talent once you hire them.

  • Why Developers Leave - Link
  • Harvard Business School on Lost Motivation - Link

Technorati : , , , , ,

Upcoming Posts

I thought it might be nice to post a list of the initial topics I plan to post on. I'll update this post with links as I post the content

In no particular order


I'm open to any input for other topic suggestions. Like I said above, I'll be posting in a fairly random order, but I'll be trying to post at least one topic a week.

Technorati : , , , , , ,

Dopod S300 / Qtek 8500 Mini-Review

The first step is admitting that you have a problem. I have a problem: I'm addicted to cell phones. I can't get enough. As soon as I hear about a new phone or accessory that is coming out, I turn into a kid the night before Christmas. I read the gadget blogs, hang out in the phone forums, contribute to some open source pocket pc apps, and anything else I can do to stay involved with the community. Anyway, since I came across this phone weeks before it is released in Europe or North America, I though I'd take the opportunity to publish a review.

First, the summary for the folks skimming this entry:

  • Style: 5/5
  • Functionality: 5/5
  • Performance: 4/5
  • Battery Life: 3/5
  • Reception: 5/5
  • Email: 4/5
  • Music Player: 3/5
  • Overall: 5/5


Style


This phone looks like a RAZR, but improves on the RAZR's shortcomings. A better keypad, better camera, better reception, and better operating system (Windows Mobile 5 Smartphone). Another nice feature for me is that the phone is slightly longer than a RAZR when it's opened, and since I have a huge head, it better positions the microphone near my mouth, rather than the side of my head. Color wise, black is in. Apple has made all of their products available in black. Computers come in black. Hip cell phones come in black.


The other cool feature is the external display. It's customizable to have a few different styles of analog or digital clocks, but it also shows notifications of new email messages, missed calls, appointment reminders. If you press the camera button with the phone closed, the camera is fully accessible from the outer display. And the music player shows current track status, volume, running time, and paused / playing / stopped state.



Functionality

This phone has it all. It runs Windows Mobile 5 Smartphone, and that basically opens it up to all types of applications. I use the phone to synchronize my calendar and contacts. I also use the features in the Windows Mobile 5 MSFP (Microsoft Feature Pack) that adds real-time push email, similar to a blackberry. In the tests I've run, the email arrives on my phone within 15 seconds of arriving at the Exchange server. It also supports address checking against the server, so you don't need to have everyone added to your local address book. The phone also has the standard collection of Windows Mobile apps like Windows Media Player, Internet Explorer, Pocket MSN, MSN Messenger, and the rest of the normal applications.

Operation while using the phone is a breeze. I was even listening to music while I received a phone call. The music paused, I received my ringtone through the wired headset (not sure if this works over Bluetooth yet), answered the call, and when I hung up, the music resumed where it had left off. This may not sound like a big deal, but it is definitely a small feature / big win piece of functionality.

Dopod included a few custom applications that I found interesting, but ended up uninstalling them to save space. They packaged a custom 3D menu, that looks cool for a demo, but ultimately is slow and doesn't expand for new menu items. there was also a custom MP3 player, but again, Windows Media Player works fine for me.

The once feature that was very important to me when selecting the phone, but one that I haven't had a chance to test out yet is the wireless stereo over Bluetooth (A2DP). This technology allows you to listen to music (MP3 or online streams) through Bluetooth headphones. My dream headset is the Sony Ericsson HBH-DS970 (Link) that I already have on order, but it's not released yet.

Performance

My last phone before this one was an I-Mate KJAM (also know as a Qtek 9100 / HTC Wizard / T-Mobile MDA / Cingular 8125 / etc...), and that ran Windows Mobile 5 Pocket PC Edition. While the operating system was richer in functionality, the phone had the exact same processor as the S300 does, the 195MHz OMAP processor. I always thought the KJAM was OK in performance, but was certainly not a speed demon. My opinion is very different with the S300. Menus are snappy, IE opens quickly, messaging opens quickly, I can have several applications open at once without much trouble. I can even switch between the camera application and IE back and forth without much lag.

The only performance issue that I've had is when I had IE, Messaging, File Explorer, and Media Player open. Then, I went to MIDLet manager and launched Google Maps mobile. This seemed to be too much for the phone to handle. I was eventually able to switch to the task manager and kill a few tasks, but I ended up rebooting the phone since it was sluggish after that. This could be a knock on the phone, but I think it is more likely a sign of an OS instability that will be ironed out in future ROM versions.

Battery Life

Of my short list of my disappointments with this phone, this is top of that list. Granted, i use my phone a ton. Email synchronizing all day long, contacts and calendar sync'ing too, 2 - 3 hours of talk time per day, a fair amount of web surfing from the phone, listening to music, and a few other things. Should I expect more than 1 day of battery life with this usage? I'm not sure, but I'd like to. I'll try to keep my talk time down one day, maybe this weekend, and see if I can get more than a day of battery life. I think this might be a downfall, but at the same time, the battery life isn't any worse than my RAZR, which I used only for talking, and still only managed about 1 day of use.

Reception

Simple answer. The reception is unbelievable. Better than my RAZR. Better than my KJAM. Better than my SMT5600. Even better than my old Nokia 6610, up until now, the phone with the best reception I've ever had.

Email

Real time push email is a life changer. I didn't invent the term crack-berry, but it is very fitting. The great news is that I have instant access to my email. The trouble for my personal life is that I have instant access to my email. My only complaint, and this is really just trouble with any non-QWERTY device, is that responding is a little painful. On my KJAM, I would write 15 - 20 emails a day. On this phone, that count is down to 5 or less. The T9 is great, and works surprisingly well, but it's still hunt and peck, instead of typing.

By the way, my phone is from Asia, so it has the Extra characters. Trust me, the entire phone operates in English. Without that, I've be very, very lost.

Music Player

I know the form factor has been out there for a little while, but this is my first "music phone" that I've owned, and I must say, I'm using it much more than I ever thought I would. My iPod Nano is now sitting in my drawer. I have 1GB of music loaded onto a memory card, and when I head to the gym, I only need to bring my phone with me. One device, light weight, one I always have with me, and there's my music. Another nice feature is that if I get bored with my MP3 collection, I just start streaming Sirius radio (Link), something my iPod definitely can't do.

I did notice one small issue, but this is definitely a software bug more than anything else. If you wake up the external display with the track forward or track backwards button, it doesn't always change the track. Sometimes you need to hit the play / pause button first, and then the track skips work fine. A minor issue, but a bug none the less. Another thing that got me the first time I used the music player is that when you pause the playback, that is not the same as stopping the playback. Lesson learned when my phone was battery dead at Noon. It seems that pause still chews up a ton of battery life, and you have to hold the play / pause button for a few seconds to get the playback to stop. Of course, I'm sure I'd have known this if I actually read the manual, but I'm in software, and RTFM is an acronym for users, not for technically savvy people ;).

Overall

In summary, I can't give this phone enough praise. I know it will be a big hit with the enthusiast market, and I can't image how well this will move once Cingular / T-Mobile / (Major GSM Operator) releases the phones. It has every bit of functionality that power users have been waiting for in the form factor that the RAZR proved was possible and the most convenient. I'd recommend to anyone that they NEED to pick up this phone. For any fellow / future owners, enjoy the new toy.

Here are some other published previews / reviews



Update (2006-06-14)

Technorati : , , , , , ,

SDLC in the Real World

SDLC - System Development Life Cycle (SDLC) - a methodology used to develop, maintain, and replace information systems.

I've run into more than a few project managers, developers, testers, and product managers that have caught the SDLC buzz word fever. They've either latched onto the newest, latest, coolest, hippest methodology, or they read in a book that you can't succeed without one, or (most likely) their manager said that they need to have one. However they get to this state of mind, they usually follow the same course of action.


  1. Go to bookstore and buy 1 book
  2. Read at least the first few chapters of said book. Some even make it all the way through
  3. Go to their next team meeting, and declare that they are implementing an SDLC. No one else can ask questions or offer input, because the book says it will work exactly as its written
  4. Meetings are called with subjects that mysteriously match the book's chapter headings
  5. The rest of the team has no idea what is going on, but they are following their enlightened SDLC leader blindly. It still seems like they're writing and testing code, so at a granular level, most everything seems to be the same
    ...... The Project Continues .....
  6. Utter chaos ensues, the product is late, the quality suffers, and it is deemed that SDLC's are worthless
  7. Team reverts to prior process, and ships with previous efficiency, tracking, quality issues, and date slips. While that may sound bad, they still ship and shipping software is a key test of success or failure in commercial software.


So where does the value from using a methodology come from? For me, it all comes down to one thing: change management. If there was only one programmer, and he knew the customers, wrote the requirements, wrote the code, tested the code, fixed the code so it was bug free, packaged the product, and shipped it, there would be no need for an SDLC. OK, now back to the real world. Requirements change. Team members quit. Testers miss bugs. Developers write more bugs when they fix the bugs QA already found. Customers can't articulate what they want. The list goes on and on. This is where having a defined methodology helps. It gets your entire team on one page. When someone falters, everyone knows, and everyone understands the impact of what that means and can adapt. It is not a blame issue, but one of good communication. When you have a team driving toward a common goal, working in a common way, helping each other succeed, then you have a team with a shared vision. A team with a shared vision can do amazing things. They can have requirements change at the last minute, and everyone knows where to help, who is impacted, and how to react. The same scenario goes into effect when someone on your team leaves. Normally, the team is lost for a bit. Some piece of critical information or a critical process lived only in that person's head, and now that they are gone, the team is lost. Again, common steps, common process, common knowledge, shared vision, and teamwork. All of this leads a team to be adaptable to change, and having a team that can adapt and manage change, rather than letting the changes manage them is key to large scale success in software.

Having a team that can adapt and manage change, rather than letting the changes manage them is key to large scale success in software


Then how does all of this apply to me? I've been through a handful of projects, and I've learned the most important lesson about SDLC: No SDLC is perfect. All of those books look really good in print, but they are all based on best case scenarios and case studies. The key is to learn as much as possible, study many methodologies, and adapt a methodology to your team. I have a personal methodology that I usually try to follow, with parts taken from a few different communities, but with each new team and each new project, the process is adapted. The value of a process is to help organize your team, not to organize your team according to the process. There is always pain, resistance, and adaptation when implementing change, but it should be for the betterment of the team, not because you are trying to fit the team to something from a book.

This is the general methodology that I have used successfully in the past. It is a combination of a traditional waterfall development cycle, but focuses on short term, iterative deliverables during the development cycle. These are similar in principal to sprints from the SCRUM methodology (my personal term is protocycles), but with a different up front planning process. There are also aspects of XP and MSF woven throughout, but I won't get into that many details in this post.

  1. Establish high level requirements. These need to be detailed enough that the technical design can be built from these requirements. This deliverable essentially drives the vision for the release. A 3 release roadmap is also required, so that the development team can understand what the future product plans are, with as much clarity as possible.
  2. Define the detailed requirements. This task takes the high level release requirements, and drills down to a sufficient level of detail required for the development team. As each detailed requirement document is completed, it is sent for peer review and acceptance by a representative from development, quality assurance, architecture, product management, and development management. This task happens in parallel with the technical design.
  3. Define the technical design (Architecture). Based on the high level requirements, establish a product architecture taking all three releases requirements into account. The architecture deliverables for version 1 should be at sufficient detail for the development team to use, and mock architectures should be vetted in order to validate feasibility for the version 2 and version 3 requirements. This task happens in parallel with defining the detailed requirements.
  4. Product Development. The development team executes the detailed requirements and the technical architecture. This process is somewhat agile in nature, since features can be started once the specification for that component is complete, rather than waiting on an entire requirements package.
  5. Quality Assurance. The QA team validates the software created by the development team meets the defined requirements. Test cases are created for each completed requirements document, following its peer review acceptance. For a test engineer, the requirements should read like a contract, validating that development met their end of the contract. As is typical during a development cycle, requirements will change. These will be handled as requirements addendums or modifications.
  6. Release to Manufacturing. This is the final step in the process. Once a product is ready to be delivered to market, this step represents the processes preparing for general availability. Depending on the organization, this could include source code escrow, marketing coordination, gold CD creation, retail packaging, etc... The timing for this process is generally organizationally dependent.


There it is, how to ship software in 250 words or less. I'm not trying to demean what any of us do, but at the end of the day, it all sounds so simple, doesn't it? Define what you want, research it, document it, code it, test it, give it to people who will pay you for it.

Technorati : , , , , , , , ,

Google Introduces a Spreadsheet - Competition for Microsoft

There's plenty of press about this one, but I thought Scoble had a good quote:

I want better software. Competition brings better software. It gets product managers to worry about customers. It causes discussions of features that were long-ago decided on.

If you want to see the other articles, click here.

Technorati : ,

Good Reading for Development Managers

I try to spend a few hours a week reading articles on the web. To me, the word "article" has a loose definition, but basically anything someone has taken time to put together that adds knowledge or value, I'll read if I can stumble across it. Here are this week's selections:

Technorati : , , , , ,

Good Reading for Software Architects

My background is in software development and architecture, so here are some good blogs that I try to read regularly.

Technorati : , ,

Read RSS on your Windows Mobile Device with AvantGo

AvantGo has finally released an updated reader for Windows Mobile devices that supports RSS. Find the full story here at MSMobiles.com. Download it here.


Update... June 11, 2006

This link all of a sudden made it to the front page of Digg, so I'd like to respond to some of the comments.

  • Good wrap up of Pocket PC RSS Clients on About.com.
  • My personal recommendations for Windows Mobile 5 RSS clients

More importantly, there has been a bunch of slamming on the Windows Mobile platform since it is from Microsoft. Most of the nay-sayers are basically saying that any product from Microsoft isn't free and sucks on principle. On the desktop platform, this is an argument that's gone on over and over again ... Linux, Mac, PC, Open Source, and I don't think it will be settled anytime soon. However, on the mobile platform, the options are more limited. If you're looking for a smartphone, it is basically Blackberry, Palm, Symbian, or Windows. Take a top of the line phone that runs on any of those platforms, and they all cost the same. The OS can't be purchased by itself, so you can argue that it's free with the hardware, or it costs the same as any other smartphone OS. Anyway, the key of this post was to highlight that there are starting to be viable offline RSS readers for the Windows Mobile 5 platform. For those who aren't as addicted to phones as I am, the OS only became commercially available in the last few months, and very few viable applications have been ported over yet.

As far as the smartphone OS debate, that's one I'd be happy to engage in, and I think these comments have given my fodder for writing an upcoming post on the topic. I've owned more phones than I can count, and I've used every single smartphone OS. I have a preference for Windows Mobile right now, but that actually has a lot more to do with form factor then with OS. As long as I can get my email, sync my calendar and contacts, and surf the web, I could care less about who wrote the OS.

Until the next post .....

Technorati : , , , , ,

Defect Count is a Constant

One of the most inspirational people in software that I've come across is Jim McCarthy. I had the privilege of seeing him give a presentation, and he had a few quotes that made a lot of sense. The one that really stood out to me was
"Defect count is a constant."



This became very clear to me last week, as my team went through a Bug Bash. In 48 hours, we closed out over 400 defects, but the number of defects open with development stayed almost level. I could go into the details of the defects, such as priority, severity, category, and so on, and we did make some substantial progress, moving our average defect severity from critical to medium, but at the end of the day, all software has problems bugs defects. And this was one of the most difficult lessons I've ever had to learn:
Shipping software is an act of reality, not a pursuit of perfection.

This lesson was extremely difficult since I come from a development background, I always want my software to be perfect, to be bug-free. Unfortunately, the larger the project, the less control that you have over it. As a manager, your job is about steering the ship, and you have to trust that your staff is all rowing in the same direction. There are things you can do to get more involved with the low level tasks, and I recommend that you do, but at the end of the day, you can't spend 40+ hours per week with each member of your team (Trust me on the math, after 4 employees, this model doesn't scale). In the world of software management, you need to accept a product that is less than perfect, and understand what is critical to ship and what is not. I'm not saying that you should ship a garbage product, but at the end of the day, if a new feature isn't ready, you can probably cut it, ship the release, and your world will not come to an end. Note the exception list here is long, like if the feature is contractually committed, or highly marketed, or the center piece of your release, etc...

I added some links at the bottom for more information about Jim McCarthy for your reading pleasure.

Jim McCarthy - I highly recommend that anyone involved with shipping software, especially in any leadership position, should check out Jim's book and video if you can get your hands on it.

Technorati : , , , ,

The Value of Product Management

When I started out, I thought that it was critically important for each developer to know all the ins and outs of the end user. If you are writing a financial application, the developer should be able to pass for an entry level accountant. Well, then I got into healthcare, and I realized that it's impossible for developers to know anything close to what an end user knows. This is when I saw the light on the value of product management.

A great product manager will perform three tasks:
  1. Drive a product's strategic road map. This means that the product manager understands the end user's needs and understands the competitive marketplace. Understands which features are competitive disadvantages, market differentiators, visionary features, and customer satisfaction issues. The road map will align these features by priority and usually group them into 3 releases. A near-term, tactical release, a longer term strategic release, and a long term visionary release. Dates on these releases are irrelevant, since the road map defines what needs to be done, and then the timeline can be wrapped around that.
  2. Cut features from a release scope. Inevitably, customers, marketing, and product management will want more features than the development team can support in a given time frame. It falls to the product manager to work with the program manager and reduce the scope list (The entire scope planning process is another topic for another day). The product manager must balance the needs of sales, marketing, existing customers, and new customers to prioritize the list and make some tough decisions. A good product manager understands and accepts this. A tell-tale sign of a poor or inexperienced product manager is one who will kick and scream to make it all fit into the scope, rather than accept the constraints of reality.
  3. Understand the customer's business. This is the most critical skill above anything else. A great product manager truly understands their customer. Usually, this means that they came out of the field that your product is now servicing. Maybe they were an account if you are developing accounting software, or a nurse if you are developing hospital software. This allows the product manager to converse with the customer in their vernacular, build a repore, and gain insight to new developments in the industry. The other benefit is that they become a key resource for the development team. The development team will not understand all of the intricacies of a particular business function, but the product manager should. And if they don't, they've built relationships with key customers that they can contact to get the exact answer. This allows your team to correct an issue in the design phase, rather than waiting until it is in the hands of customers, and is 10 times more costly to repair.

The key takeaway for anyone in development is that product managers are the ones responsible for the domain expertise, and the rest of the team should leverage and benefit from that.

Technorati : , , , , , , , ,

Wow, this is really cool - Stream Sirius to your phone

Listen to Sirius on your Windows Mobile phone. I've used this and it is very handy.

Read
Download

Technorati : , , , ,

Interesting Reads

I've added a link to my links section, but one blog that I've found very informative is Guy Kawasaki's (http://blog.guykawasaki.com). He has written a few books, and has plenty of experience in the VC space. He posts very frequently, here are a few of my favorite posts.

  • Top CEO Lies - Link
  • Top Engineer Lies - Link
  • Top VC Lies - Link
  • Scott McNealy Top 10 - Link

Technorati : , , , , , ,