Stories
Slash Boxes
Comments

Dev.SN ♥ developers

posted by NCommander on Wednesday April 02 2014, @03:11PM   Printer-friendly
from the I-remember-Applesoft-BASIC dept.

An article was recently published that looks at evaluating First Programming Languages (FPL) the language to use for an introductory course of programming.

An existing issue is that formally assessing a programming language isn't really defined, with a lot of evidence being anecdotal. The proposed evaluation framework looks at technical and environmental feature sets. "The technical feature set covers the language theoretical aspects, whereas, the environmental feature set helps evaluating the external factors." These feature sets are covered in table 2 of the article (link to PDF) and consist of the following:

Technical Features

  • High Level
  • Orthogonality
  • Strongly Typed
  • Enforceability of Good Habits
  • Security
  • Feature Uniformity
  • Less Effort for writing simple programs

Environmental Features

  • Demand in Industry
  • Contemporary Features
  • Easy Transition
  • Readable Syntax
  • Quality Coding
  • User Friendly Integrated Development Environment

The article explains each of these points in details, and gives each of the languages being evaluated a rating based on this explanation, followed by a detailed explanation of how the scores of each rating can be compared this includes allowing an evaluator to weigh certain criteria they deem important against the others. As this is for choosing a language to teach someone to program with, different places will have different reasons and goals, so would want to weight things differently.

As the default weight settings do not conform to the original popularity index of the languages, so there should be a different weighting criterion. However, it is very hard to come up with a generic and correct weighting criterion. Therefore, the scoring function should be customizable and the user should be able to tune the weight of each feature based on her preferences. As an example, consider the fact that Ada holds 3rd position in overall scoring, but is not being considered among highly used FPLs as of now.

NCommander adds: lhsi was kind enough to include a summary of the results. I looked through the paper and it seems like a fairly interesting read.

Using the default weighting, the top five First Programming Languages evaluated are as follows:

Technical
  1. Python
  2. Java
  3. Pascal
  4. Ada
  5. Modula-2

Environmental

  1. Java
  2. Ada
  3. Python
  4. C#
  5. C++

Overall

  1. Java
  2. Python
  3. Ada
  4. C#
  5. Modula-2
 
This discussion has been archived. No new comments can be posted.
Display Options Breakthrough Mark All as Read Mark All as Unread
The Fine Print: The following comments are owned by whoever posted them. We are not responsible for them in any way.
  • (Score: 2, Informative) by qwerty on Wednesday April 02 2014, @04:26PM

    by qwerty (861) on Wednesday April 02 2014, @04:26PM (#25142) Homepage

    My first language was flowcharts written in pencil on sheets of paper; then BASIC on sheets of paper. That was before the VIC-20 existed, but the VIC-20 was the first computer on which I eventually got to run the programs on my sheets of paper. This was followed by VIC-20 assembler via pokes using BASIC. This sequence helped me understand what was "inside" computers, before moving to abstracted languages. When I started CS-undergrad, it was Pascal and C on a VAX-11/780, at which point the insides of the computer started to became an opaque cloud when programming.

    When it came to time to show my son some programming at about 8 yrs old, I introduced him to VBScript; which is close-enough to BASIC to make me think that it would emulate my learning sequence. But of course, it didn't exactly. Today's PCs are very comfortable to use without ever needing to even imagine what's under the cover.

    If the goal is teaching computer architecture, then maybe assembler is the best first language. If the goal is teaching algorithms, then a teaching language like Pascal would be fine, or even Knuth's MMIX machine language. If the goal is teaching how to be a software engineer, then C++ is expected. If the goal is teaching scientists how to code, then C++ and maybe R and maybe even FORTRAN would be a good combination.

    Starting Score:    1  point
    Moderation   +1  
       Informative=1, Total=1
    Extra 'Informative' Modifier   0  

    Total Score:   2