You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

142 line
11KB

  1. %&tex
  2. \chapter{Case Study: Evaluation}
  3. \label{chap:case_evaluation}
  4. The previous chapter described the development and implementation process of the Whiteboard Writer.
  5. This chapter focusses on the evaluation of the development during the case study.
  6. The design method itself is evaluated in the next chapter.
  7. However, some of the topics discussed in this chapter have a strong overlap with those in the next chapter.
  8. The first section is about the time spend on the development.
  9. Followed by two sections on the role of stake holders and the use of modelling languages during a development.
  10. The last section is a more personal reflection about the development.
  11. \section{Time Investment}
  12. \label{sec:time_investment}
  13. Prior to each step in the development, I made an estimation on the workload of that particular step.
  14. In \autoref{fig:time_spend} the planned and spend time on each step are plotted next to each other.
  15. In addition to the steps, time was also spend on the hardware construction and software development.
  16. The original implementation of the feature definition was not feasible and had to be reviewed.
  17. As the new approach for the feature definition is based on the expected result.
  18. The time spend on performing the feature definition is not representative as there is not clear starting moment.
  19. \begin{figure}
  20. \centering
  21. \includegraphics{graphics/time_table.pdf}
  22. \caption{Overview of the planned and spend number of days for each step during the case study.
  23. Some of the values in this do not represent the time requirements of this design method:\newline
  24. \textsuperscript{1} During the feature definition the design method was reviewed. 13 days were spend on this review and execution, obfuscating the actual execution time. The execution time is an estimated 3 to 5 days.\newline
  25. \textsuperscript{2} The first cycle was cut short due to its complexity.\newline
  26. }
  27. \label{fig:time_spend}
  28. \end{figure}
  29. Furthermore, there is a significant time difference both development cycles.
  30. Prior to the first development cycle I was not confident about the feasibility of the end-effector implementation.
  31. Based on that, I decided to spend about three days on the basic model of the end-effector to collect more information.
  32. This let me to the conclusion that the end-effector was too time-consuming for this case study.
  33. For the second cycle, I also planned three days to create the basic model.
  34. This time, the basic model was finished within a couple of hours.
  35. Based this early success and prior experience, I planned an additional two weeks of development time for this cycle.
  36. To validate the design of the \ac{scara}, I build a prototype.
  37. This consisted of acquiring and assembling the hardware, and writing software.
  38. Acquiring and assembling the hardware took about two days.
  39. This was mainly due to CoViD-19 restrictions which made part ordering and printing more challenging.
  40. Without these restrictions I think it would be a day of work.
  41. The time required to get the software to a viable state was four weeks.
  42. Even though the focus was not on the software, this timespan of four weeks was too significant to ignore.
  43. Especially when the software is compared to the developed models.
  44. As explained in the previous section, I build a total of eight models.
  45. Each of these models includes documentation and an evaluation of the design process.
  46. The software, on the other hand, is in a bare minimum state; I skipped documentation and evaluation; and the code quality relatively low.
  47. Still, the software was more time consuming than the hardware modeling and development.
  48. \section{One-man development team}
  49. The case study was performed by me, as a single developer.
  50. Against all expectations, this one-man development team made the preparation phase more difficult instead of easier.
  51. The goal of the problem description and the requirements step is to get the stakeholders on the same line \autocite{shafaat_exploring_2015}.
  52. This involves creating agreed-upon requirements for the system, but with only one stakeholder, this agreement is implicit.
  53. Moreover, it undermines the incentive of the problem description and requirements step.
  54. Part of this is that there is no penalty for future reviews of the requirements, as I already agreed.
  55. Furthermore, specific details and decisions were often made subconsciously, while I was commuting, waiting in line, or even showering.
  56. Making structured documentation of these decisions at a later point in time without missing any of them is impossible.
  57. The social interaction within a design team stimulates this documenting process as it improves the recall and interpretation of information.
  58. It also improves the judgement and selection of design alternatives \autocite{lamb_221_2008}.
  59. \section{Switching Modelling Language}
  60. The initial idea of the development was to start with a basic model and extend that model by adding more detail.
  61. Meaning that one design and one model would develop in parallel with each other.
  62. However, the development of the \ac{scara} resulted in four major model versions.
  63. The basic model started with a kinematics model.
  64. To take the physics of the design into account, a 2D dynamics model was created.
  65. Multiple steps of detail into the development, the 2D model was not adequate anymore.
  66. Therefore, the design was remodeled with 3D physics.
  67. Although this 3D physics model was able to implement the dynamic behavior, the modeling language was not suitable to design the shape of the mechanical components.
  68. Resulting in a fourth model which represents the mechanical component design, in the form of a CAD drawing.
  69. There are a couple of problems with this approach.
  70. Implementing the same model with two different modelling approaches, makes both models incompatible with each other.
  71. This removes the possibility to switch back to a lower detail implementation.
  72. Additionally, it creates the possibility to transfer parameters incorrectly from one model to another.
  73. Such a switch is also labor intensive as the complete model has to be build from scratch again.
  74. Furthermore, there is the possibility that this new model has been for nothing, as the planned detail proves to be unfeasible.
  75. The point is, a future iteration of the design method must minimize these type of model switches to reduce the chance of implementation errors.
  76. \section{Reflection}
  77. In the following section, I reflect on my own impact on the development.
  78. The preparation and development phase are discussed separately.
  79. \subsection{Preparation phase}
  80. During the preparation phase often I had difficulty with getting the required information.
  81. The information was often not specific enough or it was overlooked.
  82. Even though attempting to be thorough, requirements were never really specific.
  83. As explained in the previous section, the lack of stake-holders is one of the reasons for information not being specific.
  84. Furthermore, during the preparation information was often overlooked.
  85. Resulting in a situation where I needed information that should have been the result of a previous step, which was not the case.
  86. In most situations it was possible to continue with the execution of the step.
  87. However, during the test protocol step (\autoref{sec:test_protocol}) it was not possible to continue.
  88. Resulting in additional requirements added to the design, before continuing with the design process.
  89. One of the main causes that attributes to the information shortage is that I am a novice designer/developer.
  90. The experience that I have is from a graduate course and two extracurricular projects.
  91. Being inexperienced does definitely not aid the design process.
  92. Needless to say, more experience would improve the information situation.
  93. However, it does not solve the problem.
  94. Further improvements for the design method is required, to improve the information process during development.
  95. \subsection{Development phase}
  96. \label{sec:evaluation_reflection_development}
  97. For the development phase I have significantly more experience compared to the preparation phase.
  98. Creating models is something that I really enjoy and this improves the process significantly.
  99. Even though the development phase went smoother than the preparation phase, there is still room for improvement.
  100. Originally I attempted to create separate sub-models for each component.
  101. These sub-models can then be combined into larger models.
  102. For example, the \ac{scara} and the \ac{cdc} both include two stepper motors.
  103. When I add detail to the stepper motor model, the \ac{scara} and the \ac{cdc} would then be updated as well.
  104. However, each sub-model has to be updated manually.
  105. In total four times in case of the stepper motor, which makes this workflow very labor intensive.
  106. A workflow that enables easy combination and interchange of sub-models is beneficial with this design method.
  107. It makes it easy to evaluate the latest changes, by comparing them with previous versions.
  108. In addition, it makes it possible to lower the detail on some models during the development.
  109. The lower detail of the sub-models can improve the simulation speed significantly.
  110. And during the final test use the full detail to ensure that every thing is performing as expected.
  111. \subsection{Continuation of this Case Study}
  112. \label{sec:evaluation_reflection_protoype}
  113. At the point that the \ac{scara} was implemented, I gathered so much new information that the some of the design choices felt obsolete.
  114. In this case study, the prototype is used to validate the design.
  115. However, the current prototype contains so much information that it would improve the requirements and initial design significantly.
  116. Following the current design plan, the next step would be to develop the \ac{cdc}.
  117. In theory, if I would continue the case study, my proposal is to consider the current design as an actual prototype and revisit the preparation phase.
  118. However, it is very important to note that this decision relies on the fact that the prototype is already created.
  119. In other words, the work is already done and resulted in useful information for a next design iteration.
  120. In case of a different system, I doubt that creating a prototype, followed by a full repeat of the design method is an efficient approach.
  121. Therefore, the choice to revisit the preparation phase must not be considered as an improved design method but as an argument to improve the preparation phase itself.
  122. However, I think that an improved preparation phase must be shorter and incorporate a prototype.