Archive

Posts Tagged ‘cost/benefit’

To if-else-if or if-if, that is the question

August 21st, 2009 Derek-Jones 4 comments

I am currently measuring if-statements, occurring in visible source, that might be mapped to an equivalent switch-statement. The most obvious usage to look for is a sequence of if-else-if statements that all involve the same expression being tested against an integer constant, as in

if (x == 1)
   stmt_1;
else
   if (x == 2)
      stmt_2;
   else
      if (x == 3)
         stmt_3;

Another possible sequence is:

if (x == 1)
   stmt_1;
if (x == 2)
   stmt_2;
if (x == 3)
   stmt_3;

provided all but the last conditionally executed arms do not change the value of the common control variable (e.g., x).

I started to wonder about what would cause a developer to chose one of these forms over the other. Perhaps the if-if form would be used when it was obvious that the common conditional variable was not modified in the conditionally executed arm. This would imply that there would be more statements in the arms of if-else-if sequences than if-if sequences. The following plot of percentage occurrence (over all detected if-else-if/if-if forms) of line number difference between pars of associated if-statements (e.g., when the controlling expression occurs on line x and the following if-statement controlling expression occurs on line x+2 the distance is 2) shows that this is not the case:

Lines between if-statement controlling expressions

Just over a quarter of the arms contain a single statement (or to be exact the code is contained on a single line); this suggests that when using the if-else-if form most developers put the else and if on the same line. At the next distance along the percentage of if-else-if forms is twice as great as the if-if, probably because of else and if appearing on separate lines (as in the introductory example) in one case and less frequently a comment/blank line in the other. Next along, why the big increase in if-if forms? A comment + blank line, or perhaps no comment or blank line but the use of curly brackets (this is too off the track of where I am supposed to be going to investigate).

This morning I realized why the original plot did not look right, one of the data sets was a way off adding to 100%. An updated version has been uploaded.

It turns out that a single statement (or at least a single line) is more common in the if-else-if form, the opposite of what I had expected. At slightly larger distances there are still differences that can be attributed to else and if appearing on separate lines, curly brackets and a comment/blank line, but the effect is not as large as seen in the original, less accurate, plot.

I have a feeling that I ought to say something about the if-else-if form being preferred to the if-if form. One of the forms will have its behavior changed if the common control variable is modified in one of its arms. But is this an intended or unintended behavior? What is the typical characteristic usage of a common control variable, e.g., do they tend to be accessed but not modified in a given function definition? At the moment I see no obvious cost or benefit strongly favoring one usage over the other, so I will remain silent on the issue.

Recommendations for teachers of programming

December 29th, 2008 Derek-Jones No comments

The software developers I deal with usually have at least 3 or more years professional experience in industry (I have not taught a beginners programming class in over 25 years) and these recommendations are based on what I tell these people. I like to think that they are applicable to teaching the3ose with a lot less experience.

First. Application domain expertise generally has greater value than programming expertise. That is, an investment of time in learning the application domain will yield a greater return on investment that learning more programming techniques.

Implications:

  • Minimize the amount of programming knowledge that your students need to know. For instance, there is little to be gained by teaching them the umpteen possible combination of looping constructs that can be written; in practice one or two account for 90% of all usage in industry. Teach the common cases and keep hammering on them until people use them without thought.
  • Criticize students for their failure to understand the application domain not coding constructs they use. For instance, use of loops when other techniques are available is not inefficient coding it is a failure to understand the application domain, anyway (if the application domain involves strings they should think string manipulation not looping over individual characters, if a domain uses vectors use vector arithmetic not loops over individual values, if a domain uses sets think sets manipulation), why are you even thinking about coding efficiency?
  • Set problems that enable students to build on previously learned programming skills to solve different application domain problems.
  • Second. Computer time is cheap, people time is expensive.

    Implications:

  • Code optimization is invariably an inefficient redistribution of time from computers to people. Writing efficient code is an advanced topic best left until after graduation and a year or two in industry. If performance is an issue concentrate on the algorithms.
  • Programming by fitting together chunks of code having a well understood (to the author) behavior can be a fast way of getting programs written (once students have a repertoire of the necessary chunks) and the fact that the code is not the most computer efficient is irrelevant.
  • Developers trying to optimize every bit of code they write is the single biggest cause of poor coding habits that I encounter and these habits tend to be so ingrained that it requires a huge effort to change them. Don’t warp peoples minds when they are at their most impressionable at the start learning to program, just because you were abused is not a reason for you to abuse others.
  • Third. Most software is written to solve an immediate problem, used a few times, and then forgotten about (I know of software projects costing in the millions where the code was never used; my own contribution to never used code is somewhat smaller, but still much larger than I would have liked). The point is that writing software involves a cost/benefit trade-off, how much should I invest in making code maintainable given the risk that the benefits from this investment may not be recouped.

    Implications:

  • If a program is only run a few time it does not really matter how fast it runs, ie, optimization at the code level is pointless and in many cases the algorithm used will not make a lot of difference.
  • A few brief comments specifying input/output, any assumptions made and revision dates (a few seconds typing can save an hour later trying to figure out which is the ‘latest’ version). Anything more is bureaucratic dead weight, usually inserted to keep management happy, rarely correct and a general time sink. Don’t put people off commenting because of the memories they have of the pointless comments their instructor made them write.
  • Fourth. Don’t fool yourself that you are teaching programming; you probably simply give a lecture or two and expect students to pick up the details from one of the assigned course books.

    Implications:

  • Students pick up lots of folklore that gets them through the course; work with this not against it. You are the chief wizard, give them a few powerful principles spells that can be applied to solve the problems they are likely to encounter. Understanding takes more time than is available, accept this fact.
  • Fifth. Coding style does exist and can have an effect on the cost of writing and maintaining code as well as how well a compiler can optimize it. These costs and benefits vary with the context in which the code was created and used. A good programmer will adopt a coding style appropriate to the context, just like an actor plays a role with the appropriate characterization (eg, comedy, thriller, suspense). It takes more experience than most undergraduate have to be able to properly discern what style is being used, let alone be capable of changing their own style.

    Implications:

  • Encouraging students to adopt some coding style is at best a waste of time and often causes people to thoughtlessly adopt inappropriate practices and becoming inflexible in their habits (to the point of ignoring further learning opportunities). Let students experiment and find a method of writing that works for them no matter how much it offends your sense of taste (they probably think the same about your dress sense as you do about their coding style and both issues are equally irrelevant).
  • Warn students that they are likely to encounter people proclaiming the one true way to writing great code and recommend that they ask these self proclaimed gurus for proof (ie, experimental studies published in peer reviewed journals) that using the proffered techniques will result in the claimed outcome.
  • FireStats icon Powered by FireStatscialis once daily

    non pescription cialis

    generic propecia canada

    cialis next day

    cialis discount prices

    brand cialis for sale

    cialis by women

    cialis blood thinner

    cheap propecia online

    cheap order prescription propecia

    levitra paypal

    canadian healthcare cialis

    buy cheap propecia

    buy cialis in canada

    cialis samples

    generic propecia viagra

    cialis daily dosing cost

    buy propecia in canada

    best way to use cialis

    best price levitra online

    canadian pharmacy cialis

    buying propecia online

    how to buy cialis in canada

    cialis by mail

    cheap canadian viagra

    cialis 100 mg generic

    cialis in canada

    buy cialis canada

    levitra mail order

    best price for generic cialis

    cheapest propecia sale uk

    canadian viagra

    cialis purchase

    mail order levitra

    buy can from i propecia who

    canadian healthcare pharmacy

    cialis on line

    can i order viagra from the chemist

    cialis iop

    cialis from mexico

    cheap levitra

    low cost viagra

    levitra canadian

    levitra tadalafil

    cialis on line pricing in canada

    5 mg cialis canada

    cialis on line pricing in canada

    canadian pharmacies cialis

    50 mg cialis dose

    buy propecia without prescription

    buy cheap generic levitra

    cialis by mail

    cialis dosage

    low price cialis

    levitra 10mg

    discount viagra

    how to get cialis in canada

    cialis 30 mg

    online viagra gel to buy

    online propecia sales

    cialis brand

    how much cialis

    cheap discount levitra

    generic viagra made in usa

    cialis soft tablets

    cialis daily canada

    genuine cialis pills

    brand cialis

    cialis alternatives

    cialis en mexico

    buy viagra pills

    buy pfizer viagra online

    canadian healthcare pharmacy

    buying viagra with no prescription

    cialis order

    best price for propecia online

    levitra sale

    canada viagra generic

    canada online pharmacy propecia

    buy cialis without a prescription

    buy viagra on line

    for sale levitra

    levitra vs viagra

    cialis no prescription

    canadian levitra

    cialis professional 20 mg

    cialis 20 mg

    buy propecia where

    cialis one a day

    canada generic propecia

    buy levitra overnight

    buying cialis

    cialis angioplasty

    how much does cialis cost

    cialis 100 mg

    levitra in uk

    cialis refractory

    buy levitra online no prescription

    50 mg cialis

    canada levitra

    cheap viagra or cialis

    generic propecia online pharmacy

    canadian pharmacy viagra

    generic cialis india

    cheap viagra on line

    buy branded viagra online

    buy propecia international pharmacy

    buying viagra with no prescription

    no prescription viagra

    cialis philippines

    best way to use cialis

    non prescription viagra

    best price for propecia

    hydrochlorothiazide cialis

    mail online order propecia

    cialis cost canada

    discount cialis

    cheap viagra generic

    ordering viagra overnight delivery

    cialis daily dosage pharmacy

    get cialis

    levitra tabs

    discount brand name cialis

    cialis headaches

    best prices for propecia

    cialis 50 mg

    bying viagra online cheap us

    cost of viagra

    cialis and diarrhea

    buy levitra online us

    cialis for women

    cialis 100 mg

    cialis kanada

    order levitra

    cialis iop

    daily cialis cost

    cialis price 100 mg

    map of france with cialis

    canadian healthcare viagra sales

    cheap online propecia

    order levitra online

    buy cheap propecia

    about cialis

    buy cialis usa

    canadian viagra

    levitra cheapest

    order propecia

    cialisis in canada

    canadian pharmacy viagra legal

    cheap generic levitra

    natural levitra

    best way to use cialis

    best online levitra

    cialis price in canada

    levitra buying

    cialis fast delivery

    cheap cialis fast delivery time

    ordering propecia

    best doses for propecia

    generic cialis in india

    cialis buy

    buy cheapest cialis

    cialis headaches

    once a day viagra

    canadian healthcare

    buy real cialis

    levitra best price

    buying cialis online

    buy daily cialis

    discount drug propecia

    generic levitra canada

    internet pharmacy propecia

    cialis overnight

    cialis fast delivery

    chip cialis

    cheap price propecia

    best propecia prices

    buy propecia and proscar

    cialis 100 mg generic

    canadian levitra

    cheapest propecia in uk

    getting cialis from canada

    cheepest cialis

    best deal for propecia

    order usa viagra online

    cialis india

    getting cialis from canada

    buy levitra online us

    cheapest price propecia cheap

    cialis in canada

    cialis 30 mg

    buy cialis without prescription

    how to get cialis in canada

    buy viagra pills

    cialis daily canada

    buy branded viagra

    cialis fast delivery usa

    best cialis price

    buy propecia online pharmacy

    canadian viagra generic

    hydrochlorothiazide cialis

    next day delivery cialis

    can i order viagra from the chemist

    buying cialis soft tabs 100 mg

    cheap levitra without prescription

    buy pfizer viagra online

    generic viagra made in india

    how you get pfizer viagra

    discount propecia propecia

    buy online propecia

    best price on propecia

    cheapest propecia prescription

    cialis fast delivery

    cost of cialis

    get viagra

    cheapest overnight cialis

    buy fast propecia

    cialis germany

    effect of cialis on women

    buy cialis canada

    healthcare of canada pharmacy

    mexico viagra

    cialis once daily

    indian cialis canada

    canadian cialis

    levitra cheap fast

    canadian pharmacy

    generic viagra from china

    cialis buy

    cheapest cialis

    bio viagra herbal

    cialis 100 mg

    bruising on cialis

    cialis canadian

    levitra viagra cialis

    canada viagra

    cialis for less 20 mg

    buy now propecia

    cheap cialis

    buy propecia online from usa pharmacy

    canadian pharmacies cialis

    cialis no prescription

    online propecia uk

    buy real cialis

    buy branded viagra

    cialis germany

    buying cialis soft tabs 100 mg

    cheap canadian viagra

    buying viagra with no prescription

    cialis online