Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

155 linhas
12KB

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