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.

119 line
7.2KB

  1. %&tex
  2. \chapter{Improved Design Method}
  3. \label{chap:improvements}
  4. \rro{Introduce}
  5. \rroi{Preliminairy design required complete new approach}
  6. \rroi{Better tooling}
  7. \section{System Baseline}
  8. The preliminary design phase is not a competent approach for the initial design of a physical system.
  9. In the waterfall-like approach each step is completely wrapped up before moving to the next step.
  10. Every subsequent step provides more and more information about the design.
  11. The information gives often insight in what could have been done better.
  12. Although it is possible to review previous completed steps, there is quite a barrier to revise these steps.
  13. Redoing previous work is demotivating and will be avoided as much as possible.
  14. \rrotodo{Fix these citations}
  15. This \emph{cost of change} is an inherent problem of the waterfall model \autocite{alshamrani, adenowo, petersen}
  16. The development was confronted with this decision during the feature definition step in \autoref{sec:featuredefinition}.
  17. The term feature is used for the different characteristics of the system.
  18. Were these features map adequately to specifications and software, it does not represents hardware components.
  19. Taking the following items from a single branch in \autoref{fig:robmosys}:
  20. \begin{enumerate}
  21. \item Draw a tweet on a whiteboard
  22. \item Writing
  23. \item Write a char at position
  24. \item Move Marker on board
  25. \item SCARA
  26. \end{enumerate}
  27. The first four items are characteristics of the system, where the first item is an abstract description of the complete system.
  28. The subsequent items become more specific with each step.
  29. The links between each subsequent item could be described "to perform this feature it is required that system can".
  30. These items are derived from the design specification, but are also useful as software.
  31. Item 4 would be the software implementation of the motor driver.
  32. This motor driver is called by the arm controller that is implement for item 3.
  33. The outlier in this list is the SCARA, it is not a sub-feature of \emph{Move marker on board}.
  34. The SCARA has motors, mechanical linkage, sensors, as components; it is not a feature, it is a system.
  35. Trying to combine features and systems in a single hierarchy was a known shortcoming of the design during the case study.
  36. One of the solutions that was discussed was to build a feature dependency tree with an iterative approach.
  37. Each iteration of the design process would only cover one level of the dependency tree.
  38. The first iteration would thus deliver specifications, initial design, order of operations, and tests for the mission level: "Draw a tweet on a whiteboard".
  39. Followed by the second level which would repeat everything for \emph{Writing} and \emph{Wiping}.
  40. This approach would probably be better that the current approach in the feature definition.
  41. It would however require to review all the previous steps and rewrite most of the design method.
  42. Furthermore, it was estimated that the additional effort required to restart the design process would negatively impact the overall evaluation of the design method.
  43. Nevertheless is it required to find an improved design method.
  44. The iterative design would help generate a better method, but it still generates a single dependency tree.
  45. Therefore can only cover one type of dependency.
  46. \textcite{kordon_model-based_2007} presents their \ac{mbed} that is used for two development projects within NASA's Jet Propulsion Lab.
  47. The \ac{mbed} introduces a system hierarchy that separates the dependencies over three trees: specifications, functions, and components.
  48. Additionally it adds interfaces, that connect different sub-components, and operational scenarios to this hierarchy.
  49. The hierarchy is constructed iterative where each iteration generates a new level of sub-specifications, sub-functions and sub-components.
  50. % The term feature was used as a universal concept for design features, hardware features and software features.
  51. % This led to problems while creating a list of features.
  52. % This led to problems during the feature definition step.
  53. % The aim of the approach was to create a list of features.
  54. % Due to the different nature of the features it was impossible to create a single list of features.
  55. % Making a list for each group of features would result in problems with the selection of the features.
  56. % The problem with the features became apparent during the feature definition step in \autoref{sec:featuredefinition}.
  57. % Another problem is the waterfall-like approach.
  58. %
  59. % A possible solution that was discussed during the feature definition step in \autoref{sec:featuredefinition}.
  60. % The current steps are strongly detached from each other.
  61. \rro{In general, I underestimated the importance of the preliminary research}
  62. \rroi{\textcite{broenink_rapid_2019} also skips this part.}
  63. \rroi{As the focus of that paper was on the actual implementation, the preliminary phase was over looked}
  64. \rroii{However, bringing a system into being, the preliminary design phase is extremely important}
  65. \rro{For validation \textcite{garrett_322_2000} suggests:}
  66. \rroi{Looking at comparable systems' specifications}
  67. \rroi{Use of best engineering judgements}
  68. \rroi{Apply early simulation results for feedback}
  69. \rroi{A holistic view is required for validation of the initial design/specifications}
  70. \rro{Without mechanical experience is difficult}
  71. \rro{Better specification document is a team effort}
  72. \rroi{A team with engineers in their own specific field that is included in the design}
  73. \rro{\textcite{sheard_718_1998} discusses:}
  74. \rroi{Mechanical requirements are directly derived from and bounded by physics}
  75. \rro{Result: Mechanical specifications are easier to change}
  76. \rroi{More room for initial simulations, before making concrete specs}
  77. % \section{Feature Separation}
  78. % \rro{During the case study, the planned approach was not possible}
  79. % \rro{Result: Improvised a structure that was loosly based on Robmosys}
  80. % \rro{Proposed Improvement: Split layout for requirements, functions and components from State Analysis \textcite{kordon_model-based_2007}.}
  81. % \rro{Instead of trying to start with a feature, a holistic model of essential elements should be created}
  82. % \rroi{In the holistic basic model, review the features/components on their feasibility}
  83. % \rroii{How likely is it that this specific component is going to work: And if not, what are the consequences? What do we need to change?}
  84. % \rroi{Then add detail to the different subcomponents of that model}
  85. \section{Tooling}
  86. \rro{20-sim lacks an object oriented approach}
  87. \rroi{Adding detail to a submodel that is used more than once is a PITA}
  88. \rroi{Every model is a deepcopy}