Skip to main content
Engineering LibreTexts

17: Documentation and such

  • Page ID
    43115
  • \( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)

    \( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)

    \( \newcommand{\id}{\mathrm{id}}\) \( \newcommand{\Span}{\mathrm{span}}\)

    ( \newcommand{\kernel}{\mathrm{null}\,}\) \( \newcommand{\range}{\mathrm{range}\,}\)

    \( \newcommand{\RealPart}{\mathrm{Re}}\) \( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)

    \( \newcommand{\Argument}{\mathrm{Arg}}\) \( \newcommand{\norm}[1]{\| #1 \|}\)

    \( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)

    \( \newcommand{\Span}{\mathrm{span}}\)

    \( \newcommand{\id}{\mathrm{id}}\)

    \( \newcommand{\Span}{\mathrm{span}}\)

    \( \newcommand{\kernel}{\mathrm{null}\,}\)

    \( \newcommand{\range}{\mathrm{range}\,}\)

    \( \newcommand{\RealPart}{\mathrm{Re}}\)

    \( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)

    \( \newcommand{\Argument}{\mathrm{Arg}}\)

    \( \newcommand{\norm}[1]{\| #1 \|}\)

    \( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)

    \( \newcommand{\Span}{\mathrm{span}}\) \( \newcommand{\AA}{\unicode[.8,0]{x212B}}\)

    \( \newcommand{\vectorA}[1]{\vec{#1}}      % arrow\)

    \( \newcommand{\vectorAt}[1]{\vec{\text{#1}}}      % arrow\)

    \( \newcommand{\vectorB}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)

    \( \newcommand{\vectorC}[1]{\textbf{#1}} \)

    \( \newcommand{\vectorD}[1]{\overrightarrow{#1}} \)

    \( \newcommand{\vectorDt}[1]{\overrightarrow{\text{#1}}} \)

    \( \newcommand{\vectE}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash{\mathbf {#1}}}} \)

    \( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)

    \( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)

    \(\newcommand{\avec}{\mathbf a}\) \(\newcommand{\bvec}{\mathbf b}\) \(\newcommand{\cvec}{\mathbf c}\) \(\newcommand{\dvec}{\mathbf d}\) \(\newcommand{\dtil}{\widetilde{\mathbf d}}\) \(\newcommand{\evec}{\mathbf e}\) \(\newcommand{\fvec}{\mathbf f}\) \(\newcommand{\nvec}{\mathbf n}\) \(\newcommand{\pvec}{\mathbf p}\) \(\newcommand{\qvec}{\mathbf q}\) \(\newcommand{\svec}{\mathbf s}\) \(\newcommand{\tvec}{\mathbf t}\) \(\newcommand{\uvec}{\mathbf u}\) \(\newcommand{\vvec}{\mathbf v}\) \(\newcommand{\wvec}{\mathbf w}\) \(\newcommand{\xvec}{\mathbf x}\) \(\newcommand{\yvec}{\mathbf y}\) \(\newcommand{\zvec}{\mathbf z}\) \(\newcommand{\rvec}{\mathbf r}\) \(\newcommand{\mvec}{\mathbf m}\) \(\newcommand{\zerovec}{\mathbf 0}\) \(\newcommand{\onevec}{\mathbf 1}\) \(\newcommand{\real}{\mathbb R}\) \(\newcommand{\twovec}[2]{\left[\begin{array}{r}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\ctwovec}[2]{\left[\begin{array}{c}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\threevec}[3]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\cthreevec}[3]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\fourvec}[4]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\cfourvec}[4]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\fivevec}[5]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\cfivevec}[5]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\mattwo}[4]{\left[\begin{array}{rr}#1 \amp #2 \\ #3 \amp #4 \\ \end{array}\right]}\) \(\newcommand{\laspan}[1]{\text{Span}\{#1\}}\) \(\newcommand{\bcal}{\cal B}\) \(\newcommand{\ccal}{\cal C}\) \(\newcommand{\scal}{\cal S}\) \(\newcommand{\wcal}{\cal W}\) \(\newcommand{\ecal}{\cal E}\) \(\newcommand{\coords}[2]{\left\{#1\right\}_{#2}}\) \(\newcommand{\gray}[1]{\color{gray}{#1}}\) \(\newcommand{\lgray}[1]{\color{lightgray}{#1}}\) \(\newcommand{\rank}{\operatorname{rank}}\) \(\newcommand{\row}{\text{Row}}\) \(\newcommand{\col}{\text{Col}}\) \(\renewcommand{\row}{\text{Row}}\) \(\newcommand{\nul}{\text{Nul}}\) \(\newcommand{\var}{\text{Var}}\) \(\newcommand{\corr}{\text{corr}}\) \(\newcommand{\len}[1]{\left|#1\right|}\) \(\newcommand{\bbar}{\overline{\bvec}}\) \(\newcommand{\bhat}{\widehat{\bvec}}\) \(\newcommand{\bperp}{\bvec^\perp}\) \(\newcommand{\xhat}{\widehat{\xvec}}\) \(\newcommand{\vhat}{\widehat{\vvec}}\) \(\newcommand{\uhat}{\widehat{\uvec}}\) \(\newcommand{\what}{\widehat{\wvec}}\) \(\newcommand{\Sighat}{\widehat{\Sigma}}\) \(\newcommand{\lt}{<}\) \(\newcommand{\gt}{>}\) \(\newcommand{\amp}{&}\) \(\definecolor{fillinmathshade}{gray}{0.9}\)

    Documentation

    Why have a chapter on documentation? Because documentation is needed for any program you write, however, it is also the most avoided essential. Why? Because of the oft used excuse that "I know what it does." But unfortunately you forget after awhile...so...DOCUMENT!!!!

    Documentation is one of the most important parts of programming, it is also the toughest, and most poorly implemented in general. Here we will present some general rules for documenting any program (software project).

    • Documentation for all programming projects
      • A traditional documents on paper (or pdf or html or some universal way to read the document)
        • Manual
        • One page quick guide
        • Paper (or papers) explaining the raison d'etre for your program and the theory and solutions
      • Documentation within the program itself
    • All programming languages have some method of allowing the user to enter comments
      • Comments should be added at the beginning of the program
      • Comments should be throughout the program itself near important lines
      • Don't overdo comments as this distracts from the overall documentation
        • Example: we don't need a comment on a print statement that says it displays the string to the screen...we can figure this out without documentation
        • Example: you use a special numerical method that is not very common...yes please document this
      • Octave and its ilk note: the help in Octave give the front comments; lookfor give the first line
        • So if you don't have the front comments, help won't work...the professor will not be pleased...
        • Front comments can also be where you credit yourself (and your partners if applicable)
    • Good coding techniques acts as a defacto documentation of the code
      • Use tabs for statements in loops and conditionals, etc.
        • Note you have to do this in Python (so you are force to have good coding techniques)
        • A lot of editors (for coding) do this for you as long as you have a template for that language
      • Separate functions that are used multiple times into function, subroutines, or the like
    • exampleprogram_forceadd.png help_force_add_rev.png lookfor_function_rev.png
      This is the program that we will ask for help on the right. Observe the comments written in this program. NB: open the image in new tab or window if you are having trouble reading it. This is what help returns in Octave/MATLAB for the program on the left. You will see that the comments were important in order to get the help. This is true for all the functions in Octave/MATLAB, so do your comments! lookfor is a nice feature of Octave/MATLAB (in Scilab the feature is apropos - Octave is more aligned with MATLAB) that finds specific words in the first line of a program. As you can see here we wanted all programs that deal with "vectors." Of course this depends how well comments are written by the programmer, but it really helps when you forgot that function's name you remember that deals with "vectors" (in this example).
    • Documenting in a group project
      • Documenting in a group project requires some negotiation and sharing of responsibility
        • It is required of engineers to work in groups
        • It is required of instructors to grade you on group dynamics
      • Extreme Documentation
        • Characteristics
          • Document as project progresses (not after it is done)
          • Team ownership of project
          • Independent documentation from each programmer in the group (more eyes theory)
          • Compile documentation at the end in a traditional document and in the program itself

    Writing Good Programs

    To write good programs you should follow the procedures on documentation above, but what about the actual code? It is generally agreed that you should outline the procedure before you begin to actually code your program. There are two methods for outlining a program, flowcharts which has actually done before computer programming but adopt by programmers as well, and pseudocode where you code in a generic sense and to the specific syntax after you have gone over the pseudocode.

    • Flowcharts
      • Set of graphic "blocks" with connection arrows that represents the programming flow in a visual way
      • There has been work on using set theory to actually prove if a program is valid using flowcharts
        • Just proves you get a result and it follows you procedure as you believe would work
        • Can't really prove if the result is right or not as that takes an expert opinion in the field that the programming is being written for
      • There are programs that help with flowcharting or even run programs that you have flowcharted (raptor or flowgorithm)
      • There are modern additions that allow for parallel processing in flowcharting
      • Flowcharts have official ANSI symbols
      • While an old technique it is still useful
      • Flowchart symbols on a template that was used before personal computers.
        Flowchart symbols on a template that was used before personal computers.
    • Pseudocode
      • Programming in plain English (or any other language you wish) with a limited set of rules
      • Takes away the burden of strange (in the sense of our normal English sensibility) variable names, structures, methods, etc. imposed by different computer languages
      • Lets us write the way we "think"
      • Some pseudocodes have been developed with hardware and software interaction in mind
        • Software may actually be involved in changing voltage levels (think a controller) which is hardware in nature but controlled by software
        • Pseudocode is a generally enough idea that it can be used things not necessary computer programming related - just like flowcharts
      • While generally pseudocode is what you like to say in English it is generally agreed on that it should have words similar to programming languages
        • Might use read and print in pseudocode for a C++ program and those "pseudocode" words would be changed to cin and cout when you start to program
        • There is no official pseudocode

    Comparison of pseudocode and flowchart with very simple routine

    Pseudocode of a simple routine to decide whether to use atan or atan2. Note there is input and output and a conditional. Flowchart of a simple routine to decide whether to use atan or atan2. Note there is input and output and a conditional.
    Pseudocode of a simple routine to decide whether to use atan or atan2. Note there is input and output and a conditional. Flowchart of a simple routine to decide whether to use atan or atan2. Note there is input and output and a conditional.


      17: Documentation and such is shared under a CC BY-NC-SA license and was authored, remixed, and/or curated by LibreTexts.