Archive for the 'Career' Category

Can you make a living off an iPhone app?

andy on Nov 7th 2008

Recently I’ve been investigating how much to charge for my upcoming iPhone application, and trying to determine how much money it will make in a year. Ideally, I’d like to make a living off just building apps instead of contracting. Unfortunately the App Store is still young, and there’s very little data out there. I’ve scrapped together what little data I could find, and included it with my commentary in this article.

As far as pricing goes, the general consensus seems to be that iPhone applications can range from Free to $10. I got this mainly from just looking around on the App Store and checking out the prices. That said, Medialets has some interesting data about App Store pricing. The sweet spot seems to be $5, especially for games, with only big name companies being able to command a full $10. Since Apple takes 30% off the top, my app could potentially make anywhere between $0.70 and $7.00 per unit, but on average I should expect $3.50/unit.

Now that I have an estimated price that I could charge for my app, I need to know how many units of said app I could reasonably expect to sell in a year. Unfortunately, this is where the data gets really scarce.

I found (or have been sent) ten articles where people reveal actual sales numbers. Unfortunately, there is little context for the numbers, and sometimes they are for one day only. This makes it impossible to draw decent conclusions from the data, as I don’t know if the numbers are anomalous or not, or what part of the cycle they come from (right after release or after the app has been sitting out in the hot sun all day). The ten articles are:

The articles contain data for twelve different applications of varying popularity with varying levels of advertising. I’ve also been sent data privately for eight other applications. I’ve summarized the data in the table below:

Amount Sold Time Period Price Average Sold per Day
428 1 day $5.99 428
10486 82 days $1.99/$3.99 128
24094 31 day $2.99 777
3168 31 day $0.99 102
60 1 day $0.99 60
162 10 days $2.99/$3.99/$4.99/$7.99 16
676 6 days $0.99 113
1863 14 days $0.99 133
5088 62 days $1.99 82
605 62 days $0.99 10
95 60 days $5.99 2
10 1 day $7.99 10
4037 46 days $4.99 88
191 21 days $3.99 9
75 14 days $3.99 5
451 66 days $0.99 7
59 45 days $1.99 1
2280 49 days $1.99/$0.99 49
275 9 days $0.99 31
2250 10 days $1.99 225

Some statistics of “average sold per day” from this data: Min: 1, Max: 777, Median: 49, Mean: 114.

As I said earlier, it’s hard to know if these numbers are at all representative of what’s actually happening with most applications. Still, these are the only numbers I could find, so I’ll try to do something with them.

Looking at this data, there’s clearly a worst case scenario: only selling 1/day while only making $0.70/unit. That would mean I’d only make $255.50/year. Don’t sell the bike shop yet, Wilbur. The best case would be selling 777/day while having a $9.99 price point, which would earn me $1,985,235.00/year or just under $2 million a year. That’s not very realistic though.

If I assume an average price point, $4.99, with what the data says is the mean of sales per day, 114, then that means I would make $145,635.00/year. That said, 114 sounds high to me for a real average. The 777 figure in the calculation seems to push the mean higher than I should realistically expect. So if I assume the median, 49, at the average price point, $4.99, then I would make $62,597.50/year. Or the minimum of 1/day at $4.99, then it would be $1277.50/year.

I’ve summarized the possible units per day discussion in the following table:

Scenario Average Sold per Day Price Yearly Income
Minimum 1 $0.99 $255.50
Maximum 777 $9.99 $1,985,235.00
Mean 114 $4.99 $145,635.00
Median 49 $4.99 $62,597.50
Minimum sales, Mean price 1 $4.99 $1,277.50

Disclaimer: I’m using “mean,” “median,” etc in the mathematical sense, based on the whopping data set of twenty presented above. I’m not suggesting that these are the numbers you will actually see.

I have to admit, the number of units sold per day sounds high to me, even with the 60 a day figure, although 16 per day might be reasonable to expect. I can’t tell if the quantity of apps sold is simply the nature of the low price points for iPhone applications, or if it is a temporary anomaly caused by the newness and novelty of the App Store. All the numbers are from the first year of an application. I wonder about the sustainability of the rate, and at what point would I saturate the market. I strongly suspect the number of units sold per day is going to eventually come down, and the cost per unit will have to go up.

I’m unconvinced that having one or two iPhone applications as a sole source of revenue is sustainable. Earning $4,000/year seems like the most likely scenario (at least after the first year), and that’s simply not enough money to live off of.

Addendum: As a point of comparison, here’s some data on free applications:

Amount Sold Time Period Price Average Sold per Day
123966 30 days FREE 4132

As they say, there’s a huge price increase from free to $0.01.

P.S. What this article really needs is more data. If you’ve released sales numbers, please leave a comment with a link to it. If you’d like to contribute, but remain anonymous, send me an email (see Contact tab above) with the numbers.

Filed in Career,iPhone | 18 responses so far

From Tennessean to Cocoa Programmer in 3 easy steps!

andy on May 22nd 2007

I’m easily provoked into rambling, and I was recently incited by a college student, asking how I made it into Cocoa programming. Now I was intrigued because he has a similar “problem” to what I had, of being in a public state college in Tennessee (actually a sister school of where I graduated from) and trying to get into Mac programming. Because I like hearing myself talk under the guise of being helpful, I’ve decided to answer his question publicly.

Don’t all thank me at once.

My Story

The story of my rise to Cocoa fame (hey, no snickering in the back!), is both interesting and inspirational, especially if you don’t bother to check up on any of the “facts,” or know what the word “fame” means. So here goes.

First, I should point out there was no such thing as “Cocoa” when I was in school. It was all Toolbox, non-opaque structure, procedural, event polling, love. But since that’s what Mac programming was, that’s what I taught myself during college. I even wrote three tiny freeware products and released them. (Please don’t google for them, that’s exactly the sort of blackmail material I don’t need.)

Second, I got a lucky break. After I graduated from college, the Macromedia Texas office happened to be hiring. I managed to con them into taking me, undoubtedly dazzling them with my total lack of experience, huge ego, and inability to correctly pronounce the word “boil.”

Third, Macromedia fortunately turned out to be a large uncaring corporation that sufficiently pissed me off enough to curse them and leave. Then I went to work for myself as a Cocoa programmer.

The End.

hmm… maybe that isn’t as inspirational as I first thought.

Where ever you go, that’s where you are

OK, in all seriousness, there are things you can do to increase your chances of being a professional Cocoa programmer. The first thing to deal with is your location. There aren’t many (read: none) Cocoa jobs in Tennessee or most of the southeast. So you’re going to need to find your ticket out of Squaresville.

I did it by being hired by a large company, Macromedia, who paid for my move. They moved me to Dallas, which, being a large city, has more Cocoa opportunities and hail storms than Tennessee. One of the things that helped me get hired was that I had previous Mac programming experience, and that I had released some freeware. Real word experience, whether you made money off of it or not, goes a long way, especially if you just graduated from college.

However, I should point out I really didn’t get to be a Cocoa programmer at Macromedia/Adobe. Most of their apps are Carbon based (like me) and I don’t see that changing anytime soon. It will probably be a similar situation at most large companies with established products. At the time of my departure, the only shipping Cocoa app Macromedia had was the Extension Manager, because I rewrote it in Cocoa in my spare time.

Anyway, my point is you need to find a way to a city with more tech jobs, like San Francisco, New York, Boston, Raleigh, D.C., or, to a lesser extent, Dallas or Austin. It’s the only way to a Cocoa job and true happiness.

Don’t be a sucker

So I was actually lying about having to leave Tennessee to get a Cocoa job. Only suckers do that.

The best way to be a Cocoa programmer is to just be a Cocoa programmer. Work for yourself; create your own products. Of course, there is the whole problem of making money. It takes a while to establish a product (usually a few years) and sometimes weak people need to eat in that period.

When you’re self employed there are three ways to generate money while you work on a product: contracting, venture capital, and angel investing (i.e. your parents). Contracting is what we do, and what most small independent Mac companies do. The only problem is that if you’re right out of college you won’t have many connections (which is important, seeing 99% of our work is from referrals) and a lot of people don’t want to hire contractors with no experience.

To get venture capital you need to have a great idea that needs lots of people and money, and you need to be willing to give it up to the venture capitalists. I don’t know of any Mac companies that went after venture capital.

The big advantage of staying in Tennessee (other than it being Tennessee) is that it’s cheap. And that’s very important when you’re self employed.

Expanding my ignorance

I’ve kind of ignored one last option you have, mainly because I don’t have any experience with it. That is, to go to work for a small Mac company (such as Panic, Delicious Monster, or the Omni Group). I don’t know how often they need to expand, and how many new graduates they can absorb and train. But it is an option.

Working for a small Mac company has the same advantages of being self employed in that you can concentrate on the Mac, but probably has the disadvantage of not paying as much as a large company could, and having to live where the company is.

Anyway, you have a few options to becoming a Cocoa programmer. I’m very partial to working for yourself, but that’s partly because of my previous experience with working for large corporations. YMMV.

Filed in Career,Macintosh | 7 responses so far

R.I.P. FreeHand

andy on May 17th 2007

Apparently, it’s official now: FreeHand is dead. (via Daring Fireball)

I knew it was dead back in 2003 when they laid off everyone (save a couple of people) on the core FreeHand team. They kept it alive for a while to do an updater with the few remaining people, then transitioned it off to India.

The somewhat odd thing was that the team knew FreeHand MX was going to be their last release. I remember a certain FreeHand engineer’s response to the question “why are you trying to cram so many features into this release?” as being “Because they’re not going to let us do another.” And to their credit, FreeHand MX was a return to their roots: vector based graphics program for print. At least from this observer’s perspective, it felt like FreeHand MX was the best FreeHand version in a while.

I’ve always had a soft spot for FreeHand, as I suspected most of my fellow Fireworks-ers did. After all, FreeHand and Fireworks were the only shipping products that were developed in the Texas office. Furthermore, Fireworks had been started by engineers from the FreeHand team.

Being so close in proximity, Fireworks and FreeHand often “borrowed” engineers from each other. When Fireworks was about to ship, we’d steal a couple of their engineers to help fix bugs. Conversely, FreeHand borrowed engineers from us, the Fireworks team, if they ever got behind. During the FreeHand MX cycle, I had the pleasure of spending about three months working on FreeHand, fixing bugs and bringing it up to par with the “MX” branding.

The most disappointing thing about FreeHand was Macromedia never let it live up to its full potential. After FreeHand fell behind Illustrator in market share, they pretty much ceded it. They had Dreamweaver and Flash, which were now their big money makers, and pretty much lost all interest in the print world. They kept trying to force FreeHand to be Flash, or to at least remake FreeHand for the web, instead of focusing on what FreeHand did best (print), and capturing that market.

Anyway, I digress. I’ve known for a few years that it was a dead product, but I’m still saddened to see that its official now.

P.S. Please note that FreeHand is the only product name with intercaps. i.e. Note that the F and H are capitalized in FreeHand, while in Dreamweaver and Fireworks, only the first letters are. This was a big pet peeve of the FreeHand team.

P.P.S As a technical aside, most versions of FreeHand (save the most recent ones) were written in a home grown language, that was humorously, and appropriately, called OOPS (Object Oriented Programming System). It was basically a preprocessor that generated C code that was then compiled to machine code.

Filed in Career,Personal | 22 responses so far

How do you pick a product idea?

andy on May 7th 2007

Ever since I got here at Order N I’ve been wanting to develop our own product. It’s been on the back burner for quite a while (I’ve been with the company for over a year and a half now), slowly percolating. We’ve managed to generate a few ideas (127, to be exact) as far as products go, but we haven’t done anything with them.

At this point, I think we’ve got enough ideas, and we just need to pick one and move forward with it. The question is: which one?

I wrote up a process document on how to pick any idea (which is below), but I’m wondering if its the right way to do things. So I have a question to those of you have built your own product(s) (or are in the process of doing so): How did you decide what to build?

Did you simply build what you wanted to? Did you do research and find a product gap and fill it? Did you try to find the idea that you thought would generate the most money or the most users? Did an idea just hit you one day and you decided you had to make it?

My “process” for creating and picking an idea follows:

The purpose of this document is the establish a simple, lightweight process for coming up with and evaluating product ideas. The process should result in at least one idea that we can turn into a viable (read: profitable) product. The process is flexible and can be changed as circumstances change or as better ideas are introduced. The process evaluates ideas based on business factors, not engineering factors.

1. The first step in the product idea process is generating ideas (i.e. brainstorming). At this point in the process the ideas are vague and not well defined. The purpose of this stage is to generate as many ideas as possible, without evaluating them. The hope is that enough ideas are generated that a few of them are viable both engineering and business-wise.

Ideally, at the end of this step, we should have at least a few hundred ideas to choose from.

2. Second, after generating all those ideas, the next step is to whittle them down to a manageable number so we can do research on them. This will probably be between 10 and 20 ideas. By applying some simple criteria, we should be able to arrive at the top ideas we might be able to pursue. Ideally these criteria do not require research, but can be answered easily and quickly.

Criteria:

- What user problem/pain does this solve? If it doesn’t solve a problem, no one will buy it.

- How is the user going to pay for it? Or how does the product generate money? If a cool idea can’t generate money, its not worth it. A lot of Web 2.0 apps fall into this (like digg, YouTube, etc). They solve problems, but they don’t make money.

- What is the potential customer base? i.e. Is it consumer, professional, or developer level product? This will help rate the ideas – a consumer product is usually more valuable than a developer product since there’s potentially a larger customer base.

- Without architecting or engineering the product, is the product even technically feasible? If we’re trying to make cold fusion work, we should probably pass on that for now.

These criteria probably will not eliminate all but 10 or 20 ideas, but they should help us rank them and pick out the best 10 or 20 ideas. Some ideas might have to be fleshed out a bit more, but hopefully even vague ideas can be evaluated at this step in the process.

3. Next we need to research the top 10 or 20 ideas. This means fleshing them out a bit more so we can make more critical decisions about them. The research is targeted at finding out how much money the product might bring in, how likely we are to attract customers, and what building the product might cost.

What we need to know:

- How big is the potential customer base? This is an extension of what kind of product is it: consumer, professional or developer. Do a lot of people have the problem this idea is trying to solve, or is it a niche problem?

- What can we charge for the product? What is the competition charging? Not trying to determine final pricing here, but what is the range we could expect.

- How will we sustain income with the product? Upgrades, subscriptions, ads?

- Is there any competition? If so, who is the leader? What makes the leader, the leader? Can another product be sustained in this environment?

- What are the core/basic features in the product? We don’t need or want a feature spec here, just a general idea of what we’re providing. This should help with cost of building as well as what we can charge.

- What will set us apart from the competition? i.e. Do we think we can actually capture part of the market?

- What are the engineering costs in regards to time? i.e. how many engineers for how long? We don’t need a real number, just general estimates so we can compare it against the other ideas.

- What is the required infrastructure to make this work? This would obviously be bigger for web apps which need a large number of servers. Don’t forget about add ins to do try-before-you-buy or other demo schemes.

- What kind of marketing might we need to make the product a success? Mainly we want to know how expensive it will be to market the product.

- Are there legal or other expenses (like facilities or sales people or development software) that are required?

4. Finally, we need to evaluate the product ideas based on our research. Knowing how big our customer base is and how much we can charge will give us a ballpark of how much money the product could potentially bring in. The competitive analysis and feature ideas will give us an idea of how much of that money we might be able to get. The engineering cost estimates and required infrastructure costs will give us an estimate of the total cost to build the product.

So the basic “value” of the product idea is:

(Potential money in the market) * (Part of the market we get) – (Total costs of building product) = Profit

That’s real scientific stuff. Please don’t take it too seriously.

We’re not going to get hard and fast numbers out of this step, but it should give us a vague idea which idea is more valuable, business-wise, than the others. At the end of this step we should have at least one (if not more) idea that we can then take on to the product development process.

Once again, this is a light weight process that can (and probably will) change as we learn things. If you have ideas, suggestions, or comments about how to make this better, please let me know.

As you can tell, my process focuses on what product will bring in the most money. While money is good, I don’t want to build a product that I won’t enjoy working on.

What are your thoughts?

Filed in Career,Order N,Programming | 6 responses so far

A day in the life of a software engineer

andy on Aug 17th 2006

For those of you who actually read this blog for the articles (as opposed to the pictures), you’ve probably often wondered: what is it, exactly, that you do? Other than make a fool of yourself? In order to answer that question, and have something to do, I present what my daily schedule is like.

8am – Wake up, scratch self, turn over, fall back to sleep. No respectable software engineer gets up this early.

8:15am – MacBook Pro’s dancing in my head. Unless you’re my girlfriend, in which case, I only dream about you baby.

9am – Wake up and realize I do not own a MacBook Pro. My dreams crushed, I see no reason to remain conscious, so I scratch myself, turn over, and fall back to sleep.

9:30am – Apartment maintenance personnel decide that I have slept long enough and begin pile-driving two feet outside my bedroom window, where in the alley they have apparently decided to construct a large shopping center.

9:31am – Contemplate the needed trajectory of a rock that would injure, but not kill, said maintenance person. I might need my ice maker fixed at some point.

9:35am – Give up on plan to maim maintenance personnel because it would involve moving a part of my body, and, let’s me honest, who doesn’t want an large 24-hour supermarket directly outside their window?

10am – Unsure if I am yet awake, maintenance personnel begin mowing what’s left of the grass outside my bedroom with a bush-hog machine.

10:01am – Stagger the 10 feet from my bedroom to my “office.” Manage to stub my toe on no fewer than seven objects. As required by law, at least three are more dense than depleted Uranium.

10:02am – My now semi-awake brain discovers that the computer/printer combo doesn’t not provide this “food” that the Wizard needs, badly.

10:03am – Stagger over to the refrigerator. My agile feet know the path well, and manage to run into the same seven objects.

10:05am – Think about how good a breakfast with scrambled eggs, bacon, and blueberry pancakes would taste. Unfortunately, I am a bachelor so anything that cannot be made from hot-dogs and month old bread is out of the question.

10:06am – With hot-dog flavored “PopTart” in hand, return to the computer.

10:07am – Digg and Slashdot.

11:03am – Decide to actually “work.”

11:04am – Start pulling down code to work on with Perforce, the Fast Software Configuration Management System. The file set consists of three small text files, one resource file, and a large image file describing how the software system works, assuming they had actually built it that way.

12pm – Lunch, which is a hot dog, stale bread, or some combination thereof.

1pm – Perforce, the Fast Software Configuration Management System, actually completes the synchronize operation, leaving me with three small text files, twenty corrupted resource files, and someone’s half eaten pimento cheese sandwich.

1:01pm – Consult Digg and Slashdot, while contemplating why anyone uses Perforce.

2:00pm – Remember that people use Perforce because the alternatives are worse. For example, Visual SourceSafe is a service by Microsoft in which they send a salesman to your place of business to kick you in the seat of your pants repeatedly. In the Professional version of SourceSafe, the salesman also steals your credit card and purchases a site license for Microsoft Money.

2:01pm – Attempt to log into the client’s bug database, so I know what to work on. Discover that I do not have access to bugbase, which is on the internal network, because I did not file a business case for why I need it, three years in advance.

2:05pm – Call the client’s IT department, explain that I need network access from my Mac. To avoid getting the wrong software, keep mentioning that I am using a Mac during any awkward silences and anyplace in the conversation a normal person might say something like “hello.” Sensing my urgency, IT promptly sends me five copies of the Windows software.

2:10pm – Call IT department back to explain that need Mac software, to which I am promptly told “We do not support Windows 98.”

2:15pm – Finally reach the one Mac IT person, whom they apparently keep locked in a cage in the basement, and feed old PowerTalk documentation. He cannot send the software via email because of the 32 byte email attachment limit, but he is able to smuggle out a CD of the software, on the back of one of the many fruit bats in his cage.

2:30pm – Discover that VPN software does not reliably connect to client’s network, but does, in fact, waste a large amount of space on my hard drive and not uninstall.

2:31pm – Call IT department again to explain VPN software does not work. IT carefully explains that I must either rewire my apartment, reconfigure my router so that it is solely and permanently connected to their network, or move to California and/or India for VPN to ever work. They are not sure which. Smoke signals are suggested in the interim.

2:45pm – Randomly change settings in the VPN configuration until I can actually connect to the internal network. Discover that although I can connect, I have no security access to any servers on their network, including the bug database. Furthermore, IT has decided that, for reasons of productivity, anyone connected through VPN should not be able to access anything outside their network, such as, for example, the computer sitting right in front of me.

2:56pm – Call IT department to be granted access to the bug database. The IT person that I reach calmly explains that, yes, he can grant me those privileges, but won’t, because he strongly suspects that will allow me to do actual work.

3:03pm – Have my contact within the client company call IT and explain that its OK for me to do work because I do not work in IT.

3:30pm – Feel smug about getting to bill client for all the time IT wasted.

3:31pm – To celebrate victory over IT, Digg and Slashdot.

3:52pm – Examine the first bug I am supposed to fix, which is marked as “severe” and a “crasher.” It states: “When I press Command-Q, the application quits.” I spend the next hour on the phone explain why that is expected behavior. The phone call ends with the quote “Well, that’s stupid and Apple should change it.”

4:52pm – Digg and Slashdot.

5:23pm – Examine the next bug I am supposed to fix. Although it is simply a misspelled word that has been in the software for seven years, it has now become “urgent,” “must fix,” and, “severe.” Oddly enough, the bug was entered by a technical writer.

5:33pm – Open up Xcode, Apple’s integrated development environment, specially designed for the Mac user who has lost the will to live.

5:38pm – Change the resource string to fix the misspelling, which the previous engineer was unable to do, because, apparently, he could not locate the second button on his Macintosh mouse.

5:50pm – UI designer notices that I fixed the misspelling, and suggests other improvements to the wording, such as rewriting the host operating system from scratch to use more color gradients.

6:04pm – While muttering under my breath about out of control UI designers, Digg and Slashdot.

6:45pm – Examine the next bug, which is from a customer, requesting that we add support for XML file formats and the ability to shave an enraged badger. After serious consideration, I decide to defer the bug for next time.

7:02pm – Receive call from marketing demanding to know why XML files/badger-shaving feature was deferred. They cite numerous customer anecdotes in which they needed the portability of an XML file combined with the ability to shave an angry badger. Most cases involve alcohol, in which the badger had consumed prodigious amounts.

7:30pm – Look at code for the first time today.

7:47pm – Marketing calls back saying what the customer probably, really, honestly, truly needed was a way sober up the badger. They swear the badger is a nice guy, but only acts that way when he’s drunk. Plus he has a bad 5 o’clock shadow.

8pm – Receive call from potential client, asking if we could port his Word processor for Windows to the Mac for twenty nine cents and a large portion on his company’s stock, currently held in a gum-ball machine.

8:28pm – Starving, I crawl to the refrigerator, where I discover a veritable treasure trove of food, in the form of Cheerios, underneath the fridge.

9:02pm – Realizing I am spending too much time reading Digg and Slashdot, I go read Dilbert, Get Fuzzy, and Pearls before Swine.

9:18pm – Return to code and marvel at the fact the compiler has not openly mocked the code in iambic pentameter or simply refused to compile it out of principle.

10:07pm – Digg and Slashdot.

10:41pm – iChat with business parter in which we ridicule Xcode’s speed, code quality, and inability to shave an enraged badger who’s had a few too many drinks.

11:11pm – Notice that the auto-complete in Xcode is actually recommending other, more reputable companies I could be working for.

11:38pm – Digg.

12:06pm – Slashdot.

12:49am – Change egregious code “if ( foo ) doFoo();” to the much more sane “if ( foo ) { doFoo(); }”, on the initial thought that I get paid by the character.

1:22am – Discover the entire Xcode help file is one page that recommends using a better IDE, such as MPW.

1:30am – Change the completely erroneous “if ( foo ) { doFoo(); }” to the actually readable “if (foo) {doFoo();}”. Note the bytes saved by the removed whitespace on my accomplishments.

1:40am – In an attempt to find a snippet of code in my project, Xcode inadvertently finds life on Mars. Still unable to search an arbitrary directory in less than ten steps.

1:44am – Change “if (foo) {doFoo();}” to “if ( foo ) doFoo();”, and wonder what fool added the unnecessary braces and removed the spaces.

1:54am – Against doctor’s orders, read old copies of Inside Macintosh, Volume 1 until I fall asleep. He recommended a large mallet to the head, for the reason that it is less likely to cause severe brain trauma.

As you can see, the life of an independent software engineer is not for the faint of heart. No doubt you have more respect for me now than you have ever had before.

Filed in Career,Contracting,Macintosh,Order N,Programming | 8 responses so far

Bad Behavior has blocked 339 access attempts in the last 7 days.