Customer does not want to pay for my learning curve [closed]

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty margin-bottom:0;







up vote
11
down vote

favorite
5












An acquaintance wishes to contract me for a small embedded programming project. I have not done embedded programming in many, many years.



He had, naturally, asked me for a cost estimate. This field being kind of foreign to me (these days), I said I could not give him a reliable estimate.



He said he would feel much easier if I did not bill him for my learning curve. I said this very rarely happens in the industry, that the learning curve is a very large part of our work, something client pays for. He very reluctantly agreed, but I could see he could change his mind any moment - and this little project is fun and I could not resist it. So I said, OK, you don't pay for my learning curve then, and he beamed and said he is a very fair person and will compensate me fairly. (I believe that, but what is fair to a non-programmer? Don't know!)



Looking from his standpoint, I understand where he is coming from. He knows next to nothing about me; he probably can't grind me with a good tech screening, so for all he knows, I could be clueless and bomb the project completely; I could end up costing him an unknown amount for an end result of uncertain value, and would not give him not only a promise, but even an estimate. That can be unnerving. BTDT with doctors, lawyers and such. Real hit or miss.



So it's been 9 days since, I've been programming obsessively around the clock, still have not given him an estimate (perhaps this is my main mistake right here, but I can't give an honest estimate of what I don't know!) and I realized that my actual work, not counting learning, is so tiny that, knowing what I know now, I could have done it in an hour. Now what? Bill him for an hour? Of course not!



Have not given him the code yet, either; intend to keep it this way until we come to an agreement.



The guy is a very nice guy, and we both intend to resolve this fairly; but our expectations at this point are so vague, I fear the possibility of a major mutual disappointment.



We are on a handshake agreement at this point. No papers signed, not even an NDA yet, even though I know all his IP, and he cares about his IP a lot. So yes, I believe he trusts me. But from the past experience working on a handshake with a non-programmer, this trust could evaporate instantly should any misundersatanding arise. I don't blame him: he is risking too much.



The thing is, what constitutes "learning" is open to interpretation. Just getting back to speed with embedded systems? Learning this particular microcontroller? Learning this particular protocol? Is software design "learning"? We have not discussed that, and it's widely open to interpretation.



I suppose I could split my learning time into non-billable (something an embedded programmer would expected to know) and billable (esoteric things that only a small minority of people know). But this is vague.



What should I do? I don't have much experience working for small clients.



Edit Some people felt it's unclear what I am asking. Sorry. I am asking how to



  1. get paid for my work

  2. without alienating the customer

  3. by communicating to him my POV on what's fair and

  4. building consensus while

  5. meeting his needs and

  6. making him feel secure his needs will be met, at this early stage.






share|improve this question














closed as unclear what you're asking by jmac, CMW, Rhys, IDrinkandIKnowThings, Monica Cellio♦ Mar 17 '14 at 19:43


Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.










  • 4




    Hey Таня, and welcome to The Workplace! Your question is very long and includes many details, but it isn't clear what exactly your problem is and how you would like to solve it. Could you please edit your question to specify what you're actually asking for? Do you want to know what to bill him? What's fair? How to explain to him what you found out? Thanks in advance!
    – jmac
    Mar 17 '14 at 4:21










  • Edited as to make it clear what I'm asking for. Please vote to unhold.
    – Ruby
    Mar 18 '14 at 0:21







  • 2




    Thanks for the edit Таня, but even with the edit your question isn't a good fit with the guidelines in our help center. You are now asking for 6 different things, many of which aren't ones we can help with. The Workplace isn't a place to come for advice, it's a resource to help people solve problems that others will face and benefit from answers from. If you narrow down your question, for instance, "How can I professionally inform a client that they will need to pay more for my services than they expect?" and focus on the details related to that question, you will get better answers.
    – jmac
    Mar 19 '14 at 0:32










  • Comments removed. For extended discussion, please use The Workplace Chat. For questions clarifying what is or is not on topic, The Workplace Meta is also appropriate.
    – yoozer8
    Mar 21 '14 at 13:51










  • Таня Т.: These kind of questions tend to get better quality answers in freelancing.stackexchange.com - ask your question be moved there, or ask again and better. Folks here think more "big company" style, in my experience. Even if answer from @Mσᶎ is good.
    – P.M
    Aug 5 '14 at 12:14

















up vote
11
down vote

favorite
5












An acquaintance wishes to contract me for a small embedded programming project. I have not done embedded programming in many, many years.



He had, naturally, asked me for a cost estimate. This field being kind of foreign to me (these days), I said I could not give him a reliable estimate.



He said he would feel much easier if I did not bill him for my learning curve. I said this very rarely happens in the industry, that the learning curve is a very large part of our work, something client pays for. He very reluctantly agreed, but I could see he could change his mind any moment - and this little project is fun and I could not resist it. So I said, OK, you don't pay for my learning curve then, and he beamed and said he is a very fair person and will compensate me fairly. (I believe that, but what is fair to a non-programmer? Don't know!)



Looking from his standpoint, I understand where he is coming from. He knows next to nothing about me; he probably can't grind me with a good tech screening, so for all he knows, I could be clueless and bomb the project completely; I could end up costing him an unknown amount for an end result of uncertain value, and would not give him not only a promise, but even an estimate. That can be unnerving. BTDT with doctors, lawyers and such. Real hit or miss.



So it's been 9 days since, I've been programming obsessively around the clock, still have not given him an estimate (perhaps this is my main mistake right here, but I can't give an honest estimate of what I don't know!) and I realized that my actual work, not counting learning, is so tiny that, knowing what I know now, I could have done it in an hour. Now what? Bill him for an hour? Of course not!



Have not given him the code yet, either; intend to keep it this way until we come to an agreement.



The guy is a very nice guy, and we both intend to resolve this fairly; but our expectations at this point are so vague, I fear the possibility of a major mutual disappointment.



We are on a handshake agreement at this point. No papers signed, not even an NDA yet, even though I know all his IP, and he cares about his IP a lot. So yes, I believe he trusts me. But from the past experience working on a handshake with a non-programmer, this trust could evaporate instantly should any misundersatanding arise. I don't blame him: he is risking too much.



The thing is, what constitutes "learning" is open to interpretation. Just getting back to speed with embedded systems? Learning this particular microcontroller? Learning this particular protocol? Is software design "learning"? We have not discussed that, and it's widely open to interpretation.



I suppose I could split my learning time into non-billable (something an embedded programmer would expected to know) and billable (esoteric things that only a small minority of people know). But this is vague.



What should I do? I don't have much experience working for small clients.



Edit Some people felt it's unclear what I am asking. Sorry. I am asking how to



  1. get paid for my work

  2. without alienating the customer

  3. by communicating to him my POV on what's fair and

  4. building consensus while

  5. meeting his needs and

  6. making him feel secure his needs will be met, at this early stage.






share|improve this question














closed as unclear what you're asking by jmac, CMW, Rhys, IDrinkandIKnowThings, Monica Cellio♦ Mar 17 '14 at 19:43


Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.










  • 4




    Hey Таня, and welcome to The Workplace! Your question is very long and includes many details, but it isn't clear what exactly your problem is and how you would like to solve it. Could you please edit your question to specify what you're actually asking for? Do you want to know what to bill him? What's fair? How to explain to him what you found out? Thanks in advance!
    – jmac
    Mar 17 '14 at 4:21










  • Edited as to make it clear what I'm asking for. Please vote to unhold.
    – Ruby
    Mar 18 '14 at 0:21







  • 2




    Thanks for the edit Таня, but even with the edit your question isn't a good fit with the guidelines in our help center. You are now asking for 6 different things, many of which aren't ones we can help with. The Workplace isn't a place to come for advice, it's a resource to help people solve problems that others will face and benefit from answers from. If you narrow down your question, for instance, "How can I professionally inform a client that they will need to pay more for my services than they expect?" and focus on the details related to that question, you will get better answers.
    – jmac
    Mar 19 '14 at 0:32










  • Comments removed. For extended discussion, please use The Workplace Chat. For questions clarifying what is or is not on topic, The Workplace Meta is also appropriate.
    – yoozer8
    Mar 21 '14 at 13:51










  • Таня Т.: These kind of questions tend to get better quality answers in freelancing.stackexchange.com - ask your question be moved there, or ask again and better. Folks here think more "big company" style, in my experience. Even if answer from @Mσᶎ is good.
    – P.M
    Aug 5 '14 at 12:14













up vote
11
down vote

favorite
5









up vote
11
down vote

favorite
5






5





An acquaintance wishes to contract me for a small embedded programming project. I have not done embedded programming in many, many years.



He had, naturally, asked me for a cost estimate. This field being kind of foreign to me (these days), I said I could not give him a reliable estimate.



He said he would feel much easier if I did not bill him for my learning curve. I said this very rarely happens in the industry, that the learning curve is a very large part of our work, something client pays for. He very reluctantly agreed, but I could see he could change his mind any moment - and this little project is fun and I could not resist it. So I said, OK, you don't pay for my learning curve then, and he beamed and said he is a very fair person and will compensate me fairly. (I believe that, but what is fair to a non-programmer? Don't know!)



Looking from his standpoint, I understand where he is coming from. He knows next to nothing about me; he probably can't grind me with a good tech screening, so for all he knows, I could be clueless and bomb the project completely; I could end up costing him an unknown amount for an end result of uncertain value, and would not give him not only a promise, but even an estimate. That can be unnerving. BTDT with doctors, lawyers and such. Real hit or miss.



So it's been 9 days since, I've been programming obsessively around the clock, still have not given him an estimate (perhaps this is my main mistake right here, but I can't give an honest estimate of what I don't know!) and I realized that my actual work, not counting learning, is so tiny that, knowing what I know now, I could have done it in an hour. Now what? Bill him for an hour? Of course not!



Have not given him the code yet, either; intend to keep it this way until we come to an agreement.



The guy is a very nice guy, and we both intend to resolve this fairly; but our expectations at this point are so vague, I fear the possibility of a major mutual disappointment.



We are on a handshake agreement at this point. No papers signed, not even an NDA yet, even though I know all his IP, and he cares about his IP a lot. So yes, I believe he trusts me. But from the past experience working on a handshake with a non-programmer, this trust could evaporate instantly should any misundersatanding arise. I don't blame him: he is risking too much.



The thing is, what constitutes "learning" is open to interpretation. Just getting back to speed with embedded systems? Learning this particular microcontroller? Learning this particular protocol? Is software design "learning"? We have not discussed that, and it's widely open to interpretation.



I suppose I could split my learning time into non-billable (something an embedded programmer would expected to know) and billable (esoteric things that only a small minority of people know). But this is vague.



What should I do? I don't have much experience working for small clients.



Edit Some people felt it's unclear what I am asking. Sorry. I am asking how to



  1. get paid for my work

  2. without alienating the customer

  3. by communicating to him my POV on what's fair and

  4. building consensus while

  5. meeting his needs and

  6. making him feel secure his needs will be met, at this early stage.






share|improve this question














An acquaintance wishes to contract me for a small embedded programming project. I have not done embedded programming in many, many years.



He had, naturally, asked me for a cost estimate. This field being kind of foreign to me (these days), I said I could not give him a reliable estimate.



He said he would feel much easier if I did not bill him for my learning curve. I said this very rarely happens in the industry, that the learning curve is a very large part of our work, something client pays for. He very reluctantly agreed, but I could see he could change his mind any moment - and this little project is fun and I could not resist it. So I said, OK, you don't pay for my learning curve then, and he beamed and said he is a very fair person and will compensate me fairly. (I believe that, but what is fair to a non-programmer? Don't know!)



Looking from his standpoint, I understand where he is coming from. He knows next to nothing about me; he probably can't grind me with a good tech screening, so for all he knows, I could be clueless and bomb the project completely; I could end up costing him an unknown amount for an end result of uncertain value, and would not give him not only a promise, but even an estimate. That can be unnerving. BTDT with doctors, lawyers and such. Real hit or miss.



So it's been 9 days since, I've been programming obsessively around the clock, still have not given him an estimate (perhaps this is my main mistake right here, but I can't give an honest estimate of what I don't know!) and I realized that my actual work, not counting learning, is so tiny that, knowing what I know now, I could have done it in an hour. Now what? Bill him for an hour? Of course not!



Have not given him the code yet, either; intend to keep it this way until we come to an agreement.



The guy is a very nice guy, and we both intend to resolve this fairly; but our expectations at this point are so vague, I fear the possibility of a major mutual disappointment.



We are on a handshake agreement at this point. No papers signed, not even an NDA yet, even though I know all his IP, and he cares about his IP a lot. So yes, I believe he trusts me. But from the past experience working on a handshake with a non-programmer, this trust could evaporate instantly should any misundersatanding arise. I don't blame him: he is risking too much.



The thing is, what constitutes "learning" is open to interpretation. Just getting back to speed with embedded systems? Learning this particular microcontroller? Learning this particular protocol? Is software design "learning"? We have not discussed that, and it's widely open to interpretation.



I suppose I could split my learning time into non-billable (something an embedded programmer would expected to know) and billable (esoteric things that only a small minority of people know). But this is vague.



What should I do? I don't have much experience working for small clients.



Edit Some people felt it's unclear what I am asking. Sorry. I am asking how to



  1. get paid for my work

  2. without alienating the customer

  3. by communicating to him my POV on what's fair and

  4. building consensus while

  5. meeting his needs and

  6. making him feel secure his needs will be met, at this early stage.








share|improve this question













share|improve this question




share|improve this question








edited Mar 18 '14 at 0:18

























asked Mar 17 '14 at 1:03









Ruby

1648




1648




closed as unclear what you're asking by jmac, CMW, Rhys, IDrinkandIKnowThings, Monica Cellio♦ Mar 17 '14 at 19:43


Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.






closed as unclear what you're asking by jmac, CMW, Rhys, IDrinkandIKnowThings, Monica Cellio♦ Mar 17 '14 at 19:43


Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.









  • 4




    Hey Таня, and welcome to The Workplace! Your question is very long and includes many details, but it isn't clear what exactly your problem is and how you would like to solve it. Could you please edit your question to specify what you're actually asking for? Do you want to know what to bill him? What's fair? How to explain to him what you found out? Thanks in advance!
    – jmac
    Mar 17 '14 at 4:21










  • Edited as to make it clear what I'm asking for. Please vote to unhold.
    – Ruby
    Mar 18 '14 at 0:21







  • 2




    Thanks for the edit Таня, but even with the edit your question isn't a good fit with the guidelines in our help center. You are now asking for 6 different things, many of which aren't ones we can help with. The Workplace isn't a place to come for advice, it's a resource to help people solve problems that others will face and benefit from answers from. If you narrow down your question, for instance, "How can I professionally inform a client that they will need to pay more for my services than they expect?" and focus on the details related to that question, you will get better answers.
    – jmac
    Mar 19 '14 at 0:32










  • Comments removed. For extended discussion, please use The Workplace Chat. For questions clarifying what is or is not on topic, The Workplace Meta is also appropriate.
    – yoozer8
    Mar 21 '14 at 13:51










  • Таня Т.: These kind of questions tend to get better quality answers in freelancing.stackexchange.com - ask your question be moved there, or ask again and better. Folks here think more "big company" style, in my experience. Even if answer from @Mσᶎ is good.
    – P.M
    Aug 5 '14 at 12:14













  • 4




    Hey Таня, and welcome to The Workplace! Your question is very long and includes many details, but it isn't clear what exactly your problem is and how you would like to solve it. Could you please edit your question to specify what you're actually asking for? Do you want to know what to bill him? What's fair? How to explain to him what you found out? Thanks in advance!
    – jmac
    Mar 17 '14 at 4:21










  • Edited as to make it clear what I'm asking for. Please vote to unhold.
    – Ruby
    Mar 18 '14 at 0:21







  • 2




    Thanks for the edit Таня, but even with the edit your question isn't a good fit with the guidelines in our help center. You are now asking for 6 different things, many of which aren't ones we can help with. The Workplace isn't a place to come for advice, it's a resource to help people solve problems that others will face and benefit from answers from. If you narrow down your question, for instance, "How can I professionally inform a client that they will need to pay more for my services than they expect?" and focus on the details related to that question, you will get better answers.
    – jmac
    Mar 19 '14 at 0:32










  • Comments removed. For extended discussion, please use The Workplace Chat. For questions clarifying what is or is not on topic, The Workplace Meta is also appropriate.
    – yoozer8
    Mar 21 '14 at 13:51










  • Таня Т.: These kind of questions tend to get better quality answers in freelancing.stackexchange.com - ask your question be moved there, or ask again and better. Folks here think more "big company" style, in my experience. Even if answer from @Mσᶎ is good.
    – P.M
    Aug 5 '14 at 12:14








4




4




Hey Таня, and welcome to The Workplace! Your question is very long and includes many details, but it isn't clear what exactly your problem is and how you would like to solve it. Could you please edit your question to specify what you're actually asking for? Do you want to know what to bill him? What's fair? How to explain to him what you found out? Thanks in advance!
– jmac
Mar 17 '14 at 4:21




Hey Таня, and welcome to The Workplace! Your question is very long and includes many details, but it isn't clear what exactly your problem is and how you would like to solve it. Could you please edit your question to specify what you're actually asking for? Do you want to know what to bill him? What's fair? How to explain to him what you found out? Thanks in advance!
– jmac
Mar 17 '14 at 4:21












Edited as to make it clear what I'm asking for. Please vote to unhold.
– Ruby
Mar 18 '14 at 0:21





Edited as to make it clear what I'm asking for. Please vote to unhold.
– Ruby
Mar 18 '14 at 0:21





2




2




Thanks for the edit Таня, but even with the edit your question isn't a good fit with the guidelines in our help center. You are now asking for 6 different things, many of which aren't ones we can help with. The Workplace isn't a place to come for advice, it's a resource to help people solve problems that others will face and benefit from answers from. If you narrow down your question, for instance, "How can I professionally inform a client that they will need to pay more for my services than they expect?" and focus on the details related to that question, you will get better answers.
– jmac
Mar 19 '14 at 0:32




Thanks for the edit Таня, but even with the edit your question isn't a good fit with the guidelines in our help center. You are now asking for 6 different things, many of which aren't ones we can help with. The Workplace isn't a place to come for advice, it's a resource to help people solve problems that others will face and benefit from answers from. If you narrow down your question, for instance, "How can I professionally inform a client that they will need to pay more for my services than they expect?" and focus on the details related to that question, you will get better answers.
– jmac
Mar 19 '14 at 0:32












Comments removed. For extended discussion, please use The Workplace Chat. For questions clarifying what is or is not on topic, The Workplace Meta is also appropriate.
– yoozer8
Mar 21 '14 at 13:51




Comments removed. For extended discussion, please use The Workplace Chat. For questions clarifying what is or is not on topic, The Workplace Meta is also appropriate.
– yoozer8
Mar 21 '14 at 13:51












Таня Т.: These kind of questions tend to get better quality answers in freelancing.stackexchange.com - ask your question be moved there, or ask again and better. Folks here think more "big company" style, in my experience. Even if answer from @Mσᶎ is good.
– P.M
Aug 5 '14 at 12:14





Таня Т.: These kind of questions tend to get better quality answers in freelancing.stackexchange.com - ask your question be moved there, or ask again and better. Folks here think more "big company" style, in my experience. Even if answer from @Mσᶎ is good.
– P.M
Aug 5 '14 at 12:14











1 Answer
1






active

oldest

votes

















up vote
10
down vote



accepted










IME your situation is typical of an owner operator type business. The skills are specific to their business, and every cent they spend hurts them. It seems that you started out well, on the basis that the combination of what he wanted you to do, and the unusual system you wanted him to do it with, meant that he'd be paying you to learn. But then you were persuaded that he shouldn't pay you for that, only for your eventual "expert time".



It might help to explain that programming is design if not research and development. Sure, you can sketch a high-level design, but without either experience or experiments you have little idea of the details of the design, let alone the size of the finished product (which is what, an executable?) There's almost never a time where you say "I'll use pattern A, pattern B and link them using framework X. I estimate 1800 lines of code". Which is what most engineering design looks like at the planning stages.



At this stage I think you really have to go back and say "This is more work than I can afford to do as a hobby, or on the off chance that eventually I might get paid for it. I'm willing to hand over what I've done if you pay me for the time spent. But unless you're willing to pay me from now on, I think it would be best if you found another programmer". The problem is as much the pattern (no result = no pay) as the specific case ("I'm learning, not coding").



You don't have the experience to give a solid estimate, otherwise now would be the time to say "I'll deliver X for Y money". If you did that one of you would get screwed, and I'm betting it would be you.



If nothing else you need to lay out concrete expectations and review them regularly. This is where weekly meetings where you only review what's been done and lay out your plan for the next week are key. Try to avoid demonstrating code, this is an office meeting where you talk, not a product demo where you show. But meeting every week and you saying "I have done X, here is my engineering notebook and my project plan", and him paying you, means you both have a good idea of where things are. But again, this is research, so you're not going to be able to say "I am 123 hours into the 456 hour project, therefore 123/456 % complete".



Here are three options that might work:



  1. He lends you the hardware and you build some kind of hobby project for that system. Something that he can't use, to make it clear that this is your learning process. Then he pays you a decent hourly rate for everything else, whether it's research or typing.

  2. You keep on as you are (perhaps with more non-working time in your life), and he pays you a slightly lower hourly rate while you learn on the job.

  3. He pays you as a consultant to help interview and find another programmer. If nothing else that market survey will help him re-calibrate his expectations of how much this will cost, and how common the skills he wants are.

One option that definitely will work: quit. You've learned that picking up a whole new skillset while working for a friend is not a good idea. He's learned that getting a non-expert but expecting them to work like an expert doesn't work.






share|improve this answer






















  • thank you for your answer, but the thing is.. After 9 days, I am an expert now. At least, it feels this way. I am a fast learner! And I want to continue. I like this project.
    – Ruby
    Mar 17 '14 at 3:16











  • @ТаняТ. You have to negotiate a payment that you both think is reasonable. I suggest making a list of the value you've gained/added since you started, and what you feel you should be paid for it. Don't be afraid to say "from X to Y" and if he offers more argue that Y is good. That's a judgement call, but establishing in his mind that you won't overcharge is a useful thing. Once you have that, sit down and start negotiating.
    – Móż
    Mar 17 '14 at 3:32







  • 1




    Also, I hope you're not offended but I work with people who have 20 years experience in embedded programming and after 6 months working with them I'm not an expert. You've had 9 days without expert supervision. I am/was a desktop/server expert, embedded is a whole new thing. Unless it's "embedded" Android type code, in which case 10 years Java could possibly make you an Android expert in a few months.
    – Móż
    Mar 17 '14 at 3:37











  • @ Ӎσᶎ I was being a bit facetious. My point is, byMSP430 is really simple; by now I know what I am doing, and know enough buzzwords to ask or search for what I don't know. You must be working with something much more complex.
    – Ruby
    Mar 17 '14 at 3:44











  • Also, I've spent 6 years programming embedded and/or C/C++/asm, though it's been too long ago. No offence taken, and hope I did not offend the real gurus.
    – Ruby
    Mar 17 '14 at 4:02


















1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes








up vote
10
down vote



accepted










IME your situation is typical of an owner operator type business. The skills are specific to their business, and every cent they spend hurts them. It seems that you started out well, on the basis that the combination of what he wanted you to do, and the unusual system you wanted him to do it with, meant that he'd be paying you to learn. But then you were persuaded that he shouldn't pay you for that, only for your eventual "expert time".



It might help to explain that programming is design if not research and development. Sure, you can sketch a high-level design, but without either experience or experiments you have little idea of the details of the design, let alone the size of the finished product (which is what, an executable?) There's almost never a time where you say "I'll use pattern A, pattern B and link them using framework X. I estimate 1800 lines of code". Which is what most engineering design looks like at the planning stages.



At this stage I think you really have to go back and say "This is more work than I can afford to do as a hobby, or on the off chance that eventually I might get paid for it. I'm willing to hand over what I've done if you pay me for the time spent. But unless you're willing to pay me from now on, I think it would be best if you found another programmer". The problem is as much the pattern (no result = no pay) as the specific case ("I'm learning, not coding").



You don't have the experience to give a solid estimate, otherwise now would be the time to say "I'll deliver X for Y money". If you did that one of you would get screwed, and I'm betting it would be you.



If nothing else you need to lay out concrete expectations and review them regularly. This is where weekly meetings where you only review what's been done and lay out your plan for the next week are key. Try to avoid demonstrating code, this is an office meeting where you talk, not a product demo where you show. But meeting every week and you saying "I have done X, here is my engineering notebook and my project plan", and him paying you, means you both have a good idea of where things are. But again, this is research, so you're not going to be able to say "I am 123 hours into the 456 hour project, therefore 123/456 % complete".



Here are three options that might work:



  1. He lends you the hardware and you build some kind of hobby project for that system. Something that he can't use, to make it clear that this is your learning process. Then he pays you a decent hourly rate for everything else, whether it's research or typing.

  2. You keep on as you are (perhaps with more non-working time in your life), and he pays you a slightly lower hourly rate while you learn on the job.

  3. He pays you as a consultant to help interview and find another programmer. If nothing else that market survey will help him re-calibrate his expectations of how much this will cost, and how common the skills he wants are.

One option that definitely will work: quit. You've learned that picking up a whole new skillset while working for a friend is not a good idea. He's learned that getting a non-expert but expecting them to work like an expert doesn't work.






share|improve this answer






















  • thank you for your answer, but the thing is.. After 9 days, I am an expert now. At least, it feels this way. I am a fast learner! And I want to continue. I like this project.
    – Ruby
    Mar 17 '14 at 3:16











  • @ТаняТ. You have to negotiate a payment that you both think is reasonable. I suggest making a list of the value you've gained/added since you started, and what you feel you should be paid for it. Don't be afraid to say "from X to Y" and if he offers more argue that Y is good. That's a judgement call, but establishing in his mind that you won't overcharge is a useful thing. Once you have that, sit down and start negotiating.
    – Móż
    Mar 17 '14 at 3:32







  • 1




    Also, I hope you're not offended but I work with people who have 20 years experience in embedded programming and after 6 months working with them I'm not an expert. You've had 9 days without expert supervision. I am/was a desktop/server expert, embedded is a whole new thing. Unless it's "embedded" Android type code, in which case 10 years Java could possibly make you an Android expert in a few months.
    – Móż
    Mar 17 '14 at 3:37











  • @ Ӎσᶎ I was being a bit facetious. My point is, byMSP430 is really simple; by now I know what I am doing, and know enough buzzwords to ask or search for what I don't know. You must be working with something much more complex.
    – Ruby
    Mar 17 '14 at 3:44











  • Also, I've spent 6 years programming embedded and/or C/C++/asm, though it's been too long ago. No offence taken, and hope I did not offend the real gurus.
    – Ruby
    Mar 17 '14 at 4:02















up vote
10
down vote



accepted










IME your situation is typical of an owner operator type business. The skills are specific to their business, and every cent they spend hurts them. It seems that you started out well, on the basis that the combination of what he wanted you to do, and the unusual system you wanted him to do it with, meant that he'd be paying you to learn. But then you were persuaded that he shouldn't pay you for that, only for your eventual "expert time".



It might help to explain that programming is design if not research and development. Sure, you can sketch a high-level design, but without either experience or experiments you have little idea of the details of the design, let alone the size of the finished product (which is what, an executable?) There's almost never a time where you say "I'll use pattern A, pattern B and link them using framework X. I estimate 1800 lines of code". Which is what most engineering design looks like at the planning stages.



At this stage I think you really have to go back and say "This is more work than I can afford to do as a hobby, or on the off chance that eventually I might get paid for it. I'm willing to hand over what I've done if you pay me for the time spent. But unless you're willing to pay me from now on, I think it would be best if you found another programmer". The problem is as much the pattern (no result = no pay) as the specific case ("I'm learning, not coding").



You don't have the experience to give a solid estimate, otherwise now would be the time to say "I'll deliver X for Y money". If you did that one of you would get screwed, and I'm betting it would be you.



If nothing else you need to lay out concrete expectations and review them regularly. This is where weekly meetings where you only review what's been done and lay out your plan for the next week are key. Try to avoid demonstrating code, this is an office meeting where you talk, not a product demo where you show. But meeting every week and you saying "I have done X, here is my engineering notebook and my project plan", and him paying you, means you both have a good idea of where things are. But again, this is research, so you're not going to be able to say "I am 123 hours into the 456 hour project, therefore 123/456 % complete".



Here are three options that might work:



  1. He lends you the hardware and you build some kind of hobby project for that system. Something that he can't use, to make it clear that this is your learning process. Then he pays you a decent hourly rate for everything else, whether it's research or typing.

  2. You keep on as you are (perhaps with more non-working time in your life), and he pays you a slightly lower hourly rate while you learn on the job.

  3. He pays you as a consultant to help interview and find another programmer. If nothing else that market survey will help him re-calibrate his expectations of how much this will cost, and how common the skills he wants are.

One option that definitely will work: quit. You've learned that picking up a whole new skillset while working for a friend is not a good idea. He's learned that getting a non-expert but expecting them to work like an expert doesn't work.






share|improve this answer






















  • thank you for your answer, but the thing is.. After 9 days, I am an expert now. At least, it feels this way. I am a fast learner! And I want to continue. I like this project.
    – Ruby
    Mar 17 '14 at 3:16











  • @ТаняТ. You have to negotiate a payment that you both think is reasonable. I suggest making a list of the value you've gained/added since you started, and what you feel you should be paid for it. Don't be afraid to say "from X to Y" and if he offers more argue that Y is good. That's a judgement call, but establishing in his mind that you won't overcharge is a useful thing. Once you have that, sit down and start negotiating.
    – Móż
    Mar 17 '14 at 3:32







  • 1




    Also, I hope you're not offended but I work with people who have 20 years experience in embedded programming and after 6 months working with them I'm not an expert. You've had 9 days without expert supervision. I am/was a desktop/server expert, embedded is a whole new thing. Unless it's "embedded" Android type code, in which case 10 years Java could possibly make you an Android expert in a few months.
    – Móż
    Mar 17 '14 at 3:37











  • @ Ӎσᶎ I was being a bit facetious. My point is, byMSP430 is really simple; by now I know what I am doing, and know enough buzzwords to ask or search for what I don't know. You must be working with something much more complex.
    – Ruby
    Mar 17 '14 at 3:44











  • Also, I've spent 6 years programming embedded and/or C/C++/asm, though it's been too long ago. No offence taken, and hope I did not offend the real gurus.
    – Ruby
    Mar 17 '14 at 4:02













up vote
10
down vote



accepted







up vote
10
down vote



accepted






IME your situation is typical of an owner operator type business. The skills are specific to their business, and every cent they spend hurts them. It seems that you started out well, on the basis that the combination of what he wanted you to do, and the unusual system you wanted him to do it with, meant that he'd be paying you to learn. But then you were persuaded that he shouldn't pay you for that, only for your eventual "expert time".



It might help to explain that programming is design if not research and development. Sure, you can sketch a high-level design, but without either experience or experiments you have little idea of the details of the design, let alone the size of the finished product (which is what, an executable?) There's almost never a time where you say "I'll use pattern A, pattern B and link them using framework X. I estimate 1800 lines of code". Which is what most engineering design looks like at the planning stages.



At this stage I think you really have to go back and say "This is more work than I can afford to do as a hobby, or on the off chance that eventually I might get paid for it. I'm willing to hand over what I've done if you pay me for the time spent. But unless you're willing to pay me from now on, I think it would be best if you found another programmer". The problem is as much the pattern (no result = no pay) as the specific case ("I'm learning, not coding").



You don't have the experience to give a solid estimate, otherwise now would be the time to say "I'll deliver X for Y money". If you did that one of you would get screwed, and I'm betting it would be you.



If nothing else you need to lay out concrete expectations and review them regularly. This is where weekly meetings where you only review what's been done and lay out your plan for the next week are key. Try to avoid demonstrating code, this is an office meeting where you talk, not a product demo where you show. But meeting every week and you saying "I have done X, here is my engineering notebook and my project plan", and him paying you, means you both have a good idea of where things are. But again, this is research, so you're not going to be able to say "I am 123 hours into the 456 hour project, therefore 123/456 % complete".



Here are three options that might work:



  1. He lends you the hardware and you build some kind of hobby project for that system. Something that he can't use, to make it clear that this is your learning process. Then he pays you a decent hourly rate for everything else, whether it's research or typing.

  2. You keep on as you are (perhaps with more non-working time in your life), and he pays you a slightly lower hourly rate while you learn on the job.

  3. He pays you as a consultant to help interview and find another programmer. If nothing else that market survey will help him re-calibrate his expectations of how much this will cost, and how common the skills he wants are.

One option that definitely will work: quit. You've learned that picking up a whole new skillset while working for a friend is not a good idea. He's learned that getting a non-expert but expecting them to work like an expert doesn't work.






share|improve this answer














IME your situation is typical of an owner operator type business. The skills are specific to their business, and every cent they spend hurts them. It seems that you started out well, on the basis that the combination of what he wanted you to do, and the unusual system you wanted him to do it with, meant that he'd be paying you to learn. But then you were persuaded that he shouldn't pay you for that, only for your eventual "expert time".



It might help to explain that programming is design if not research and development. Sure, you can sketch a high-level design, but without either experience or experiments you have little idea of the details of the design, let alone the size of the finished product (which is what, an executable?) There's almost never a time where you say "I'll use pattern A, pattern B and link them using framework X. I estimate 1800 lines of code". Which is what most engineering design looks like at the planning stages.



At this stage I think you really have to go back and say "This is more work than I can afford to do as a hobby, or on the off chance that eventually I might get paid for it. I'm willing to hand over what I've done if you pay me for the time spent. But unless you're willing to pay me from now on, I think it would be best if you found another programmer". The problem is as much the pattern (no result = no pay) as the specific case ("I'm learning, not coding").



You don't have the experience to give a solid estimate, otherwise now would be the time to say "I'll deliver X for Y money". If you did that one of you would get screwed, and I'm betting it would be you.



If nothing else you need to lay out concrete expectations and review them regularly. This is where weekly meetings where you only review what's been done and lay out your plan for the next week are key. Try to avoid demonstrating code, this is an office meeting where you talk, not a product demo where you show. But meeting every week and you saying "I have done X, here is my engineering notebook and my project plan", and him paying you, means you both have a good idea of where things are. But again, this is research, so you're not going to be able to say "I am 123 hours into the 456 hour project, therefore 123/456 % complete".



Here are three options that might work:



  1. He lends you the hardware and you build some kind of hobby project for that system. Something that he can't use, to make it clear that this is your learning process. Then he pays you a decent hourly rate for everything else, whether it's research or typing.

  2. You keep on as you are (perhaps with more non-working time in your life), and he pays you a slightly lower hourly rate while you learn on the job.

  3. He pays you as a consultant to help interview and find another programmer. If nothing else that market survey will help him re-calibrate his expectations of how much this will cost, and how common the skills he wants are.

One option that definitely will work: quit. You've learned that picking up a whole new skillset while working for a friend is not a good idea. He's learned that getting a non-expert but expecting them to work like an expert doesn't work.







share|improve this answer














share|improve this answer



share|improve this answer








edited Aug 15 '16 at 2:12









Rohan Jhunjhunwala

1054




1054










answered Mar 17 '14 at 2:55









Móż

1,81911523




1,81911523











  • thank you for your answer, but the thing is.. After 9 days, I am an expert now. At least, it feels this way. I am a fast learner! And I want to continue. I like this project.
    – Ruby
    Mar 17 '14 at 3:16











  • @ТаняТ. You have to negotiate a payment that you both think is reasonable. I suggest making a list of the value you've gained/added since you started, and what you feel you should be paid for it. Don't be afraid to say "from X to Y" and if he offers more argue that Y is good. That's a judgement call, but establishing in his mind that you won't overcharge is a useful thing. Once you have that, sit down and start negotiating.
    – Móż
    Mar 17 '14 at 3:32







  • 1




    Also, I hope you're not offended but I work with people who have 20 years experience in embedded programming and after 6 months working with them I'm not an expert. You've had 9 days without expert supervision. I am/was a desktop/server expert, embedded is a whole new thing. Unless it's "embedded" Android type code, in which case 10 years Java could possibly make you an Android expert in a few months.
    – Móż
    Mar 17 '14 at 3:37











  • @ Ӎσᶎ I was being a bit facetious. My point is, byMSP430 is really simple; by now I know what I am doing, and know enough buzzwords to ask or search for what I don't know. You must be working with something much more complex.
    – Ruby
    Mar 17 '14 at 3:44











  • Also, I've spent 6 years programming embedded and/or C/C++/asm, though it's been too long ago. No offence taken, and hope I did not offend the real gurus.
    – Ruby
    Mar 17 '14 at 4:02

















  • thank you for your answer, but the thing is.. After 9 days, I am an expert now. At least, it feels this way. I am a fast learner! And I want to continue. I like this project.
    – Ruby
    Mar 17 '14 at 3:16











  • @ТаняТ. You have to negotiate a payment that you both think is reasonable. I suggest making a list of the value you've gained/added since you started, and what you feel you should be paid for it. Don't be afraid to say "from X to Y" and if he offers more argue that Y is good. That's a judgement call, but establishing in his mind that you won't overcharge is a useful thing. Once you have that, sit down and start negotiating.
    – Móż
    Mar 17 '14 at 3:32







  • 1




    Also, I hope you're not offended but I work with people who have 20 years experience in embedded programming and after 6 months working with them I'm not an expert. You've had 9 days without expert supervision. I am/was a desktop/server expert, embedded is a whole new thing. Unless it's "embedded" Android type code, in which case 10 years Java could possibly make you an Android expert in a few months.
    – Móż
    Mar 17 '14 at 3:37











  • @ Ӎσᶎ I was being a bit facetious. My point is, byMSP430 is really simple; by now I know what I am doing, and know enough buzzwords to ask or search for what I don't know. You must be working with something much more complex.
    – Ruby
    Mar 17 '14 at 3:44











  • Also, I've spent 6 years programming embedded and/or C/C++/asm, though it's been too long ago. No offence taken, and hope I did not offend the real gurus.
    – Ruby
    Mar 17 '14 at 4:02
















thank you for your answer, but the thing is.. After 9 days, I am an expert now. At least, it feels this way. I am a fast learner! And I want to continue. I like this project.
– Ruby
Mar 17 '14 at 3:16





thank you for your answer, but the thing is.. After 9 days, I am an expert now. At least, it feels this way. I am a fast learner! And I want to continue. I like this project.
– Ruby
Mar 17 '14 at 3:16













@ТаняТ. You have to negotiate a payment that you both think is reasonable. I suggest making a list of the value you've gained/added since you started, and what you feel you should be paid for it. Don't be afraid to say "from X to Y" and if he offers more argue that Y is good. That's a judgement call, but establishing in his mind that you won't overcharge is a useful thing. Once you have that, sit down and start negotiating.
– Móż
Mar 17 '14 at 3:32





@ТаняТ. You have to negotiate a payment that you both think is reasonable. I suggest making a list of the value you've gained/added since you started, and what you feel you should be paid for it. Don't be afraid to say "from X to Y" and if he offers more argue that Y is good. That's a judgement call, but establishing in his mind that you won't overcharge is a useful thing. Once you have that, sit down and start negotiating.
– Móż
Mar 17 '14 at 3:32





1




1




Also, I hope you're not offended but I work with people who have 20 years experience in embedded programming and after 6 months working with them I'm not an expert. You've had 9 days without expert supervision. I am/was a desktop/server expert, embedded is a whole new thing. Unless it's "embedded" Android type code, in which case 10 years Java could possibly make you an Android expert in a few months.
– Móż
Mar 17 '14 at 3:37





Also, I hope you're not offended but I work with people who have 20 years experience in embedded programming and after 6 months working with them I'm not an expert. You've had 9 days without expert supervision. I am/was a desktop/server expert, embedded is a whole new thing. Unless it's "embedded" Android type code, in which case 10 years Java could possibly make you an Android expert in a few months.
– Móż
Mar 17 '14 at 3:37













@ Ӎσᶎ I was being a bit facetious. My point is, byMSP430 is really simple; by now I know what I am doing, and know enough buzzwords to ask or search for what I don't know. You must be working with something much more complex.
– Ruby
Mar 17 '14 at 3:44





@ Ӎσᶎ I was being a bit facetious. My point is, byMSP430 is really simple; by now I know what I am doing, and know enough buzzwords to ask or search for what I don't know. You must be working with something much more complex.
– Ruby
Mar 17 '14 at 3:44













Also, I've spent 6 years programming embedded and/or C/C++/asm, though it's been too long ago. No offence taken, and hope I did not offend the real gurus.
– Ruby
Mar 17 '14 at 4:02





Also, I've spent 6 years programming embedded and/or C/C++/asm, though it's been too long ago. No offence taken, and hope I did not offend the real gurus.
– Ruby
Mar 17 '14 at 4:02



Comments

Popular posts from this blog

Long meetings (6-7 hours a day): Being “babysat” by supervisor

Is the Concept of Multiple Fantasy Races Scientifically Flawed? [closed]

Confectionery